diff options
Diffstat (limited to 'WaterfallFile_UI')
-rw-r--r-- | WaterfallFile_UI/FileSpectrum.swift | 55 | ||||
-rw-r--r-- | WaterfallFile_UI/WaterfallFile_UIApp.swift | 2 |
2 files changed, 51 insertions, 6 deletions
diff --git a/WaterfallFile_UI/FileSpectrum.swift b/WaterfallFile_UI/FileSpectrum.swift index 6415dfa..ce64836 100644 --- a/WaterfallFile_UI/FileSpectrum.swift +++ b/WaterfallFile_UI/FileSpectrum.swift @@ -13,8 +13,15 @@ import CoreImage class FileSpectrum: NSObject, ObservableObject { - let default_width = 512 - let default_height = 512 + static let default_width = 512 + static let default_height = 512 + static let defaultSleepTime:UInt32 = 1 + var offset:Int=0 + let fileReader = FileReader() + var dataBuffer:[Int8] = .init(repeating: 0, count: FileSpectrum.default_width) + var allData:[Int8]? = nil + let fft512 = NaiveFFT512() + var line_counter:Int = 0 let sessionQueue = DispatchQueue(label: "sessionQueue", attributes: [], @@ -22,7 +29,7 @@ class FileSpectrum: NSObject, ObservableObject { @Published var outputImage = emptyCGImage - let simpleImage = SimpleImage(width: 256, height: 256) + let simpleImage = SimpleImage(width: 512, height: 512) /// A 1x1 Core Graphics image. static var emptyCGImage: CGImage = { @@ -40,24 +47,62 @@ class FileSpectrum: NSObject, ObservableObject { return buffer.makeCGImage(cgImageFormat: fmt!)! }() + + init(_ input_filename: String) { + //get data from u8 file + + do { + try fileReader.open(filename: input_filename) + } catch { + print("Cant open file \(input_filename)") + exit(0) + } + var i8_arr:[Int8]? = nil + do { + try i8_arr = fileReader.readAll() + allData = i8_arr + } catch { + print("Got error \(error)") + } + + fileReader.close() + } func makeSpectrogramImage() -> NSImage { return NSImage(cgImage: FileSpectrum.emptyCGImage, size: .zero) } + + //just get data time to time from databuffer and pretend to be realtime data + func dataFileProcessor() { + //all now is about 512pixels + let processingSlice = allData![offset...offset+FileSpectrum.default_width-1] + let dataBuffer = Array(processingSlice) + var transform_result:[Float] = .init(repeating: 0.0, count: FileSpectrum.default_width) + //DispatchQueue.main.async { + transform_result = self.fft512.computeLine(dataBuffer) + self.simpleImage.drawPalletLine(line: self.line_counter, pixelLine: transform_result) + if self.offset+FileSpectrum.default_width < allData!.count { + self.offset += FileSpectrum.default_width + self.line_counter += 1 + } + //} + + } func startRunning() { sessionQueue.async { print("lets start the task for spectrum analysis") - for i in 0..<100 { + for i in 0..<512 { print("Process the task \(i)") self.simpleImage.drawPixel(i, i, PixelData(a: 255, r: 255, g: 0, b: 0)) DispatchQueue.main.async { + self.dataFileProcessor() self.outputImage = self.simpleImage.toCGImage()! } - sleep(1) + sleep(FileSpectrum.defaultSleepTime) } } } diff --git a/WaterfallFile_UI/WaterfallFile_UIApp.swift b/WaterfallFile_UI/WaterfallFile_UIApp.swift index 959fe55..be9f25a 100644 --- a/WaterfallFile_UI/WaterfallFile_UIApp.swift +++ b/WaterfallFile_UI/WaterfallFile_UIApp.swift @@ -11,7 +11,7 @@ import SwiftData @main struct WaterfallFile_UIApp: App { - let fileSpectrum = FileSpectrum() + let fileSpectrum = FileSpectrum("rtlsdr_99.5M_m.cu8") @Environment(\.scenePhase) private var scenePhase |