sdrangel/plugins/channelrx/freqtracker
..
CMakeLists.txt
freqtracker.cpp
freqtracker.h
freqtrackerbaseband.cpp
freqtrackerbaseband.h
freqtrackergui.cpp
freqtrackergui.h
freqtrackergui.ui
freqtrackerplugin.cpp
freqtrackerplugin.h
freqtrackerreport.cpp
freqtrackerreport.h
freqtrackersettings.cpp
freqtrackersettings.h
freqtrackersink.cpp
freqtrackersink.h
freqtrackerwebapiadapter.cpp
freqtrackerwebapiadapter.h
readme.md

readme.md

Frequency tracker plugin

Introduction

This plugin can be used to track the center frequency of a carrier. It will try to adjust its center frequency on the carrier center frequency. It is normally used in conjunction with a utility program that monitors the plugin center frequency via reverse API. This utility can then make use of this information to control other plugins or any other purpose.

☞ You will find the freqtracking.py (Python script) utility program that can be used to manage frequency tracking in the scriptsapi folder of this repository. More details can be found in the Readme.md file in the same folder.

Interface

Frequency Tracker plugin GUI

1: Frequency shift from center frequency of reception

When the tracking is active (7.1) with a FLL or PLL tracker (7.3) and the squelch is open (8) the tracking system will change the frequency shift automatically to try lock on the carrier center frequency.

Both manual and automatic controls are active at the same time and the user can force the center frequency at any one time but the tracker will try to lock it to the carrier again.

To change the frequency manually use the wheels to adjust the frequency shift in Hz from the center frequency of reception. Left click on a digit sets the cursor position at this digit. Right click on a digit sets all digits on the right to zero. This effectively floors value at the digit position. Wheels are moved with the mousewheel while pointing at the wheel or by selecting the wheel with the left mouse click and using the keyboard arrows. Pressing shift simultaneously moves digit by 5 and pressing control moves it by 2.

2: Instantateous tracker error

This is the instantaneous frequency error in Hz. It is activated as soon as the FLL or PLL tracker is selected (7.3) regardless of the tracking activation (7.1)

☞ Note that the correction is limited to +/- 1/1000th of the channel sample rate in Hz. In the screenshot example the channel sample rate is 25 kS/s and thus the correction is effective only if the tracker error is larger that +/- 25 Hz.

3: Channel power

Average total power in dB relative to a +/- 1.0 amplitude signal received in the pass band.

4: Level meter in dB

  • top bar (green): average value
  • bottom bar (blue green): instantaneous peak value
  • tip vertical bar (bright green): peak hold value

5: Decimation factor

The baseband sample rate can be decimated by a power of 2 between 1 (no decimation) and 64 the resulting sample rate in kS/s is displayed on the right. The FLL and PLL will run at this sample rate.

8: RF bandwidth

This is the bandwidth in kHz of the channel signal before demodulation. Steps are in 0.1 kHz between 1 kHz and the limit set by the sample rate (equal in kHz to the sample rate in kS/s)

7: Tracker controls

Frequency Tracker tracker controls

7.1 Tracking toggle

Use this button to enable or disable tracking. When enable the locker is closed and when disabled it is opened.

It is also used to signal PLL lock with a green background. Note that the lock status cannot be determined for FLL.

7.2 Alpha factor of frequency error EMA

The frequency error is passed throug an Exponential Moving Average (EMA) stage to smooth it out. This is the decrease factor or alpha in the formula:

Si = α xi + Si-1

Alpha can be set between 0.01 and 1.0

☞ The lower alpha the lesser new values influence the average and thus the smoother the variations but also the slower the system reacts and the longer the acquisition. So you may want to start with values from 0.5 to 1.0 and reduce the value as the tracking achieves the correct frequency to reduce jitter. You may also let the system take the time to reach the correct value progressively with alpha values from 0.01 to 0.1.

7.3 Tracker type selection

You may select the type of tracker with this combo box:

  • No: No tracking
  • FLL: Frequency Locked Loop suitable for CW and FM type signals covering also any kind of digital m-ary FSK modulation. ☞ Note that for FM digital modulations the PLL may work also and sometimes with better stability.
  • PLL: Phase Locked Loop suitable for digital phase modulations i.e. m-ary PSK in power of two orders. The order can be selected with the combo on the right (7.4)

7.4 Order of PSK modulation

This is the order of m-ary PSK modulation for the PLL. It can be selected in powers of 2:

  • 1: Continuous Wave (no modulation)
  • 2: BPSK
  • 4: QPSK
  • 8: 8-PSK
  • 16: 16-PSK
  • 32: 32-PSK

7.5 Toggle root raised cosine filter

Use this toggle button to activate or de-activate the root raised cosine (RRC) filter. When active the bnadpass boxcar filter is replaced by a RRC filter. This takes effect only in normal (DSB) mode (see control 14).

7.6 Tune RRC filter rolloff factor

This button tunes the rolloff factor (a.k.a alpha) of the RRC filter in 0.01 steps between 0.1 and 0.7. Default is 0.35.

8: Squelch open indicator

This indicator lights in green when the squelch is open. When the squelch is closed the tracking (if active) is suspended.

9: Squelch threshold

This is the squelch threshold in dB. The average total power received in the signal bandwidth before demodulation is compared to this value and the squelch input is open above this value. It can be varied continuously in 0.1 dB steps from 0.0 to -100.0 dB using the dial button.

10: Squelch time gate

Number of milliseconds following squelch gate opening after which the signal is declared open. 0 means squelch is declared open with no delay and is suitable for burst signals. The value can be varied in steps of 10 ms from 0 to 990 ms.