FPGA implementation of multi frequency continuous phase frequency shift keying (MCPFSK) modulation techniques for HF data communication by Jaswar, Fitri Dewi & Sha’ameri, Ahmad Zuri
[ME04] FPGA implementation of multi frequency continuous phase frequency shift 
keying (MCPFSK) modulation techniques for HF data communication 
 
Fitri Dewi Bt Jaswar, Ahmad Zuri bin Sha’ameri 
 
Digital Signal Processing Lab, Faculty of Elect. Engr, Universiti Teknologi Malaysia, 81310 UTM Skudai, 
Malaysia 
 
Introduction 
In HF (High Frequency) data 
communication systems [1,2], FSK 
(Frequency Shift Keying) digital modulation 
is widely used. The simplicity in the 
implementation is the main reason for its 
popularity. Since noncoherent detection is 
possible, additional components such as 
timing recovery circuits [3] are not necessary 
as required in PSK (Phase Shift Keying) 
modulation. In addition, FSK is robust to 
noise and phase synchronization error that 
present in a HF communication environment 
(ie. multipath fading)[4]. Existing 
implementation utilized DSP processor [1,2]. 
The use of hardware based design such as 
FPGA (Field Programmable Gate Array) can 
further miniaturize system size and add more 
features into existing systems. The importance 
of FPGAs in communication system 
application is described in[5,6]. This paper 
describes the implementation of a MCPFSK 
(Multi frequency Continuous Phase FSK) 
modem on the FLEX10K board 
EPF10K70RC240. Both transmitter and 
receiver modules are integrated into a single 
FPGA. This is achieved by adopting a 
multiplierless and parallel algorithm at the 
receiver module. Comparisons with 
conventional filtering or FFT detection 
techniques demonstrate significant reduction 
in components besides increasing the 
transmission rates. 
 
 
Signal Model 
A received signal within a bit-duration is 
given as 
 
   (1) )()()( twtxty +=
 
where x(t) is the true signal, and w(t) is the 
interference due to additive white Gaussian 
noise with zero mean and power . The true 
signal x(t) is [7] generated by using multi 
frequency modulation where one baud or 
symbol will represent more than a bit. M 
frequencies are used to transmit n combination 
of bits that can be calculated as 
2
pσ
nM 2= [7]. 
For this project, 16 frequencies are used for a 
combination of 4 bit binary data per symbol. 
By using this method, the bit rate increases to 
4 times of the baud rate. 
For simulation purposes, the modulation 
parameters of the signal are as follows: 
subcarrier frequencies at 1800Hz, 
frequency deviation 
cf
devf at 100 Hz, bit-rate of 
100 bits/sec and sampling frequency of 8000 
Hz. The time and frequency domain 
representation of the signal for transmitting a 
character sequence ’12345678’ is shown in 
Fig. 4 and 5 with different index modulation. 
 
A. Generation Of CPFSK  
A conventional FSK signal can be 
expressed as 
 
      ( )tfftx devc ±= π2cos)(  
  
t
T
hf
b
c ⎟⎟⎠
⎞
⎜⎜⎝
⎛ +=
2
2cos π  
 
⎟⎟⎠
⎞
⎜⎜⎝
⎛ += t
T
htf
b
c
ππ2cos   (2) 
 
where h is the modulation index, is the 
deviation frequency, is the center frequency 
and  is the baud duration. By assuming that  
devf
cf
bT
( ) bThtt πϕ =  Equation (2) can be derived 
as 
 
 
( )( )ttftx c ϕπ ±= 2cos)(  
         
       ( ) (( ttf c ϕπ ±= cos2cos2
1 ))  
 ( ) (( )ttf c ϕπ ±− sin2sin2
1 )  
 
The 4th Annual Seminar of National Science Fellowship 2004
450
       ( ) (( )ttf c ϕπ cos2cos2
1= )
 ( ) (( ttf c ϕπ sin2sin2
1m ))    (3) 
 
From Equation (3), a CPFSK signal can be 
produced by using 4 different signals with 2 
frequencies. Consider =1900Hz, h= 4 and 
T
cf
b=1/100.  The carrier frequency and 
modulation index derived from the 
modulation parameters in section 2.0 are 
 
1900201 =−= fffc  
 
22)18002000)(1001(22 =−== devb fTh  (4) 
 
B.    Multi Frequency CPFSK (MCPFSK) 
Multi frequency modulation is an 
advanced modulation technique, allowing the 
increase of bit transmission rate of 
communication system without changing the 
baud rate. The combination of bit are 
organized in gray code and x(t) is considered 
as the generated MCPFSK signal. 
 
( ) (( )ttftx devc ϕϕπ cos2cos2
1)( = )
 ( ) (( )ttf devc ϕϕπ sin2sin2
1m )  (5) 
 
where 
devϕ  is an integer number and depends 
on the amount of combination  bit that will be 
used, and ( )tϕ  =   . tf devπ2 devϕ is an odd 
number that appears until nM 2= . For this 
project, value of devϕ  is 15,13,11,9,7,5,3, and 
1. Phase can be calculated as 
bdevdev Tfπϕ 2*  
with consideration that  ,  
=1/100, and =1900 for this project. 
100=devf bT
cf
  
 
C.  Detection of CPFSK 
In FSK modulation, the binary information 
is represented in frequency mode. This 
information can be extracted by calculating 
the power spectrum of the signal in frequency 
domain. The peaks of the power spectrum 
occur at the frequency of the signal. Spectrum 
based detection [9] utilizes the concept of the 
power spectrum. The BER (bit-error rate) 
performance is slightly lower than that of 
coherent detection but phase synchronization 
is not critical in spectrum based detection. The 
power spectrum can be expressed as 
 
2)(1)( fX
T
fS
b
XX =    (6) 
              
2
0
0
),()(1 ∫
+
∗=
bTt
tb
dtftbtx
T
 
 
where x(t)  is the signal and b(t,f) is the basis 
function. If a complex sinusoid is used as 
basis function, the resulting spectrum is the 
Fourier spectrum. The basis function based on 
the complex square wave defined within a 
period T=1/f is 
 
1),( =ftb  
f
t
f 4
1
4
1 ≤≤−          (7) 
  =-1  
f
t
f 2
1
4
1 ≤≤  
 =j1 
f
t
2
10 ≤≤  
 =- j1 0
2
1 ≤≤− t
f
 
The square wave basis function is chosen to 
eliminate multiplication in the hardware 
implementation. 
 
D. Detection of MCPFSK 
For detecting 16 frequencies, the same sub 
module for detecting FSK signal is used. 
Instead of detecting 2 frequencies, 16 sub 
modules are designed in parallel to detect 16 
frequencies. In multi-frequency modulation, 
each frequency of each symbol will have a 
different probability of error. Data bits are 
generated by using gray code, to minimize to 
only one bit error for each symbol. The 
probability of symbol error is the summation 
of each frequency’s probability shown as 
 
( )
⎟⎟⎠
⎞
⎜⎜⎝
⎛
⎥⎥⎦
⎤
⎢⎢⎣
⎡−=⎟⎟⎠
⎞
⎜⎜⎝
⎛
⎥⎥⎦
⎤
⎢⎢⎣
⎡−−=
pp
e N
A
N
AP
2
exp
2
1
8
15
2
exp
2
1
2/16
116 22   
(8) 
 
For the general case, the probability of symbol 
error for multi-frequency FSK can be 
expressed as   ( )
BFSKe PM
MP
2/
1−=   (9) 
 
Implementation Methodology 
The designed system is divided into 2 
major parts, which is the transmitter and 
receiver part. Before the hardware of the 
The 4th Annual Seminar of National Science Fellowship 2004
451
system is designed, each method is generated 
and tested using MATLAB.  
 
A. Transmitter 
The transmitter is designed using digital 
recursive generator, which is a multiplier 
based modulator. For this project, multi 
frequency CPFSK signal is generated at the 
modulator. Consider x(n) the generated 
CPFSK and can be expressed as 
 
( ) (( )ttftx c ϕπ cos2cos2
1)( = )
 ( ) (( ttf c ϕπ sin2sin2
1m ))    
        BA coscos
2
1= BA sinsin2
1m  (10) 
 
From equation (10), there are 4 different 
signals that should be generated to produce 
CPFSK. A Coupled standard quadrature 
oscillator structure can be used to generate 
sinusoidal A and B frequencies. This structure 
is chosen because it features both quadrature 
and equi-amplitude outputs. However, this 
oscillator requires four multipliers per 
iteration. A serial coupled standard quadrature 
oscillator structure is used to implement 
complex sinusoidal and CPFSK signal, which 
limits the used of only one multiplier in the 
system. 
A coupled standard quadrature oscillator 
is capable of generating both sine and cosine 
wave   which have same frequency 
simultaneously. Let  and  denote 
the two outputs of the generator given by 
][1 ns ][2 ns
 
 ( )θα nns sin][1 =  
 ( )θβ nns cos][2 =   (11) 
 
Equation (11) can be expressed as equation 
(12) and (13)  for n=n+1 and is used in the 
chosen oscillator structure. 
 
( )( )θα 1sin]1[1 +=+ nns  ( ) ( )
][sin/][cos
sincoscossin
21 nsns
nn
θβαθ
θθαθθα
+=
+=  (12) 
 
( )( )θα 1cos]1[2 +=+ nns  ( ) ( )
][sin/][cos
sinsincoscos
12 nsns
nn
θαβθ
θθβθθβ
−=
−=   (13) 
 
The only difference between CPFSK and 
multi frequency CPFSK is the value of B, 
which is the frequency deviation value. 
Instead of 1 value in CPFSK, multi frequency 
CPFSK has 8 values and this value is stored in 
a buffer and is selected by using multiplexer 
according to bits transmission. 
 
// pseudo code to generate MCPFSK signal 
for ( n=0;n<nbit;n++)  
{    // generate cosA & sinA 
  SinA1=SinθA X CosA(n) 
SinA2=CosθA X sinA(n) 
SinA(n+1)=SinA1 + SinA2 
 
CosA1(n+1)=CosθA X cosA(n) 
CosA2(n+1)=sinθA X sinA(n) 
CosA(n+1)=cosA1- cosA2 
     
    // generate cosB & sinB 
SinB1=SinθB X CosB(n) 
SinB2=CosθB X sinB(n) 
SinB(n+1)=SinB1 + SinB2 
 
CosB1(n+1)=CosθB X cosB(n) 
CosB2(n+1)=sinBA X sinB(n) 
CosB(n+1)=cosB1- cosB2 
 
     
    //x[n]=1/2*cosA*cosB(+-)1/2*sinAsinB 
 
    mult1=1/2 *cosA[n]*cosB[n]; 
    add3=mult1; 
    mult1=1/2 *sinA[n]*sinB[n]; 
    x[n]=add3 ± mult1;        
   //add/sub depends on generating the MSB bit 
'1/0' 
} 
FIGURE 1 Pseudo code to generate MCPFSK 
signal. 
 
 
 
B.     Receiver 
A square wave detector is designed and 
implemented as the receiver system to 
optimize implementation of hardware (such as 
using ASIC and FPGA) by avoiding the use of 
multipliers. A multiplier is required to 
calculate the signal-basis function product 
x(t)b*(t,f) in Equation (13). If the complex 
square wave is used as a basic function, then 
the multiplication function can be done by 
replacing the multiplier with a sign check and 
compliment module. The overall system is 
generated based on the pseudo code shows in 
Fig. 2.  
 
 
 
 
 
 
 
 
The 4th Annual Seminar of National Science Fellowship 2004
452
 
// pseudo code to detection of MCPFSK; 
 
   // freq[n,M] is basis function for each frequency 
   // x[n] is input 
    
for ( M=1;M<16,M++) 
{  
// for one bit sample 
sum0=0; 
sum1=0; 
detect_bit=0; 
 
for ( n=0;n<Nsample,n++) 
  {  
   if (freq[n,M]=1) 
       { if ( x[n]>0) 
            { sum[M]= sum[M] + x[n];} 
                else  if ( x[n]<0) 
                  { sum[M]= sum[M] - x[n];} }      
       
  }   
 
if (sum[M]>sum[M-1] ) 
 { detect_bit=M;} 
 else detect_bit=detectbit;} 
}       
 
FIGURE 2 Pseudo code to generate parallel multi 
frequency square wave detection. 
 
 
Results 
There are several ways of designing multi 
frequency detectors such as filtering for 
noncoherent detection or using FFT module. 
Coherent structure is not considered in this 
project because of the complexity in designing 
its timing recovery circuit due to the nature of 
HF channel. Figure 3 shows the MATLAB 
simulation performance for different types of 
detectors and shows that a square wave 
detection performs with better results than 
using FIR filters in terms of BER 
performance. Table I lists the simulation 
results from MAXPLUS II tools for MCPFSK 
design, which is includes the startbit detection 
module for data synchronization and CRC16 
for error detection. For comparison purposes, 
data from ALTERA megacore function for 
FFT and FIR filter module is used. From 
collected data, the FIR filter is not a good 
choice in terms of design area and speed 
performance to implement 16 CPFSK, where 
16 filters is needed to detect 16 frequency 
simultaneously. FFT technique is much more 
reasonable for detection of 16 frequencies. 
Data from TABLE I and TABLE II shows that 
FFT module uses  double the amount of  logic 
cells than the proposed technique not 
including the RAM block for multiplier 
design.    
The proposed technique has better 
performance in terms of BER and size of 
implementation design. It is also proposed for 
MSK modulation, which use the minimum 
frequency deviation. For noncoherent 
detection, a filter with larger length is required 
to implement MSK detection. But, with this 
proposed technique, no extra component is 
needed. Figure 5 shows the generated signal 
from modulator and have been used as input 
for the demodulator for index modulation, h= 
½, which is a MSK signal. 
 
 
TABLE I List of components for MCPFSK 
modulation technique for HF data transmission. 
 
 
Module Input
Pin 
 Output 
Pin 
Bidirect
ion Pin 
Memory Chip size 
    Bit’s Utili
zed 
LC’s Utili
zed 
Modulator 6 46 16 128 0% 1578 42%
a)CPFSK 13 30    1001 26%
b)serialop(U
ART) 
28 43    268 7% 
c)CRC 12 20    98 2% 
        
Demodulator 6 56 16 384 2% 3121 83%
a)Startbit 12 19    315  
b)square 
wave 
detection 
16 22 256 256 1% 2275 60%
c)CRC 12 20    98  
d)serialop(U
ART) 
28 43    268 7% 
        
Modulator 
and 
demodulator(
without 
UART) 
64 117 16 384 2% 3583 96%
 
 
 
TABLE II List of streaming data flow performance 
and device utilization for the FFT MegaCore 
function in Stratix II devices. 
 
 
 
 
 
 
 
 
 
The 4th Annual Seminar of National Science Fellowship 2004
453
 
 
FIGURE 3   Probability of error for MCPFSK 
signal with different type of detection. 
 
 
 
 
 
 
  
 
 
 
 
 
 
 
 
FIGURE 4  Time and frequency distribution for 
MCPFSK for index modulation,h=4. 
 
Conclusion 
This paper describes the design of an 
MCPFSK modem on FPGA. The hardware 
approach is adopted with the objective to 
miniaturize system size. The design module is 
compared to FFT and FIR ALTERA modules. 
The square wave detector has 50% less logic 
component because no multiplier is used in 
the algorithm. Thus, the modem designed with 
the square wave detectors can be made 
smaller. Besides that, it can also be used for 
MSK detection. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
FIGURE 5  Time and frequency distribution for 
MCPFSK for index modulation,h=1/2. 
 
 
References 
[1]   PK-232/PSK Modem,Timewave      
Technology Inc, http://www.timewave.com 
 
[2]   RF-5710 HF Modem, Harris Corporation, 
http://www.harris.com 
 
[3] Proakis, J.G., Digital Communications, 
McGraw-Hill Inc 3rd edition 1995. 
 
[4] Clarke, K.C.; Cipolle, D.J.; Rhodes, R.R., 
“Development of a real-time testbed for 
studying demodulation techniques in a 
jamming environment,” Military 
Communications Conference, 1991. 
MILCOM '91, Conference Record, 'Military 
Communications in a Changing World'., IEEE 
, pp. 610 -616 vol.2,4-7 Nov 1991. 
 
[5] Togawa, N.; Sakurai, T.; Yanagisawa, M.; 
Ohtsuki, T., “A hardware/software 
partitioning algorithm for processor cores of 
digital signal processing”, Design Automation 
Conference, 1999. Proceedings of the ASP-
DAC '99. Asia and South Pacific , pp.335 -
338 vol.1 18-21, Jan 1999  
 
[6]Cummings, M.; Haruyama, S., “FPGA in 
the software radio”, IEEE Com. Mag., 
Volume: 37 pp. 108 -112, 2 , Feb 1999 . 
The 4th Annual Seminar of National Science Fellowship 2004
454
[7]  Ziemer,R.E.; Peterson, R.L.; Introduction 
to Digital Communication, Prentice Hall 
Int.  Inc.,edition 2001. 
 
[8] Shanmugam, K.S., Digital and Analog 
Communication Systems, John Wiley, 
New York, 1985. 
 
[9]   Sha’ameri,A.Z.;Jaswar,F.D.” Detection 
of binary data for FSK digital modulation 
signals using spectrum estimation 
techniques” 4th National Conference on 
Telecommunication Technology (NCTT 
2003),2003. 
 
[10] Mitra, S.K, Digital Signal Processing, 
McGraw-Hill Int. edition 2001. 
 
[11] FFT Megacore Function, ALTERA Corp. 
http://www.altera.com/products/ip/dsp/tra
nsforms/m-ham-fft.html 
 
[12] Implementing FIR filter in FLEX, 
ALTERA Corp., 
http://www.altera.com/literature/an/an073.
pdf 
 
 
 
 
 
 
 
 
The 4th Annual Seminar of National Science Fellowship 2004
455
