This is a basic Morse receiver for GNURadio, containing:
- signal demodulation and detection of Morse signals with an SDR using GNURadio (and Python modules)
- a simple live decoder of received symbols provided by the GNURadio Morse receiver
The flowgraph is provided in the examples
folder:
Morse_receiver.grc
- for SDR reception
A supplementary tool is provided in the python
folder:
DecodeMorse.py
decodes the received symbols from a specified ZMQ server upon receiving them. It shows the decoded ASCII symbols.
The Morse receiver was tested with:
- gnuradio & GNURadio Companion 3.10.1.1 (Linux)
- Radioconda 2023.02.24 & gnuradio & GNURadio Companion 3.10.5.1 (Windows)
- Python 3.10.6
- PyQt5 5.15.7
- pyzmq 23.1.0
- gnuradio-osmosdr 0.2.0
- An SDR receiver capable of receiving in the range of at least 1 kHz - 1 MHz, e.g. an Airspy Discovery HF+ is configured and used for this project.
- An antenna that provides sufficiently clear Morse signals, e.g. a simple YouLoop loop antenna was used for this project. Indoor reception should probably be possible. You should mount the antenna close to a window or outside.
- The user might also need some antenna cables and adapters to connect the SDR with the antenna.
- This project has been successfully tested in:
- Ubuntu 22.04.2 LTS
- MS Windows 11
-
Set up your SDR with your computer.
-
Ensure that the raw Morse signal reception is good enough, e.g. using gqrx or another signal analysis tool. It should reach at least at approximately -95dB or better.
-
To start the Morse receiver, open the flowchart in
/examples/Morse_receiver.grc
with GNURadio Companion- Press
run
button. - Set the CW band entry frequency if needed in the edit box entitled CW band entry frequency.
- Set the frequency slider values so that stronger signals in the waterfall chart get close to 0.00 (so that it begins either slightly left or right of it). Use the mouse to drag the slider for the rough frequency adjustment.
- You can further adjust and fine-tune the frequency with the mouse wheel, to improve signal reception.
- You can also zoom into the waterfall plot.
- Adjust the gain slider values to boost or dampen the signal (and noise) strength.
- Adjust the low_thres and high_thres slider values, if needed.
- The theshold limits will be shown in the time signal plot.
- Adjust the loudness, especially if the audio tone is clipped.
- Activate checkbox print durations of ON to view the signal durations during OFF.
- Set the short mark slider, long mark slider and tolerance sliders, accordingly.
- Deactivate checkbox print durations of ON.
- Activate checkbox print durations of OFF to view the signal durations during OFF.
- Set the element space slider, letter space slider and word space slider accordingly.
- Deactivate checkbox print durations of OFF.
- Activate checkbox print symbols to show the detected Morse symbols. After picking a good signal, the GNURadio Companion debug console should show debug messages each for each received symbol (streams of . and _).
- Press
-
Next, open a terminal.
- Change to your cloned repository.
- Run DecodeMorse with
python3 ./python/DecodeMorse.py
. - The terminal should show the decoded ASCII symbols.
- NOTE: Morse messages are often shortened and technical. The messages "TEST", or "CQ", in the decoder output are a good indicator that decoding worked sufficiently well.
- NOTE: Sometimes a symbol can not be decoded correctly, e.g. due to bad reception. Then the decoder will produce decoding errors.
- NOTE: Some Morse signals tend to fade in and out, so that some symbols might get lost sometimes.
- NOTE: Interfering Morse signals might disturb the decoder.
- NOTE: The transmission speed of Morse symbols (and pauses) varies among different senders. Feel free to optimize the Morse decoder timing and other reception parameters according to your needs.
- This project has not been tested with other SDR receivers.
- This project has not been tested with a receiver setup using a sound card.
- This project has not been tested with other antennas.
- A Low Noise Amplifier (LNA) is not needed.
- Additional resilience of the Decoder has not been implemented yet.
- The maintainer is only a hobbyist, not a Morse professional ;-).