Ejemplo n.º 1
0
        public void Configure(float sampleRate, int bufferSize)
        {
            //Complain if too low
            if (sampleRate < BAUD_RATE)
            {
                throw new Exception($"The sample rate specified, {sampleRate}, is too low to be useful. Must be >= {BAUD_RATE}.");
            }

            //Create parts
            fmDemod = new FmBasebandDemodulator();
            fmDemod.Configure(bufferSize, sampleRate);
            amDemod          = new AmBasebandDemodulator();
            osc              = new Oscillator(sampleRate, -2400);
            symbolsPerSample = BAUD_RATE / sampleRate;

            //Make filter
            var filterBuilder = new LowPassFilterBuilder(sampleRate, 2080)
                                .SetAutomaticTapCount(200)
                                .SetWindow();

            filter = RealFirFilter.CreateFirFilter(filterBuilder);

            //Create buffer
            buffer?.Dispose();
            buffer = UnsafeBuffer.Create(bufferSize, out bufferPtr);
        }
Ejemplo n.º 2
0
        private void Form1_Load(object sender, EventArgs e)
        {
            //Add all entries to the pie graph to start off with
            for (int i = 0; i < 32; i++)
            {
                rdsGroupChart.Series["Groups"].Points.AddXY("", 0);
                rdsGroupChart.Series["Groups"].Points[i].IsVisibleInLegend = false;
            }

            //Configure table
            rdsHistory.Columns.Add(GenerateColumn("PI", 40));
            rdsHistory.Columns.Add(GenerateColumn("Group", 50));
            rdsHistory.Columns.Add(GenerateColumn("Description", -1));

            //Create buffers
            iqBuffer    = UnsafeBuffer.Create(BUFFER_SIZE, out iqBufferPtr);
            audioBuffer = UnsafeBuffer.Create(BUFFER_SIZE, out audioBufferPtr);

            //Open USB device
            usb    = new LibUSBProvider();
            device = AirSpyDevice.OpenDevice(usb);

            //Configure radio
            device.SetLinearGain(gain.Value / 100f);
            device.CenterFrequency = (long)(freq.Value * 1000000);
            device.SampleRate      = 3000000;
            device.StartRx();

            //Create filter
            var filterBuilder = new LowPassFilterBuilder(device.SampleRate, BANDWIDTH / 2)
                                .SetAutomaticTapCount(BANDWIDTH * 0.1f, 50)
                                .SetWindow();

            filter = ComplexFirFilter.CreateFirFilter(filterBuilder, filterBuilder.GetDecimation(out float decimatedSampleRate));

            //Create FM and RDS
            fm = new WbFmDemodulator();
            fm.Configure(BUFFER_SIZE, decimatedSampleRate, 48000);
            fm.OnStereoDetected += Fm_OnStereoDetected;
            fm.OnRdsDetected    += Fm_OnRdsDetected;
            rds = new RdsClient();
            fm.OnRdsFrameEmitted += (ulong frame) => rds.ProcessFrame(frame);

            //Bind RDS client commands
            rds.ProgramService.OnPartialTextReceived += ProgramService_OnPartialTextReceived;
            rds.PiCode.OnPiCodeChanged          += PiCode_OnPiCodeChanged;
            rds.ProgramType.OnCategoryChanged   += ProgramType_OnCategoryChanged;
            rds.RadioText.OnPartialTextReceived += RadioText_OnPartialTextReceived;
            rds.OnCommand += Rds_OnCommand;

            //Create worker thread
            worker = new Thread(WorkerThread);
            worker.IsBackground = true;
            worker.Start();
        }