-
Notifications
You must be signed in to change notification settings - Fork 188
Digimodes
The UHSDR software supports three digimodes (FreeDV, RTTY, and CW) at the moment. Work is underway to implement some more modes.
Common for all digital modes (except for CW decoding, see below):
- Once only: enable "Digital Modes" in Standard Menu
- With touchscreen
- touch on blue box "DIGITAL" --> changes to orange and displays the digital mode
- to switch to other digital modes touch box again
- With menu (no touchscreen)
- Go to "Touch via menu" Menu
- Select desired "Digital Mode"
- Leave menu mode
- The blue box should show the desired digital mode.
- Now switch to digital mode using the Mode button (G1). The blue box switches to orange and digital mode is active.
Implemented modes:
- select digital mode "FREEDV" as described above
- bla bla bla
FreeDV is a digital voice mode designed for reception and transmission of voice on the HF bands. It uses a low bitrate voice coder-decoder (Codec 2) which is in the public domain (licensed under the GNU GPL). Decoding voice is possible down to signal-noise-ratios of 4dB. We are grateful to David Rowe for writing the source code and putting it into the public domain and also for answering questions and helping with design decisions for implementation of FreeDV into the UHSDR software. More details here: http://freedv.org/tiki-index.php?page=FreeDV+Specification
- select digital mode "RTTY" as described above
- set AGC speed to very long (very slow) or (best) switch it off completely
- change mode to RT-L (LSB aka normal polarity, Mark is the high RF frequency) or RT-U (USB aka reverse polarity, Mark is the lower RF frequency) according to desired RTTY mode
- use filter bandwidth 1.4k BPF --> do not try to use a very narrow bandwidth, this does not help the decoder, maybe it helps your ears, but the decoder needs relatively wide bandwidth to avoid distortion decoder errors
- with button M1 change orange focus to box BD
- with encoder 1 adjust baud rate (BD)
- with button M2 change orange focus to box SFT
- with encoder 2 adjust shift (SFT)
- adjust frequency until mark and space frequencies are accurately aligned with the vertical markers
- if vertical markers are invisible, change their colour in Display Menu --> TX Carrier Colour
- enjoy RTTY being decoded and displayed as running text
Ham RTTY:
- RTTY LSB mode = RT-L
- shift 170 Hz
- 45.45 bauds
- signals at 915 and 1085 Hz
Shipping RTTY broadcast (marine weather, warnings etc.) of the Deutscher Wetterdienst DWD:
- RTTY USB mode = RT-U
- shift 450 Hz
- 50 bauds
- signals at 915 and 1365 Hz
- try 4581.865 kHz, 7644.860 kHz, 10099.660 kHz, 11037.860 kHz or 14466.160 kHz
- Switch CW Keyer Mode (CW menu) to Iambic or Ultimate
- Set CW TX RX delay (CW menu) high enough so that RTTY keeps transmitting between your morse letters
- As soon as you start using the keyer, your decode morse code will be sent out as RTTY (or idle RTTY is sent)
Simple RTTY TX via USB Keyboard now possible, most but not all USB keyboards work. Keyboard layout is QWERTY, no matter what the keyboard says.
- Switch CW Keyer Mode to Straight (disables RTTY CW Keyer Input)
- Now select desired RTTY mode
- Hit F1 on keyboard to start TX (or press PTT)
- Enter text, text is immediately sent out
- Hit F2 on keyboard to stop TX (or press Tune twice)
- You can also enter text before you press F1, it is stored and sent when you start TX.
RTTY is a simple FSK (frequency shift keying) mode which transmits digital data at relatively low speeds without error correction. We use a simple but apparently quite well working decoder based on a DSP tutorial written by Norbert, HA2NON, adapted and extended for use in the UHSDR firmware. The demodulator filters both frequencies and passes the energy difference through a simple 50Hz filter. The resulting signal is passed to a digital PLL which handles the bit decoding timing and a symbol decoder which then decodes the bitstream into RTTY characters.
We extended the decoder with code bits from FlDigi to implement ATC = automatic threshold correction. This is a technique to optimize the decision threshold level in the presence of selective fading and QRM. We implemented the "Optimal ATC" algorithm also used as the standard in FlDigi. For more information see: http://www.w7ay.net/site/Technical/ATC/
A nice example for a digital mode which existed for a long, long time.
We know that experienced CW operators do not need this feature (and will probably also never use it ;-)), but it could be useful for beginners in CW or for refreshing your CW knowledge, or (we hope so!) could even motivate hams to learn CW from scratch!
The decoder code has been adapted from Lofturs´ implementation of an algorithm designed by Guenther (1973) (for military use on a "modern" microcomputer (modern in the seventies!), see reference below). Thanks, Loftur, for putting your code under the GNU GPL license!
Please note that the CW decoder is definitely not better than your ear-brain interface. This is also expressed by the huge amount of scientific effort still recently put into developing new algorithms to decode CW (eg. Zhang et al. 2006, Wu et al. 2010, Wang et al. 2016 and the "Machine Learning Challenge" in 2014: http://ag1le.blogspot.de/2014/09/morse-learning-machine-challenge.html).
So, for the moment, there seems to be no better CW decoder available than your ears and brain working together (which is somehow appeasing and alarming at the same time ;-)).
Use a slow or very slow AGC or no AGC in your audio path. Make sure you have tuned to the CW station properly assuring that the audio pitch of the station matches your sidetone frequency (because the CW decoder only "hears" CW signals which are on the pitch of your selected sidetone frequency).
CW decoder enable - ON/OFF
- Switches the CW decoder ON or OFF. This is possible in every mode, the decoder works on basis of the audio signal. Honestly, this is only useful, if you have a narrow filter and a one sideband mode, eg. 300Hz/700Hz in LSB or CW-L. Do not combine this with RTTY demodulation mode, this will produce garbage ;-)
Signal threshold:
- Adjust this threshold while checking the red LED until the red LED is modulated with the rhythm of the CW signal you are listening to. This adjustment is dependent on the signal strength of your CW station and band and antenna noise. So you would likely have to adjust this threshold when changing bands, antennas, or frequency. ATTENTION: the audio signal has to match the pitch of your CW sidetone.
Blocksize
- in order to be able to filter out and determine the real time signal strength of the CW impulses, we use the Goertzel algorithm. Similar to an FFT, we need a certain no. of samples and calculate the magnitude from the sample levels. The number of samples used for one signal magnitude value is called "Blocksize". Blocksize can be changed from 8 to 128 in steps of 8 samples.
Noise cancel ON/OFF
- a special noise canceling algorithm for the decoder.
Spike cancel OFF/SPIKE/SHORT
- yet another spike cancelling algorithm, which helps the decoder to ignore short noise impulses. Has three options: OFF/SPIKE cancelling/SHORT spikes cancelling
Use 3 Goertzels
- may come in the future, there is nothing to choose here yet
The decoder works as follows (see Guenther 1973 for details):
- collect a block of samples (with size "Blocksize")
- calculate one "optimized Goertzel" magnitude value from this block of samples [Goertzel algorithm works like an FFT, giving you the magnitude of a signal for a given frequency --> the CW sidetone frequency you are listening to]
- lowpass filter the magnitude values ("averager")
- automatic gain control for these values ("AGC")
- determine whether we have a pulse or a space by comparing the magnitude level to a "threshold"
- noise canceling: determine whether two consecutive magnitude values are the "same" (pulse/space) and accepting only when this is true
- light the red LED when we have a pulse
- shut off the red LED when we have a space
- the pulses and spaces and the time length of these pulses and spaces are stored in a ring buffer
- the ring buffer is used to INITIALIZE the decoder: a set of equations from Guenther (1973) is used to determine the speed (WPM) of the received CW message, i.e. the length of dots, dashes and inter-character and inter-word spaces. This is the essential step for decoding the message
- then the message stored in the ring buffer is being decoded by the DATA RECOGNITION routine using the timing information from the initialization --> this produces another data buffer with all the dits and dahs and spaces of the message
- the dits and dahs are then interpreted in the CHARACTER IDENTIFICATION routine, where basically a look-up-table is used to interpret the dits and dahs as characters
- the characters and the inter-character-spaces are then sent to the printer routine which prints them out on the display
- One very important addition is an error correction routine which -in the case of a sequence of dits and dahs that can not be assigned to a character in the look-up-table- tries out several possibilities to eliminate single dots in order to finally match the dit/dah sequence to existing characters in the look out table. Also the error correction tries to correct too short character spaces
- So, we are finally there: a sequence of characters and spaces which hopefully matches the transmitted CW message to a certain extent
Please note that still -in 2017!- there is no algorithm which performs better on decoding of CW signals than the human ear/brain of trained CW experts! Even highly sophisticated machine learning algorithms do not perform better than experienced CW operators.
RTTY
http://dp.nonoo.hu/projects/ham-dsp-tutorial/18-rtty-decoder-using-iir-filters/ [the source of the RTTY algorithm used]
http://www.w7ay.net/site/Technical/ATC/ [Automatic threshold correction algorithm for RTTY]
http://www.w1hkj.com/FldigiHelp-3.21/html/rtty_page.html [how FlDigi does it]
http://elecraft.365791.n2.nabble.com/AGC-and-RTTY-Decoding-was-K3-AGC-White-Paper-td7627781.html [why you need a slow or no AGC for RTTY decoding]
https://github.com/ukhas/dl-fldigi/tree/master/src/cw_rtty [Fldigi source code: CW and RTTY decoding]
FREEDV
http://freedv.org/tiki-index.php
CW
https://sites.google.com/site/lofturj/cwreceive [Machine recognition of hand sent morse code incl. C source, GNU GPL3]
GUENTHER, J.A. (1973): Machine recognition of hand-sent morse code suing the pdp-12 computer. - Air Force Institute of Technology Wright-Patterson Air Force Base, Ohio. [http://www.dtic.mil/dtic/tr/fulltext/u2/786492.pdf]
https://codebender.cc/sketch:152917#Morse%20Code%20Decoder.ino [Arduino morse code decoder incl. C source]
ZHANG, R.B., HE, L.G. & X.-Y. LI (2006): Automatic detection and recognition of Morse signal in strong noise environment. [http://en.cnki.com.cn/Article_en/CJFDTOTAL-HEBG200601023.htm]
WU et al. (2010): Design and Implementation of Morse Code Recognition Based on Finite State Machines. [http://en.cnki.com.cn/Article_en/CJFDTOTAL-WJFZ201005045.htm]
WANG et al. (2016): An Automatic Decoding Method for Morse Signal based on Clustering Algorithm. - Advances in Intelligent Information Hiding and Multimedia Signal Processing pp 235-242 [https://link.springer.com/chapter/10.1007/978-3-319-50209-0_29]
PSK31
https://github.com/gmtii/STM32-SDR/blob/master/STM32-SDR/code/main/src/PSK_Det.c [PSK31 decoding and encoding, source code under GNU GPL]
- Supported SDR Hardware
- UHSDR: Manuals
- mcHF: Building your own SDR
- OVI40: Building your own SDR
- UHSDR: SW Installation on SDR
- UHSDR: Theory of Operation
- UHSDR: SW Development
- UHSDR: Supported Hardware
- UHSDR: Manuals
- Building a mcHF SDR
-
Building a OVI40 SDR
- UHSDR SW Installation
- Theory of Operation
- UHSDR SW Development