MFSK16

How MFSK16 is Transmitted

Transmitting MFSK is very simple. The data (say from the keyboard) is stored in a buffer, and once the transmitter is started, is sent on via a series of coders to the transmit modulator, then to the sound card for conversion to audio.

Study the top half of the diagram after this section.

Idle Insertion
When the transmitter keyboard buffer is empty, non-printing idle characters are stuffed into the transmitter via the coder, as it is important that the transmitter continues to operate without pause in order for synchronism to be maintained at the receiver.

Varicoder
The keyboard data and idle characters are sent through the transmitter at a constant rate, first going to the Varicoder, which uses a look-up table to convert the fixed-length ASCII text into Varicode text, where the length of the character depends on how frequently it is used. This is just like Morse code, and has three advantages:
  • It is more efficient (fewer data bits per word in plain text).
  • It turns a byte-oriented text into a bit-stream, easily transmitted no matter how many bits-per-symbol are involved.
  • It allows the data to be handled by a sequential convolutional coder and decoder used for error correction.
  • It provides a virtually unlimited character set - extended ASCII with accented characters, plus non-printing control codes.

The Varicoder used for MFSK16 is similar to, but not the same as that used for PSK31. In particular, the need for continuous "00" signals to identify idle is not required, and so a more efficient code utilising combinations with repeated zeros is possible. Other codes outside the 256 character ASCII set are used for control purposes.

Convolutional FEC Coder
If Forward Error Correction (FEC) is selected, the next stage is a Convolutional Coder, which generates extra data bits in such a way that the original data can be reconstructed in most cases, even with errors in reception. Two algorithms define the value of two output data bits for every input data bit. A standard NASA R=1/2 K=7 coder is used. The output is a bit stream at twice the input data rate.

Interleaver
The convolutional coder is followed by an Interleaver which simply jumbles up the order of the data. The effect of this is that when the data is received and "unjumbled", the errors caused by bursts of noise are spread out and have a less serious effect on the FEC decoder. Of course the data must be mixed up in a standardised way. The MFSK16 Interleaver is unusual - many small diagonal interleavers are used. Each interleaver uses a table of bits the same size as the number of bits per symbol. This allows the receiver de-interleaver to be completely self-synchronising, which is important where reception can be very poor and synchronism can be lost. Details are given further down the page.

Uncoded Data
MFSK is very robust, and in many cases it is unnecessary to use FEC. This improves the text throughput. In this case the output bit stream is direct from the Varicoder. (Note - to save confusion, no version of MFSK16 without FEC is to be released until the matching receiver software can automatically detect this condition and switch modes).

DSP MFSK Transmitter
The Modulator
The tone generator is relatively straighforward, but hard to describe in simple terms. In the block diagram it is shown as just one block. The MFSK signal is a series of phase synchronous sine wave tone segments, all the same length. The tones always start and end with the same phase, and so have an integer number of cycles each. Since no gaps are permitted between tones, the simplest way to generate them is to use a sine-wave Look-up Table (a large table defining many points on one sine period), and simply sample the table over and over at a constant rate, but skipping a fixed number of table entries between samples. With a fast PC the samples can actually be generated by solving sin(x) on the fly!

The following example was generated using a table and skipping algorithm exactly as described, but simulated using a spreadsheet. The apparent sine wave represents four symbols weighted 010, 100, 000, 010, and is actually four frequencies - four sequential symbols - which might represent tones of 1008, 1012, 1000 and 1008 Hz. Each symbol has approximately 10 cycles, but because of the smooth transition from one to the next, you really can't tell. Using a ruler you might see the difference in frequency, but as is obvious, the phase is continuous.

Four CPFSK Tones
Four CPFSK Tones

When the number of samples skipped is fixed, a constant frequency is generated. However when the number of samples skipped changes, a different frequency is generated, and the frequency of the sine wave generated smoothly changes from one frequency to the next, without the phase changing. This technique is called Continuous Phase Frequency Shift Keying, or CPFSK, and generates the cleanest possible FSK signal.

The technique of sampling a table in steps is called a Direct Digital Synthesizer. Many modern HF rigs use this technique for the "VFO". In the CPFSK modulator, the number of entries skipped is controlled by three, four, or five bits of data from the coders, depending on the number of tones selected. The speed at which tones are switched depends on the selected baud rate.

Look at the lower part of the above block diagram. All this functionality is in the one block entitled "CPFSK Modulator". Because the transmitter signal is generated "on frequency" to avoid mixing, the transceiver NCO used by the receiver cannot be used directly (since it runs at about 1/4 the transmit frequency). However, the software knows the receiver division ratio and the NCO offset, so adds these factors into the transmitter table skipping algorithm.

Thus the Transmitter and Receiver operate as a "Transceiver", on the same frequency. Finally, the stream of values are sent to the PC sound card for conversion to audio tones to be sent to the transmitter. There is no variation in amplitude in the MFSK signal - only the frequency changes. The signal consists only of sine waves and needs no further filtering.

Matching Data Bits to Tones
The data bits to be transmitted don't have any particular relationship to the characters being transmitted, so it does not matter how many bits are transmitted at a time, so long as they are transmitted in the order they arrive. One of the advantages of MFSK is that each tone burst or symbol can represent several bits of data, for example, if there are 8 tones, three bits, 16 tones four bits and 32 tones 5 bits.

Each of the tones in a particular mode are assigned a bit value, for example for 8 tones, the values are:


   8 Tones:                      16 Tones:
   Tone         Weight           Tone         Weight           Tone         Weight
    0 (lowest)   000              0 (lowest)   0000             8            1100
    1            001              1            0001             9            1101
    2            011              2            0011            10            1111
    3            010              3            0010            11            1110
    4            110              4            0110            12            1010
    5            111              5            0111            13            1011
    6            101              6            0101            14            1001
    7 (highest)  100              7            0100            15 (highest)  1000
So the transmitter has a small table which defines for each group of three four or five bits to be transmitted, which tone to use. Notice that the "weight" of each tone does not increase in binary order. This is to ensure that if there is a mis-tuning error, the maximum bit error is one bit. If the order was binary, for example, the transition from "011" to "100", which involves changing all three bits, could cause serious error. This is called a "Gray" code.

The Diagonal Interleaver
The Interleaver used during FEC operation was only briefly described above. This is how it works. Imagine the data bits to be transmitted (0 or 1) can be represented by
"ABCDEFGHIJKLMOPQRSTUVWXYZ0123456789....."

and so on. Then the bit stream about to be sent is arranged by the Interleaver into a table as deep as the number of bits per symbol, like this:
8 Tones:                    16 Tones:                      32 Tones:
  ADGJMPSVY2...                AEIMQUY...                      AFKPUZ...
  BEHKNQTWZ3...                BFJNRVZ...                      BGLQV1...
  CFILORUX14...                CGKOSW0...                      CHMRW2...
                               DHLPTX1...                      DINSX3...
                                                               EJOTY4...
The bits are arranged as they arrive, but are sent on diagonally. The first group of bits sent has been highlighted in each case in the above table. So the bits sent are:
 8 Tones: AEI DHL GKO JNR MQU PTX SW1 UZ4 ...
16 Tones: AFKP EJOT INSX MRW1 ...
32 Tones: AGMSY FLRX4 KQW39 ...
Once again the first group of bits sent on in each case is highlighted. The spreading of the bits is quite modest since the table is not very deep, but since the order of the bits is always known at the receiver (from the bit order in the received symbol), synchronisation of the Interleaver is automatic.

Notice that bits "B" and "C" never seem to be sent. In practice the first few user data bits are not lost, as the transmission always starts with a few idle (unprintable) characters. The more important issue is that the transmission cannot be completed until the Interleaver has been flushed to ensure the data bits in the table have beenall sent. Once again, this is achieved by sending idle characters through the Interleaver, but involves an unavoidable delay as the Interleaver is flushed.

The purpose of an Interleaver is to spread the errors caused by burst noise, so the errors need to be spread further than the constraint length of the FEC coder (8 bits for K=7), and also spread beyond the length of a typical noise burst. One to two seconds is considered a reasonable spreading figure.

In order to increase the spread to meet these requirements, the MFSK16 Interleaver works as though it consisted of 10 sequential diagonal interleavers, one after another, exactly as described. In practice a single sliding interleaver is used, but the offset is 10 bits, not one. The technique is not very clever, but is very fast and simple to execute, with very little load on the computer processor. The output seems to be random, but is in fact mechanistic and therefore completely and automatically "untangled" by the de-interleaver, which simply reversed the process described. Most importantly, this can be achieved without any need to send any interleaver synchronizing information. With 16 tones at 16 baud (the default mode) the spreading amounts to 94 bits (1.5 seconds), and the Interleaver adds 1.2 seconds delay.

Baud Rates
MFSK is renowned for its very low baud rates, even though the text speed is higher. Low baud rates allow narrow bandwidths to be used, which improves the robustness of the receiver, and also helps defeat one of the most serious distortion problems on HF, the timing errors of multi-path reception.

Baud rates for MFSK are typically in the range 10 - 20 baud. This is a compromise between Doppler flutter modulation (and difficulty with receiver stability) at the lower end, and multi-path timing errors (plus selective fading and more risk of interference) at the upper end. The MFSK8/16 baud rates seem to have very odd numbers - 15.625 and 7.8125 baud. The reason for choosing these strange values is that they are binary divisions of 8000 Hz, the sampling rate of the PC sound card. It does not matter what the baud rate is, so long as everyone uses the same one!

In the MFSK transmitter the Symbol Clock operates at the transmitter baud rate, and sends different symbols (tones) from the sound card at this rate. In the receiver the Symbol Clock is recovered from the data, and used to synchronise the blocks of data sent to the receiver filter and demodulator.


Copyright © M. Greenman 1997-2005. All rights reserved. Contact the author before using any of this material.
home 
MFSK Home Page