A new multiple-access telecommunication system by Thomas, Paul Robert
 warwick.ac.uk/lib-publications  
 
 
 
 
 
 
A Thesis Submitted for the Degree of PhD at the University of Warwick 
 
Permanent WRAP URL: 
http://wrap.warwick.ac.uk/94045  
 
Copyright and reuse:                     
This thesis is made available online and is protected by original copyright.  
Please scroll down to view the document itself.  
Please refer to the repository record for this item for information to help you to cite it. 
Our policy information is available from the repository home page.  
 
For more information, please contact the WRAP Team at: wrap@warwick.ac.uk  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
A NEW 
MULTIPLE-ACCESS TELECOMMUNICATION 
SYSTEM 
Thesis submitted in partial requirement for the degree of Doctor of 
Philosophy 
University of Warwick 
by 
Paul Robert Thomas MSc 
September 2000 
TABLE OF CONTENTS 
List of figures vi 
List of tables xi 
Acknowledgements xii 
Declaration xiii 
List of symbols xiv 
Summary xv 
CHAPTERl Introduction 1 
1.1 History 3 
1.2 Techniques 6 
1.3 The CV -CCMA system 18 
CHAPTER 2 Survey of recent research 25 
2.1 Introduction 25 
2.2 Information sources 26 
2.3 Channel models 27 
2.4 Multiple-access 'information theory 28 
2.5 Multiple-access coding 32 
2.6 Time/frequency division multiple-access 34 
2.7 CV -CCMA research 35 
2.8 Code division multiple-access 36 
2.9 High speed radio digital signal processing 38 
2.10 Modern digital radio design 40 
2.11 Summary 41 
CHAPTER 3 CDMAlCV·CCMA comparative discussion 43 
3.1 Introduction 43 
3.2 CDMA summary 44 
3.3 Standards 46 
ii 
CHAPTER 3 (continued) 
3.4 Comparisons 48 
3.4.1 Capacity 49 
3.4.2 Power control 50 
3.4.3 Timing 51 
3.4.4 Noise 52 
3.4.5 Multipath propa~ation 52 
3.4.6 Cost 53 
CHAPTER 4 Multiple-access capacity limits 55 
4.1 Single-channel theoretical capacity limits 55 
4.2 Multiple-channel theoretical capacity limits 60 
CHAPTER 5 Theory of operation 65 
5.1 Introduction 65 
5.2 System synchronisation 69 
5.3 Receiver processing 72 
5.4 System simulations 74 
5.5 Codewords 78 
5.6 Convolutional coding 86 
CHAPTER 6 Implementation 89 
6.1 General implementation 89 
6.1.2 System control 90 
6.1.3 Synthesisers 93 
6.1.4 Synthesiser implementation 100 
6.2 CV -CCMA transmitter implementation 108 
6.2.1 Input stages 108 
6.2.2 Speech digitisation 110 
6.2.3 Implementation 115 
6.2.4 Transmitter filters 118 
6.2.5 Radio frequency modulation 122 
6.2.6 Discussion 123 
iii 
CHAPTER 6 (continued) 
6.3. Receiver implementation 128 
6.3.1 Front-end circuitry 129 
6.3.2 Second stage and mixer 131 
6.3.3 Analogue-to-digital conversion 133 
6.3.4 Signal processor interface 138 
6.4. Software implementation 142 
6.4.1 Introduction 142 
6.4.2 Software operation 143 
6.4.3 Software emulation of receiver 
combinational matrix calculations (QPSK) 156 
6.4.4 QPSK decode example 158 
6.4.5 BPSK combined matrix calculations 162 
6.4.6 Summary 165 
CHAPTER 7 Results 166 
7.1 Introduction 166 
7.2 The synthesisers 168 
7.3 The transmitters 177 
7.4 The receiver 185 
7.5 Bit error rate performance 192 
7.6 Synchronisation 201 
7.7 Summary 204 
CHAPTER 8 Conclusions, discussion and further work 205 
8.1 Introduction 205 
8.2 Coding 206 
8.3 Optical systems 207 
8.4 Mobile radio 208 
8.5 Low-cost radio telecommunications 210 
8.6 Military applications 211 
8.7 Speech digitisation 213 
8.8 Filters 214 
8.9 Control 214 
iv 
CHAPTER 8 (continued) 
8.10 General 
8.11 Conclusions 
REFERENCES 
GLOSSARY OF ACRONYMS 
APPENDICES 
Appendix 1 Texas DSP decode programs 
DSK kernel program 
Appendix 2 Mathcad pseudo-inverse 
calculation program 
Appendix 3 Mathcad variation of g 
simulation program 
Appendix 4 Spice results and netlists 
Appendix 5 12C software, circuits 
Appendix 6 87C750 interface 
Appendix 7 Phase-locked loop 
Appendix 8 Codeword generation circuit 
Appendix 9 TMS320C50 filters code 
Appendix 10 Maxim modulators data 
Appendix 11 Burr-Brown A-D data 
Appendix 12 Low-noise block 
Appendix 13 Set-up routines for the DSP 
Appendix 14 Set-upDSK 
Appendix 15 12C output for bypass 
Appendix 16 Timing diagrams Tx & Rx 
221 
230 
237 
237 
246 
247 
249 
253 
259 
267 
268 
269 
273 
275 
277 
280 
280 
281 
282 
216 
218 
v 
CHAPTERONE 
Figure 1.1 
Figure 1.2 
Figure 1.3 
Figure 1.4 
Figure 1.5 
Figure 1.6 
Figure 1.7 
Figure 1.8 
LIST OF FIGURES 
Time division multiplexing 
Primary rate time division multiplexing 
Frequency division multiplexing 
AT & T frequency division multiplexing hierarchy 
Code division multiplexing 
Code division multiple-access 
Space diversity multiple-access 
Complex valued collaborative coding 
multiple-access system 
CHAPTER TWO 
Figure 2.1 Channel capacity of T -user binary phase shift keying 
8 
9 
10 
11 
13 
14 
16 
24 
31 
Figure 2.2 Channel capacity of 2-user binary multi -phase shift keying 31 
CHAPTER THREE 
Figure 3.1 Typical CDMA handsets 
CHAPTER FOUR 
Figure 4.1 
Figure 4.2 . 
Figure 3.3 
Bit error probability for multi-phase signalling 
(coherent M=2k) 
Normalised channel bandwidth verses Et/No 
Capacity region of 2-user multiple access channel 
CHAPTER FIVE 
Figure 5.1 QPSK I BPSK phasor plots 
Figure 5.2 Codeword generation 
54 
59 
59 
60 
75 
80 
vi 
CHAPTER FIVE (continued) 
Figure 5.3 BPSK possible codeword combinations 82 
Figure 5.4 Block diagram of CV -CCMA demonstrator 85 
CHAPTER SIX 
Figure 6.1 I2C bus PC interface 92 
Figure 6.2 fc bus microcontroller interface 92 
Figure 6.3 Type 1 synthesiser timing 96 
Figure 6.4 Type 2 synthesiser timing 96 
Figure 6.5 Type 3 synthesiser timing 97 
Figure 6.6 Basic phase locked loop 99 
Figure 6.7 Synthesiser block diagram (simplified) 99 
Figure 6.8 Synthesiser output spectrum 104 
Figure 6.9 CV -CCMA synthesiser circuit diagram (reduced) 105 
Figure 6.10 Inter-integrated circuit bus loading circuitry 106 
Figure 6.11 PC386 I2C bus loading circuitry and TMS320C50 filters 106 
Figure 6.12 Synthesiser surface-mount printed circuit board 107 
Figure 6.13 CV -CCMA transmitter functional 109 
Figure 6.14 CV -CCMA demonstrator transmit audio stages 111 
Figure 6.15 CV -CCMA demonstrator pattern generator circuit 111 
Figure 6.16 Basic Delta modulator /demodulator 114 
Figure 6.17 Continuously variable slope Delta modulator/demodulator 114 
Figure 6.18 Transmitter codeword generation 117 
Figure 6.19 Pulse shape filtering 121 
Figure 6.20 Typical pulse shapes/spectra 121 
Figure 6.21 Transmitter radio frequency stages 124 
vii 
CHAPTER SIX (continued) 
Figure 6.22 Codeword generator boards I test pattern generator boards 
Figure 6.23 Two transmitters and data load circuitry 
Figure 6.24 Low-noise block stripline layout 
Figure 6.25 CV -CCMA receiver functional 
Figure 6.26 Receiver circuit (reduced) 
Figure 6.27 Burr-Brown DSP102 analogue input/digital output 
Figure 6.28 Analogue-digital daughter board 
Figure 6.29 Receiver 1 in the laboratory at Warwick 
Figure 6.30 Receiver filter implementation 
Figure 6.31 Pseudo-inverse calculation flowchart . 
Figure 6.32 Digital signal processor initialisation flowchart 
Figure 6.33 Digital signal processor receiver flowchart (type 1) 
Figure 6.34 Digital signal processor receiver flowchart (type 3) 
Figure 6.35 Multiplication routines flowchart 
Figure 6.36 Sort minimum routine (BPSK) 
Figure 6.37 Sort minimum routine (QPSK) 
CIIAPTERSEVEN 
Figure 7.1 
Figure 7.2 
Figure 7.3 
Figure 7.4 
Figure 7.5 
CV -CCMA Block diagram 
S ynthesiser 1, minimum frequency 
output spectrum 
Synthesiser 1, operating frequency 
output spectrum 
Synthesiser 1, maximum frequency 
output spectrum 
Synthesiser 2, minimum frequency 
output spectrum 
126 
126 
130 
134 
135 
137 
137 
141 
141 
144 
145 
151 
152 
153 
154 
155 
167 
174 
174 
175 
175 
viii 
CHAPTER SEVEN (continued) 
Figure 7.6 Synthesiser 2, operating frequency 176 
output spectrum 
Figure 7.7 Synthesiser 2, maximum frequency 176 
output spectrum 
Figure 7.8 Test equipment layout (transmitter) 178 
Figure 7.9 Transmitter 1 output spectrum 179 
(test pattern 1 input) 
Figure 7.10 Transmitter 2 output spectrum 179 
(test pattern 1 input) 
Figure 7.11 Transmitter 1 : input test pattern 180 
Figure 7.12 Transmitter 2 : input test pattern 180 
Figure 7.13 Combined output spectrum (test pattern inputs) 181 
Figure 7.14 a) Audio test tone input 
b) Deltamodulator output (overdriven for clarity) 
c) Recovered Deltamod I transmitted Deltamod 
d) Coder output 182 
Figure 7.15 Combined output spectrum with recorded audio 
inputs and codeword set 1 (unique set for each tx.) 183 
Figure 7.16 a) Audio input test tone 
b) Deltamodulator output 
c) Combined spectrum (input test set 2) 184 
Figure 7.17 Receiver test equipment layout (type 1) 187 
Figure 7.18 . PC screen showing disassembly of fast5.asm 188 
Figure 7.19 Recovered test pattern data (BPSK) 189 
Figure 7.20 Recovered test pattern data (QPSK) 189 
Figure 7.21 Equipment set-up (University of Warwick) 190 
Figure 7.22 Equipment set-up(Cable & Wireless PLC, Coventry) 191 
Figure 7.23 Simulation results from [74] 193 
Figure 7.24 Simulation(l) from 7.23 redrawn for 
comparison purposes 193 
ix 
CHAPTER SEVEN (continued) 
Figure 7.25 Test equipment layout (BER testing) 198 
Figure 7.26 Link 1 fixed and link 2 varied 199 
Figure 7.27 Link 2 fixed and link 1 varied 199 
Figure 7.28 Link 1 varied and link 2 varied 199 
Figure 7.29 Test equipment layout (synchronisation testing) 202 
Figure 7.30 Spectrum of 10 MHz recovered synchronisation 189 
signal (type 3 system) 
Figure 7.31 Spectrum of recovered data signal (type 3 system) 189 
x 
LIST OF TABLES 
Table 1.1 Important dates in electronic communications 5 
Table 1.2 Collaborative coding - example 1 20 
Table 1.3 Collaborative coding - example 2 20 
Table 3.1 Forward link channel parameters rate set 1 46 
Table 3.2 Forward link channel parameters, rate set 2 47 
Table 3.3 Reverse link channel parameters, rate set 1 47 
Table 3.4 Reverse link channel parameters, rate set 2 48 
Table 5.1 Codewords and modulated output system 1 75 
Table 6.1 Synthesiser I2C programming data 102 
Table 6.2 Codeword test set 1 summary 159 
Table 6.3 Test set 1 summary 163 
Table 7.1 Synthesiser programming format 169 
Table 7.2 I2C data transmitted (50MHz output) 169 
Table 7.3 I2C data transmitted (90MHz output) 170 
Table 7.4 I2C data transmitted (100MHz output) 170 
Table 7.5 Synthesiser 2, fc data transmitted (658MHz output) 171 
Table 7.6 Synthesiser 2, I2C data transmitted (850MHz output) 172 
Table 7.7 Synthesiser 2, fc data transmitted (1. 12095GHz output) 172 
Table 7.8 Lock times for synthesisers 173 
Table 7.9 BER results, link 1 fixed, link 2 varied 196 
Table 7.10 BER results, link 2 fixed, link 1 varied 197 
Table 7.11 BER results, link 1 varied, link 2 varied 197 
xi 
ACKNOWLEDGEMENTS 
I would like to acknowledge the guidance and support given to me by my project 
supervisors, Dr Steven Chandler (University of Warwick, now Rural Radio Systems) and 
Professor David Hutchins (University of Warwick). I would also like to thank Professor 
David Whitehouse (University of Warwick) for his encouragement to get the work started 
and Professor Roger Green for his constructive comments. 
I would also thank my colleagues at Cable and Wireless for putting up with 
me over the last five years, especially Professor David Ashton (Chief Executive - retired) 
for allocating me some time to get the work underway, Dr Habib Rashvand (ex-TT & E 
lecturer) for his helpful comments, Mark Abbott (ex-TT & E technician) for making the 
surface mount circuit boards and Richard Hallows (ex-Head TT & E) for his support. 
Finally, my thanks to Alison for keeping our son Harry occupied, allowing me 
some time to finish writing up the Thesis. 
xii 
DECLARATION 
This thesis has been written by myself and is based on research undertaken at the 
• 
University of Warwick between 1995 and 2000. The information recorded herein has not 
been previously published, except in [18] and [127-130] 
All other sources of material are acknowledged and appropriately recorded. 
Paul Thomas 09/2000 
xiii 
LIST OF SYMBOLS 
Symbol Meaning Units 
g the phase shift and attenuation occuring between the 
transmitter and receiver 
a mean 
c velocity of light (in vacuo) metres per second 
f frequency Hertz or cycles I second 
I electrical current Amperes 
j square root of -1 
t time seconds 
v velocity metres per second 
V electrical voltage volts 
W power watts 
= equals 
-
identical 
< less than 
> greater than 
L sum 
A wavelength metres 
11 correlation ratio 
. therefore .. 
\:;f all of 
E belongs to the set 
* convolution 
cr standard deviation 
[AJ matrix array 
Multiples and sub-multiples used: 
m milli 10-3 K kilo 10+3 
J! micro 10-6 M mega 10+6 
n nano 10-9 G giga 10+9 
p pico 10-12 T tera 10+12 
xiv 
SUMMARY 
This thesis records the research and development work carried out on a new 
telecommunications multiple-access system called the 'Complex Valued Collaborative 
Coding Multiple-Access' (CV -CCMA) system. The CV -CCMA system enables more 
than one transmission to use a communication channel without significant bandwidth 
expansion. The work has been completed between 1995 and 2000 whilst researching for a 
(part-time) Doctor of Philosophy degree at the University of Warwick. 
The new mUltiple-access system follows the general trend in communication 
systems that has been taking place over recent years. The reduction in the cost of 
processing power (million floating-point operation devices are now only a few pounds), 
has meant that the complex processing components of communication systems have 
moved from the analogue to the digital domain. Systems once regarded as too expensive 
to implement (except by the military) are now commonplace. The main digital processing 
element used for development of the system is a standard floating-point digital signal 
processor (DSP). A summary of the algorithm developed and software produced is 
included in this thesis. New techniques were developed to solve the multi-access 
resolution problems using the DSP and these are presented. 
The fundamental theory underlying the CV -CCMA system is described in 
detail with simplified examples showing the processes involved. A practical two-
transmitter, one-receiver implementation was designed and constructed in order to prove 
the viability of the system, and details of this work are included in the thesis. Computer 
programs were written to solve the various linear algebraic equations relating to the 
operation of the decoding algorithm. Simulation programs enabling parameter variation 
without circuit construction are also recorded in the thesis. Problems encountered with the 
new circuitry are discussed and the solutions detailed. This includes a new high-stability 
oscillator that was designed, built, and tested and which was required in order for the 
system to function properly. Also described is the high-speed conversion circuitry. 
A new sequence of codewords has been developed, helping to reduce the 
stringent requirement on timing and synchronisation, and results are presented. New 
methods of synchronisation are discussed together with future development of the system. 
Projections as to possible uses of the system are also presented. 
Finally, there is a short comparative discussion of the CV-CCMA system and 
the broadband code division multiple-access system, recently on trial in the United 
Kingdom. This is of specific interest to Cable and Wireless PLC, the main sponsor of the 
research. 
xv 
1 INTRODUCTION 
As we enter the second century of radio communication the demands on the radio 
frequency spectrum are becoming ever greater. The range extends from systems 
operating at very low frequency for world-wide submarine communications, to super 
high frequency telecommunications systems and direct broadcast satellite services for 
commercial use. With the advent ot all these new services, the electromagnetic 
communications spectrum is nearing saturation. The usable section of the 
electromagnetic communications spectrum is bounded; therefore new techniques and 
systems are required to enable further expansion of services. A number of techniques 
have been developed which enable multiple-access. This requires the sharing of the 
communication bandwidth resource, giving increases in the efficiency of usage of the 
available spectrum. Although there are theoretical limits on the amount of 
'information' that can be communicated over a given bandwidth, the new techniques 
aim to optimise the information transfer, and reduce interference between multiple 
users of the same bandwidth. At the present time there are many different contenders 
for this already large, and potentially very large, market. However, the circuitry 
required to enable most of these systems to operate is fairly complicated and requires 
a substantial amount of processing power in order to function. The cost of this 
processing power has decreased by orders of magnitude in recent years, and this has 
given additional impetus to the commercial exploitation of multiple - access systems. 
This thesis records the research, design and development of one such 
system, called the 'Complex Valued Collaborative Coding Multiple-Access' system 
(CV-CCMA system). The system is demonstrated operating with a single floating-
point digital signal processor (DSP), which, together with radio frequency 
1 
components designed for the global system mobile (GSM) system, produces a very 
cost-effective multiple- access telecommunication system. 
The main objective of the research was not just to produce further 
simulations of the multiple-access system, varying either a transmission parameter or 
some. component part of the coding or decoding process, but also to generate a 
hardware demonstrator that would identify any problems which might have been 
neglected in simulations. This path was followed because of problems experienced in 
communications research in other fields. A lot of simulation-based communication 
research is limited in use due to the many additional problems that become apparent 
only when the systems are implemented in hardware. This is particularly true in the 
telecommunications industry, which uses a lot of relatively old equipment. For 
example, Cable and Wireless PLC, the main sponsor of this research, is now over one 
and a quarter centuries old. This means that there are systems installed that are quite 
ancient, usually costing substantial sums to maintain, and a lot of the newer 
technologies need to be able to interface with, and often work alongside, these older 
systems. This is the area where many problems have arisen, for example in the 
implementation of newer statistical trunk systems with installed trunk transmission 
plant. Loading/capacity simulations have shown that the systems should work 
perfectly, but in practice the systems do not actually work, requiring further 
investment to get them working. Similar problems have been encountered with radio 
systems and so it was decided at an early stage to 'prove' the theory with some actual 
hardware, and to progress the research by implementation of any new techniques 
before advancing the whole system. This meant that the research tended to progress in 
bursts, but as the research was (is) being undertaken on a part-time basis the available 
2 
time could be utilised effectively. Practical demonstrations were found to be essential, 
to verify nothing had been forgotten about in the simulations. 
1.1 History 
It has been over a century since Alexander Graham Bell transferred 'voice-shaped 
currents' over copper wire, thus starting the telecommunications revolution. Early 
telephone systems were directly connected to an exchange and then caIIs were routed 
manually by switchboard operators. The operator's attention was gained by winding a 
handle attached to the telephone, connected to a magneto and generating a large 
voltage which rang a beII in the exchange. A similar system is still used today by 
dealer systems in the financial sector, called generator-generator signalling, and also 
for military field telephone systems. In an effort to stop illicit eavesdropping, an 
undertaker in the United States, named Almon B. Strowger, invented an automatic 
telephone exchange, which comprised electromagnetic relays linked to a dial on the 
telephone, automatically connecting subscribers together. These systems were in use 
until the 1970s in the United Kingdom. The next major advance came with the 
invention of the transistor by Brittain, Bardeen and Shockley at Bell Laboratories in 
the United States, designed for telephone switching and able to switch quite large 
currents very rapidly, making the slow and unreliable electromagnetic relays obsolete. 
Major advances have followed at an exponential rate and developments in other fields 
have been used in the telecommunications industry to gain competitive advantage. For 
example, field effect transistors, developed by NASA for the Apollo space program in 
the 1960s are now widely used in telecommunications systems. Virtually from the 
beginning of electronic communication, over a century ago, the demand for services 
has outstripped the available resources, mainly bandwidth, and techniques have been 
3 
continually developed to increase the capacity and reliability of telecommunications 
systems. Table 1.1 lists a few milestones with particular relevance to this thesis. 
In the last twenty years the telecommunications industry has seen a 
number of techniques that enable transmission and reception by a number of users, all 
using the same transmission resource. Trunk telecommunications traffic is either 
carried over a fibre-optic cable (usually callea a bearer) or over a radio system. The 
radio is usually a back-up to the fibre. However, the local loop is often still a twisted 
pair of copper cables, with all the associated problems of interference and limited 
bandwidth. There are a number of standard techniques to reduce these problems, 
enabling the transmission of data, at reasonable rates, over twisted pairs. Modem 
telecommunications networks are now completely digital, leading to simple 
interfacing with current high-speed digital circuitry and associated cheap processing 
power. The CV -CCMA system is a completely digital system for multiple access that 
will interface easily with current telecommunications systems. 
The last few years have also seen unprecedented growth in data 
services, fuelled ,mainly by the explosive, growth of low-cost Internet traffic, 
electronic commerce, etc. This trend shows no sign of abating; if anything the rate of 
increase is such that within a couple of years, voice traffic will be consigned to a 
small proportion of bandwidth carried on the back of data traffic. Anew, low-cost, 
radio-based multiple-access system could be used for the implementation of these 
new services. 
Today, in most of the developed world there is a substantial 
telecommunications infrastructure, which has cost thousands of millions of pounds to 
install and millions of pounds per annum to maintain. In contrast, the developing 
world has very little infrastructure, especially in the more rural areas. It will require a 
4 
Year Event 
1834 Carl F. Gauss and Ernst H. Weber build the electric telegraph. 
1838 William F. Cooke and Sir Charles Wheatstone build the telegraph. 
1844 Morse demon states the Baltimore and Washington telegraph line. 
1846 M. Faraday's 'Thoughts on ray vibrations' form basis for e-m field theory. 
1858 The first transatlantic cable is laid, and fails after 26 days. 
1864 James C. Maxwell predicts electromagnetic radiation. 
1876 Alexander Graham Bell develops and patents the telep_hone. 
1883 Thomas A. Edison discovers the flow of electrons in a vacuum, called the 
'Edison effect' providing the foundation of the electron tube. 
1885 Edward Branly invents the 'coherer' radio-wave detector. 
1887 Heinrich Hertz verifies Maxwell's theory. 
1894 Oliver Lodge demonstrates wireless communication over 150 yards. 
1897 Guglielmo Marconi patents a complete wireless telegraph system. 
1900 Guglielmo Marconi transmits the first transatlantic wireless signal. 
1904 John A. Fleming invents the vacuum tube diode. 
1918 Edwin H. Armstrong invents the superheterodyne receiver circuit. 
1927 H. Black develops the negative-feedback amplifier at Bell Laboratories. 
1933 Edwin H. Armstrong invents frequency modulation. 
1935 Robert A. Watson-Watt develops the first practical radar. 
1937 Alex Reeves conceives pulse code modulation (PCM). 
1947 Walter H. Brittain, John Bardeen, and William Shockley devise the 
semiconductor transistor at Bell Laboratories. 
1948 Claude E. Shannon publishes his work on information theory. 
1950 Time-division multiplexing is applied to telephony. 
1950s Microwave telephone and communication links are developed. 
1953 The first 'multiple-access' transatlantic cable (36 channels) is laid. 
1960 Theodore H. Marman produces the first successful laser. 
1963-66 Error-correction codes and adaptive equalization for high-speed error-free 
digital communications are developed. 
1965 The first commercial comms. satellite, 'Early Bird', is placed into service. 
1966 Kao and Hockham publish 'The principles of fiber optic communications'. 
1971 Intel Corporation develops the first single-chip microprocessor, the 4004. 
1976 Personal computers are developed. X25 Packet delivery standardised. 
1979 64-Kbit random access memory launched. 
1981 mM PC is introduced. De-nationalisation of United Kingdom Post Office. 
Cable and Wireless partial privatisation. Falcon (Mercury) launched by 
Cable and Wireless as a competitor to British Telecom. 
1984 First generation cellular telephones introduced to UK (Cellnet + 
Vodafone, BT - Securicor and Racal Electronics). 
1988 Global system mobile launched in Europe. 
1990s Texas DSP chips increase processing power by orders of magnitude. 
1990s Explosive growth in Internet usage alters dynamics of telecom. networks. 
Mobile penetration is greater than fixed line in some European states. 
Table 1.1 Important dates in electronic communications 
5 
major investment program to cable them up. For example, it cost Cable and Wireless 
PLC over one hundred million pounds to put a basic digital trunk network into Latvia, 
a small country with a fair amount of infrastructure already in place, and with most of 
the population concentrated in one city. This investment will take many years to 
repay. This is another area in which a cheap multi-access radio system, such as CV-
CCMA, will find a ready market, specifically for high density flow-cost access, and 
low-density flow-cost access. This thesis will describe the possible implementation of 
the CV -CCMA system on existing low-cost rural access radio systems; this work is 
briefly covered in Chapter 8. 
1.2 Techniques 
It is standard practice in telecommunication networks for the electrical representation 
of speech to be first digitised by the process of pulse code modulation (PCM), a 
technique invented by Alex Reeves in 1937 [1] whilst working in Paris at the IT & T 
laboratory and patented by them in 1938. Some of the technology was used in the 
early radar systems to detect aircraft. After the war the process was further developed 
by the AT & T laboratories in the United States. However, the technique only became 
popular commercially with the advent of cheap semiconductor circuitry. The 
International Telecommunications Union has standardised the process of PCM with a 
series of recommendations, 0701, G703, etc. [2], which have been adopted on a 
world-wide basis. In the G series of recommendations the process is defined briefly; 
the speech waveform is sampled at 8000 per second, and to comply with the sampling 
theorem the speech waveform is band-limited to 300-3400 Hz. Each sample is then 
converted to an 8-bit binary code. The code consists of a sign bit and 7 amplitude bits; 
the output is quanti sed to the nearest direct conversion value - there is no dither. The 
6 
conversion is not direct; it is non-linear or logarithmic. The audio input is assumed to 
be standard speech so more 'bits' are assigned to the lower-level signal amplitudes 
than to the higher ones. The process approximates the output I input transfer function 
to a logarithmic law and two world-wide standards have evolved, the 'J!' law in the 
United States and the 'A' law in the rest of the world (conversion circuitry is needed 
between the two standards). There are 8 bits output for each sample taken 8000 times 
per second, giving a digital output rate of 64 Kb/s, or 32 Kb/s with Adaptive PCM, an 
adaptive predictive technique defined in 0732. 
These digitised streams of audio information are then combined 
together with other digitised traffic, data or encoded video, by a process called time 
division multiplexing (TDM). Each digital input is buffered and assigned a period in 
the time domain called a time slot. The time division multiplexer then combines these 
inputs and outputs them, at a higher rate, together with synchronisation and signalling 
information. Figure 1.1 illustrates the concept of TDM and Figure 1.2 shows a 
standard primary rate 30 channel (2 Mb/s or S-bearer) roM in operation, used 
throughout the world as the first level of mUltiplexing. The multiplexer's output 
aggregates are then combined with other mUltiplexer outputs, giving (currently) 
defined data rates up to about 10 ObIs. The TDM process is now a mature technology, 
with international standards set by the International Telecommunications Union 
enabling the world-wide inter-connection of systems operating to these standards. 
The main problems arise with synchronisation and management of the 
links. If synchronisation cannot be guaranteed then buffers must be used at the 
interfaces which causes delay problems, particularly with speech. The other problem 
. 
with TDM is that the system does not allow for instant access; the transmitter must 
wait until its assigned time slot occurs before data is transmitted and this is wasteful 
7 
of transmission time, requiring buffers, and inefficient. Speech is time-critical, and so 
it becomes inefficient to assign a time slot, whether it is required or not. Data tends to 
be less time-critical, so queuing can be successfully applied. Recently, adaptive or 
statistical TDM systems have become popular, for example asynchronous transfer 
mode (ATM), especially with the larger telecommunications commercial operators. 
These systems work by dynamically assigning bandwidth on the trunk only when it is 
required, giving much higher efficiencies. Statistical systems are also more flexible. 
They can be used to implement quality of service parameters, required for today's 
multimedia systems. Most importantly, time-critical signals (speech and video) can be 
combined with non-time-critical signals (data) and passed over the same trunk 
network. The carrier's network can always be fully loaded, which means the carrier 
generates as much revenue as possible. As well as the benefits of flexibility the 
advantage to the user is mostly in cost reduction, rather than any fundamental 
improvement to quality of service. 
Amplitude 
AI" 
user user user user user 
1 2 3 4 5 
Time 
Figure 1.1 Time division multiplexing 
8 
Speech Signal 
+ 
............ 
. ' ' . 
....................... ··· .... ~amPle •................................ 
,,- ", 
o 1 1 0 1_,0 I 
: SIGN: Magnitude 
j ........ ;.; .......................................... ·····················1 
! I 
..... :<~ ____ Channel --------~~~: ~:~~---------
.... _-
---
---
---
1 -15 
---
---
'. I 
Frame Structure 
---
") 
I 
I 
I 
I-- ---
I 
I 
I 
Multiframe Structure 
---
---
Figure 1.2 Primary rate time division mUltiplexing 
Time 
Time 
Channel 
16-30 
---
---
---
~I I 
I 
I 
I 
I 
I 
I 
---
9 
The aggregate signals are then converted using frequency conversion 
techniques and combined in the frequency domain (FDM - frequency division 
mUltiplex or WDM - wavelength division multiplex); the translation may be up or 
down. The input signals are assigned to a band of frequencies and passed over the 
transmission link. In the case of the fibre-optic trunk cable transmission, these 
wavelengths are limited to the precisely defined boundaries of the low-loss window, 
and the line width of the laser transmitters and photodiode receivers. These techniques 
are generically called dense wavelength division multiplexing (DWDM), and current 
operating practice gives a maximum of twenty carriers each operating at data rates of 
2.5 ObIs (STM-16 rate with adaptation). 
Current radio systems operate at maximum data rates of 140 Mb/s 
within various frequency bands up to 500Hz. Figure 1.3 illustrates the concept of 
frequency division multiplexing and Figure 1.4 illustrates the AT & T standard FDM 
hierarchy, still in use throughout the world, although now declining in popUlarity. 
Amplitude 
n 
user user user user 
1 2 3 4 Frequenc y 
r' 
Figure 1.3 Frequency division multiplexing 
10 
First level group 
.-------------------, 
1 1 
:ml(t) Fsc = 108 KHz 1--_ ... 1 _-., 
1 
1 
1m2(t) 
1 
I 
:m3(t) 
1 
I 
Im4(t) 
1 
I 
Im5(t) 
I 
1 
:m6(t) 
1 
I 
Im7(t) 
I 
1 
:m8(t) 
I 
I 
Im9(t) 
I 
1 
Fsc= 104KHz 
Fsc = 100 KHz 
Fsc =96 KHz 
Fsc=92 KHz 
Fsc = 88 KHz 
Fsc= 84 KHz 
Fsc= 80KHz 
Fsc =76 KHz 
ImlO(t) Fsc = 72 KHz 
I 
I 
:mll(t) Fsc = 68 KHz 
I 
I 
Supergroup 
r------------I 
t-~ __ ~ Fsc = 612 KHz : 
-r--~ Fsc = 564 KHz 
- ....... --~ Fsc = 516 KHz 
Fsc=468 KHz 
1 
Fsc = 420 KHz 1 
1 1 L ____________ I 
ImI2(t) Fsc = 64 KHz I---~--,.I ______________ • 
1 ~----~ 1 
1 
--------------------~ 
12 Voice frequency inputs 
Mastergroup output 
2.S2MHz 
bandwidth 
r--,---t Fsc = 3396 KHz 
,....,r---f Fsc = 3148 KHz 
Fsc = 2900 KHz 
Fsc = 2652 KHz 
I 
1 
~I 
~ _______ ~ 1 
1 
\--1r----I Fsc = 2356 KHz 
Fsc = 2108 KHz 
Fsc = 1860 KHz 
Fsc = 1612 KHz 
~~--f Fsc = 1364 KHz I 
I 1 
'---+---1 Fsc = 1116 KHz : 
!.. - - - -.- _ - _ - _ ____ J 
Figure 1.4 AT & T Frequency division multiplexing hierarchy 
11 
A third technique for multiple-access is called code division multiple-
access (CDMA). There are two main types which mostly follow generic algorithms. 
The first type is called frequency hopping (FH) CDMA and is a system that modulates 
the signal onto carriers whose frequency is selected from a sequence or randomly. 
Slow PH is where the hopping rate is less than the information rate and fast PH is 
where multiple hops are used for each information bit. Bit interleaving is used as well 
as error-correcting codes to overcome some of the fading problems inherent to the 
system. These frequency-hopping systems are mainly used by the military and users 
requiring high levels of security. 
The second type is called direct sequence (DS) and in this system the 
individual users are assigned sequences that are separated from one another by the use 
of a set of nearly orthogonal waveforms or sequences. These are often referred to as 
spreading codes because they cause the output bandwidth to spread. Due to the nearly 
orthogonal nature of the sequence when they are combined together, assuming they 
are properly synchronised and with no errors, the cross-correlation between different 
users will be nearly zero. 
A number of different transmitters can then be overlaid using the same 
bandwidth providing they are using distinct sequences. The receiver multiplies the 
composite signal by the same orthogonal sequence as the required transmitter, 
producing an output which is integrated over a bit period to give the recovered data. 
Note that the mUltiplication of the signal by the orthogonal sequences produces an 
increase in bandwidth, and drop in efficiency: the signal is 'spread'. Figure 1.5 shows 
a simplified representation of code division multiple-access, and Figure 1.6 shows a 
block diagram of a typical spread spectrum system. The technique is derived from a 
military system used for secure communications [3]. Note that it is very difficult to 
12 
block a signal that has a wide bandwidth, without using large amounts of power. 
CDMA is more complex than the other techniques described for multiple-access and 
has a number of unique problems associated with it. Some of these problems are 
described in Chapter 3. The near-far problem, in which strong DS signals swamp 
weaker DS signals, requires quite complicated power-control circuitry to be 
implemented in DSCDMA systems. Also the coherence bandwidth must be less than 
the spread bandwidth, and this may be 10 MHz for small-room operation, and far in 
excess of this for satellite operation. 
Amplitude 
Code 
user 1 ' 
Time user 2 
user 3 
user 4 
user 5 
.--------j 
--1 User 1 : 
__ t ________ , 
.---------
--1 User 2 : 
__ ! ________ I 
Frequency 
Frequency 
Hopping 
Direct 
Sequence 
Frequency 
Figure 1.5 Code division multiplexing 
13 
message 1 
+1-1 +1 Tf It! J (ml) 
PI ml 
Integrator Squarer 
spreading code 1 ScI 
-1 -1 +1 +1 (ScI) 
spreading code 2 
-1 +1 +1 -1 (Sc2) Sc2 
message 2 Integrator Squarer 
+1 +1-1 m2 
(m2) .. Tf It2 J P2 
Note: ScI and Sc2 are orthogonal, ie the cross-correlation is zero: 
(-1)( -1)+(-1)(+ 1)+( + 1)(+ 1)+(+ 1)(-1) = 0 
Transmitter one Transmitter two 
r------------------------, r-----------------------1 
ml 
------. 
ScI 
_--J 
PI 
_--J 
L.. ______ _ 
2 r -+ 1 
SI 0 r-
21 
- 1-1--.1 
+1 
ScI -I ~ ___ ---J 
SI=Pl+P2 
m2 1 
1 
1 
1 
1 
1 
1 
1 
-----_ .... 
1 
1 
1 I 1 
I I 1 
I 1 1 
SI*ScI I : : I: 1 I I U I....--.-J: 
It! r--n-.::::=.-n--l--~nn-31-, --~-----:::J 
+1 ·1 . +1 
Figure 1.6 Code division multiple-access 
14 
A more recently developed multiple-access system, which is popular in 
the local area network (LAN), is the collision detection carrier sense multiple-access 
(CDCSMA) method. This is a variation of the time division multiplex (TDM) systems 
already described, generically called statistical TDM. In this system the access 
channel is sensed for activity and the transmitter output is buffered until a gap appears 
in bus activity when it can transmit its data. Weaknesses of this system are the lack of 
instant access, particularly when the network is busy, and the complexity of the sense 
circuitry. However, the system is cheap and is now very popular. 
Another technique of multiple access is the space diversity multi-
access (SDMA) system, mainly used with radio or optical systems. In these systems 
the network is subdivided into geographical areas, thus ensuring the transmitters and 
receivers operating on the same frequencies are always physically more than a certain 
distance apart. This distance is sufficient to stop interference between the systems 
because the attenuation on the signal drops it below the interfering threshold value. It 
is usual to employ different polarisation in the signals in an effort to reduce further 
any interference. This method is used in cellular radio systems with the same 
frequencies re-used in cells, but only when they are a minimum distance apart. Figure 
1.7 illustrates the concept of SDMA. There are many problems with this simple 
system as radio propagation is very variable and the signals may propagate 
substantially further than intended, under certain atmospheric conditions. This causes 
problems with multiple cells both being accessed and the possibility of dropped calls. 
Another problem is that, at the higher frequencies, the waves propagate along 
overhead lines (power I rail feed, etc.), which act as waveguides and may lock into or 
interfere with a cell a considerable distance away from the transmitter. The network 
manager then has to decide which is the valid signal, and which is the ghost signal. 
15 
Cluster 
(Size=7) 
Figure 1.7 Space diversity multiple-access 
Figure 1.7 illustrates a typical cellular radio network layout. The cells are drawn as 
hexagons and the letters A-G represent the group of frequencies that are used 
within a cell. Note that coverage area is only approximated by a hexagon. At the 
edge of coverage, where geographical features cause problems, directional aerials 
are used to prevent interference. The system is easily combined with one (or 
more) of the other multiple-access techniques already discussed. Note also that 
Figure 1.7 shows a frequency re-use factor of 7 and that there are always at least 2 
cell diameters between cells that are using the same frequencies. 
All of the systems described thus far combine the individual signals 
in a common medium, usually silica glass-fibre, copper co-axial cable or the radio 
spectrum ether. A substantial amount of work has been done over recent years 
16 
producing mathematical models of various different types of channel. The model used 
in this thesis is the adder channel with discrete input and output [4-12]. The other 
channel models used are detailed in Chapter 2, the research survey section of this 
thesis. A lot of the work in these papers is related to the theoretical maximum data 
rates that the multiple-access channels can accommodate. The individual transmitters 
and receivers are treated as independent units, which in the case of the implemented 
. 
. CV-CCMA system is not strictly true, as the components of the system need to be 
synchronised in order to function. For further discussion on the channel, including the 
effect of feedback and interference, see Chapter 2. Some work was done on a 
performance comparison between CV -CCMA and COMA. This used a rather more 
complicated model of a mobile radio channel with different types of noise and fade I 
synchronisation loss (from [3]); see Chapter 3 for details. 
To summarise, there are three other multiplex technologies, FDM, 
COM and TOM. The fact that only a subset of a number of users wish to 
communicate at a time enables sharing of a channel between them; there is no need 
for each user to be allocated a permanent bandwidth. The larger the number of users 
that can share resources the larger the statistical gain possible. TOM often uses a 
multi-access protocol to partition time slots dynamically, e.g. COCSMA. 
COMA uses near orthogonal sequences and so long as no more than a 
number proportional to the number of orthogonal channels are in use at anyone time, 
error-free transmission is possible. This makes COMA ideal for statistical 
multiplexing. FDM cannot easily be made to handle dynamically varying 
transmission rate requirements, with each user allocated its own frequency channel. 
All of the multiple-access systems described are limited in 
., 'information' transfer ability by the theorem of Shannon, which sets an upper limit on 
17 
all the systems. The relative advantages and disadvantages of the different systems lie 
in the ease of use, or otherwise, when used as part of a complete multiple-access 
system. Within the telecommunications field, the ability to interface with existing 
(legacy) systems is probably one of the most important considerations. 
1.3 The CV -CCMA system 
In 1994 work was started at Warwick investigating new multi-access techniques with 
specific application to the telecommunications industry, particularly satellite 
communications and digital mobile telephones. These are two very important areas of 
interest to the candidates employer, Cable and Wireless PLC. It was decided that the 
'Complex Valued Collaborative Coding Multiple-Access' (CV-CCMA) system 
offered the most promise for development as a new multi-access radio technique. The 
work was developed from discussions with Dr Steve Chandler at Warwick, which 
indicated that ordinary collaborati ve coding techniques were impractical for use over 
a radio channel. 
It was decided to develop the CV -CCMA system as a digital radio 
system using digital signal processing techniques with spatial diversity. This would 
enable simultaneous reception of a number of superimposed signals within the same 
bandwidth and without the use of spreading. The system can increase the capacity of 
telecommunication systems, particularly satellite and digital mobile telephones, 
providing significant performance improvements over other multiplexing and 
multiple-access techniques. 
CV -CCMA is inspired by the technique of collaborative coding, 
which, though theoretically interesting, was not practicable for use on radio systems 
., because of the variability of gain and phase of each of the contributing transmissions. 
18 
Collaborative coding is based on the superposition of two signals from different users, 
producing a combined signal which can be decoded to recover the original signal 
transmissions. The system is best explained with the aid of a simple example. Assume 
we have two transmitters and one receiver with the transmitters programmed to output 
codewords as below. 
Transmitter 1: 
'0' = 0 0 
'1'=11 ('Data input' = codeword output) 
Transmitter 2: 
'0' =00 
'1'=01 ('Data input' = codeword output) 
The codewords can be modulated by superimposing onto a radio 
frequency or optical frequency carrier as a varying amplitude level. Note that the 
combining channel is assumed to be a simple adder channel, that is each component 
bit is added to the corresponding bit from the other transmitter. The system is 
assumed to have ideal synchronisation, so both bit and frame timing are ideal. The 
only possible combinations are tabulated in Table 1.2 . 
19 
User 1 data User 1 data 
0 1 
Codewords o 0 1 1 
'generated' 
User 2 data 0 o 0 o 0 1 1 
User 2 data 1 o 1 o 1 1 2 
Table 1.2 Collaborative coding - example 1 
The bold figures indicate the allowed codeword combinations; thus, if we receive any 
one of the four combinations the original transmitted data can be recovered as it is a 
unique solution to the addition of the original collaborative codes. Also of note is the 
fact that, even with the simple two-user example described, the channel is loaded at an 
efficiency of 1.0 bit per baud, as each user runs at 0.5 bitlbaud giving 1.0 when added. 
Table 1.3 shows how this can be extended to obtain better efficiencies. 
User 1 data User 1 data 
0 1 
Codewords o 0 1 1 
'generated' 
User 2 data a o 0 o 0 1 1 
User 2 data b o 1 o 1 1 2 
User 2 data c 1 0 1 0 2 1 
Table 1.3 Collaborative coding - example 2 
20 
Note that all the states (in bold) are still uniquely decodeable. The 
codewords shown give an efficiency of approximately 1.3 bits per baud. Work has 
been carried out on the efficiency of collaborative codes [13] setting out the 
definitions for capacity boundaries on these efficiency measures. 
The system is quite simple and elegant, requiring accurate timing and 
an adder channel between the transmitters and receivers. However, in the case of 
radio transmission, there will not be an ideal adder channel between the transmitters 
and receivers, but an attenuation and a phase shift (called the g value). This g value 
may be variable, particularly if the systems are mobile. This means that in order to 
resolve the combined signals an accurate timing relationship between the transmitters 
and receivers is required. The receivers will be pre-programmed with all the 
transmitted codewords. Then, using the processing power of the digital signal 
processor, the original transmissions can be resolved. The receiver can resolve the 
phase shift, the attenuation and the transmitted codewords simultaneously. This now 
becomes a CV -CCMA system. The operation of the system is covered in detail in 
Chapter 5. 
Following the logic of the argument, even if some of the combined 
codewords are theoretically identical, provided they are received over different paths 
involving different attenuations and phase shifts, then the original codewords can be 
reconstructed. This is because the signals are multiplied by the attenuation and phase 
shift, and they are different for each path. This is the principle of the first of the CV-
CCMA systems to be designed and built at Warwick. 
Previous research, (into radio multiple-access), has produced a number 
of proposed techniques designed to resolve the individual transmissions of a multiple-
-, access system. In [14] the authors proposed enhancements to a Collaborative Coding 
21 
Multiple Access (CCMA) system. The receiver incorporated an estimation technique 
based on the gradient descent algorithm [15,16]. This, together with a predictor and 
corrector, was proposed as a receiver, with the capability of resolving multiple signals 
within the same bandwidth. The CV -CCMA system differs from this serial approach 
in that the g values are simultaneously estimated with the data values. 
The basic algorithm of CV -CCMA is sufficiently computationally 
. efficient to enable implementation of a system, with realistic data rates, using a 
standard floating-point digital signal processor. This is a major advance because the 
previously proposed advanced systems for co-channel interference suppression or 
simultaneous demodulation of superimposed signals have required large and 
expensive amounts of processing. 
The CV-CCMA system does not separate the individual inputs to the 
MAC (multiple-access channel) in terms of frequency or time but assigns unique 
collaborative codes to each user. These codewords are unique to each transmitter and 
in the first practical implementation are all linearly independent [17]. The pre-
calculated combined matrices, necessary for correct receiver operation, are stored in 
the receiver memory. The receive process then proceeds by calculating the minimum 
Euclidean distance between the received vector and the pre-calculated codeword 
combination. The recovered data is then output using a simple look-up table. The 
system is simpler in implementation than CDMA and without the need to 'spread' the 
output signal. The two systems are compared later in the thesis but there are 
advantages and disadvantages to each. CDMA is substantially more complicated in 
implementation but both systems require accurate timing in order to work. 
The requirement for linearly independent codewords to be used at each 
.. transmitter restricts the range of available codewords so work was carried out 
22 
investigating this problem [18] at Warwick. It was shown that for unique decodability 
a less restrictive set of rules could be implemented. Details of this work are discussed 
and included later in this thesis. The simulation programs that were written, and the 
actual hardware constructed, were designed for ease of experimentation with 
codeword variations. Figure 1.8 illustrates the system concepts in a block diagram of 
a basic CV-CCMA system. 
This introduction has described in simple terms some of the systems 
and techniques the CV-CCMA has been designed to improve upon, and work with, in 
the modem digital telecommunications industry. The system has known limitations, 
for instance the fact that perfect timing is assumed and the problems of multi path, 
which have yet to be addressed; the latter could be resolved but this would 
substantially increase the complexity of the system, as is the case with most radio 
systems. The issues raised in this introduction are discussed and expanded upon in 
later chapters. The thesis also records the work done to demonstrate the viability of 
the system. If the system were not viable there would be no point in solving the other 
issues. The thesis also develops some of the ideas generated during the research. For 
example, once the g values are determined they can be used to decode the mUltiple 
transmissions, as they are unique to each path. This removes the need for codes, 
timeslots or frequencies dedicated to each user. 
The next chapter records a survey of recent research into the multiple-
access and related fields. 
23 
Input 
1 
Input 
2 
Transmitter 1 
r--------------------------------------
Buffer + Radio 
.. collaborati ve .. frequency . 
.... ... 
code generator modulator 
--------------------------------- ______ 1 
Transmitter 2 
r--------------------------------------
Buffer + Radio 
... collaborati ve ... frequency I .... ~ 
code generator modulator 
--------------------------------- ______ 1 
Receiver 
, V-
, V 
r--------------------------------------------------
TMS320C31 Precision Radio 
Floating point analogue - frequency 
signal digital de-modulation 
processor convertor 
olp 1 olp 2 
gl 
= Rl+jXl 
g2 
= R2+jX2 
~ I 
\ , 
\ , 
~ ,: 
Figure 1.8 Complex valued collaborative coding multiple-access system 
24 
2 SURVEY OF RECENT RESEARCH 
2.1 Introduction 
The introductory chapter to this thesis gave a flavour of the different systems 
currently in use in the multiple-access telecommunications area. Whilst researching 
the thesis it became apparent that different people / companies and institutions 
interpret the term 'multiple-access' in different ways. 
The more theoretical research encompasses the mathematical 
foundations of the multiple-access channel. This area is quite active and has produced 
a number of interesting papers, usually based on fundamental information theory 
papers, which have been adapted and advanced into the digital age. In the 
telecommunications industry the term multiple-access is common to a number of 
different systems: time division multiple-access - used in trunk multiplexing 
equipment; frequency division multiple-access - used mainly in satellite 
communications and high-capacity fibre-optic systems; code division multiple-access 
- used in mobile telephone systems; space division multiple-access - also used in 
mobile systems and carrier sense/collision detect systems which are mainly used in 
local area networks. There are fundamental restrictions to all the systems and each has 
advantages and disadvantages over the others. The more commercially orientated 
research mostly pushes the already established advantages and disadvantages of each 
system forward in the same direction. 
In the military area, multiple-access communications are a 'hot' topic, 
but it is difficult to investigate this field, as a lot of the material is restricted and not 
available to the general public. However, useful research was done by investigating 
., the military equipment manufacturers' data, particularly from the United States. 
25 
The initial research carried out revealed a vast amount of information 
in the multiple-access field. This has been filtered down to material specifically of 
interest and relevant to the work recorded in this thesis. 
2.2 Information sources 
The Institution of Electrical Engineers (lEE) [19] and the Institute of Electrical and 
. Electronic Engineers (IEEE) [20] have proved to be a source of much material. The 
IEEE runs a communications society [21] and publishes Communications Monthly, 
containing interesting and up-to-date material. The lEE publishes Electronic Letters 
[22] and Proceedings- Communications [23] also containing much information. The 
most productive searching was done manually, searching the 'Inspec' documents of 
key abstracts in telecommunications research; these are produced monthly by the lEE 
and contain short abstracts of current research publications. The electronic search 
engines tended to miss information. One problem with both institutions has been a 
financial one. The cost of material is cheaper when requested from an academic 
institution than if your request originates from a commercial organisation. 
The University of Bath database BIDS [24] was found to be very 
useful as were the Cable and Wireless [25] and British Telecom (BT) [26] databases 
of current research and state-of-the-art material references. The BT technical journals 
were also quite enlightening [27]. University libraries at Cambridge, Southampton, 
Sussex and Lancaster were found to contain useful research material, as well as 
Warwick. 
A number of companies sponsor research into multiple-access 
techniques, and these companies publish some very useful material. The Qualcomm 
[28] web site contained detailed work on CDMA and equations developed for 
26 
network-loading calculations that were used in the later comparison work. The 
American company, Hewlett-Packard [29], produces a number of technical briefs and 
technical references, which can be ordered over the Internet, although many are not 
published in an electronic format. These were very useful in the radio frequency 
design stages, especially when problems were encountered with the modulators. The 
Dutch company, Philips [30], produces a wealth of literature relating to their 
. 
. semiconductors and microcontrollers, most of which is accessible electronically over 
the web. Philips sponsors a centre of excellence at Warwick and generously supplied 
a lot of equipment and reference material, particularly useful with the design and 
implementation of the synthesiser, control circuitry and frequency-conversion stages 
of the transmitters and receivers. The American company, Texas Instruments (TI), 
produces the digital signal processors that are used in the system. There are two main 
web sites and a data base, which can be accessed via [31], containing a lot of 
information that was very valuable when trying to get the various routines working. 
The company sponsors certain universities and Warwick was enrolled into the 
European scheme. This meant hardware and software could be bought at substantial 
reductions. Analogue Devices [32], Harris Electronics [33] and National 
Semiconductor [34] all had useful websites and integrated circuits were used from 
these manufacturers on the strength of the data placed at these sites. 
2.3 Channel models 
Most of the work recorded in this thesis treats the information-carrying channel as an 
adder channel with discrete input and output. This provides the closest model to the 
actual situation in the CV-CCMA demonstrator. In the demonstrator the channel has 
attenuation and phase shift; hence the relationships are complex. The other models 
27 
used to model the multiple-access channel are: logical OR [35-37]; logical XOR [38]; 
logical AND [39-40]; collision [41-43]; and switching [44]. 
2.4 Multiple-access information theory 
A good starting point when researching information theory is the seminal paper 
written by Claude Shannon in 1948, 'A mathematical theory of communication' [45] . 
. This paper derived the formula for the capacity of a channel (C bits/sec), with additive 
white Gaussian noise power (N watts), in terms of signal power (8 watts) and 
bandwidth (Whertz): 
bits/sec .......... (1) 
This is for a single channel. So if we have multiple transmitters and receivers 
occupying the same channel, then if one occupies all the bandwidth and power the 
other must be zero. Therefore there must be definable bounds to equate these limits 
together. Shannon looked at this problem in 1957 at a symposium at Berkeley, in a 
paper entitled 'Two-way communication channels' [46] and defined these bounds for 
different codes. 
Further work was done by Bergmans and Cover [47] in 1974, showing 
that several transmitters operating in an additive white Gaussian noise environment (N 
watts) can send at rates (R, bits/sec) strictly dominating time multiplex and frequency 
multiplex rates. This is done by the use of a superposition scheme that pools the time 
(T, secs), bandwidth (W, hertz) and power (P, watts) allocation of the transmitters. For 
frequency division multiplexing, where r = W/W, i = 1,2, the fraction of the total 
28 
bandwidth allocated to each transmitter, and ~ = P/P, i = 1,2, the fraction of the 
total power, then: 
.......... (2) 
For time division multiplexing, where T is the division in time, Pj is the power of 
transmission during communication to user i and Ai = TjP/P, then: 
.......... (3) 
The two sets of equations, (2) and (3), illustrate the duality between time and 
frequency mUltiplex. The two can be considered equivalent if time variations in input 
power are allowed in time multiplex and spectral variations of power are allowed in 
frequency multiplex. Several other papers summarise the findings of researchers in 
the field. Wyner [48] summarises very concisely research up to the mid-seventies and 
van der Meulen [49] continues in a similar vein. The IEEE Information Theory 
Society published a selection of reprint papers in 1994 [50], which contains a lot of 
interesting material based around multiple-access communications. Bringing the 
research up to date is a paper by Verdu [51] summarising most of the work done over 
the last 50 years, including 440 references. 
A number of papers appearing in the summaries just described are 
relevant to the CV -CCMA system of multiple-access. A broad spectrum of material is 
covered in the paper by Gamal and Cover [52] which sets out to characterise the 
29 
capacity region of multiple-access channels, broadcast, relay, etc., for all achievable 
rates. Following on is the paper by van der Meulen [53] which looks at capacity limits 
for multiple-access channels and amalgamates a lot of work. Especially interesting are 
the comments on asynchronous and quasi-synchronous multi-access channels. 
Another paper which contained a lot of interesting information was 
written by W. Lee [54] in 1990 and concerns the channel capacity in a Rayleigh 
. fading environment, the type of environment in which the CV -CCMA system would 
have to operate in a mobile telecommunications network. The channel capacity in a 
Rayleigh fading environment is derived and shown to be always lower than the 
Gaussian noise channel, a 33% reduction at 10 dBm average power but only a 11 % 
reduction at 35 dBm average power. He also shows that a diversity scheme can bring 
the channel capacity up and that the average channel capacity with Rayleigh fading 
equals the channel capacity over a Gaussian noise channel when the bandwidth 
approaches infinity. Summarising: 
(~) = log, e.e -io( -E+lnr+ ~) bitlsecIHz 
.......... (4) 
where (C) is the average channel capacity, B is the bandwidth, ris the power 
and E is the Euler constant. Note the channel capacity in a Rayleigh environment is an 
average value. Extrapolating these results to the multi-access channel was achieved by 
Ali [55] in 1991 who based his work on the previous work described and the work of 
Ni and Honary [56]. He produced two charts illustrating the capacity limits when 
operating in a flat Rayleigh fading environment with additive white Gaussian noise. 
These diagrams are reproduced as Figures 2.1 and 2.2, and represent binary phase 
shift keying and multi phase shift keying respectively. 
30 
4.' 
I 
10 SNR(dB) 
I 
20 
I 
30 
-- : Gaussian Channel·--·-- : Rayleigh Fading Channel 
I 
40 
Figure 2.1 Channel capacity of T -user binary phase shift keying 
-- : Gaussian Channel •••• - : Rayleigh Fading Channel 
Figure 2.2 Channel capacity of 2-user binary multi-phase shift keying 
31 
2.5 Multiple-access coding 
Research into the coding systems used in multi access communications also proved to 
be fruitful. A paper published by Ungerboeck [57] in 1982 describes a coding 
technique to improve error performance using channel coding with expanded sets of 
multilevel I phase signals. This increases the free Euclidean distance and hence the 
detection performance of the system. He shows that coding gains of up to 6 dB can be 
achieved with different multilevel and multi phase coding schemes; however, these 
gains are obtained with codes of 210 states. To obtain 3-4 dB of gain only requires 
codes with four or eight states and, although the paper shows simulation results only, 
the implementation of these Viterbi-type schemes [58] would make an interesting 
. experiment with the CV-CCMA system. However, any extra gain would be limited by 
the processing power of the receiver. 
Another important piece of work with direct relevance to CV -CCMA 
was written by Farrell [59] in 1981 and included a concise explanation of the 
collaborative coding scheme, of which the complex valued system is a direct 
enhancement of the original system. Published by the same author, together with 
Brine, Clark and Tait [14], was another very useful and relevant paper. Two 
collaborative schemes are reported, with the suggestion that two users ~an operate on 
one channel with adequate performance. The paper also includes error-rate analysis of 
a proposed estimation and detection algorithm, showing performance improvements 
with diversity reception (i.e. 2 aerials). The CV-CCMA demonstrator, described in 
chapters 5 and 6 of this thesis, advances and develops some of the ideas presented in . 
these papers. A prediction I detection algorithm was n.ot implemented on the CV-
CCMA. In the CV-CCMA system the g value was estimated at the same time as the 
data. This meant that the decode program, running in the signal processor, could 
32 
operate at a reasonable rate, and continue to operate whilst performing the other tasks 
that were required of it. See chapter 8 for further discussion. 
References [60 - 63] give different insights into multi-access coding. 
The paper by Kasami and Lin [60] attempts to solve the synchronisation problem 
common to all these systems by applying an asynchronous collaborative code scheme 
to the channel. Following on from this work, Ni [64] introduced state-independent 
. unique decodable collaborative multi-access codes. He ran some simulated systems 
and showed a fairly good service even in a noisy environment. A slightly different 
approach was adopted by Ali and Honary in 1991 [65] using a low-complexity soft-
decision decoding technique for T -user collaborative coding multiple-access channels. 
'Another paper of interest by Daett and Wolf [66] showed simple codes in a two-user 
multiple-access channel, apparently working with no synchronisation between codes. 
Further relevant work was carried out by Ni [67] in 1992 on codes to 
be used in a CCMA. He considered the problem of varying numbers of active 
transmitters accessing the same channel, as would be the case in a mobile phone type 
network. He introduced a set of codes that would be always decodable, called state-
independent uniquely decodable codes, and introduced a technique showing how they 
could be generated. 
A set of codes was generated in a paper written by Wu and Chang [68] 
for the US military. It contains a new coding scheme with asymptotically good, 
uniquely decodable codes for the multiple-access adder channel, with and without idle 
users, and is developed from the Lindstrom combinatory detection algorithm. To 
complete the survey of current MAC theory, a paper by Steinberg [69] sets out the 
resolvability region of an independent input MAC, with equations relating the 
resolvability region to the capacity region of the multiple-access channel. 
33 
2.6 Time/frequency division multiple-access 
TDMA techniques are a mature technology, and the Telecommunication Standards 
Sector (TSS) have standards in place governing the technical aspects of all of the 
TDMA systems used in modern telecommunications systems. The standard text by 
Feher [70] covers the more up-to-date TDMA techniques. The equipment 
manufacturers (Alcatel, Marconi, Newbridge etc.) provided information regarding 
research into fast synchronous digital hierarchy (SDH) multiplexers that are currently 
in development. 
The FDMA radio systems used in telecommunications networks are 
also defined by the TSS. Feher [70] gives a good overview of the current state of the 
art, with explanations of the trade-off between performance, cost, modulation 
methods, etc. The Hewlett-Packard company [71] produces some excellent technical 
briefs covering the theoretical and practical aspects of FDMA radio systems. It would 
be relatively simple to incorporate the FDMA system into the CV-CCMA system. A 
separate channel carrying timing and control information could be used with CV-
CCMA and could give performance enhancements. 
Of more interest is the current research and development into the 
wavelength division multiplexing (WDM) systems used for very high capacity trunk 
links over fibre-optic cable. The British Telecom Technology Journal [27] contains a 
summary of current research at Martlesham Heath (British Telecom research site) and 
the University of Southampton [72] has a very active research group that publishes 
very interesting work. The IEEE Communications Magazine has recently produced a 
special issue dedicated to state-of-the-art WDM systems [73]. Included are technical 
details of current receivers and narrow-band lasers. Collaborative codes and complex 
valued collaborative systems could be used with certain fibres that have different, but 
34 
quite predictable, attenuation and phase change characteristics to give even greater 
capacity to the trunk systems currently being developed. 
This area of research is important, especially to the trunk carriers of 
telecommunications traffic. The bandwidth requirements placed on the trunk network 
are doubling every few months, and the rate of increase of Internet traffic is colossal. 
Within a couple of years, speech will form only a small fraction of traffic, tagged on 
the back of Internet and data traffic. 
2.7 CV -CCMA research 
Research into the complex valued collaborative coding multiple-access system has 
. been more restricted. The paper by Chandler [74] contains the distance calculation 
used to decode the incoming combined waveforms. Care is needed when reading it 
because there are a couple of misprints in the matrix calculations which can confuse. 
The matrix array at the bottom of page 223 has two elements crossed and a + I -
missed. There is a similar calculation in Chapter 5, section 5.4, of this thesis. This is 
to illustrate the decoding of a two-transmitter one-receiver CV -CCMA system. A 
more recent paper [75] shows a method of code construction for binary block codes 
that can be resolved by the receiver using vector techniques. 
When the work detailed in this thesis was started in 1995 it was 
originally planned that the research was to be a co-operative venture between the 
University of Sussex and the University of Warwick. However, problems due to the 
distances involved and the lack of funding have meant that the two institutions have 
progressed along different, though complementary routes. 
The original plan was for hardware design and development to be done 
at Warwick and software to be done at Sussex. Problems arose due to different signal 
35 
processors being used. Once the hardware was assembled and working it was decided 
to write the software for the Texas Instruments processor at Warwick. This was done 
directly in assembler language, reproduced in Appendix 1. 
2.8 Code division multiple-access 
The research work on CDMA systems provided a wealth of information and many 
ideas as to possible solutions to the problems of the implementation of the CV -CCMA 
system. The two systems are both multiple-access, the main difference being that the 
CDMA technique of multi-access requires a spreading signal to be applied to the 
baseband data. This produces an output signal whose bandwidth is many times greater 
than required for normal communication systems. The Qualcomm web site [76] has a 
selection of technical documentation explaining the operation of the system, but no 
current research findings. In more detail is a paper by Scholtz [77] which describes an 
idealised spread spectrum system and shows the inherent robustness of 
communication performance of the system in the presence of interference. Spread 
spectrum systems have been used by the military for a number of years because of 
this immunity to jamming signals and the inherent security of a spread spectrum 
communication link. In the same journal, but published five years later, is a paper by 
Pickholtz, Schilling and Millstein [78] which is an in-depth tutorial on the workings 
of CDMA with some interesting comments on synchronisation. A paper by Verdu 
[79] gives a good comparison between different codes and different detector systems. 
There are a number of texts covering the theory of CDMA; the 
engineering aspects of the system are covered in [80]. Two interesting papers by 
Viterbi [81,82], covering the coding used and the problems encountered with a 
practical implementation of a CDMA system, were found to be very useful. Recent 
36 
research at Bellcore, published by the IEEE [83], describes a number of important 
multi-user DS-CDMA detectors which have been proposed, showing that with 
additional information about the different users decoding can be done more 
efficiently. In these systems, the code and timing information of multiple users are 
jointly used to better detect each individual user, minimising the need for power 
control but greatly increasing the complexity of the receiver, which is already a fairly 
complicated piece of equipment. The sub-optimal detectors he describes have been 
developed over recent years, reducing the complexity but trading off performance. 
The linear multi-user detectors apply a linear transformation to the outputs of a 
matched filter bank to reduce the interference experienced by the other users. The 
detector applies the inverse of the correlation matrix to the matched filter bank 
outputs, thus decoupling the outputs. This type of technique could be tried with the 
CV -CCMA system, although the implementation would be complicated; the 
technique is in any case very similar to what is being done in CV -CCMA. The other 
type he reviews is the subtractive interference cancellation detector, which estimates 
and subtracts the interference. Again this could be useful with CV -CCMA but 
difficult to implement. 
Another interesting paper written by Adachi, Sawashi and Suda [84] 
shows various techniques for increasing the data rate over a cellular mobile channel, 
up to 2 Mb/s and above. This is an area of great interest as current GSM I CDMA 
systems are pushed to transfer data at 9.6 Kb/s and much more capacity is required for 
the future. There is currently (1999) a stand-off between the authorities in Europe and 
the USA as to the promotion of the next generation of 'wideband' cellular telephones, 
both sides wishing to protect their own manufacturers with claims and counter-claims 
., of patent infringements. The system that is adopted will effectively become a world 
37 
standard, so the potential market is colossal. A new system, or variation that could be 
easily implemented, could upset both sides in the dispute and this is what may happen 
if the stalemate continues. Adachi, et al introduce an intercell pilot channel, which 
would be very useful with the CV -CCMA system for control and synchronisation. In 
the CDMA system it allows fast cell search, fast power control, coherent spreading 
code tracking, coherent Rake receiver, orthogonal multispreading factor forward link 
. 
and variable rate transmission with blind rate detection. It allows code division 
multiple-access to support interference cancellation and adaptive aerial techniques to 
significantly increase link capacity and coverage. They present computer simulation 
results showing the advantages of the proposed new system. 
Finally, a code division multiplex system using Manchester coding and 
shown with a simplified radio MAC is written up by Rabudi, Rasequi and Makura 
[85]. They show how good error performance can be obtained with a '3M plex' 
system, a proprietary multi-level orthogonal code system. 
2.9 High-speed radio digital signal processing 
Digital signal processing research is mainly restricted to the larger manufacturers of 
the devices themselves, who endeavour to push the performance of their products to 
the limit and drive the cost per million instructions per second (MIP) down. Texas 
Instruments [31] publishes very useful literature, which can be found at the Internet 
file transfer protocol (FTP) site, and includes interface circuits and illustrations of 
calculations of performance limits. There is also a bulletin board containing software 
that is of great value when trying out systems, useful test routines and initialisation 
routines. The company sponsors worldwide research and a number of papers 
-, contained very useful information. For an overview of the Texas Instruments floating 
38 
point system [86] is quite detailed; for interfacing [87] contained the most 
information. A most useful paper showing the floating point format in operation and 
how to convert between the different standard formats of floating point operation, 
with code included, is [88]. There are a number of standard self-teach texts available 
[89,90,91] which give excellent examples of standard floating point operational 
telecommunications systems. British Telecom Technology Journal produced a special 
issue on digital signal processing in telecommunications [92], which included a 
number of interesting papers. One describes a low-complexity digital transceiver 
using low-cost components, and another gives a good overview of digital signal 
processing in telecommunications. 
The filters within the CV -CCMA were implemented using a fixed-
point TMS320C50; useful information was also found at the Texas Instruments FrP 
web site. There are a lot of theoretical texts and papers that cover the design of filters. 
A design text [93] provided charts and code illustrating standard implementations. An 
article in IEEE Communications Magazine [94] on digital signal processors in cellular 
radio applications gives standard architectures and cost per MIP comparisons. They 
include an interesting section on future trends in which they speculate about the 
problems (already apparent) of very high-density chips having difficulty interfacing 
with the external world. The solution is to incorporate everything on one piece of 
silicon, and the new CDMA systems have signal processing systems built into them as 
part of the ASIC (application specific integrated circuit). They also review some of 
the new digital signal processing integrated circuits that are specifically designed for 
the wireless market. The integrated circuits would form an interesting implementation 
project for the CV -CCMA system. 
39 
2.10 Modern digital radio design 
This is the most difficult area to research, as most companies (understandably) do not 
publish their development and research into radio systems. Most British universities 
do not appear to be active in the field. The textbook literature contains standard and 
stable techniques for radio frequency generation and reception. However, there are 
• two American magazines [95] and [96] that cover the technical aspects of radio 
research design and implementation, and publish some interesting research. The CV-
CCMA system requires stable and accurate frequency sources in order to work, 
necessary to synchronise the component parts of the system together. CDMA uses a 
military technique adopted by the global positioning system (GPS) using satellites, 
however there is a licence to pay and CV -CCMA needs to be able to stand alone. An 
article published in 1998 [97] gives an extremely good summary of the various 
techniques used to generate very stable control oscillators. The author gives 
comparisons of stability with different crystals and ovens, different circuits and 
different costs. This was very useful and led to a redesign of the TcXo in the CV-
CCMA system. Another article in the same journal in 1995 [98] gives a detailed 
explanation of the measurement techniques used in digital radio systems, and 
illustrates with spectra and constellation diagrams the effects of various signal 
impairments. 
Liu [99] investigates the effects of in-phase I quadrature (I-Q) 
imbalance in quadrature phase shift keying (QPSK) receivers. This was useful 
because it calculates some bit error rate (BER) relationships in terms of amplitude and 
phase imbalance. 
The demonstrator of the CV-CCMA system described in the thesis 
". uses a type of Delta speech modulation,· and a paper by Dunn and Sandler [100] 
40 
shows alternative techniques that could be used to improve the resolution and hence 
the 'quality' of the speech with different multi-bit quantisers. It shows that with ideal 
multi-bit quantisers, fixed modulators exhibit superior characteristics to adaptive 
systems, which is interesting and has importance for the next generation of CV-
CCMA. Another interesting paper by Armstrong and Strickland [101] shows a novel 
method of symbol synchronisation. Signal values between the sample points are 
calculated by interpolation and then processed to find a suitable strobe point; this 
could be useful on initial set-up of the CV-CCMA system. Some time was spent 
investigating different synchronisation systems, the CV-CCMA would operate most 
effectively with reverse synchronisation, ie equalisation applied at the transmitter. As 
the information for the different links needs to be transferred from the receiver back to 
the transmitter, the situation becomes complicated. Some possible solutions were 
investigated and are discussed in chapter 8. There are a number of coding papers 
which were interesting but did not really advance the solution of the CV -CCMA 
problems. 
Finally, Hewlett-Packard [71] have produced a series of digital radio 
frequency technique refresher modules for design engineers, which were extremely 
useful. 
2.11 Summary 
This chapter contains previously published research material that has direct relevance 
to the rest of the thesis. The research into current design practice proved beneficial 
and prevented unnecessary design work being undertaken. Modem filter design and 
digital signal processor techniques were areas that were intensively studied, producing 
tangible benefits to the overall work. 
41 
However, it was found that" the most useful background reading was 
material and papers published by other researchers in the field. These led to 
investigations into different codewords, synchronisation techniques and speech 
digitisation, amongst others. 
The next chapter is a short comparative discussion of the merits of 
CDMA and CV -CCMA. 
42 
3 CDMAlCV -CCMA COMPARA TIVE DISCUSSION 
3.1 Introduction 
One of the reasons for Cable and Wireless PLC sponsoring the research, which is in 
part recorded in this thesis, was to increase the general company knowledge-base of 
modem multiple-access techniques, particularly radio-based systems. This was 
desired because a number of competitors were becoming very active in local radio 
access systems, with other mobile phone operators offering web-browsers etc. on 
mobile phones. It is thus of interest to discuss the comparative merits of CDMA 
and CV -CCMA in the context of the present work. 
CDMA is a multiple-access technique that is being promoted by 
certain parties as a solution for all the ills of the current generation of mobile 
telecommunication systems, that is, a fix for the lack of capacity and a technique 
whereby significant data rates (Mb/s) can be transferred over a mobile telephone. It 
is under debate at the present time which of the variations of the system will be 
implemented as the next worldwide standard for the third generation (30) of 
mobile telephones. There are two camps, the American and the European, with 
governments backing their own manufacturers and interest groups. The most likely 
outcome is that the manufacturer with the more substantial financial backing will 
buyout the others and this is likely to be a Swedish company. In the United 
Kingdom a trial has recently finished of a number of different CDMA systems and 
because of this it was decided to investigate the proposed systems and compare 
them with the CV -CCMA system. It is difficult to do a direct technical comparison, 
particularly as some of the solutions to the problems inherent in using CDMA are 
.. kept strictly confidential for commercial reasons. This section attempts to outline 
some of the strengths and weaknesses of both systems. 
43 
3.2 CDMA summary 
COMA is a spread-spectrum technique that grew out of military anti-jamming 
systems developed in the second world war. A introduction to COMA operating 
principles is included in Chapter 1. The system has only been used commercially in 
the last ten years; prior to this it was the preserve of the military. COMA has an 
inherent weakness when used as a multiple-access technique. Assume that there is a 
20 dB difference between the signal-to-noise ratios of two units that are trying to 
access a single receiver (like the CV-CCMA system). To accommodate this 
difference, the system would need to operate a spreading bandwidth at least 40 dB 
greater than the data rate, i.e. massive. If a lesser bandwidth system is used the 
lower signal will not be able to access the local node (usually called ON -
distribution node). The problem is solved in commercial multiple-access systems 
by controlling the power of the transmitters so that the signal strengths at the 
receiver are of the same order of magnitude. 
If we assume perfect power control, with M users, and energy per bit of Eb, 
with noise power density No , where S is the average modulating signal power and 
T is the time duration of each bit, and bit rate is R , then: 
Eb=ST .................. (5) 
and Eb=S I R .................. (6) 
therefore: 
.................. (7) 
44 
Now substitute the noise power density No for total noise power N divided by 
bandwidth W, No = N I W: 
Eb I No = (S I N )(WI R) .................. (8) 
Because perfect power control is assumed it can be stated that at the receiver the 
. received powers from all users are equal. So with M users: 
Eb I No = (1 I M - 1 )(WI R) ................. (9) 
Solving for M-l gives the equation relating the number of users to the energy per 
bit per noise power density (Eb I No) and the processing gain (W I R) : 
M - 1 = (WI R) I (Eb I No) ................ (10) 
Note that other types of interference are ignored, for example thermal noise, which 
would degrade the capacity of the system. 
Using a 9.2 Kb/s data rate gives a value for M of about 15 dB, or 
about 32 users in the same bandwidth compared to just two users on the old AMPS 
system. This gives an idea of the capacity increase available with CDMA, but 
remember this assumes perfect power control. At present with the CV -CCMA 
system we can cope with a maximum variation between input signal powers of 40 
dB without the complexity of the power control circuitry required in the CDMA 
system. This illustrates the first possible advantage of the newer system, showing 
45 
~ 'I 
" 
the reduction in complexity over the first system and hence cost savings and 
reliability benefits. 
3.3 Standards 
The North American CDMA standard IS95 [102], which has become one of the 
• 
more popular world standards specifies that each user's baseband data is input at 
9.2 Kb/s . This is called rate set 1, and the final spread signal is set to 1.2288 Mb/s 
giving an output bandwidth of approximately 1.25 MHz. This frequency was 
chosen because it is one eighth of the original advanced mobile phone system 
(AMPS) allocation, so telcommunication operators can migrate to CDMA in 
sections. IS95 specifies the transmission as a forward channel, from the mobile to 
the base station, and a reverse channel from the base station to the mobile. Tables 
3.1, 3.2, 3.3 and 3.4 summarise the specification; for the complete details please 
refer to [102]. The third-generation CDMA system standards are in the process of 
being defined; refer to the relevant ITU-T committee for details. 
Channel Sync Pal ing Traffic 
lData rate (b/s) 1200 4800 9200 1200 2400 4800 9200 
Code repetition 2 2 1 8 4 2 1 
1M0duiation 4800 19,200 19,200 19,200 19,200 19,200 19,200 
symbol rate (sis) 
IPN chipslmod 652 64 64 64 64 64 64 
symbol 
PN chipslbit 1024 252 128 1024 512 252 128 
Table 3.1 Forward link channel parameters, rate set 1 
46 
The IS95 forward link currently supports a 9200 bls rate family in the 
three data-bearing channel types, traffic, sync. and paging. In all cases the forward 
error correction code rate is 112 and the pseudo-random sequence rate is 1.2288 MHz. 
Channel Traffic 
Data rate (b/s) 1800 3200 7200 14400 
Code repetition 8 4 2 1 
Mod. symbol rate (sIs) 19,200 19,200 19,200 19,200 
PNchips/modulation symbol 64 64 64 64 
PN chips/bit 282.27 341.33 170.27 85.33 
Table 3.2 Forward link channel parameters, rate set 2 
The second channel rate family has a maximum rate of 14400 bls . 
Rate set 2 uses a forward error correction code rate of %; this is created by puncturing 
the code used in rate set 1. 
Channel Access Traffic 
Data rate (b/s) 4800 1200 2400 4800 9200 
Code rate 113 113 113 113 113 
Symbol rate before 14,400 3,200 7,200 14,400 28,800 
repetition (sIs) 
Symbol repetition 2 8 4 2 1 
Symbol rate after 28,800 28,800 28,800 28,800 28,800 
repetition (sIs) 
Transmit duty cycle 1 1/8 1/4 1/2 1 
Code symbolsl 6 6 6 6 6 
modulation symbol 
PN chips I 256 256 256 256 256 
modulation symbol 
PN chips transmitted 252 128 128 128 128 
/bit 
Table 3.3 Reverse link channel parameters, rate set 1 
47 
The IS95 reverse channel currently supports a 9600 b/s rate family in 
the access channel and traffic channel. The forward error correction code rate is 1/3, 
the code symbol rate is always 28,800 symbols per second and there are six code 
symbols per modulation symbol; the pseudo-random sequence rate is the same as 
before, 1.2288 MHz. The modulation is 24-ary orthogonal using the same Walsh 
functions as the forward channel. The secondary traffic channel also operates at 
. 
14400 b/s and uses a rate 1/2 code in place of the rate set 1 code. 
Channel Traffic 
Data rate (b/s) 1800 3200 7200 14400 
Code rate 1/2 1/2 1/2 1/2 
Symbol rate before repetition(s/s) 3,200 7,200 14,400 28,800 
Symbol repetition 8 4 2 1 
Symbol rate after repetition 28,800 28,800 28,800 28,800 
Transmit duty cycle 1/8 1/4 1/2 1 
Code symbol/modulation symbol 6 6 6 6 
PN chips/modulation symbol 256 256 256 256 
PN chips transmittedlbit 256/3 256/3 256/3 256/3 
Table 3.4 Reverse link channel parameters, rate set 2 
3.4 Comparisons 
Although both systems are multiple-access radio technologies, it is difficult to do a 
technically valid direct comparison between the two because the two systems are 
fundamentally different in operation. Both systems have advantages and 
disadvantages when compared to one another and to the other multiple access 
technologies. The main operational characteristics of both systems are highly 
interrelated, especially the geographical coverage of the. system, the quality of 
service and the capacity of the system. All these parameters are dependent upon 
., one another, that is you cannot improve one parameter without degrading another. 
48 
3.4.1 Capacity 
The capacity of the CDMA system is limited by a number of factors: the receiver 
demodulator and sensitivity, power control and interference. If we assume the 
transmitter stations have perfect power control, then the received signals will all 
have approximately the same power on arrival, but obviously this will not happen 
in reality because of the fluctuations present on a mobile signal. If we assume an 
available bandwidth of 1.25 MHz (IS95), and taking EJNo to be between 3 and 9 
dB, we have a maximum capacity of 24 users. The AMPS systems, which the 
CDMA is designed to replace, would have only 42 channels (1.25 MHz 1 30 KHz). 
However, this is not a fair comparison as the adjacent cells in the AMPS network 
need to be taken into account because the channels cannot be re-used in adjacent 
cells. 
Taking into account a frequency re-use factor, F and interference 10: 
F = Total interference power 1 own cell interference 
.......... (11) 
Assuming even cell loading gives CDMA an advantage of 2111.6 over the AMPS 
system, with sectored cells, or 7/1.6 without. 
In the CV -CCMA system, if we assume a maximum of four users 
per 30 KHz channel of the 1.25 MHz bandwidth (this is the maximum that has been 
proved to work in the laboratory, although in theory this can be much improved 
upon), then we have 160 (40 x 4) users simultaneously communicating in the same 
49 
bandwidth at 9.6 Kb/s. This shows another advantage of the CV-CCMA system: a 
large possible capacity increase over CDMA. 
3.4.2 Power control 
One of the weaknesses of CDMA is an overloading effect which means that 
transmitters need to have quite complicated two-way power control. A crude 
version is built into cellular systems anyway but CDMA requires very accurate 
control because the other users will appear to a station as noise, so the level of that 
noise must not desensitise the receiver. This is sometimes known as the near-far 
problem. If there are two transmitting stations communicating with one base station 
or receiver and one of the transmitters is much nearer to the receiver than the other 
one, then with no power control the receiver would receive a much stronger signal 
from the near station than from the far one. If the required signal-to-noise ratio is 
1: 10, and the difference between the distances between the transmitters and 
receiver is of an order of ten, then the distant station is on the limit of the required 
signal-to-noise ratio. This is because of the 'noise' from the other transmitter. If 
another station fires up in the cell, the third station will not gain access and will 
probably drop the others out as well. To prevent turn-on problems of this type, a 
series of access probes are defined to set up communication into a CDMA network; 
a low-power probe is initially sent and then the power is gradually ramped up until 
access is made. 
Standard mobile phone cellular networks operate with the reverse of 
this system; they transmit a burst of maximum power to log-on to the network, and 
then ramp down the RF power output,' mainly to conserve battery power. This 
" power control and access technology is an additional complexity of the CDMA 
50 
system. The CV -CCMA system will be less prone to power desensitising. The test 
set-up had hardwired connections with attenuator/phase shifters interconnecting the 
transmitters and receivers which showed the system to be resistant to desensitising. 
Provided there is sufficient input signal, nominally greater than -100 dBm into the 
Philips front-end integrated circuit, which has a noise figure of 2-3 dB, the CV-
CCMA will decode the incoming waveforms. On the initial test set-up a larger 
signal was required because the UHF amplifiers were disconnected. If an 
interfering signal is approximately 1 MHz removed from the wanted carrier, it 
needs to be at 0 dBm or greater before the mixer outputs become affected. 
However, closer interference caused quite drastic problems and would need to be 
resolved in a production unit by better filter and layout design. The CDMA system 
is inherently more conservative with transmitter radio frequency output, as each 
transmitter is constantly adjusted for minimum output power in order to achieve 
optimum performance. The carrier is also lowered to a pilot level whenever gaps in 
the speech are presented to the transmitter. CV-CCMA has none of these facilities 
(at present) but could have power control implemented relatively easily as the 
Philips driver integrated circuits are inter integrated circuit (I2C) devices [103] and 
therefore the gain could be controlled via the I2C bus. 
3.4.3 Timing 
The CV -CCMA system is as prone to timing problems as the CDMA system, but 
with any multi-access technique it is evident that in order to decode the 
contributing signals the start and stop points are required; the ideal way to do this is 
with very accurate timing. The optimum multiple-access technique would 
« incorporate an asynchronous timing scheme; however, this has proved to be an 
51 
elusive goal. Both systems therefore require expensive timing circuitry. The initial 
demonstrator incorporated hard-wired, central clock synchronisation in which all 
the component parts of the demonstrator were locked to a master timing source, 
(type 1 sync). The system was then developed to recover timing from the data 
streams (type 2 sync). However, the implementation of the synchronisation 
recovery from a separate radio frequency channel, (referred to as the type 3 
system), and multiple sampling software together with pulse shaping and RF filters 
helped to reduce the sensitivity of the CV -CCMA to timing drift and other 
synchronisation anomalies. 
3.4.4 Noise 
A comparison of the two systems in terms of noise performance is difficult, mainly 
because of the many different types of noise affecting the systems in different 
ways. In a mobile radio environment noise is often spiky; if these spikes, which 
often have sweep bandwidths of tens of MHz, fall across the CV -CCMA channels 
then data will be lost. The CDMA system is more resilient due to the spreading of 
the waveform and data will be preserved. If the noise is a more broadband noise, 
for instance other CDMA network stations, secure communication systems, etc., 
then CV -CCMA should prove the more resilient. 
3.4.5 Multipath propagation 
System capacity is affected by propagation phenomena. The fading of signals in a 
moving vehicle is caused by the motion of the vehicle through interference 
patterns. This is a big problem with the older cellular technologies and will cause 
" problems with CV -CCMA as the g value will be subject to some large variations. 
52 
CDMA is more robust, and multipath components can be resolved if their delays 
are separated by at least the de-correlation time of the spreading. They will not 
interfere because each component correlates to a different delay. If the delay is less 
than the de-correlation time then CDMA falls over; this is due to flat fading. Most 
modem systems incorporate fairly substantial forward error correction and 
interleaving to reduce these effects, but at the cost of yet more complexity. 
3.4.6 Cost 
Comparing the two systems on a cost per bit basis gives the CV -CCMA system a 
major advantage due to its greater spectral efficiency, and the (much) lower cost of 
the electronic components needed to construct the system, a cost that would further 
reduce if the system was ever put into mass production. In the United States, and 
recently in the United Kingdom, the governments have raised quite significant 
revenues by auctioning the radio spectrum. The CV -CCMA would therefore make 
an ideal candidate for triaIling in one of these bands, for example, a cheap phone 
plus internet access service. The low cost of the system means that it could be used 
in non-professional applications, such as amateur radio. The system could be used 
as an access coding requirement for input to a radio repeater, or on one of the 
packet data channels as this would increase the spectrum-usage efficiency and 
prevent some of the overcrowding problems currently plaguing the restricted 
amateur bands. 
The next chapter looks at the theoretical capacity limits for multiple-
access systems. 
53 
QCP'" 1960 COMA 
Dlgttal pes Phone 
Figure 3.1 Typical CDMA handsets (courtesy Qualcomm) 
54 
4 MULTIPLE· ACCESS CAPACITY LIMITS 
A brief introduction to, and explanation of, the basic operating principles of the 
complex valued collaborative coding mUltiple-access system has been given in 
Chapter 1. This chapter contains a more detailed investigation of the background 
theory relating to the capacity limits of multiple-access channels. This theory is then 
. expanded in the next chapter, with specific reference to CV -CCMA. 
4.1 Single-channel theoretical capacity limits 
Most telecommunication systems are designed so that the minimum amount of 
bandwidth is used in order for the system to operate correctly. However, there is a 
theoretical minimum bandwidth requirement for any communication channel that is 
defined in the theorem of Nyquist [104]. It states that Rs symbols per second can be 
received without inter-symbol interference (lSI) in a Rsf2 Hz minimum bandwidth 
channel. If we take into account filtering or pulse shaping: 
minimum (Nyquist) bandwidth 
W 
= W 
= 0.5(1 + r) Rs 
where r is the filter roll-off factor. 
.......... (12) 
When we then double sideband (DSB) modulate a radio frequency carrier by 
amplitude shift keying (ASK) or phase shift keying (PSK) the output, we require 
twice the bandwidth of the original baseband signals, giving: 
WPSK = WASK = (1 +r)Rs .......... (13) 
Most modem, especially lower frequency, communication systems suppress one of 
., the sidebands, and also possibly the carrier, in order to give better spectral efficiency. 
55 
These systems are called single sideband (SSB) systems. Current telecommunications 
microwave radios operate up to 256 quadrature amplitude modulation points in the 
output constellation (256 QAM). 
If we have a multi-symbol coding system, as CV-CCMA effectively is 
at the receiver, with the coder assigning to each of M symbols a k bit representation 
giving M = 2k , then as k increases the efficien~y in bitslslHz also increases. However, 
_ efficiency is traded against Eb I No where Eb = energy per bit and No = noise power 
spectral density, as more power is required at the transmitter and/or a better noise 
figure (NF) at the receiver. NF is the ratio of the signal to noise at the input to the 
signal to noise at the output. Bit error probability curves [105] are reproduced in 
Figure 4.1 to show this trade-off, showing different modulation schemes versus best-
case bit error rates. The theorem produced by Claude Shannon [45] in the late 1940s 
showed channel capacity to be a function of noise in the channel, receive power and 
bandwidth. Although interference and synchronisation are not included, the theorem 
provides a good basis to bound maximum channel capacity. The theorem is stated as: 
channel capacity = C = W log2(1 + SIN) bit/sec 
where W = bandwidth (Hz) 
S = average signal power (Watts) 
N = average noise power (Watts) 
.......... (14) 
Thus it is theoretically possible to transmit data at a rate R over the 
channel with an arbitrarily small error rate if R is less than C, by using suitable coding 
schemes. Using (14), Shannon plotted the achievable limits of practical systems, as 
56 
reproduced in Figure 4.2. Note the noise received is proportional to the bandwidth 
available for the channel as explained below: 
At the receive detector, N = No W, and substituting back into (14) gives: 
C I W= log2 ( 1 + SINoW) .......... (15) 
At the limit of capacity, where R = C (i.e. transmission bit rate = capacity): 
~=Eb 
NoC No 
~ =10g.[1+ !:( ~)] 
.......... (16) 
where Eb = bit energy and No = noise power spectral density. 
There is a limit of EJNo below which there can be no error-free 
communications. This can be calculated from (16) using the mathematical identity: 
lim x~O (1 + x)lIx = e .......... (17) 
let x =EJNo(CIW) .......... (18) 
where x is a variable and e is the base of natural logarithms. 
At the limit CIW goes to zero; 
E 1 . . 
_b = __ = 0.693 = -1.59dB 
No log2 e 
.......... (19) 
57 
This value is called the Shannon limit. It is not possible to reach the Shannon limit 
because as lIx increases, the bandwidth and implementation complexity increase to 
infinity. For a bit error rate of 1 in 100,000, using direct binary phase shift keying (as 
used in the first practical implementation of the CV-CCMA system) an Et/No of 9.6 
dB per channel is required. Using coding schemes implemented over each channel of 
the CV -CCMA this could be reduced. 
Shannon's work predicted improvements of over 11 dB (-1.59 ~ +9.6 
dB) by using coding techniques. However, modern commercial systems improve 
Et/No by approximately 7 dB. For detailed work on these limits refer to [106]. 
The Shannon theorem assumes an additive Gaussian noise enviroment. 
However, digital radio communication in the mobile enviroment, a major potential 
application of CV -CCMA, has channel characteristics often approximating to 
multiplicative Rayleigh varying statistics. 
W. Lee [54] explained that the channel capacity in a Rayleigh fading 
enviroment has to be calculated in an average sense due to the fading, and that the 
channel capacity can be increased to Gaussian channel capacities if we introduce 
diversity with M (the number of branches) greater than four. The paper shows the 
reduction in capacity of the channel to be approximately 30% and proves the average 
channel capacity over Rayleigh fading equals the channel capacity over Gaussian 
noise when the bandwidth approaches infinity. The calculations for channel capacity 
in the mobile enviroment take into account the Rayleigh effects, and as a first 
approximation will reduce the capacity for each link by one third. 
58 
1 
10-1 
>. 
..... 
. -
- 10-2 .-~ 
,.0 
8 p.. 
.... 10-3 g 
II) 
..... 
. -t:Q 
10-4 
10-5 
-10 J 
Shannon limit 
-1.59 dB 
o 10 20 30 
Figure 4.1 Bit error probability for multi-phase signalling (coherent M = 2k) 
W/C (Hzlbits/sec) 
16 
+6 
Unattainable 
0.0625 
Practical region 
12 18 
EblNo (dB) 
24 
Figure 4.2 Normalised channel bandwidth versus EblNo 
30 
59 
4.2 Multiple-channel theoretical capacity limits 
The CV -CCMA is a multiple-access system and each of the contributing 
transmissions needs to be added together (as the channel is treated as an adder 
channel). Shannon produced a paper in 1961 [46] on two-way communication 
channels which looks at decode probabilities with different codes and different 
channel types. Work was also carried out by El-gamal and Cover [52], Slepian and 
Wolf [107] and Ahlswede [108] in the 1970s and 1980s. The following is derived 
from these together with the summary of Shannon theory by Wyner [109]. 
Assume that we have two transmitters and one receiver, and Gaussian 
characteristics in the communication multiple-access channel. The output of the 
channel Y is the sum of XI. X2 and G, where XI and X2 are the inputs and G is the 
noise random variable; then all achievable rates must lie in the shaded area indicated 
in Figure 4.3. The references contain more rigorous mathematical derivations. 
R2 (bits/channel) 
\.S 
1.0 
o 0.5 1.0 1.5 Rl (bits/channel) 
Figure 4.3 Capacity region of 2-user multiple-access channel 
60 
If we combine the achievable rate region found by Bergmans and 
Cover [47] and the capacity region found by Wyner [109] with the proof by Keilers 
[110] and the summary of van der Meulen [49], the capacity region of the discrete 
time multiple-access channel is given by: 
......... (20) 
The channel has additive white Gaussian noise, K21 defines a discrete 
memoryless MAC with two input users and controlled powers PI and P2 and noise 
varianceN. 
Work by Chandler et al studied channel capacity limits for multiple-
access channels with slow Rayleigh fading [111]. They used the technique described 
by Ungerboeck [112] with a Monte-Carlo technique to calculate the capacity for a 
multi-user CV -CCMA system in a slow Rayleigh fading enviroment (the MAC) with 
additive white Gaussian noise. 
Summarising, assuming there are T transmitters, each with M levels or phases, then 
there are N = MT inputs to the MAC and at the output of the MAC: 
z = {Zo , ... , Zk ,,,,ZN-l} .......... (21) 
61 
where Zk is the kth composite signal representing the kth combination of T user 
transmissions given by: 
T 
Zk = LSjk(hjgj ) .......... (22) 
j=O 
where sl is the ith user transmitted complex symbol and hj is the ith user constant. 
They extended the expression from [112] for channel capacity C: 
C= max ~pr(k).7p(YIZk)log2 N-l P(yIZk) Y 
Pr(O) ... Pr(N-l) k=O -DO L Pr(u )P(y I zu) .......... (23) 
u=O 
where Pr(k) is the probability associated with Zk. and treated as equiprobable, and 
P(YIZk) is the conditional probability for the received composite symbol y, y = Zk+W, 
and w is the complex valued noise sample with zero mean and variance Ow 2, The 
capacity equation is then simplified by assuming the values of gi are drawn from a 
zero mean uncorrelated bivariate Gaussian distribution, giving a Rayleigh amplitude 
distribution and a uniform phase distribution: 
C=log2(n)--LE log2 Lexp k u2 
1 N-l { N-l [-I Z + w - Z 12 -I W 12 ]} 
Nk~ u~ 2aw 
.......... (24) 
This equation is used with a Monte Carlo analysis to find the capacity limits for the T 
user MAC, and they show that the maximum channel capacity for a given value of T 
and M is achieved in a slow Rayleigh fading channel at a signal-to-noise ratio 
approximately 10 dB higher than in a Gaussian channel. 
62 
The results do give a good first approximation for capacity limits, but 
the real life situation is somewhat more complicated. The probablities Pr(k) are 
assumed to be equiprobable, in order to simplify the equations, which they mayor 
may not be. More significant is the fact that the complex channel loss g values are 
taken as constant; this is fine in the laboratory set-up but this will not be the case in 
the mobile-radio type enviroment. Due to the fact that CV -CCMA identifies the g 
values as a part of the demodulation process, this must reduce the net capacity under 
time-varying conditions. It therefore seems logical and reasonable that the reduction 
in capacity would be related to the g value estimation, more precisely the entropy of 
the g value estimation. If we can increase entropy by other means, for example a 
multiple aerial array which would give additional information about the incoming 
signals, then a benefit in the capacity of the system could be expected. This would be 
especially beneficial if we have multiple receivers which all require a g value 
estimation in order to decode the incoming signals. The aerial system would then be 
connected to the various receivers and information about the signals could be resolved 
by a high-speed scan and used by all of the receivers. Another dedicated processor 
would be required but the implementation need not be too complicated. The system 
could incorporate other useful features, possibly automatic transmitter power output 
adjust and/or input sensitivity variation. This is another interesting offshoot of the 
CV -CCMA research which will hopefully be pursued in the future. 
In the laboratory set-up the processing/speed limitations are caused by 
the time taken by the digital signal processor to input, multiply and resolve the 
incoming data. The first implementation uses a 50 MHz DSP and, taking instruction 
time as 40ns, the ,minimum number of calculations are approximately (11 x 3) + 19 + 
(16 x 4) = 116, giving a calculation time of 4640ns , and a maximum symbol clock of 
63 
21.55 KHz. This calculation is approximate and assumes the parallel commands of the 
digital signal processor are fully used. The multi-sample software, used with the type 
3 synthesiser to reduce timing criticality, has a reduced maximum data rate of 1.5 
Kb/s per channel. See the software section, Chapter 6, section 4, for comment and 
further discussion about this. Obviously a more powerful processor would increase 
these capacities. Texas Instruments have recently launched a processor with an order 
of magnitude more processing power than the devices used in the current CV -CCMA 
and these will be tried when funds allow. It was found that the much-vaunted parallel 
command sets of the digital signal processors were so restrictive in operation that it 
was often found that faster code could be written by ignoring them and going for 
restrictions to the iterative loops in the receiver. 
In the single transmitter/single receiver channel, feedback does not 
increase the capacity of the channel. However, with multiple-access the situation 
becomes somewhat more complicated. Gaarder and Wolf [113] showed that the 
capacity of an additive white Gaussian noise multiple-access channel increases with 
noiseless feedback. This work was enhanced by Thomas [114] who proved that the 
maximum increase in capacity for the noiseless multiple-access channel with 
feedback is approximately doubled. Apart from the filter implementations and some 
experimentation with a coarse analogue automatic gain control, no feedback was 
applied to the CV-CCMA systems developed at Warwick. 
The next chapter looks in detail at the theory underlying the CV-
CCMA system. 
64 
5 THEORY OF OPERATION 
5.1 Introduction 
This section explains in detail the theory behind the operation of the new CV -CCMA 
system. The CV -CCMA is designed for multiple-access operation and the simplest 
implementation is therefore two transmitters and one receiver, operating over the 
. same bandwidth. This is how the initial design was envisaged and so the explanation 
of the theory of operation will be expanded upon assuming this configuration, unless 
stated otherwise. 
Each of the transmitters has programmed into its coder memory a 
number of unique collaborative codes. The input signal, either a test pattern or 
digitised speech, is buffered and then fed to the coder. In the initial implementation of 
the system these codes were required to be linearly independent [115]. This means 
that there are no multiplying constants (apart from zero) which would set the vector 
sum of any number of transmissions to iero, preventing reception at certain 
combinations of complex loss (g) values. That is: 
If gJ, gz, g3, etc. are complex loss values, treated as constants, 
and VI, Vz , V3, etc. are vectors, of the same type, 
then for linear independence: 
gl VI + gzVz + g3V3 + ... gnVn = 0 ......... (25) 
only when all constants are zero. 
The codewords were also required to be partitioned between users. This enables any 
combination of signals transmitted by the users to be uniquely decoded and allocated 
65 
to the particular user. However, with the codewords all linearly independent, the 
capacity of the system is restricted more than is necessary, as will be described later. 
Decoding is based on the fact that each combination of transmitted codewords 
describes a unique hyperplane as g is varied. Positioning on it will be determined by 
the complex loss coefficient (the g value), that is the phase change and attenuation 
occurring between the transmitter(s) and the receiver(s). Note this is assumed to be 
constant over the period of the codeword and unique to each transmission path. 
The transmitter outputs may be considered as connected together via 
attenuators and phase shift networks when launched into free space via the aerials and 
hence transferred to the receiver. At the input of the receiver a waveform is received 
that is made up of the sum of all the transmitted codewords, weighted by complex 
transmission loss coefficients (the g values). In the first stage of the receiver the signal 
is amplified and is then presented to the next stage as the received vector. The 
distances of the received signal vector from each of the hyperplanes is calculated and 
the one with the minimum distance is chosen as the most likely transmitted codeword 
pair. The position of the projection onto the plane gives and its distance a measure of 
the noise. The mathematics relating to the process will be covered later in this section. 
Note that in order for the system to function it is necessary to have synchronisation 
between the transmitters to provide simultaneous bit transitions at the receiver to 
which it can be synchronised. This is so that the receiver will 'capture' the combined 
signal at the correct instant and hence be able to process and decode the individual 
contributing codewords. Sub-section 5.2 looks at this problem in more detail. 
Stored in the memory of the receiver's digital signal processor are pre-
calculated matrix values associated with all combinations of the transmitted codes 
.. used within the system. The transmitted codeword matrix array is multiplied by its 
66 
generalised inverse and then the result is subtracted from the standard identity matrix 
(I). The size of I is determined by the size of the codeword array. If vector array Sk is 
the transmitted codeword array, and Pk is the array corresponding to the 
pseudoinverse (generalised inverse) of the transmitted codewords, the calculation 
required is I - SkPk. This equation will be explained in more detail later in the 
• 
section. Then, as a subroutine running on the receiver signal processor these stored 
arrays are multiplied by the received vector, and the Euclidean norm is calculated for 
each of them and stored. The minimum value is selected and this corresponds with the 
minimum distance to any plane defined by a valid combination of transmitted 
codewords. It is then necessary to use a simple look-up table to recover the original 
codewords and output the recovered data to the speech decoder or the data sink. It is 
also possible to recover the g values, assuming the codewords have been correctly 
decoded, by simply mUltiplying the pseudoinverse by the received vector. The g value 
could be stored in a temporary buffer and used as an aid to decode the next received 
codeword. The codewords used in the demonstrator used a common first symbol. This 
was to simplify the operation of the decoder. The g value is assumed not to change 
between codewords and if the first symbol is known then less processing is required. 
The complete receive process will be explained in more detail in the receiver 
processing section. 
In the laboratory, an initial training sequence is used with a fixed, 
known value of loss, and a fixed phase shift between the transmitter and the receiver. 
This makes a useful check on the operation of the decoding process, it is beneficial to 
compare calculated g with actual g. In the laboratory set~up, attenuation and phase 
shift are easily applied. Apart from training, the sequence of events just described 
needs to occur for every codeword combination received. 
67 
In order to reduce sensitivity to timing impairments, a multiple-sample 
system was implemented. Three samples were taken, based at an even spacing and 
centered around the recovered synchronisation points. The last sample of the group of 
three was used as the first sample of the next group, providing overlap. This reduced 
the throughput of the system but made it more robust in operation. The operation of 
this later system is discussed in sub-section 5.2 and the results obtained with it are 
reproduced in Chapter 7. The Texas Instruments dual floating point digital signal 
processor (development system), together with the Burr-Brown dual 18-bit analogue-
to-digital converter, was found to have sufficient dynamic range and processing 
power to achieve this. 
In the initial implementation(s) of the system, the transmitter codeword 
generators restrict the codewords to a subset of the total number of codewords 
available, enabling unique decodability. Only one codeword can be shared, as 
otherwise it would be impossible to know who had transmitted which codeword, or so 
it was initially thought. Also, there must be some certainty of two transmitters 
transmitting, as without this it would be difficult to know whether both had sent it or 
one had stopped (although this would give a g = 0 value which could be correctly 
interpreted by the DSP). However, if we assume that the g value will remain relatively 
constant from one codeword to the next, and providing that the g values for the 
different transmitters are not too close together, then data from successive pairs of 
codewords can be separated into distinct streams. 
This means that all users could use the same codeset, and identification 
data could be embedded within each transmitter's output stream. This effectively 
removes the need for pre-allocation of timeslots, frequency or codes, as required by 
., other multiplex systems, and gives a major advantage to CV-CCMA. The only 
68 
weakness is that of decoding the signals when the g values are similar, as, for 
example, with mobile CV-CCMA users located in the same car in a traffic jam or in 
the same carriage of a train. However, the g value is two-dimensional so the 
probability is small, and the two users would need to be within a fraction of a 
wavelength of one another, or an exact integer number of wavelengths apart. 
5.2 System synchronisation 
It is an essential requirement of the CV -CCMA system that the component parts of 
the system be correctly synchronised. The receiver needs to know the correct 
synchronisation points in the incoming stream of data in order to decode and process 
the information. Three types of synchronisation were used with the CV-CCMA 
demonstrator, type 1 synchronisation, type 2 synchronisation, and type 3 
synchronisation. Type 1 comprised one master oscillator, with all system components 
slaved to it. Type 2 recovers timing from the incoming data streams and type 3 has a 
separate lOMHz timing channel, with a single master oscillator. 
The transmitters, two or more using a particular channel, are operated 
with the same output frequency. In the demonstrator they are effectively synchronised 
together due to the high-stability oscillators which are used as reference frequency 
sources in the transmitters and receivers. These are identical devices having very little 
drift - in the order of fractions of a part per million. Even so, if there is a relative 
frequency difference of one part per million with the system operating at one 
gigahertz, then the frequencies would be one kilohertz awry. The codewords must be 
short compared to one millisecond in order for constant relative phase to hold for the 
duration of the codeword. Enhanced synchronisation techniques were investigated and 
better performance would be achieved by synchronisation to a recovered timing 
69 
channel. This synchronisation technique was implemented as a separate 10 MHz 
channel and used to phase-lock the PLL's to the master timing source (referred to as a 
'type 3' synthesiser). With the system operating in the mobile environment the 
Doppler effect (relative frequency change due to the movement of the stations) would 
provide an ultimate limit to this synchronisation technique. If we have a mobile 
transmitter (A) operating at an output frequency (/) of 1 GHz, communicating with a 
fixed base station (B), and the duration of the transmission is t seconds, then the 
number of waves emitted is jt and they cover a distance AB to the base station. If the 
wavelength is A: 
AB =jtA .......... (26) 
If the mobile is moving with velocity v mls towards the base station, then it will have 
moved to A' in t seconds and the waves emitted will have a shorter wavelength, A' : 
Distance 
A'B 
AB 
jtA 
A 
=jtA' 
= A'B + vt 
=jtA' + vt 
=A'+vl! 
The ratio of the wavelengths 
AI A' = 1 + vlfA' 
Now v = fA = c (c in free space) and the ratio of the frequencies; 
fl! = 1 + vi/A' 
(f-f)I! = vi/A' 
(f-f) = v/ Ie = Doppler frequency. 
.......... (27) 
.......... (28) 
. ......... (29) 
70 
If we take the frequency as 1 GHz and velocity as 70 mph, approximately 31 mis, 
then the Doppler frequency works out at 103 Hz or 0.1 ppm, within the tolerance 
limits using the coding scheme described later in this thesis. However if the 
transmitter was airborne, or on a satellite, then the relative speeds would be orders of 
magnitude greater and the Doppler effect would limit the operation of the system. 
Possible improvements would be a tracking of g values and implementing some form 
of compensation circuitry at the transmitters. 
The other possible problem area when using a synchronisation 
recovery system would be multipath propagation. This is the arrival at the receiver of 
signals that have travelled there by different paths. The multi path problem is 
noticeable on broadcast television and is seen as the ghost effect on television screens; 
commercial digital radio also suffers quite badly from multipath effects. MUltipath 
could cause problems with the CV -CCMA system in a number of areas. The 
synchronisation could be compromised by the recovery circuit locking onto a signal 
that has arrived via a different route. This is quite likely to occur in the type 3 
synchronisation system as the frequencies used for synchronisation and data are quite 
different (10 MHz as opposed to 850 MHz). This could be reduced by careful design 
and/or using very high stability circuits with long sample times as the timing source. 
In view of the problems described, the first laboratory circuit was initially hard-wired 
together, a technique often called central synchronisation, in which all of the phase-
locked loops were hard-wired to one master frequency source. This would not be 
viable in the field. Note that even with the type 3 synthesisers and the multi-sample 
software with filters applied, the oscillators must still be plesiochronous within tight 
constraints and also preferably locked to a recovered sync channel. 
71 
To try to reduce the sensitivity of the system to synchronisation 
impairments the characteristics of the filters used within the system were deliberately 
altered. This was in order to increase the window size of valid data at the receiver. 
With fixed g values, some improvement was obtained; some results are presented in 
Chapter 7. However, the increase in processing required to implement the filters 
• 
reduces the transfer capacity of the system. The trade-off between different 
performance parameters is a common problem in modem communication systems. 
The optimum selection of codewords/synchronisation/power, etc., would depend on 
the overall system requirements. Also, further work was undertaken on the receive 
algorithm in order to reduce the sensitivity of the system to timing impairments. A 
multi-sample process was implemented. Although limited to 3 samples per symbol 
timing pulse, due to processor limitations, it did provide an improved system 
performance in the presence of applied jitter. The algorithm operated by outputting 
the majority decision (of the 3 samples), as to the correctly decoded data. If no 
agreement could be made, the result with the, minimum distance to a known, pre-
programmed value is output as the valid data. The software section of Chapter 6 
contains flow charts, and explanations of the operation of the various systems 
developed. Another solution would have been to use the distance to projection (error) 
signal and chose the best, thus requiring only 2 samples. 
5.3 Receiver processing 
This section looks in more detail at the actual decoding process taking place in the 
receiver of the CV-CCMA, or more specifically in th~ signal processor within the 
receiver, where most of the 'intelligence' of the system resides. In aT-user 
72 
collaborative code we can represent the allowable combinations of codewords 
resulting from the T -user transmissions by: 
.......... (30) 
Here, L is the maximum number of allowable codeword combinations and akj is the /h 
symbol of the klh allowed codeword combination. Therefore, for each Ak there is a set 
of T symbols sij which defines a hyperplane described by gi, (gi is the complex loss 
coefficient from the ith transmitter). 
The distance squared between the received vector r and the kth 
codeword combination can be written as; 
.......... (31) 
where Sij is the /h symbol of the i lh codeword. The estimated values of gi can be found 
from minimising IIdkW with respect to all gj. 
Using partial derivatives and equating to zero 
.......... (32) 
This gives T equations which can be solved for T values of Gi and can be substituted 
back to find the distance squared to the kth combination of codewords. This process is 
repeated for all values of k, and the combination of codewords . with the minimum 
squared distance is chosen as the correct transmitted codewords. 
73 
In matrix fonn, where: 
I = Identity matrix 
Sk = The transmitted codeword combination matrix 
Pk = Pseudoinverse of Sk (General Inverse in Mathcad) 
r = The received vector 
then G =PkT .......... (33) 
and (from (31)): 
.......... (34) 
Therefore the square of the distance can be calculated by multiplication of r by a fixed 
matrix. The value of k is estimated as that which minimises the expression. For a 
more rigorous treatment, including worked examples, refer to [74]. The first practical 
implementation of the CV-CCMA system used two transmitters and one receiver, and 
was constructed with the QPSK (quadrature phase shift keying) modulators restricted 
to two states, i.e. binary phase shift keying (BPSK). The initial simulations of the 
system are worked through to illustrate the theoretical operating principles. Note that 
all quantities in these expressions and simulations are, in general complex. 
5.4 System simulations 
To prove the viability of the system and to give confidence before hardware design 
commenced, the system operation, or more precisely the receiver decode system, was 
simulated using a proprietary mathematical program (Mathcad). With the modulation 
stage set to BPSK, a logic one is coded as a phase of 180 degrees and a logic zero 
coded as a phase of 0 degrees. Figure 5.1 recaps BPSK and QPSK. 
74 
-1 
+j 
-j 
QPSK 
Figure 5.1 
+1 -1 +1 
BPSK 
QPSK I BPSK phasor plots 
N.B. The vectors rotate-anti-clockwise by convention. 
Table 5.1 summarises one set of codewords selected and the corresponding modulated 
output for the system, using length three codewords with BPSK modulation. Note that 
the codewords used are unique and they are partitioned between the two transmitters, 
enabling the identity of the transmitter to be determined as soon as the codeword is 
recovered at the receiver. This was a deliberate design feature of the first systems 
because fault finding I signal tracing is much simplified with unique and therefore 
easily identifiable transmission sources. In the initial implementation, the first phase 
state is the same in all codewords, and although this is inefficient, it aids the decode 
process because the decoder always has a fixed starting point. 
Station ill Data Input Codeword output Modulated output 
. 
User 1 0 000 +1 +1 +1 
User 1 1 001 +1 +1 -1 
User 2 0 010 +1 -1 +1 
User 2 1 011 +1 -1 -1 
Table 5.1 Codewords and modulated output for system 1 
75 
The combinational matrices are then calculated, using computer programs Mathcad 
and Matiah. Programs were written in both languages to solve the equations; see 
Appendix 2 for the programs and Chapter 7 for the programs and results. With binary 
inputs to both transmitters (0 or 1), four possible combinations of codewords are 
possible, SI-S4, and pseudo-inverses for these combinations are calculated, PI-P4: 
[
+1+1] 
SI= -1+1 
+1+1 
[
+ 1+1] 
S2= -1+1 
+1-1 
[
+1+1] 
S3= -1+1 
-1+1 
[
+1+1] 
S4= -1+1 
-1-1 
[
+ 0.25 - 0.5 + 0.25] S1.Pseudoinverse = PI = 
+ 0.25 - 0.5 + 0.25 
[
+ 0.5 - 0.25 + 0.25] S2.Pseudoinverse = P2 = 
+ 0.5 + 0.25 - 0.25 
[
+ 0.5 - 0.25 - 0.25] S3.Pseudoinverse = P3 = 
+ 0.5 + 0.25 + 0.25 
[
+ 0.25 - 0.5 - 0.25] S4.Pseudoinverse = P4 = 
+ 0.25 + 0.5 - 0.25 
Next, the combinational matrices are calculated. 
Cl=(I-SkPk)OO =[~~:~_[:~:~J+o.25-0.5+0.25J=[ 0~5 : -:.5] + 0.25+ 0.5 + 0.25 001 +1+1 . -0.5 0 0.5 
[100] [+1+1] [0 0 005] C2 = (1- S,p,)" = 01  - ,..   [+0.5-0.25+0.25] =  0.5 
001 + 0.5 + 0.25 - 0.25 
+1-1 0 0.5 0.5 
[100] [+1+1] . [0 0 
-:.5] C3 = (1-S p) = 010 - -  +1 [+0.5-0.25 -0.25] =  0.5 
. Ie Ie 10 + 0.5 + 0.25 + 0.25 
. 001 -1+1 0 
-0.5 0.5 
[
100] [+ 1 + 1] [0.5 0 0.5] + 0.25 - 0.5 - 0.25 
C4=(I-SIcPIe)u = 010 - -1+1 [ ]=0 0 0 
00 1 +0.25+0.5-0.25 1 -1- 0.5 0 0.5 
76 
These results are stored in the DSP (manually input into an assembler array). To 
illustrate system operation with an example, assume complex loss component 1 has 
attenuation but no phase change, gl = 0.5 + OJ ; and complex loss 2 has both 
attenuation and phase change, g2 = 0.9 + 0.2j. The received vector Rl will be: 
Rl = Oo{~]+ (009 + OoZi{ :;] 
This vector is multiplied by the pre-calculated combinational matrices, the Euclidean 
nonn of the result is calculated and the minimum value assumed to equate to the valid 
combination of original codewords. Program (Pau13.mcd) in Appendix 2 perfonns 
these operations and can be used to tryout all combinations (can be used for test 
purposes). Next the Euclidean distances (DI-D4) are calculated by multiplying the 
received vector by the l·SkPk matrix and hence the minimum distance can be found. 
Distance 1 =Dl = Cl *r 
[
0.5 
Dl= 0 
-0.5 
ID11=0 
o - 0.5] [+ 1.4 + 0.2~] _ [0] o 0 . - 0.4 - 0.2J - 0 
o 0.5 + 1.4 + 0.2j . 0 
D3 = [~ 0~5 - ~.5][~ ~:: ~ ~:~~] 
o - 0.5 0.5 + 1.4 + 0.2j 
D3 = [- 0.9 ~ 0.2j] 
0.9+0.2j 
ID31 =1.304 
Distance 2 =D2 = C2*r 
[
0 0 
D2= 0 0.5 
o 0.5 
o ][+ 1.4 + 0.2j ] [0] 0.5 - 0.4 - 0.2j = 0.5 
0.5 + 1.4 + 0.2j 0.5 
ID21 =0.707 
[ 
0.5 0 - 0.5] [+ 1.4 + 0.2~] 
D4 = 0 0 0 . -0.4-0.2J 
- 0.5 . 0 0.5 + 1.4 + 0.2j 
[
1.4 + 0.2j ] 
D4= 0 
1.4+0.2j 
ID41=2 
77 
IVII is the minimum distance; therefore the receiver selects codewords 
(111) and (1-11) as the correct transmitted codewords and outputs (0,0) as the 
decoded data from the two transmitters. The g values can also be output if required for 
further processing. 
_[0.25 -0.5 
g - 0.25 0.5 
= [0.9 + 0.2j] 
g 0.5 
0.25 
J[ 
1.4+0.2j ] 
-0.4-0.2j 
0.25 
1.4+0.2j 
The results show that the system decode process is a viable technique for the 
reception of at least two CV -CCMA transmitters operating in the same bandwidth. 
Chapter 7 contains details of the actual results obtained with the laboratory 
implementation of the system, and the receiver decode simulation just described 
matches the actual results quite closely. The DSP code written for the first test system 
is an assembler language version of the Mathcad program and so is not as easy to 
interpret, but the code is sectioned to follow the same procedure; refer to Appendix 3 
to view the code. 
5.5 Codewords 
In the original conception of CV -CCMA, codewords were required to be linearly 
independent, partitioned into unique sets, one for each of the transmitters, but 
operating an algorithm where any number of combined user unique codewords could 
(theoretically) be decoded. Although this gave poor capacitylbandwidth 
characteristics, it made the practicalities of actually getting it to work easier. This 
system was developed and is currently at a breadboard stage. With the system up and 
78 
running it was decided to produce another system that was more readily reconfigured 
and upgraded. The first task was to investigate the possibility of reducing the 
restrictions on the generation of codewords, that is the requirement for linear 
independence, which substantially increases the coding rate, particularly with short 
codes and a restricted number of users. In all systems, signals from both transmitters 
are summed by the channel, having been multiplied by complex gain coefficients gj to 
give the combined signals: 
T 
Rn = LSingi 
i=1 
for 
l'5:n'5:N 
.......... (35) 
where N is the length of the codeword and Sin is the nth symbol of the codeword sent 
by the ith of a set of T transmitters. The locus described by the vector Rn forms a 
subspace of T complex dimensions as the gi are varied. Since gi may be zero these 
hyperplanes must go through the origin. The· reception process involves the 
calculation of distances from these hyperplanes. To be able to do this it is necessary 
that T < N , as if T = N the subspace includes the whole vector space, and the 
distances are all zero. This can be demonstrated easily using program paul2.med in 
Appendix 3. 
The greater the difference between T and N the less the likelihood of 
error. However, to uniquely decode the received signal the hyperplanes only need to 
be distinct. If two combinations of codewords give identical hyperplanes, then both of 
the vectors defining the first combination would have to be a linear combination of 
the second pair of vectors. Therefore, it is logical that for unique decodability the 
codewords do not lie on any hyperplane defined by the combination of any pair of 
79 
other codes. This provides much less restriction on the choice of codewords than full 
linear independence, as required in the initial implementation. In fact, if we could 
remove the restrictions on the symbol sequence altogether and insert identity codes 
into the streams we would also remove the need for frame timing, although accurate 
bit timing would always be required. Detection could be performed on an arbitrary 
sequence of QPSK symbols with decoding using overlapping codewords by 
considering three-symbol CV -CCMA codewords. This will then define the set of 
codewords to be searched in the next step; effectively each three-symbol codeword 
would be selected from sixteen or four of the sixty-four possible codewords for which 
the first symbol or pair of symbols were the same as the last ones. This would give us 
a processing advantage in performing the CV -CCMA decoding. 
As an example to illustrate the relaxation on codeword restriction, 
consider the first implementation equipment, with two transmitters and only one 
receiver (T = 2), and with the modulation restricted to BPSK and codewords of length 
N = 3 symbols, which are selected from (+1 -,1). This gives us 23 = 8 possible 
codewords, as illustrated in figure 5.2. 
No. Codeword 
A +++ 
B ++-
C +-+ 
D Codewords form +-- into 4 pairs separated 
D' 
-++ by multiplication of -1 
C' 
-+-
B' 
--+ 
A' 
Figure 5.2 Codeword generation 
80 
These codewords form a set of vectors pointing to each of the vertices of a cube based 
around the origin. We eliminate those that are negatives of one another as these would 
be the same sign if g were reversed, leaving four (1,1,1), (1,1,-1), (1,-1,1) (1,-1,-1) 
vectors, none of which can be formed from any other two. This shows that with two 
users and the codewords described, the combined codewords, (A+B), (A+C), (B+D), 
(C+D) produce unique combinations which can be resolved even with identical g ; 
(A+D) and (B+C) give identical combinations, which could still be resolved with 
different g. Figure 5.3 shows all possible combinations and indicates that the 
restriction on choice of codeword is less than full linear independence, as was 
previously stated as required for CV -CCMA. 
Note, however, any codeword can be formed from the other three. We 
now advance the argument with a second example, using the later equipment and 
removing the restriction on the modulators, thus giving full QPSK with symbols 
selected from (+I,-I,+j,-j). Again we have two transmitters, one receiver and 
codewords of length N = 3. In this case we have 43 = 64 possible codewords but we 
can only select codewords that are not scaled versions of one another, leaving 43-1 = 
16 possible codewords. If there are M symbols in the alphabet there are MN-1 
codewords that are not scaled versions of others. 
One system implemented for making the selection of codewords is to 
make the same choice of first symbol for all the codewords, as shown in the previous 
example (combinations grouped into sets). This also gives the advantage of 
simplifying the decode algorithm, as previously explained. 
81 
Codeword Codeword 
Set 1 Set 2 
A = 1 1 1 A'=-1 -1 
B= 1 1 -1 B' = -1-1 
C= 1-1 1 C' = -1 1 
0= 1-1-1 0' = -1 1 
Possible combinations (ignoring zero solutions) 
AB 2 2 0 A'B' 
AC 2 0 2 A'C' 
AD 2 0 0 A'D' 
BC 2 0 0 B'C' 
BD 2 0 -2 B'D' 
CD 2 -2 0 C'D' 
AB' 0 0 2 iv 
AC' 0 2 0 iii 
AD' 0 2 2 
BA' 0 0 -2 vi 
BC' 0 2 -2 
BD' 0 2 0 iii 
CA' 0 -2 0 v 
CB' 0 -2 2 
CD' 0 0 2 iv 
DA' 0 -2 -2 
DB' 0 -2 0 v 
DC' 0 0 -2 vi 
Note: Combinations indicated by roman numerals 
The original codewords cannot be made from 
any combination of any other two 
-1 
1 
-1 
1 
-2 -2 
-2 0 
-2 0 
-2 0 
-2 0 
-2 2 
Figure 5.3 BPSK possible codeword combinations 
0 
-2 
0 ii 
0 ii 
2 
0 
82 
It may still be possible that: 
For this to happen: 
C Sir D Smr -1 -+ --
Skr Skr 
for r = 1,2,3 such that C:;t 0 and D:;t 0 
.......... (36) 
.......... (37) 
If ar = Sir/ Skr E {1,j,-I,-j} and Pr = Smr/ Smr E {1,j,-I,-j} this can be rewritten as: 
c + D = 1 
Cd2 + DfJ2 = 1 
Cd3 + DfJ3 = 1 
Rewriting: 
.......... (38) 
Substituting back gives us the condition for a set of three codewords to be 
unacceptable: 
.......... (39) 
83 
Thus each of the products on the right-hand side must be E {l,j,-l,-j} so the whole of 
the right-hand side must be E {2,-2,1+j,-1-j,1-j,j-l,O,-1-j,2j,-2j}, and the left-hand 
side must be E {4,2,O,-2,-4,3+j,3-j,2+2j,2-2j,1+3j,1-3j,-1+3j,-1-3j,4j,-4j,2j,-2j}. 
The only common elements are {2,-2,O,2j,-2j}. This implies U2 = U3 or ~2 = ~3 . 
corresponding to C = 0 or D = 0 or both are zero and thus all are trivial. This proves 
the set of codewords consisting of three QPSK symbols with the first symbol fixed is 
an allowed code set for CV -CCMA. 
The two examples described show that the previously-stated restriction 
on codewords of linear independence is not required in order for CV -CCMA to work. 
The combined codewords are shown to be able to be individually decoded. Figure 5.4 
illustrates in a block diagram form the CV -CCMA system with two transmitters and 
one receiver. The processes that have been described can be pictured fitting into the 
component blocks of the diagram. 
84 
Audio 
input 
1 
Audio 
.. input 
2 
Audio 
output 
1 
Audio 
output 
2 
Speech 
digitisation 
Sb 
Speech 
digitisation 
Digital I 
analogue 
Digital I 
analogue 
Buffer + 
Coder 1 
Sb 
Bufter+ 
Coder 2 
Floating pOint 
digital signal 
processor 
r---~ Sa 
Sync 
Generation 
r---~ Sb 
Pulse 
shaper 
Radio 
Sa 
-----, 
MAC I 
1 
I 
I 
I 
L.._ _I 
Pulse 
shaper 
Radio 
frequency 
Modulation 
Precision 
analogue Radio 
digital frequency 
conversion de-modulation 
filtering etc. 
Sa 
Sa 
Sb 
Figure 5.4 Block diagram of CV-CCMA demonstrator 
85 
5.6 Convolutional coding 
Convolutional coding is a channel-coding technique that is mainly used where high 
rates of error correction are required, for example with satellites / mobiles etc., due to 
the slow degradation in these environments. It is essentially discrete convolution, that 
is the superposition of appropriately weighted and delayed unit response sequences. 
If y = output, x = input and h = unit response: 
i 
Y = Lxkhi - k 
k=O 
.......... (40) 
At the transmitter, bits are added into the output stream and the output becomes 
restricted to follow a certain pattern of changes. At the receiver, if there is a deviation 
from this sequence of changes (i.e. errors are received) then, in the maximum 
likelihood demodulator, the receiver can back-track and restore the original sequence 
of changes, usually called the 'maximum likelihood' path. The CV-CCMA system 
could use a 'version' of convolutional coding, or more particularly the reception 
process, to help cope with error propagation problems by storing the received signals 
and comparing the sequence with a known good sequence, and / or using the sequence 
to predict where the next codeword will be. 
Convolutional encoders are simple to implement. The data to be 
encoded is loaded into a shift register, and the number of stages in the shift register is 
called K, the constraint length of the code. The shift register is tapped at various 
points depending on the code polynomials used, and these sets of taps are chosen 
according to the coding rate required. This is usually expressed as a fraction; for 
example R = Yz means one bit is shifted into the register per encoder cycle and two is 
the number of code polynomials generated. The sets of tapped data from the shift 
registers are then modulo two added, that is they are fed through an exclusive OR gate 
and the output of the gate forms one of the encoder outputs. Now at the receiver / 
86 
decoder the data is compared to locally generated 'hypotheses'. Then, because of the 
additional information encoded we can generate a metric which gives an estimate of 
the closeness of fit of the received data to the calculated metric. This may be just a 
single value or may consist of a number of computed metrics, with the final decoded 
data being selected from the nearest solution to a valid sequence. The decoder 
investigates all the possible user data sequences and picks the closest match; certain 
sequences cannot belong to the 'maximum likelihood' path and are therefore 
discarded. The complexity of the decoder increases exponentially with the constraint 
length K so there is obviously a trade-off between better noise performance with the 
larger length codes and processing power. NASA implemented a R = Y2 , K = 7 
encoder on the Voyager probes, a typical compromise. 
A variation of the technique is being used in an experimental radio fast 
packet (asynchronous transfer mode) system at Cable and Wireless PLC. The whole 
packet of information is buffered and the most likely path selected before passing the 
data on. Systems that run very high error rates use convolution coding together with 
different types of block coding to cope with large burst errors. The simple hardware 
implementation is also a major advantage. 
Some time was spent considering the possibility of adapting 
convolutional coding into the CV-CCMA system. This would be done by adding 
circuitry to generate the correct sequences of codewords at the encoders. The receiver 
processor would have the correct sequences programmed and sufficient memory to 
operate correctly. The system could also be altered to operate in a 'cell' mode: with 
the cell size kept small the decoder could operate on the entire cell before a 
good/bad/best effort decision is made. If a CV -CCMA network were to be constructed 
then this more secure channel could be overlaid onto the system and used as a 
87 
network manager channel. However, a substantial increase in processing would be 
required but this is another very interesting area and hopefully will be pursued in the 
future. 
Implementation over a CV -CCMA link would be beneficial because it 
would make the system more robust under the influence of channel impairments . 
• 
However, apart from simulation data (see Chapter 6), it was not possible to test the 
convolutional coding implementation due to processor limitations. The Texas DSP 
integrated circuit was running at near capacity with the standard decode functions 
already implemented. 
Chapter 6 details the actual implementation of the system at the 
University of Warwick and Cable and Wireless PLC. 
88 
6 IMPLEMENTATION 
6.1 General implementation 
Working on the implementation of the CV-CCMA system has occupied a sizeable 
amount of time. A number of novel circuit techniques have been developed, 
particularly regarding the codeword generation/recovery and synchronisation of the 
CV -CCMA system. The implementation of the digital signal processor and its 
associated interfacing circuitry followed a more conventional approach. In an effort to 
keep costs down, wherever possible integrated circuits were used that were intended 
for the GSM (global system mobile) market; no custom or semi-custom integrated 
circuits were used and standard two-layer printed circuit boards were used in all of the 
designs. 
The design of the circuits involved using computer-aided design 
techniques. Spice (simulation program integrated circuit emphasis) was used as a 
general purpose nodal circuit simulation tool. Compact was used to simulate the radio 
frequency circuits, in particular the high-frequency components and the modulators. 
The programs and results are included in Appendix 4. The board designs (which had 
to be surface-mounted due to the high frequencies involved) were generated using 
Protei software, an advanced electronic circuit design package, and produced using 
lithographic equipment at Cable and Wireless PLC. Protei was also used to simulate 
the combinational logic used in the transmitters. It was decided at an early stage to try 
to produce 'functional units' that could be used as component parts in the receivers, 
the transmitters and the control circuitry throughout the entire CV -CCMA system. It 
was envisaged that this approach would keep costs down, and this has proved to be 
the case. 
89 
6.1.2 System control 
A number of the integrated circuits that were investigated for possible use in the 
system had high-speed control circuitry built into them, to enable the control of circuit 
operation by a microprocessor or other controlling system. This is particularly useful 
with dynamic circuits, such as frequency synthesisers that require rapid changes in 
output frequency, or to shut down amplifiers in order to conserve battery power. It 
.. was decided to design each of the 'functional units' so as to be controllable via a 
standard bus. The interconnecting bus chosen was a Philips development bus called 
the I2C bus or inter-integrated circuit bus. The eC bus was introduced approximately 
twenty years ago and is a high-speed serial bus designed for implementation in silicon 
and aimed at reducing the chip area used by conventional high-speed parallel bus 
architectures. The bus is specified to bi-directional data rates of 400 Kb/s but can 
function well up to -0.5 Mb/s. The higher speeds were not required in the CV -CCMA 
system, but would be required if the bus was to be used to control the other 
component parts of a radio 'node'. The bus has only three connections: clock, data 
and ground. Each device on the bus has its own unique address and collision detection 
and arbitration is done in software. Each device connected to the bus is software-
addressable and there is a master-slave relationship between devices connected to the 
bus at all times. A master is a device which initiates a data transfer on the bus and 
generates the clock signals to correctly time the data transfer. The device addressed is 
the slave. There are unique conditions that signify the start (clock = high, data = high 
to low) and stop (clock = high, data = low to high). 
All data on the bus is in a serial format with 8-bit bytes. The address is 
transmitted first by the master, the slave responds with an acknowledge and then data 
"transfer can take place. There is no limit to data length so a timer was incorporated in 
90 
the programming software to prevent lock-up problems. There is no limit as to 
minimum operating speed so a program was written to output serial data from the 
printer port of a portable personal computer, and an interface designed to buffer the 
signals, level shift and prevent contention on the bus. The program, circuit diagram 
and operating notes are included in Appendix 5 and a reduced circuit is reproduced in 
Figure 6.1. The interface and software have been used in a number of test functions, 
and specifically used in the CV-CCMA to program the memory chips containing the 
test patterns that are used at initial set-up. 
At this stage Philips Electronics offered reduced-cost integrated 
circuits, so it was decided to use these components in the radio frequency circuitry as 
well as the synthesiser. 
The integrated circuits were all interconnected using the I2C bus and 
some memory chips were also controlled via the bus, so this meant frequency and 
codeword shifting could all be done from a portable computer. The computer 
interface worked well and was used in the bench-test implementations. However, to 
make the system more portable a new control circuit was designed and made. The 
new circuit was stand-alone and used a PCF8584 chip specifically for the control of 
the r2c bus. This proved to be very difficult to program as the in-built memory could 
only be written to a few times before it locked up. The required programming pulses 
were of a very short duration and quite high voltage. 
Thus, the circuit was re-designed around a more general purpose 
controller chip, the 87C750, which proved to be easier to program, was cheaper and 
more reliable. The circuit diagram (simplified) is reproduced in Figure 6.2 and the full 
circuit and control software is included in Appendix 6. 
91 
Toshiba PC 
10Im 
Type GO return 12 
to start program Q.) 
~ 
... 
0 
>. 17 ~ 
I 
II') 
~ 
15 
1: 
0 
c.. 2 ~ 9 
'C 
~ 
11 
Figure 6.1 12C bus PC interface 
(Pin out for 74LSOS) 
SDA 
SCL 
-.... 
,... 
-
7 
8 
87C750 
13 
A-D 
20 
10 
.1.!1-
40MHz T 
:1-12 
-'--
-
Philips DS-7S0 development system 
programming, assembling, 
de-bugging etc. 
6 
Figure 6.2 12C bus micro controller interface 
5 
+5V 
10 KQ (x5) 
-0 
SCL serial clock 
SDA serial data 
o V Ground 
Analogue 
output 
g 
p:: 
~ 
0 
U 
~ 
~ 
0 
E-< 
til 
~ 
U 
el 
u 
92 
The only additional complexity and expense was the requirement to use the Philips 
DS750 development system to program the controller. This prevented contentions 
arising between the bus driver integrated circuits. Using the storage oscilloscope to 
view the data lines showed a number of handshake sequences which were not detailed 
in the literature. These sequences were required by the controller chip to make sure it 
• 
was operating in the correct mode. All of the sequences were implemented with the 
DS750 eC driver software. 
6.1.3 Synthesisers 
The first stage in the design involved researching the current state-of-the-art 
synthesiser technology. It appeared that the small level of drift required for the system 
to operate could be achieved by independent synthesisers, as long as they were never 
turned off and were regularily recalibrated (every few months). This was deemed to 
be impractical in the field and so it would be necessary to recover timing and/or lock 
to a central source, for example the GPS (global positioning system) satellites. The 
synthesisers are an important component of the CV-CCMA system; they supply the 
control and timing signals for the transmitters/receivers and, once locked together, 
cannot be allowed to drift more than a bit period per symbol message. Theoretically 
only a very small amount of drift can be tolerated between transmitters and receivers. 
Hence one of the most expensive components in the CV -CCMA is the TCXO 
(temperature controlled crystal oscillator). This is used as a reference for all of the 
frequency-generating components within the system. The drift coefficients of the 
TCXOs are restricted to fractions of a part per million - annually. A number of 
synchronisation techniques were investigated, using clock-recovery schemes from 
pilot channels, etc. However, for speed of implementation the initial (X) models were 
93 
constructed usmg a hardwired central clock system, that is all the frequency-
generating circuits were locked to a single source via a coaxial cable. Once this 
system was working the other techniques were investigated. The initial 
synchronisation system, 'type 1', is shown in Figure 6.3. 
The first enhancement was a clock recovery scheme based on the 
'ethernet' system, called a 'type 2' system. This involved setting the CV-CCMA 
system up with a single timing master source, at a designated master node, with the 
rest of the nodes recovering timing from it, and being designated slave nodes. The 
initial timing sequence is then used to lock the synthesisers together. The master 
station will then continue to transmit bursts of timing synchronisation sequences at 
regular intervals. In a lightly loaded network this would be controlled by a timer, and, 
in a heavily loaded network during gaps in the transmission of data. The data flow 
across the network would be in a 'packet' format, ideally of length 53 bytes. This 
would enable the use of standard high-speed ATM integrated circuits, thus reducing 
costs. 
Some time was spent working on the implementation of the type 2 
timing system. All the nodes had to be converted to transceivers, with the 
transmit/receive function and the synthesiser master inputs controlled via the fc bus. 
This proved difficult to achieve with the simple controller, really requiring a fully 
compatible microprocessor to run the system as a background operation. Also, the 
'packets' of information andlor 'packets' of timing synchronisation needed to be 
identified with unique headers within the 'packet'. This proved difficult to implement. 
The SRTS (serial residual time stamp) system, as used in ATM, could not be 
translated to CV-CCMA due to the high CDV (cell delay variation) figures. A more 
"reliable detection process is required. In view of time constraints it was decided to 
94 
progress with the type 3 system, as the implementation is simpler. The type 2 system 
is sound in theory, but proved difficult to implement with the limited facilities 
available. The type 2 system is shown in Figure 6.4. 
The third enhancement to the synchronisation system involved setting 
up a dedicated synchronisation channel, running alongside the data channel. This 
system is called the 'type 3' system. The synthesisers used by the CV-CCMA are PLL 
(phase-locked loop) types that are referenced to a 10 MHz TCXO. In the type 3 
system, one node is designated a master, and at this node the 10 MHz signal is 
buffered, amplified and transmitted. All other nodes are then designated slave nodes 
and are fitted with a radio receiver to recover the 10 MHz signal. This recovered 10 
MHz signal is then used to phase-lock the slave nodes to the master node. The 
receivers used are hybrid devices, modified to operate at 10 MHz and originally used 
for the remote control of garage doors etc. The system was implemented into the 
demonstrator and worked satisfactorily. The type 3 synchronisation system is shown 
in Figure 6.5. 
However, further development of· the system is required. The 
frequency of the timing channel needs to be moved closer to the data channel 
frequency. This would mean that the two signals would suffer similar impairments 
(loss/phase shift) between the transmitter and receiver. Also, to ensure the system can 
be used legally, the frequency needs to be moved into a licenced band. The 
synchronisation circuitry could be re-designed to fit within a 'timing' module. This 
module could be shielded from external interference with a small Faraday cage. Some 
equalisation could be applied at the transmitters, see Chapter 8 for discussion of this. 
Results obtained with the type 3 system are reproduced in Chapter 6. 
95 
Transmitter 1 
PLL 
Radio frequency 
output 1 
_ TCXO 
(master) 
Receiver 
PLL 
TCXO 
(slave) 
" r----' 
'MAC :-' ___ ~ ... 
Transmitter 2 
L ____ J .... 
A~ Combined 
PLL 
TCXO 
(slave) 
signal 
Radio frequency 
output 2 
PLL J TCXO (slave) 
75 ohm low-loss cable 
Figure 6.3 Type 1 synthesiser timing 
Transceiver 1 
Main 
PLL processing 
TCXO 
-(master) ...... 
~r 
- -
'-
r --, 
, MAC , ,~ 
Transceiver 3 
I Main ~I processing 
---.. I 
... I 
Transceiver 2 synchronisation 
L ____ J 
Notes: 
recovery 
TCXO PLL (slave) 
Data is formed into packets, fixed length (53 bytes) comprising 
header (5 bytes) for synchronisation / addressing and data (48 bytes) 
Timing packets are generated by master node. Decodingof sync/data 
by standard header error checksum in byte 5 of the header. 
Figure 6.4 Type 2 synthesiser timing 
o/p 1 
... 
..... 
o/p 2 
_ .... 
96 
Transmitter 1 
PLL 
Transmitter 2 
PLL 
TCXo 
save 
RF receiver 
Radio frequency 
output 1 
r----' 
I MAC 
I I 
------ Combined 
signal 
Radio frequency 
output 2 
Figure 6.5 Type 3 synthesiser timing 
Receiver 
PLL 
It was decided to construct a phase-locked loop (PLL) type synthesiser . 
as this would give the best option for good frequency stability due to the outputs 
being referenced to a standard very high-stability TCXO. This would also mean that 
the output frequency could be quickly and easily altered, simply by changing the 
division ratio in the feedback loop. With the advent of high-speed, cheap logic 
circuitry and modular radio frequency components the phase-locked loop has become 
the standard circuit used for frequency generation. The basic PLL consists of three 
components connected in a feedback configuration, a voltage-controlled oscillator 
(YCO), a phase detector and a low-pass filter. Figure 6.6 shows the block diagram of 
the basic PLL. 
The YCO produces a periodic output waveform, not necessarily 
sinusoidal, the frequency of which may be varied about some free-running frequency, 
97 
Fo , according to the value of the applied voltage Va. The phase detector produces an 
output Vb that is a function of the phase difference between the input signal Vin and 
the VCO output signal Vo The filtered signal Va, which will be a slowly varying DC 
wavefonn due to the low-pass filter, is the control signal that is used to control the 
output frequency of the VCO. The output of the VCO will effectively be the same as 
the input signal, and if the input signal varies, 'the VCO will track the changes; in this 
state the PLL is locked to the input wavefonn. 
In order to vary the output frequency of the VCO, without varying the 
input or reference frequency, it is necessary to alter the frequency of the feedback 
signal, and/or the frequency ofthe reference input to the phase comparator. As long as 
the phase comparison is still valid, that is the two wavefonns are harmonically related 
in some way, the phase lock will be preserved and the output frequency will be stable. 
This technique is used in the CV -CCMA synthesisers; both the feedback signal and 
the reference signal are fed to programmable dividers which can be set to match the 
signals together. Figure 6.7 illustrates the CV-CCMA synthesiser operation in block-
diagram fonnat. The Philips phase detector used in the circuit not only outputs pulses 
of current to charge the capacitor in the low-pass filter up, but also sinks current, thus 
enabling the voltage on the input to the VCO to be rapidly altered. 
A number of integrated circuits were obtained and tested against one 
another in tenns of ease of construction, spectral purity, drift and ease of 
programming. A Philips UMAI014 synthesiser chip came out ahead and was built 
into a breadboard with the other components. The integrated circuit operates using the 
.. 
Philips 12C (inter-integrated circuit) patented system; this restricted the choice of the 
other components used in the design. [116]. The integrated circuit is manufactured in 
bipolar technology but has a power-down mode for saving power in an idle state. 
98 
.... 
... 
Temperature 
controlled 
crystal 
oscillator 
Voltage-
Vb Low-pass Va Phase controlled _ .... .... _ ..... filter detector - III" oscillator 
~~ 
Figure 6.6 Basic phase locked loop 
Programmable 
divider 
I 
Phase 
detector 
Low-pass 
filter 
Programmable 
'---, divider 
L __ _ 
-. 
I 
___ ...1 
12CCONTROL 
FROM PC 
Fig. 6.7 Synthesiser block diagram (simplified) 
III" 
Voltage 
controlled 
oscillator 
Buffer 
OUTPUT 
99 
The circuit is designed to operate with a channel spacing of 5 to 100 KHz and radio 
frequency input of 50 to 1100 MHz. The circuit diagram reproduced later in this 
chapter illustrates in block-diagram fonn the internal working of the chip. Of note is 
the dead-zone eliminator, which was a problem with earlier PLL type synthesisers, 
caused when the synthesiser was in a locked state, with effectively no, or constant, 
output from the comparator to the filter. This level may have drifted a small amount, 
causing phase noise and some output drift. The Philips integrated circuit eliminates 
the problem by having switched charge pump rates and a cyclical output when locked. 
6.1.4 Synthesiser implementation 
The first synthesiser that was designed and built (synthesiser 1) follows standard 
practice and uses a voltage-controlled oscillator (VeO) to generate the radio 
frequency (RF) output. The RF carrier is centred on 90 MHz and some output is fed 
. back to the dividers before being phase-compared with the reference oscillator 
(operating at 10 MHz). The result of this comparison is a series of pulses, a series of 
pulse 'sinks', or a tri-state high impedance. These are fed to a charge pump, the output 
of which is filtered and amplified before being fed back to drive the voltage-
controlled oscillator. 
A veo has an output frequency proportional to the voltage on its drive 
inputs, and the charge pump circuitry effectively charges up or discharges a capacitor 
in a low-pass filter circuit, that is, it controls the output frequency of the yeo. This 
gives a feedback circuit with a stable output phase locked to the frequency reference. 
The feedback circuitry was designed with a switch-timing constant of 15 ms and the 
veo chosen was a mini circuits POS 1 00 device, chosen for availability and 4.5 
MHzIV sweep over the range of frequencies of interest, i.e. initially 45 - 100 MHz. 
100 
The second synthesiser, which was used to generate the higher frequencies (up to 1.1 
GHz) necessary for the down-conversion stages, used a POS 1025 VCO and was 
locked to the first synthesiser by using the same TCXO. 
A high-stability buffer amplifier was chosen for the loop 
filter/amplifier. A summary of the calculations for the components is given below. A 
complete set of derivations and calculations is included in Appendix 7. 
Loop bandwidth = 3 / switching time .......... (41) 
= 200Hz 
Loop time constant Tl = 1/ ffin2 X T2 .......... (42) 
T2 = 1 / cosq> - tanq> / ffin .......... (43) 
Summarising Appendix 7 : 
Cl = T2x(C3 + C1) = 1.47xl0-7 . 
Tl 
C3 = (C3 + CI) - CI = 7.123xlO-7 
R2 = Tl / C3 = 2695.49 
.......... (44) 
The design was based on an active second-order filter/amplifier and 
was simulated with Spice before being constructed. Some 'tweaking' of the filter 
values was required due to the loading effect of the VCO. 
The next calculation required was for the divide ratios. There are two 
sets of dividers in the Philips system, the reference dividers (also called the swallow 
101 
dividers), which divide the reference input so that the frequency is compatible with 
the divided main sample frequency. Both are fed in as 4 x 8 bit data streams via the 
eC bus; there is no default with the Philips system. If the divide ratios are not fed in 
correctly the synthesiser will not lock; therefore, this is required to be the first activity 
on the fc bus. The integrated circuit provides an output indicating an out-of-Iock 
condition which is wired up to a LED, this is fed back to the PC and used to indicate 
that results may not be valid due to oscillator drift. The initial fill routine is 
reproduced in Table 6.1. 
Data Hex. Function 
00 Null string indicates start 
00 of valid data 
C4 Write to main synth 
18 Null 
06 Swallow divide ratio 
87 Main divide ratio 
00 Fill register C 
00 Fill register D 
Table 6.1 Synthesiser I2C programming data 
It was found to be necessary to output a number of complete null strings before the 
UMAI014 would accept programming. This is because when the fc bus is not active 
the chip switches to a power-save mode, as it assumes the batteries in the mobile 
102 
phone are going flat, and therefore need to be 'woken up'. In a production unit 
background scans would be output every 0.25 s, preventing this problem. However, 
the synthesiser unit consumes an order of magnitude less power than the signal 
processor. Therefore, as low power consumption is not an essential requirement an 
easier solution would be to implement the circuit using an earlier integrated circuit 
without the power controls. Chapter 7 contains the output strings necessary for the 
synthesisers to lock at the correct frequency for the system to operate; also included 
are the lock-up times for the two synthesisers. 
Quite a few problems were encountered with the synthesiser, many of 
which were traced to the Mini Circuits VCO not having a linear characteristic over the 
range of output frequencies being used, causing some instability in the control loop. 
This showed up as slow lock and jitter on initial set-up and after frequency changes. 
The solution would be a better quality VCO and in a production unit this would have 
to be done. However due to cost restraints the POS unit was kept in service with the 
loop filter adjusted manually until fast lock was achieved. This was fine in the bench 
units as they were not required to change frequency, just to lock up quickly when 
commanded to do so via the eC bus. 
Synthesiser 1 produces an output of 0 dBm into 50 n and this is 
buffered by a wideband amplifier (OMA type) before it is connected to other 
circuitry. The feedback signal is taken prior to the buffer stage, before additional 
phase shifts that could be problematic. With the loop filter parameters as previously 
described the synthesiser produces a nice 'clean' output. A copy of the spectrum 
analyser trace is reproduced in Figure 6.8. The basic circuit diagram of the synthesiser 
is reproduced in Figure 6.9. The I2C circuitry is shown in Figures 6.10 and 6.11. The 
surface-mount PCB is shown in Figure 6.12. 
103 
N E 
::CO 
:~ 1) 
Q rJ 
fJ ('~ Q • 
• 0) 
o 
0) 
~ 
~ 
~ 
.. - ...... "! ..... ' .. _. ~ ' .. ... C 
: ' -~ , 
.. , -... , .... .. . -.. - ··-r-·"··· ...... !' .. ..... . ..... - t · · 
.. +- .. - ..... . . .. 0' ~: . ,. _ •• _ •• ' 
. ~ . 
... -:'! . 
... . ... ~"'; 
.it 
·'f.-1 , ;.t . 
- .•.. --..... . . - .. - - ' - 1" .. - .•.. - .. ~ . ~ .... - . - . . .... . _ .. , .. ....... - - •• ---• • --- · ~ · ·· · · · :": t·l 
. , . __ ....:5 : -< 
T : fu 
r .... " .. _ ... _ ,,_, _._ ••• ,: .. _ _ .-.~C~ ..... •.. _ ... N.'_~ .. . V. _ .. .... ,. ... . _ ... _!, ..... .. . _ ... .. . " ___ .. '", .. . _.. ,"  ? 
: -')- . 
. -;;?~ ... : 
1 . ..--=-- . 
..... -. ' • .• j ..... .. . -. - "'- .•.. _ .. _ . ..... \ . .,. M O· • •••• •· .. •• • " ••• • , .. ~ .. ... . . , ' , " , _ .. . . - .- -4tf. , ~ •. ~"":i= •.. ••. ., 
1 -=~ . 
-~;; 
--- ~ .. - .-- -..;- " .,,- ..... - ,--"" 
....... -
N 
J: 
X 
---_ ...... . . 
.... .- .- - .. - .. -.------,----.----.-~ .. .. .. _ ..... .. '" •. . t .... .. ........ . "".'._ ...... ....... _ ... _ 4.., __ ...... ___ .r __ ~_::...-~ ... :- -: ~~~ .. ::: ._ .. _ , • 
0) 
0) 
0) 
• -t 
(Y) 
r.J 
E 
!P 
1] 
~I. .. 
bl 
rr: 
~ 
< ~11 
c.. 
. - - - r · .... ··--·-· ~ 
l _ .. __ .... ;.. .. .. ...... , .... . ... - .. . 
e ~ -, 
<.) r.J :'.D 
_ I ..... 'tJ 
" "-"'- '- .. 
. - .... -
,. - ........ .. _ .... . 
-"', .,,~ 
_ ... ... ... ~ ...... ............. .. :1£~-.. -.. ... : 
.. ~
.~
.) , 
. ~ . 
.. .. ..-..... .... . _. _ ... ......... ...... -.. ..... ?~ 
~ : 
." . -·i~ : N 
-I.. : N J: 
... ",,;;:> ~ J: X 
"$ : :~ 
,,"- , ~ 
.i. ._ .. . _ . .. ...... : .. ~,i ~ g~: 
;!,;.- • • m 
.. ?- . r~ 
_,,"; 0> U) 
•. - ..... t .. - .. . . " ...... .. _ 4 - .. - . ~J 0:: ~ 
m u 0.: ILl 
U) t.L. n:: f.-
o 
<DU 
:.?=Ul 
Figure 6.8 Syntbesiser output spectrum 
104 
Regulated power 
supply unit 
+5V 
UMAI014 
To frequency counter 
Alarm indication 
1--....... --0 +sv 
Serial clOCk} . Programming 
information 
Serial data 
veo 
lOOnF 
+SV 
RF AMPLIFIER 
OM2064 
RFC 
RFC 
+12V 
sonOUTPUT 
Figure 6.9 CV-CCMA syntbesiser circuit diagram (reduced) 
105 
Figure 6.10 Inter-integrated circuit bus loading circuitry 
Output bytes are set by the switches on the bottom of the board and then output on the 
eC by pressing the adjacent push button. 
Figure 6.11 PC386 J2C Bus loading circuitry + TMS320C50 filters 
The PC is used to output eC data, to control the TMS320C50 DSPs and to program 
the EPROMs that contain the test patterns. 
106 
PCB TOP VIEW 
PCB BOTTOM VIEW 
Figure 6.12 Synthesiser surface-mount printed circuit board 
107 
6.2 CV -CCMA transmitter implementation 
The transmitters were designed and built in three stages. The first stage involved a 
literature search and a comparison of the various integrated circuits available for 
speech digitisation and modulation/transmission at the frequencies required by the 
system. The decision was reduced to a cost basis and because Maxim were offering 
free devices, and Philips reduced-price devices, these manufacturers became the two 
main suppliers. The second stage was to design and test the operation of the circuit 
using one of the simulation packages available, Spice (general analogue), ProteI 
(digital), Compact (radio frequency) and Z-match (radio frequency). The third stage 
involved the construction of a breadboard or printed circuit board and then testing the 
operation of the circuit. It was decided to go for circuitry that was electrically and 
functionally robust; hence speech digitisation and recovery were implemented by a 
system of Delta modulation/de-modulation. A functional block diagram of the first 
transmitter is reproduced in Figure 6.13. 
6.2.1 Input stages 
An electrical representation of the audio speech signal was input to the transmitter 
from a standard microphone via a band-limiting filter. This restricted the frequencies 
of the incoming audio in preparation for the next stage and ensures the Nyquist 
criteria are met. The filter is a standard pulse code modulation (PCM) 
telecommunications filter with a 300-3400 Hz bandwidth. 
The amplitude variations present in the speech are now controlled by 
using a VOGAD (voice-operated gain adjustable device). The VOGAD is a high-gain 
. differential amplifier circuit that gives a fairly constant analogue output in response to 
108 
-o \0 
o \lI 
-()-O i 
Band 
Audio ~ pass Input Filter 
I-W W H H H ~~ Mod VOGAD DELTA CODER ______ 
MOD. ~ I Q IMax. 
' 'R 2450 
Buffer 
1---4 Filter 
Amplify 
Frequency 
~ Conversion 
Fig. 6.13 
CV-CCMA TRANSMITTER 
FUNCTIONAL 
• I •• Filter 
EPROM 
Pattern 
Generator 
t 
• 45c30 + Mar 8 
Phase-locked 
Oscillator ~ TcXo 
1.------11 ! 0-L---1 -r---T. i-.l UMA1014 On-board L..-_..J1 Reference I2CBus 
L-...f Divider 
Circuitry 
~ 
........ 
To Master 
Receiver ~ Oscillator 
90MHz 
•• 
Auto-
program 
generation 
P.C. 
J2C Bus Monitor 
and Control 
a large dynamic range of inputs, that is the typical range of inputs may have a 50 dB 
amplitude range - too large for the modulator to digitise. The attack time of the 
VOGAD is set to a small value «1 ms) to ensure there is a limited delay introduced 
into the processed audio signal. Any delay, especially a variable delay, would cause 
problems with the rest of the system. The output of the VOGAD is now fed to the 
digitisation stages. Figure 6.14 illustrates the audio stages of the first demonstrator 
transmitter. The transmitters were constructed with a buffer stage in parallel with the 
analogue input stages. The buffer is a FIFO (first-in first-out) type and enables the 
connection of external digital TTL level signals. This would be useful for the 
connection of external test equipment used for generating particular line codes and for 
the testing of different signalling systems. There is also a pattern-generator circuit 
built into the transmitter breadboards. This provides for a test pattern, which is used to 
ensure that the transmitters and receivers are synchronised; it does not connect to the 
buffers. The simplified circuit is reproduced in Figure 6.15. 
6.2.2 Speech digitisation 
The speech digitisation process was designed around a standard Delta modulator. The 
lower bit rate schemes (code excited linear predictive, etc.) were deemed to require 
too much processing and would introduce delays which would cause problems in the 
system. Delta modulation is a relatively simple, efficient method of digitising an 
analogue signal, usually speech. The name derives from the mathematical delta or 
derivative, indicating that the output is a 'differential' function of the input, that is 
changes in the input signal are coded rather than specific levels. To increase dynamic 
range, modem systems adopt techniques of varying the digitisation depending on the 
.. type of signal present. 
110 
Vcc 
2.2uF 
3 
4 
CVSD 9 
MC34115 
13 
7 6 15 
OIP 
Figure 6.14 CV-CCMA Demonstrator transmit audio stages 
Counter 
Auto reset 
-
...... 
D +-
inputs 
rn 
..... 
O'~ 
.& 
::s 
0 
EPROM 
-
...... 
.... 
-
.. 
.... 
Clock 
-Recovery ...... 
To level shifters 
and I and Q inputs 
modulator 
I2C control 
From Main 
Synthesiser 
Figure 6.15 CV-CCMA Demonstrator pattern generator circuit 
Encode 
Decode 
"t:j 
Cl) 
rn ~ 
'':= c.J 
..... Cl) 
.!:P Cl) 
o ~ 
111 
In the CV -CCMA it was decided to opt for a CVSD (continuously variable slope 
delta-modulation) system. This gave the best compromise between cost and speech 
quality. Relatively good speech quality can be obtained at an output data rate of 16 
Kb/s and intelligible speech can be obtained at data rates as low as 4 Kb/s. A Delta 
modulator is a sampled data system employing a negative feedback loop. A 
comparator senses whether or not the instantaneous level of the analogue voice is 
greater or less than the feedback signal. If the voice input is greater than the feedback 
signal the output is a one, if it is less the output is a zero. The comparator output is 
clocked by a flip-flop to produce a continuous non-return to zero (NRZ) data stream. 
The feedback signal is set up so the integrator ramps up and down to produce an 
approximation of the speech waveform, which, when filtered at the demodulator, 
reproduces the original speech. Figure 6.16 illustrates the basic Delta modulator. 
The standard Delta modulator cannot track large amplitude high-
frequency signals with its fixed integrator; neither will it resolve small amplitude 
changes which are less than the height of the integrator ramp during one clock period. 
The CV -CCMA requires better quality than this so the CVSD technique was 
implemented. The simple Delta modulator has a second integrator built in with 
additional logic and an analogue mUltiplier to become a CVSD. The circuit of the 
CVSD is reproduced in Figure 6.17. Under small input signals the second integrator, 
known as the syllabic filter, has no input, and circuit function is identical to the basic 
delta modulator, except the multiplier is biased to output quite small ramp amplitudes 
giving good resolution for the smaller signals. A larger signal input is characterised by 
consecutive strings of' 1 's or 'O's in the data as the integrator attempts to track the 
input. The logic input to the syllabic filter actuates whenever three or more 
"consecutive 'O's or '1 's are present in the data. When this happens, the syllabic filter 
112 
output starts to build up, increasing the multiplier gain and passing larger amplitude 
ramps to the comparator, enabling the system to track the larger signal. Up to a limit, 
the more consecutive 'l's or 'D's generated, the larger the ramp amplitude. Since the 
larger signals increase the negative feedback of the modulator and the forward gain of 
the demodulator, companding takes place. A syllabic filter of between four and about 
ten milliseconds was found to give the optimum reproduction of speech (even with an 
industrial English Midland accent, which is accentuated by the distinctive 'nasal' 
sound of Delta modulation). 
Standard telecommunication type digitisation (e.g. ADPCM) will be 
interfaced at a later date, when time and funds allow. In a production device the low-
bit rate processing could be implemented as a sub-routine performed by the signal 
processor, with the necessary rate adaptation transmitted as unique codes. Good 
quality speech can now be communicated at very low digital bit rates, but the systems 
involve prediction techniques with the addition of variable delay; this would cause 
problems with synchronisation of the CV -CCMA system and so Delta modulation 
was used in both the prototype units. The first breadboard versions of the Delta 
modulator used a discrete implementation, which created problems due to the filters 
drifting. A Harris military integrated circuit was then used. This worked very well and 
had security coding options built in which could be implemented in the future. The 
manufacturers of the integrated circuit have been bought out and have now stopped 
production. The modulation/demodulation circuitry could be implemented in a semi-
custom device, together with the rest of the transmitter coding logic; this upgrade is 
presently underway. 
113 
Mic. 
Low 
pass 
filter 
Transmitter 
Ck QI-T-~ 
D 
Figure 6.16 Basic Delta modulator I demodulator 
M· Low IC. 
pass 
filter 
v+ 
Divided clock from 
main synthesiser 
Clock 
Shift 
Receiver 
Clock 
Figure 6.17 Continuously variable slope Delta modulator I demodulator 
low 
114 
6.2.3 Implementation 
The second part of the design involved actually developing the circuit with simulation 
using Spice to check the viability of the designs. Appreciable effort was put into 
working out how the systems could be synchronised together and a number of unique 
circuit schemes were developed. The Spice exercise (see Appendix 4) indicated that 
the audio amplifiers would give sufficient dynamic range for the modulators to work 
correctly. 
The VOGAD output is fed to the input of the Delta modulator, which 
samples at a clock frequency derived from the central clock. This is implemented with 
standard divider integrated circuits which are fed from the feedback signal at the 
synthesiser. The Delta modulator is a CVSD (continuously variable slope delta-
modulator) type; this gives an adequate speech quality at low bit rates. This is 
achieved by adjusting the slope of the feedback integrator when strings of continuous 
'1 's or 'O's are being fed back from the output. This gives a closer approximation for 
speech with rapid amplitude changes and is reproduced with better clarity after re-
integration. 
The main problem with Delta modulators is due to the integrators built 
into the circuit. If a very low signal, that is no audio or only quiet background noise, is 
fed into the modulator the integrator will ramp up (akin to charging a capacitor) and 
then discharge. This causes a large popping at the receiver audio output and the 
receiver can lock up when in this state. To get around this problem in the CV -CCMA 
there is a level detector built in; if an input signal falls below a certain level for a 
certain time, a 'quieting' pattern is output. This causes the receiver's Delta modulator 
to mute its audio output and prevent the 'popping'. The output mute function is also 
_, connected to the 'out of lock' indication on the synthesiser, preventing noise on start-
115 
up and when out of lock. The quieting pattern is very similar to the pattern transmitted 
at start-up to synchronise the transmitters and receivers, this is actually an advantage 
as the speaker is muted when the system is initially trying to synchronise itself. Refer 
to the circuit diagram of the audio stages, which were built onto a separate board, 
reproduced in Figure 6.14. 
The Delta modulator output is fed into a buffer and then into the 
codeword generator. The codeword generator consists of standard combinational logic 
circuitry built onto a large breadboard with the codewords selected by dual in-line 
(DIL) switches. The QPSK implementation has eight parallel-to-serial converters, the 
outputs of which are logically OR'd together and then fed to the buffer/level shifter 
and then to the In phase and Quaternary inputs of the modulator. The parallel-to-serial 
converters are arranged in pairs and each pair is selected by its associated two bits of 
input, i.e. 00, 01, 10 or 11. The required output sequence is programmed into the 
buffer by selecting the correct DIL switch and pushing the load button. The 
programmed output sequence will continue to be output as long as power is on and 
the converter pair is selected. To change the output the board needs to be powered 
down and the switches reset; this will lose synchronisation and the circuitry needs 
improving to stop this problem. The bit and symbol timing pulses are generated by 
interconnected flip-flops that are slaved to a Harris timing generator integrated circuit, 
which is itself slaved to the divide circuits fed from the main synthesiser. A simplified 
codeword-generation circuit is reproduced in Figure 6.18 and the full circuit is 
reproduced in Appendix 8. The codeword generator also outputs a 'word-valid' pulse 
which is used to frame each codeword. The timing for the word-valid generator is also 
derived from the dividers that feed the modulator. 
116 
-
-~ 
Timing signal 
to Deltamod I 
Pattern gen. 
.... ~----I 
Sync. 
recovery --.....,. 
From master 
sync. source 
Figure 6.18 Transmitter codeword generation 
N.B. For complete circuit diagram refer to Appendix 8 
OV +5V 
o I I 1 
Codeword '1 '1 ---~ All converters. 
Select T T 
8 bit serial- parallel converter A I~_ ..... 
8 bit serial- parallel converter I---
'\ 
-\ 
I 
8 bit serial- parallel converter B 
I 2 
8 bit serial- parallel converter H-
8 bit serial- parallel converter C 
'\ Q 
8 bit serial- parallel converter 
-c::... 
8 bit serial- parallel converter D 
8 bit serial- parallel converter ~ 
Output clock ------' 
Alongside the circuitry used to digitise and code the speech waveform, 
on a separate breadboard, is an erasable programmable read-only memory (EPROM) 
code generator which is used to generate the initial synchronisation sequence of 
codewords. This can also be used to generate test patterns, by operating a simple 
push-button selector switch on the board, and used to check the operation of an 
already-synchronised system. The EPROM circuitry consists of a Harris timing 
generator integrated circuit, slaved to the main synthesiser via the divider integrated 
circuits. The output of the Harris integrated circuit is squared up with a flip-flop and 
fed into a binary counter set for auto reset. The parallel outputs of the counter are fed 
to the least significant address lines of the EPROM; thus the various memory 
locations of the EPROM are cycled through in sequence. The outputs of the EPROM 
are level-shifted and fed to the I and Q inputs of the modulator. The EPROM is 
programmed, using proprietary software and interface, via the large computer visible 
in the laboratory photographs, Figure 6.11. 
The codeword-generation circuitry is an ideal candidate for inclusion 
in a standard logic gate array, which would make an interesting project and would 
reduce the size of the circuitry and improve the reliability of the system. The large 
breadboards, with many connections between the integrated circuits, are the main 
cause of the CV-CCMA's current reliability problems. The pattern-generation 
circuitry could also be included in a gate array, also simplifying implementation. 
6.2.4 Transmit filters 
The generated codewords are output from the buffer, to a level shifter and then to the 
I (in-phase) and Q (quaternary phase) inputs of the MAXIM modulator. Level shifting 
.. is required because the 5 V combinational logic code generator is required to interface 
118 
with the 3 V modulator, which can only tolerate a maximum voltage of 1.35 V on its 
inputs. The pulse-shaping filters (matched) would be connected at this point; 
however, in the initial test set-up they were not required and were hard-wire bypassed. 
All of the filters were connected in the later implementations. One reason for this 
increase in complexity was to try and reduce the criticality of the synchronisation of 
the system. The results obtained are described later in Chapter 7. The filters would 
need to be implemented in a commercial radio, in order to reduce the bandwidth of 
the modulated carrier. If the pulses were fed in directly the rapid changes between 
states would increase substantially the bandwidth requirement of the system; there is a 
good derivation of this in [117]. An approximation to the root raised cosine shape 
gave satisfactory results. Note that the first type 1 synchronisation transmit spectrum 
plots in Chapter 7 are taken without the transmit filters being connected in circuit; this 
gives the spectra the 'wideband' plot shown. 
Some time was spent implementing different filters using a pair of 
Texas TMS320C50 digital signal processor development boards. This is a small 
project in its own right and in order to reduce the construction time it was decided to 
use standard code to implement the filters, obtained from the Texas Instruments ftp 
website, a summary is copied in Appendix 9. It was found that the Texas code 
produced the most reliable results. Various other sites were investigated, and a 
number of the code-generation programs written in the standard DSP textbooks were 
also tried, but produced some very cumbersome code that did not work very well. 
A lot of useful code was developed using the Texas development 
boards in order to implement different filters. Figure 6.19 illustrates the filter 
implementation using two Texas TMS320C50 fixed-point digital signal processor 
.. development boards as implemented on the test set-up. Figure 6.20 illustrates the 
119 
typical pulse-shaping curves used In modem digital telecommunications and 
summarises their properties. It was originally planned to use differential QPSK 
modulation together with square root raised cosine pulse shaping at the transmitter' 
with a matching square root raised cosine filter at the input of the receiver; thus when 
combined together the overall response is of a raised cosine shape. The phase change 
values could be Gray-coded (or similar) to ensure the minimum change of phase 
_ between states, thus reducing the bandwidth of the transmitted waveform. 
The baseband filters have linear phase and a nominal square root raised 
cosine frequency response of the form: 
IH(r~ = {~~0.5(1-sin(7l"(2f -1)/2a»} 
f ~(1-a)/2T 
1-a / 2T ~ f ~ 1 + a / 2T 
f~l+a/2T 
.......... (45) 
where T is the symbol period and a. is the roll off factor, 0.35 in Tx 1 and 0.5 in Tx2. 
A 20 tap FIR (finite impulse response) filter was implemented using 
the Texas TMS320C50 DSK development board. Tap coefficients are stored in the 
program memory, the same coefficients being used for the in-phase and the 
quadrature channels. The transmit filter was implemented using one of the circular 
buffers of the TMS320C50 with an interpolation factor of four, reducing the number 
of multiplications required by a factor of four. The five I delays are immediately 
followed by the five Q delays in the internal dual-access ~. 
120 
JUL 
• 
Delta 
modulator ~ 
JUL 
JUL 
Codeword 
generation -. 
-. 
TMS320C50 
Digital signal 
processor 
FIR20tap 
4.8 Kb data 
Signal 
... 
processmg ....... 
Figure 6.19 Pulse shape filtering 
, 
Modulator 
-. 
~ 
" 
Radio 
frequency 
Rx .-
filter 
N.B. Timing I frequency conversion and RF filtering not shown for clarity 
,. -- - ---, 
, 
Square pulse 
Shaped pulse 
Rectangular 
pulse 
Raised Cos spectra 
Figure 6.20 Typical pulse shapes I spectra 
121 
The MADS and MADD (multiply and accumulate with dynamic address) instructions 
are used to simplify the process. In the receiver the matching baseband filter is 
implemented using similar code but without the interpolation. Code is reproduced in 
Appendix 9. The filters worked well but the additional delays introduced caused 
problems. The system now comprised six digital signal processors, which were all 
critical to the operation of the system and so needed to be carefully implemented. To 
reduce the complexity a simple bypass was implemented to get the system working. 
This comprised a hardwire switch to lock out the operation of the filters. Further work 
is required on the filters; due to time constraints this had to be assigned a lower 
priority and will be worked on when time allows. 
6.2.5 Radio frequency modulation 
The conditioned data baseband signal, at 7.2 Kb/s in the first test system, is now fed 
into the radio frequency stages of the transmitter. Initially, this was the MAXIM 
standard QPSK modulator. Within the MAXIM modulator, circuitry is designed to 
minimise spurious feedback; the internal oscillator is set to twice the IF (intennediate 
frequency) or output frequency. The modulator gives sideband rejection of 38 dB, 
which is very good and adequate for the CV -CCMA system. A fairly large input 
signal (+2 dBm at 90 MHz) was required to override the internal free-running 
oscillator and lock the system to the synthesiser. This may cause problems in a 
production unit and another modulator requiring less drive, and hence less leakage, 
less mixing products and therefore blocked channels, would be preferable. However, 
as the MAXIM units were free they were screened properly and made to work. The 
MAXIM integrated circuit contains a prescale Idivider and this only gives an output 
-, when the input levels are within specification to run the circuit. This output is taken as 
122 
an indication of the correct operation of the modulator, and is fed back to the 
frequency counter as a check. The modulated signal is fed out as a differential pair, at 
a low level. A summary of the modulator specification is included in Appendix 10. 
The rest of the transmit circuitry is conventional in design. The output of the 
modulator is filtered by a standard 45 MHz centre frequency, 300 KHz bandwidth 
crystal-type filter in order to remove any unwanted product frequencies. It is then 
amplified by a Philips NE5219 and a Mini-Circuits MAR-8, giving an output power 
of+10 dBm into a 50 n load. This is sufficient power to free-transmit approximately 
half a mile, with external aerials. Circuits of the modulator and amplifier are shown in 
Figure 6.21. The frequency up-converters are disconnected in the test set-up. 
Complete program listings are included in the Appendices. 
6.2.6 Discussion 
One of the main problems with the CV -CCMA transmitters was a tendency to 'take-
off, producing unwanted radio frequency outputs and causing the amplifiers to 
overheat and shut down. This seemed prevalent when operating with a common code 
set, and was caused by certain mixer/modulator product frequencies being passed to 
the amplifiers and hence causing some instability. Tweaking the filters reduced the 
effects. 
Initially, to check the operation of the system, it was decided to operate 
with known g values between the transmitters and receiver. A number of possible 
techniques were studied and the best solution was thought to be the transmission of a 
training sequence at the start of transmission. In the breadboard implementation the 
transmitters and receivers are locked together, effectively hardwired, with attenuators 
"connected between the transmitters and the receivers. On initial start - up these 
123 
.... 
tv 
.j:>. 
Data 
m 
Modulator 
QPSK 
PSKorDQPSK 
MAXIM 2450 
elk ... 1 ( 
Filter 
45U30 
-><-
..-........... 
~
'4~2 2 -=- 7 
Divider Output 
First stage 
amplification 
NE5219 
L.-.---.-..I' 2 
Figure 6.21 Transmitter radio frequency stages 
Frequency Power 
up converter amplifier 
HP3760 I (linear) 
MAR8 
900MHz 
..-,c, 
~ 
-::-
attenuators are set to zero attenuation and zero phase shift, and then one at zero and 
the other at O.5+jO. The system requires a test pattern to be transmitted before 
information transfer can take place. This is achieved by programming a test pattern 
into an EPROM . This memory circuit is also controlled by the eC bus so it can be 
switched in and out by the controlling computer as required. On receipt of this test 
• 
transmission the receiver locks to the test pattern and, when valid decoded data 
appears at the receiver, the transmitter can then switch to encoded speech or data. This 
is done manually in the bench set-ups but it has been found that a very short sequence 
is all that is required to synchronise the two systems. Therefore a simple timer would 
do for synchronisation at power-up. In a production model the situation is somewhat 
different and in a mobile radio situation the g value would be constantly varying. This 
requires a fast lock up (if a signal is present) or, if no signal is present, slows down the 
effective scan until a signal is captured. To increase dynamic range the g value could 
be fed from an AGC circuit (automatic gain control) in the receiver, derived from the 
signal processor and some additional hardware. This section of the CV -CCMA still 
requires some development, and possibly some research into other methods (CDMA 
adopts a two-way power adjusting method to prevent similar problems, but increases 
the circuit complexity greatly). 
The circuitry designed to be used in the CV -CCMA system is only at 
an 'X' (experimental) model state. Development work is required to sort out 
outstanding problems; some of these were known before but others have come to light 
during the research. See Chapter 8 for more details. Figure 6.22 shows the codeword 
generator boards and contains the circuitry for clock recovery and system 
synchronisation, used to time the generated output patterns with the rest of the system. 
125 
Figure 6.22 Codeword-generator boards (foreground) 
Test pattern generator boards (background) 
Figure 6.23 Two transmitters and data load circuitry 
126 
The board on the left of the photograph also contains one Delta modulator and 
demodulator, together with an output buffer. Codeword selection is by the DIL 
switches visible on the breadboards. There are eight sets of switches, one for each I 
and Q input for each of the four phase states of the QPSK modulation format. The 
test-pattern generator board also contains clock-recovery circuitry and the two 
EPROMs used to generate the patterns are clearly visible. 
The photograph illustrates that the associated circuitry necessary for 
the system to run, in the prototype system is quite complicated, so the amount of 
general wiring on the breadboards is fairly substantial. As previously mentioned, this 
part of the circuit is ideally suited to implementation in a semi-custom integrated 
circuit and this is planned for the future. 
Figure 6.23 is a photograph of the two transmitters set up in the 
laboratory at Warwick, where some of the interconnecting wiring is removed for 
clarity. The blue breadboard between the transmitters contains buffer circuitry and 
clock dividers and the blue breadboard in the foreground is the receiver I1Q buffer. 
The Maxim development board is visible in the diecast metal box. The box was found 
to be necessary in order to keep interference levels to a minimum. 
127 
6.3 Receiver implementation 
The design of the receiver followed conventional digital radio design procedures. In 
order to generate the various frequencies that were required the same synthesiser was 
used in the receiver as in the transmitter. Also, as with the transmitter, the output 
frequency was controlled from a Toshiba computer, via the eC bus. This necessitated 
the implementation of additional combinational circuitry, as the address of the 
dividerlsynthesiser integrated circuit is only one bit address selectable. The oscillator 
select pin on the integrated circuit was used, giving the option of two synthesisers on the 
same bus. However, there are a minimum of three synthesisers required, and different 
address lines were used to control the different synthesisers. Hence the additional wiring 
was implemented from the start. 
The receiver follows the superheterodyne arrangement, which is a circuit 
technique developed in the 1930s to improve the performance of radio receivers [118], 
especially the early radar receivers. In a superheterodyne receiver the incoming signal is 
mixed with a locally generated signal called a local oscillator (LO).The output of the 
mixer contains sum and difference frequencies as well as the original frequencies. If the 
local oscillator is made variable the receiver can tune to different input frequencies 
whilst the same frequency (called the intermediate frequency - IF ) is output from the 
mixer. This gives the advantage of being able to amplify, detect and decode at lower 
frequencies with fixed filters that can have much better characteristics than variable 
filters, at much lower cost. The end result is a receiver that is sensitive and selective. 
The receiver was designed from the outset to be a single conversion type, where only 
one intermediate frequency is employed for the bulk of the amplification. An IF of 45 
"MHz was chosen because of the restricted range of frequencies available with the 
128 
Maxim integrated circuits used. III a production unit the performance of the receiver 
would be improved by changing to a multi-conversion type superheterodyne. This 
would produce an improved image rejection and self-blocking performance. However, 
this requires board and circuit redesign and so was not attempted on the initial test set-
up. The AGC circuitry built into the first-stage amplifiers is disabled but this would 
• 
need to be implemented on a production unit. On the test model the RF amplifier was 
.. simply switched in or out of circuit depending upon whether it was required or not. 
Refer to [118] for a good analysis of the trade-offs involved in receiver design. 
6.3.1 Front-end circuitry 
In the CV -CCMA system the incoming signal is first amplified by an amplifier that is 
designed for optimum noise performance, rather than maximum gain. Any noise 
generated at this stage will be amplified by the later stages of the receiver and degrade 
the performance of the whole receiver by a proportionally large amount. This first stage 
is called the low-noise block (LNB), and was designed in strip line using computer 
program Compact to check the design. The amplifier is a single-stage low- noise HEMT 
(high electron mobility transistor) M9SFET (metal oxide semiconductor field effect 
transistor) device. The circuit was constructed using standard-quality circuit board and 
worked satisfactorily when tested, giving a power gain of approximately 15 dB at 850 
MHz with a noise factor of 1.5 dB. The noise factor is the ratio of the signal to noise at 
the input to the signal to noise at the output, and thus gives a good indication of the 
noise that has been added by the stage. A copy of the circuit, the simulation results and 
the actual results are included in Appendix 12 and Figure 6.24 illustrates the stripline 
layout of the amplifier. A production unit would require the low-noise block to be 
" constructed on a more professional substrate. This is needed for better consistency of 
129 
-5 
3.74 
I 
2.5 
4.4 
1.r 
4 
5 ~ 
1.19 
1.5 1.5 
5 
2.5 
4 
3.76 
5 
1.07 
2.5 
2.2 
5 
2 
1.15 
1.19 
.. Figure 6.24 Low-noise block stripline layout (not to scale all dimensions in mm) 
130 
pennittivity and improved dimensional stability; an aluminalberyllia based material 
would probably be best suited. This was not implemented on the test set-up due to cost 
restraints. The low-noise block amplifier was constructed on a separate board and 
housed within the diecast metal box containing the rest of the receiver components; this 
was done to reduce interference and noise problems. A separate low-noise block 
amplifier would not be required on a production unit because the more up-to-date 
mobile phone integrated circuit sets now incorporate most of the radio frequency stages 
within the main integrated circuit. 
6.3.2 Second stage and mixer 
The front-end second stage incorporated another radio frequency amplifier and used a 
Philips GSM integrated circuit (NE600) as its first-stage amplifier and frequency down 
converter. The low-noise amplifier selected had a 2 dB noise figure at 900 MHz with 16 
dB of gain. Although these figures are not state of the art the integrated circuit has 
excellent stability with automatic compensation for temperature drift. These parameters 
are more critical for the correct operation of the CV-CCMA system, rather than absolute 
values of gain and intercept point. The integrated circuit also has automatic overload 
capability: the on-board amplifier is bypassed and the input is fed straight to the mixer, 
which switches to mode 2, giving a +26 dBm third intercept. All the ports are designed 
to operate into 50 n, which makes interfacing easier. The mixing frequencies were 
generated by another Philips synthesiser integrated circuit (UMA 1014) which was 
programmed up via the 12C bus with data fill generated by a computer. (Refer back to 
Section 6.1 for a more detailed description of the design of the synthesiser). The 
generated intennediate frequency signal (45 MHz) was then fed via a filter and Philips 
., standard digital IF strip into the demodulator section of a MAXIM 2450 integrated 
131 
circuit. Crystal filters were used, the 45U30 having a 3 dB bandwidth of 30 KHz. This 
worked fine with minimum shift type modulation schemes, and a broader bandwidth 
unit (300 KHz) was used in the QPSK implementation. Better quality filters would be 
needed in a production unit. The digital intermediate frequency amplifier used was a 
NE5209, which has gain to 1.5 GHz with an 850 MHz bandwidth. The gain is 
controlled via a single input between ~ and 1 V, giving over 60 dB of control range. The 
_ automatic gain control implemented in the IF stages of the receiver is very basic in 
operation. The automatic gain control voltage, required for a production unit, could be 
generated by a sub-routine of the signal processor. This ensures the input values to the 
analogue-to-digital converter are always within specification and the g values can be 
simply calculated. The circuitry is fairly standard so development of existing circuits 
rather than new circuit design is all that is required. In the breadboards that were 
constructed for the demonstrator CV -CCMA the front-end stages are built onto the 
surface-mount circuit boards. However, in the first test set~up the circuitry is bypassed, 
so the receiver input is connected directly to the 45 MHz generated by the transmitters. 
The IF is fed directly into the demodulator which contains a single-ended to differential 
converter. Gilbert cell multipliers are used to mix the IF signal with the quadrature local 
oscillator signal (90 MHz input, then divide by two in order to prevent spurious 
feedback). Baseband in-phase and quadrature signals are then output and amplified by 
the baseband amplifiers (21 dB). The I and Q outputs are further amplified and fed to 
the input of the analogue-to-digital converter. A Burr-Brown precision device was 
chosen, again mainly on cost considerations rather than performance criteria. The later 
implementations of the test set-up incorporated additional filtering. This comprised two 
Texas Instruments fixed-point DSPs connected in the I and Q lines, after the Maxim 
integrated circuit. They are connected to act as root-raised cosine filters, matching the 
132 
transmit filter. The design was based on a MODEM (modulator demodulator) design 
published by Texas Instruments [119]. The system uses 4 interrupts in a 20 tap FIR 
(finite impulse response) filter. To increase the sampling rate 3 zero pads are inserted in 
between each of the 5 channel data stream symbols. This means that 15 of the 
mUltiplications in each convolution are by zero, so that only 5 coefficients are required 
to be mUltiplied. Consult [119] for a detailed explanation of operation and assembler 
code used. Functional block diagrams of the receiver and a reduced circuit diagram are 
shown in Figures 6.25 and 6.26. 
6.3.3 Analogue-to-digital conversion 
The CV -CCMA system requires a fast and accurate conversion of the recovered 
baseband signal to a digital format. Some effort was put into investigating the many 
different types of analogue-to-digital (A-D) converters currently available in order to 
choose the best device. The decision was taken to go for a Burr-Brown [120] DSPI02 
device, again mainly on cost parameters. The DSP102 is a two-channel A-D and is 
configured to sample its two inputs and concatenate the two 16-bit outputs as a 32-bit 
serial word, which is read into a buffer on the serial port of the signal processor. This is 
a major advantage because with the low-cost Texas Instruments devices only one serial 
port is built into the DSP. This means a single port can be directly interfaced with a dual 
A-D converter without resorting to store and shift buffering. 
The DSPI02 consists of two independent I8-bit sampling analogue-to-
digital converters, which can sample up to 200 KHz. The sample clock is derived from 
the master synthesiser, but the signal processor generates the output clock. The buffer is 
only 32 bits so it is essential that the processor can 'read' the samples faster than the 
-. receiver can generate them. The DSP102 is a fast successive approximation device with 
133 
\ V 
Amp. 
filter 
down 
-
converter 
12C 
Bus 
-
~ - I I ~ Bufferlbypass 
I I 
I I Analogue 
I TMS320C50 
-B-20 tap FIR to De r-- digital filter 
Mod converter I"-
245 
-------. Burr-Brown 
DSPI02 r--TMS320C50 
-A-r-- 20 tap FIR filter 
r-
! [t PLL TCXO 
- Vma 
1014 Timing 
recovery Automatic 
programmmg 
generating 
I 90 MHz (type 
" 
1) 
To transmitter 
Figure 6.25 CV -CCMA Receiver functional 
Notes: 
• Front end is standard GSM mobile phone chip set 
• Auto-Program is standard PC with interface to drive the 12C bus 
• De-modulator is Maxim device designed for mobile low power 
• Buffer-amps are a matched pair op-amps 
!50MHZ 
TMS320C31 
Digital 
signal 
processor 
~, 
" 
o/pA o/pB 
To PC or Delta 
Demodulator 
• Burr-Brown precision A-D has concatenated outputs (2 x 16 bit) and 
interfaces with the Texas signal processor via the serial port. 
• Data is clocked out of the A-D a sample in delay at a rate determined by 
the signal processor. There is limited buffering so it is important to keep 
synchronisation once obtained. 
134 
..... 
(..) 
Ul 
Input 
from 
LNB 
L.O. input 
from 
synth.(850 MHz) 
..I 
MAXIM 2450 
~T'~ 
T 
NE5209 
Receiver 1 
handset audio 
Receiver 2 
handset audio 
From synth.1 
200mV@ 
90 MHz 
Delta demodulator 1 
See Tx for circuit 
Delta demodulator 2 11-----1 
Buffer 
decode 
Figure 6.26 Receiver circuit (reduced) 
DSP filters 
DSP102 
TMS320C50DSK 
cr-o 1 ilp A 
TMS320C50DSK ~ 
~----11 C>' ~--~ 
'------tl C> 
Matched buffer 
amps 
So/p 
Clko/p 
ilpB 
ssf 
case 
Sout olp 
ClkXo Si/p 
ClkRo 
Eint3 
TMS320C31 
Clock i/p 
+5V 
+5V 
Start pulse 
all the required reference voltages generated internally. The sampling is done via a 
switched capacitor array inside the integrated circuit. It was found necessary to buffer 
the signals on the two inputs because, although the specified input impedance was 
quoted as approximately 1 KQ, in practice it was found to be less than half this. This 
caused problems with loading of the IF chain. The buffers were also set up to level-shift 
the signals, as the full input range of the A-D is -2.75 V to +2.75 V. In the BPSK 
receiver the range is restricted to the positive section only; the QPSK system uses the 
full range of input voltages in order to obtain the better resolution required. It was 
important to match the performance of the two buffers closely, and it was decided to 
select the Burr-Brown devices as the two amplifiers are built onto the same silicon and 
hence have identical temperature and drift characteristics. 
Figure 6.27 illustrates the range of inputs, voltages and the digital 
outputs generated by the analogue-to-digital converter. Note that the minimum step size 
shown is not applicable to the CV -CCMA as the two least significant bits are treated as 
noise, with no valid data on them. The A-D chosen has an 18-bit resolution but 16 bits 
are chosen for ease of interfacing with the DSP. Figure 6.28 is a simplified diagram of 
the analogue-to-digital board. The analogue-to-digital converter, buffers and associated 
circuitry were constructed on a separate multi-layer printed circuit board; this was to try 
to keep noise problems to a minimum. It was found that the lower two bits of converted 
output were just noise, so concatenating the output to two 16-bit streams lost no useful 
information. The initial codeword set-up sequence provides a framing pulse to provide a 
start reference point for the signal processor to enable differentiation between symbols. 
In the initial implementation this start pulse is hard-wired via some combinational logic 
between the transmitter and the receiver. In the later bench set-up the start pulse is 
derived from the training sequence, but only when using fully independent and unique 
136 
lFFFF 
00001 
Digital 
output 
I 
I 
-2.75 V I 
00000 L - - - , - - - - - - - - - - -.---,---1. - ..J - - - - ____ ..J - -
I 
+2.749979 V 
3FFFF I ~ 
+20.98 J,lV 
Analogue input 
20000 OV 
Figure 6.27 Burr-Brown DSPI02 analogue input I digital output 
i/pA 
.75V i) +/- 2 
ii) +2.7 5V 
i/p B 
.75 V i) +/- 2 
ii) +2.7 5V 
Clock 1 
Clock 2 
C> VinA 
VinB 
Buffer filter 
matched 
amplifiers 
C> Conv 
j~ 
Conversion 
logic 
DSPl02 
XClk 
Sout 
Oscl 
~~ 
.-
~. 
.... 
--.. 
Clock 3 
To Delta 
demodulator 
N.B. Clock sl&2are 
master clock, 
DSPclock 
derived from 
clock 3 from 
Figure 6.28 Analogue-digital daughter board 
137 . 
code sets at the transmitters. The data is now temporarily stored in the output buffer of 
the analogue-to-digital converter ready to be output to the digital signal processor to be 
decoded. Note that the output of the analogue-to-digital converter is controlled by the 
digital signal processor and the input of the analogue-to-digital converter is controlled, 
that is timed, by a derived system clock. It is therefore essential that the digital signal 
processor can operate on the data be~ng fed to it faster than the analogue-to-digital 
converter can produce it. A feedback technique was triaIled, which slowed down the 
sampling rate of the analogue-to-digital converter when the digital signal processor was 
overloaded. This circuit created more problems than it cured and was dropped. The 
timing problems were fixed by careful programming in assembler language, the code 
generated by the 'c' compiler proving to be very cumbersome and too slow. 
6.3.4 Signal processor interface 
The interface with the signal processor was designed and built a number of times, and 
was eventually reduced in size to a single circuit board. The TMS320C30 digital signal 
processor has two serial input ports and on the breadboard models the I and Q inputs 
were fed directly into serial port 1 and serial port 2 respectively. The later 
implementations used the low-cost TMS320C31 which has only one serial port interface 
and necessitated the two outputs from the analogue-to-digital converter being 
concatenated. This was no problem with the Burr-Brown device but required major 
additional circuitry to be designed for use with the other analogue-digital devices tested 
(H-P, National and Analogue devices). 
An external interrupt line is used to provide the 'start' information, 
indicating the first burst of valid data will immediately follow. This is generated by 
.. combinational logic in the hard-wired type 1 system, and by receipt of the initial 
138 
synchronisation sequence in system types 2 and 3. Then the data is clocked into the 
signal processor from the analogue-to-digital converter buffer under the control of the 
signal processor using a clock derived from the DSP 50 MHz clock. This is the only 
clock in the system that is not synchronised to the master clock. The framing 
information is derived by the signal processor from the fIrst valid clock pulse, so it is 
vital that the fIrst pulse is correctly interpreted; if errors run continuously the system will 
reset itself and attempt to synchronise again. The later versions of the system attempted 
to use Viterbi-type coding and identifIers in the data streams and hence the frame timing 
was not required. This area of research is still ongoing and results will not be presented 
in this thesis. 
With no audio input to the transmitter the Delta modulator outputs a 
quieting pattern; this is in order to switch the audio off at the receiver and prevent 
'popping' as the integrators ramp to rail. This caused a few problems as the repetitive 
pattern was sometimes interpreted as start synchronisation so the next few bytes of data 
were lost, producing annoying gaps in the speech. The problem did not arise if the 
system (type 1) was transmitting data as there are no gaps in the traffIc. This is another 
development requiring further work before the system could be viable as a production 
unit. There are also recently announced analogue-to-digital converter integrated circuits 
aimed at the digital audio market from Texas Instruments that could be used with the 
signal processor and enable the 'glue' logic to be reduced. 
The various set-up routines for the registers, clocks, timers, etc., are 
reproduced in Appendix 13. Figure 6.29 illustrates the fIrst of the receivers (that 
worked), as set up in the laboratory at the University of Warwick. The computer display 
shows the recovered data and the disassembled code. The spectrum analyser shows the 
-, spectrum of the combined signal produced by the two transmitters with codesets 1 and 2 
139 
fed into them from the EPROM, that is linear-independent and unique 3-bit codewords. 
Figure 6.30 illustrates the two Texas Instruments TMS320C50 fixed-
point digital signal processor development boards, which were used as filters in the 
receiver, connected into the in-phase and the quadrature feeds from the intennediate 
frequency board. They are not connected into the system 1 set-up (as shown in Figure 
6.29). The computer in the background is used to download code to the digital signal 
processors and to program the EPROMs with the test-pattern data used for 
synchronisation and testing. 
The receiver boards, viewed left to right, are: 
i) Timing recovery board (buffer removed) 
ii) Maxim demodulator board 
iii) Burr-Brown precision analogue-to-digital converter board 
iv) Texas Instruments DSP board. 
The next sub-section explains the operation and implementation of the 
software developed for the CV -CCMA system. 
140 
Figure 6.29 Receiver 1 in the laboratory at Warwick 
Figure 6.30 Receiver filter implementation 
141 
6.4 Software implementation 
6.4.1 Introduction 
A number of digital signal processors were investigated for possible use with the CV-
CCMA system. The choice was restricted to relatively few devices due to the unique 
nature of the system and the processing required. Firstly, the signal processor needed 
to be a floating-point device because of the very large differences in the signal 
strengths of received signals, especially in a mobile radio implementation. The Texas 
Instruments digital signal processor was fully floating-point compatible; although the 
floating-point system used by Texas is unique, the numbers are easily translated to 
fixed-point format and IEEE floating-point format. This made interfacing with other 
systems easier. The second consideration was processing power. The DSP needed to 
perform a minimum number of floating-point operations in order for the system to 
function. The processing power requirements are dependent on the software that is 
running, and a more detailed analysis is worked through later in this chapter. In the 
first instance, processing power of the order of five million floating-point operations 
per second gives an approximate minimum requirement. This takes into account an 
overhead for system management. The third consideration was cost, and on this score 
the Texas Instruments devices won easily. The Analogue Devices and the Hewlett 
Packard processors were shortlisted, but the Texas Instruments floating-point signal 
processor was chosen because it was also the easiest to interface with external 
circuitry. Also, development software was issued free by Texas Instruments and a 
number of development boards were available in the telecommunications laboratory 
at the University of Warwick. Cable and Wireless PLC also supplied a Texas 
" Instruments development system. This also helped to keep the costs down. 
142 
6.4.2 Software operations 
A number of operations needed to be carried out prior to running the main receiver 
decode software. The first operation that needed to be performed was the calculation 
of the I-S.K matrices (where I = identity matrix, S = codewords and P = pseudo-
inverse) Mathcad and Matlab programs were written to do this as it is very laborious 
to calculate pseudo-inverses by hand. A pseudo-inverse is the inverse of a non-square 
,matrix. The complete programs are reproduced in Appendix 2. A flowchart 
illustrating the process is reproduced in Figure 6.31. Shortened versions of the 
Mathcad programs, with results obtained for standard linear independent codewords 
(test pattern 1) with QPSK modulation and BPSK modulation (test pattern 2), are 
reproduced later in this section. 
When the pre-calculation program was run, two sets of output data 
were produced: a standard denary number array which was used in the simulation 
program and any rough calculation in case of errors; and a number array consisting of 
the results, the input combination giving rise to the set of results. Also, if required, the 
numbers could be output in Texas Instruments floating-point number format, ready to 
be input into the data array of the digital signal processor. These calculated results 
were loaded manually (via an assembly language array) into the signal processor 
memory. In a production device these would all be loaded into an EPROM and 
codeword selection achieved via a simple switch connected to the address lines. This 
would then access the pre-calculated matrices. These could be calculated on-line 
using a more powerful signal processor. Once loaded the signal processor was 
initialised, all the registers to be used were flushed and interrupts correctly primed and 
set-up. The various output strings required are reproduced in detail in Appendix 14 
and a summary of the set-up routine is reproduced in flowchart form in Figure 6.32. 
143 
Select codeword pair 
for operation 
" 
Transpose pair (row - column) 
" Change to complex conjugate 
(Hermitian matrix) 
" Multiply complex conjugate 
by original matrix 
" 
Calculate the inverse 
" 
Multiply inverse by Hermitian 
to obtain pseudo-inverse, convert 
to TI floating-point format olp 
" 
Check answer by multiplying 
result with original codeword 
pair; result should be the 
identity matrix ( I) 
Figure 6.31 Pseudo-inverse calculation flowchart 
144 
Power on and test memory (automatic) 
• Define names for the timers, interrupts and interrupt 
service routines, DMA if needed and locate at first free 
memory location. DSK warning LED should be green. 
" 
Set up transmit and receive interrupt vectors and mask 
globally before proceeding. 
" 
Load null data into the various control registers in 
the correct sequence. 
" 
Clear memory (working) by flushing out with 'O's 
" I Unmask all interrupts I 
" 
Initialise timers and control registers 
~r 
Ready to receive and decode data 
Figure 6.32 Digital signal processor initialisation flowchart 
145 
Also, at this stage, global control and receive/transmit timing were initialised. The 
stand-alone signal processor (TMS320C30) implementation required much more 
rigorous attention to detail in the programming, particularly in the set-up stages. The 
various registers all had to be initialised in the correct sequence. The development 
system, using the Texas TMS320C31, was far simpler to initialise due to the inclusion 
of a basic 'kernel' of code, ensuring that the processor was always correctly 
initialised. This was for operation with an on-board speech interface, and always 
performed at power-up and was easily selected from the personal computer during 
operation. 
To ensure correct system timing, both hardware and software interrupts 
were used to correctly time the data into and out of the system. The bench 
demonstrator system (types 1-3) included a set-up stage in which the two transmitter 
outputs are connected together and then fed to the receiver input. The attenuators and 
one phase shifter were set to zero phase shift with a fixed attenuation only (e.g. 1 + jO, 
jO = no phase shift). The other attenuator has fixed attenuation together with a fixed 
phase shift (e.g. 0.5 + jO.S). These values were then programmed into the DSP. The 
received values in this state were stored as the reference value to be used later when 
calculating g values. Some time was spent trying to develop a system which would 
enable the transmitters and receivers to synchronise on start-up. The problem is that if 
the combined states are uniquely definable they can be decoded, so long as we send a 
start code, as in asynchronous data systems, to enable correct resolution. However, if 
we do not know the gain and phase shift occurring between the transmitters and the 
receivers we cannot say that they are both transmitting and if not thus producing a 
false start point and incorrect resolution. This was the purpose of the synchronisation 
sequence run at the start of the test sessions, which also gave confidence in the 
146 
workings of all the component parts of the system before switching to the decode 
algorithm. 
Most of the theoretical work on MACs has assumed perfect 
synchronisation; however, this was without giving any ideas how to achieve it. Cover 
et at [52] did some interesting work and envisaged a 'quasi-synchronous' channel 
• 
sometimes called 'mild synchronisation' in which the decoders are kept m 
synchronisation with the encoders, but the encoders are allowed to slip out of 
synchronisation with each other by a restricted amount. They illustrated the effect on 
the capacity of the MAC; not suprisingly it dropped. 
In the practical implementation of the system it was found that with an 
initial training sequence ofpattems 101 - 010 - 101, etc., with known g values, the 
symbol synchronisation could be easily established. In the type 1 system the bit 
synchronisation is assumed to be perfect because the transmitters and receivers are all 
hardwired together. In the type 3 radio system a background timing channel is used, 
similar to the CDMA synchronisation channels (a CDMA forward link actually 
consists of four channel types, pilot, paging, synchronisation and traffic). This 
increases bandwidth usage, but all stations use the same synchronisation channel. The 
areas of timing and synchronisation are important to the operation of any multi-access 
system and further research and development is required in this area. The concept of a 
separate timing channel, with other functionality, has already been discussed in the 
theory section and this would appear to be the best way to progress. 
The final stages of the set-up procedure, for the type 3 system, 
comprised initialising and running the DSP filters (they are bypassed in the type 1 
system). These are pulse-shaping filters that were placed in the I and Q data streams. 
"The filters were implemented using Texas Instruments TMS320C50DSK 
147 
development systems, and using industry standard code. The perfonnance of the 
fixed-point digital signal processor is sufficient for this simple filter function. It is 
planned for the filter function to be incorporated into the main digital signal processor 
function as development progresses with the new digital signal processor. 
When the set-up stage was completed the receiver idled until the first 
interrupt was received. An EINT (external interrupt) was used to time the initial bit 
. and then RINT (receive interrupt) to time the symbols that were required to be loaded 
into the digital signal processor. The RINT is a simple load counter, so whatever 
infonnation was received, as a codeword, was loaded directly, and was then processed 
by the digital signal processor. The Burr-Brown analogue-to-digital converter had an 
output to indicate that the input was out of conversion range. This was used as an 
input to an interrupt line on the signal processor and then used to interrupt the decode 
and jump to the next set of inputs. This section of the programming caused a lot of 
problems; the DSP locked up and caused the receiver to crash. The problem was 
tracked down to the addresses that were used by the DSP to communicate with the 
PC. The code was nulled out in the prototypes. This could be reinstated quite easily, 
when de-bugged, and fitted into a production unit. 
The sampled receive vector was then loaded into memory, as' a 
floating-point number. Later versions of the software, designed to operate with the 
type 3 system, used a multiple-sample decode process. This was developed to reduce 
the systems timing sensitivity and involved 3 evenly-spaced samples being taken and 
resolved. The decoded output was taken as the agreement between 2 of the 3 samples, 
or if no agreement, then the output becomes the sample with the minimum distance to 
a valid combination. 
148 
There was some initial mathematical manipulation required because of 
the two numbers being concatenated and this was performed with a series of shift 
commands. The two floating-point numbers were then stored in the digital signal 
processor's precision registers. The multiplication of the pre-calculated matrices with 
the received vector was then performed as a series of nested loops. In the BPSK 
system this produced four floating-point numbers that were stored in the four 
precision registers, R4, R5, R6 and R7. The minimum value of Euclidean norm was 
then selected by a series of interconnected sub-routines. Included at the end of each 
sub-routine is a simple load and output which effectively transmits the recovered data 
back out of the serial data port. This was then clocked into a buffer and fed to the 
Delta demodulator or PC for decoding. The position of the bits in the buffer 
determines the destination address, for example in the two-transmitter set-up this is 
simply receiver output 1 or output 2. The program then jumped back to await the next 
interrupt, indicating the arrival of the next set of codewords. With a 40 ns instruction 
time the maximum symbol clock frequency worked out to approximately 21 KHz. 
This does not directly translate to data rate due to the synchronisation/coding 
procedure but is still equivalent to the capacity of current GSM data capability and 
was adequate for the test set-up. Due to the additional processing required, the multi-
sample system has a reduced data rate, results were obtained with rates up to 1.2 Kb/s, 
these are reproduced in Chapter 7. 
Digital signal processor systems are designed to perform floating-point 
multiplications very rapidly. A selection of commands are also available to perform 
mutiplication simultaneously with load and shift commands. A typical floating-point 
mUltiplication and floating-point addition only takes a single cycle, and these were 
widely used in the programming. The Euclidean norm calculation initially involved an 
149 
iterative process; this proved too long for the system to operate with 50 MHz 
processing. This was reduced to 50 cycles in order to reduce the processing time, and 
then further reduced to a simple self-multiplication, to remove any negative values. 
This did not cause any obvious loss of accuracy and meant that the TMS320C31 
development board could be used in the receiver. The latest DSP devices have orders 
of magnitude more processing power ~nd it is planned to rebuild the system using one 
of these devices. This will require re-programming, however the Texas digital signal 
processors are generic, this means a lot of the earlier work can easily be 'ported' onto 
the later devices. 
The complete receiver decode program listings, which were written in 
Texas Instruments assembler code, are included in Appendix 1. The 'C' programs that 
were written were found to compile to twice the size of the assembler programs. The 
performance, especially the sort routines, was found to be inferior. This was a 
weakness of the compiler; later versions of the compiler are reported to have much 
improved performance. 
Figure 6.33 illustrates, in a flowchart format, the operation of the 
overall receiver (type 1) system. Figure 6.34 illustrates the multi-sample (type 3) 
system, with the additional selection processes shown at the bottom of the diagram. 
Figure 6.35 illustrates the input store and multiplication routines, the multiplication 
routines were found to have the fastest resolution when calculated as nested loops, as 
shown in the diagram. Figure 6.36 illustrates the BPSK Euclidean norm minimum 
calculation, and Figure 6.37 the QPSK Euclidean norm minimum calculation, all are 
drawn in flowchart form. 
150 
Power-up, initialise processor, reset counters, clear 
buffers. Start TOD (time of day) 
" 
Store the pre-calculated I-SkPk matrices in memory. 
The QPSK system has 16 and the BPSK 8. Each 
matrix is a 3x3 array. 
,Ir 
Run synchronisation routine to ensure transmitters and 
receivers are phase locked. Select input option, fixed, 
unsigned, signed or floating point. (Depends on A-D) 
" 
Set interrupt and idle until next valid 
sync pulse. Set samples per sync. (1-3) 
" 
Input samples to precision register on valid sync pUlse. 
Perform arithmetic shift and store to separate the concatenated 
samples. Load into the precision registers. 
" 
Perform the complex multiplications as a series of nested 
loops. Store the results in the precision registers. Set loop 
counter if QPSK modulation. 
~, 
Compare the results, find the minimum and output 
the decoded data from the serial port. See Figures 
6.36 and 6.37. 
Figure 6.33 Digital signal processor receiver flowchart (type 1) 
151 
Power-up, initialise processor, reset counters, clear 
buffers. Start TOD (time of day) 
• Store the pre-calculated I-SkPk matrices in memory. 
The QPSK system has 16 and the BPSK 8. Each 
matrix is a 3x3 array. 
Run synchronisation routine to ensure transmitters and 
receivers are phase locked. Select input option, fixed, 
unsigned, signed or floating point. (Depends on A-D) 
• Set interrupt and idle until next valid 
sync pulse. Set samples per sync. = 3. 
" 
Input samples to precision register on valid sync pulse. 
Perform arithmetic shift and store to separate the concatenated 
samples. Load into the precision registers. 
" 
Perform the complex multiplications as a series of nested 
loops. Store the results in the precision registers. Set loop 
counter if QPSK modulation . 
• 
J 
. Compare the results, find the minimum and store. I 
-
I 
I I If 3 results agree output data. I ... ou 
I 
-
tput 
I 
I If 2 results agree output data. I .... ou I 
-
tput 
I 
I If no results agree then output I' .... result with minimum distance I 
-
ou tput 
.. 
..... 
Figure 6.34 Digital signal processor receiver flowchart (type 3) 
152 
Store pre-calculated values as floating-point array. 
Size = (3 x 3) x4 or x16. 
Await valid data on sync pulse. Store as received data array. 
Set up auxiliary registers to point,to data via loop counters. 
Set loop counter 1 = 3 
Set loop counter 2 = 2 
Load first set of numbers to be 
multiplied into precision registers 
Multiply together, store result in working register, 
auto-advance the pointer, decrement loop counter 2. 
N 
Store result in precision register. Set QPSK 
counter. Decrement loop counter 1. 
N 
Figure 6.35 Multiplication routines flowchart 
153 
Calculated results in precision registers R4,R5,R6,R7 
y 
R5 is smallest 
Output = 01 
R4 is smallest 
Output = 00 
R 7 is smalles 
Output = 11 
R6 is smallest 
Output = 10 
Return to main 
program 
Return to main 
program 
Return to main 
program 
Assembler Code 
LDI 
LDI 
LDI 
LDI 
CMPF 
CALLLT 
CALL 
B 
NEGl 
CALLGT 
CMPF 
CALLGT 
STI 
B 
NEG2 
CALLGT 
STI 
B 
NEG3 
CALLGT 
STI 
B 
NEG4 
B 
OOOOh,RO 
OOOlh,Rl 
OlOOh,R2 
lOOOh,R3 
RS,R4 
NEGl 
NEG2 
SLOOP 
CMPF ,R6,R4 
NEG2 
R7,R4 
NEG2 
RO,@DATAOP 
SLOOP 
CMPF,R6,RS 
NEG3 
Rl,@DATAOP 
SLOOP 
CMPF,R7,R6 
NEG4 
R2,@DATAOP 
SLOOP 
STI,R3,@DATAOP 
SLOOP 
Output when R4 contains smallest value 
Output when R5 contains smallest value 
Output when R6 contains smallest value 
Output when R7 contains smallest value 
Compare floating point 
Call subroutine Neg 1 if less than 
Call subroutine Neg 2 
Branch if floating overflow or underflow 
(RO) to serial port 
(Rl) to serial port 
(R2) to serial port 
(R3) to serial port 
Return to main program 
Figure 6.36 Sort minimum routine (BPSK) 
154 
-Vl 
Vl 
Calculated results in precision registers RI-R8 
RlMinimum 
output set 1 
output set 3 
R2Minimum 
output set 2 
output set 5 
output set 6 
R8Minimum 
) .1 output set 8 
R7Minimum 
output set 7 I ~ Return to start for second 
load and 
Return to start for second 
load and cycle 
Return to start for second 
load and cycle 
output set 4 
Return to start for second 
load and cycle 
Return to start for second 
load and cycle 
Return to start for second 
load and cycle 
Return to start for second 
load and cycle Figure 6.37 Sort minimum routine (QPSK) 
6.4.3 Software emulation of receiver (QPSK) 
combinational matrix calculations 
To illustrate the operation of the decoder software, the following is a shortened 
Mathcad program, which solves for the generalised inverse and checks the result. It 
works well with linearly independent sets of vectors. A more general solution and 
program is included in Appendix 2 which will work with all codewords. 
The Moore-Penrose generalised inverse or pseudo-inverse of a non-
square matrix can be found by multiplying the Hermitian result of the matrix with 
itself, then finding the inverse and multiplying again with the Hermitian matrix. A 
Hermitian matrix is simply the complex conjugate transpose of the original matrix. 
Note that ':=' is a Mathcad symbol which forces the program to solve the equation. 
Defining the codeword pairs, PI-P16: 
r -, ] t i -i ] [i -i ] t i -il.] PI = -{ ~ P2 =-j 1 P3 =-j jl P4 =-I 1 -1 1 -J 
fi -i] ri -i] ti -i] r -i] P5 =-j 1 P6=-j 1 P7=-j 1 P8=-j! 
-1 1 -1 -1 < -1 1 -1 -J 
[
-j -j] [-j -j] tj -J] [-j -j] P 9 = - } 1 P 10 = - } 1 P 11 = - } ! P 12 = - } ! 
J 1 J -1 J J J -J 
[
-j-;] [-j-i] [-j-i] [-j-j] P 13 = =} 1 P 14 = - j 1 P 15 = - } ! P 16 = - } ! 
J 1 -J -1 -J J -J -J 
Codewords were selected to match the type! implementation. The first symbol is the 
same for all transmitters, to aid recovery and to match the work done on codeword 
156 
selection, recorded in Chapter 5 of this thesis. Selecting a codeword combination for 
illustration: =PI 
[
- ~ - j 1 
= -J 1 
1 1 
Calculate PT, the transpose of PI: 
T P'F=PI 
PT=[~{ -~ ~] 
Calculate R, the complex conjugate: 
Calculate Z, the first product ; 
Then calculate Y, the Inverse: 
-1 y:=Z 
Z:=(R PI) 
z=L~j 2~j] 
[ 
0.75 -0.5- 0.25] 
Y= -0.5t- 0.25j 0.75 
Calculate WI, the Pseudo-inverse: 
WI = Y.R 
_ [0.25+ 0.25j -0.5+O.5j 0.25-0.25;1 
Wl- -0.25+0.25j 0.5-o.5j 0.25+0.25J 
Finally, check result: C = WI .PI 
= [~~] 
(press ctrl + 1) 
(press ") 
157 
This proves that WI is the general inverse of PI because the product is the 1 matrix. 
This program is run for the 16 sets of codeword combinations possible with the 
QPSK system. The program now calculates the I-SkPk matrices ready to be stored in 
the DSP. Define I, identity matrix: 
[
1 0 0] 
1:= 0 1 0 
001 
Define F as calculation of I-SkPk matrices: 
F :=1 - (PI.WI) 
Taking the first combination: 
[ 
0.5 0 O.5j ] 
Fl= 0 0 0 
-O.Sj 0 0.5 
The rest of the matrix array is calculated in a similar manner and 
loaded into the memory of the DSP. Table 6.2 is a summary of the results obtained. 
6.4.4 QPSK decode example 
As an example to test the results, and prove the viability of the system, two 
transmitters and one receiver are simulated with gl and g2 as below; Mathcad is used 
to check the mathematical integrity ofthe system. 
gl := 0.2 + 0.9j 
g2 := 0.8 + 0.6j 
Assuming combination codeword set 15 is transmitted, that is transmitter 1 transmits 
(-j 1 j) and transmitter 2 transmits (-j -j -j) : 
Calculate the Received vector = Rv 
158 
-VI 
\J:) 
1* 
-S* 
p 
· -j 
-j 
1 
· -j 
-j 
-1 
• 
-j 
-j 
+j 
· -j 
-j 
-j 
! 
-j 1 
r--
0.5 0 
0 0 
-0.5j 0 
'--
-
0.25 -0.25+ 0.25j 
-0.25+ 0.25j 0.5 
0.25 -0.25+ 0.25j 
-
-
0.5 0 
0 0 
-O.5j 0 
- . 
-
0.5 0 
0 0 
-O.5j 0 
-
1 -j 1 -1 -j 1 +j 
-
r--
-
r--
-
O.5j 0.25 -0.25+ 0.25j -0.25 0 0 0 
0 -0.25+ 0.25j 0.5 0.25+ 0.25j 0 0.5 0.5j 
0.5 -0.25 0.25- 0.25j 0.25 0 0.5j 0.5 
- - - - -
- - - - -
O.5j 0.5 0 -0.5j 1 -0.5+ 0.5j 0.5-0.5j 
-0.25+ 0.25j 0 0 0 -0.5+ 0.5j -O.5j O.5j 
0.25 O.5j 0 0.5 -0.5+0.5j - 0.5j 0.5j 
- - - - -
- - -
r--
-
O.5j 0 0 0 0.5 0 0.5 
0 0 0.5 0.5 0 0 0 
0.5 0 0.5 0.5 0.5 0 0.5 
- - -
L.-
-
- - - - -
O.5j 0.5 -0.25+ 0.25j -0.25-0.25j 0.25 -0.25+ 0.25j -0.25j 
0 -0.25- 0.25j 0.25 -0.25j -0.25- 0.25j 0.5 -0.25+0.25j 
0.5 -0.25+0.25j -0.25j 0.25 +0.25j -0.25-0.25j 0.25 
- - -" - -
Table 6.2 Codeword Test Set 1 - summary of I-S.P matrix calculations 
-j 1 -j 
r--
-
0.25 -0.25+ 0.25j -0.25 
-0.25+ 0.25j 0.5 0.25+ 0.25j 
-0.25 0.25- 0.25j 0.25 
L.-
-
r-- -
0 0 0 
0 0.5 -O.5j 
0 0.5j 0.5 
- -
- -
0.25 -0.25+ 0.25j 0.25 
-0.25-0.25j 0.5 0.25-0.25j 
-0.25 0.25+ 0.25j 0.25 
- -
- -
0.5 0 -0.5 
0 0 0 
-0.5 0 0.5 
'-
-
Rv := g1.( -j I j) + g2 . (-j -j -j) 
Rv := ( 1.5 - j 0.8 + O.lj -0.3 - 0.6j ) 
Now calculate the transpose of the receive vector: 
b
l
.
5
- j ~ RvT = 0.8+0.lj 
- 0.3 - 0.6j 
Now multiply the receive vector by the I-SkPk matrices from Table 6.2. 
RI :=F1.RvT 
[ 
1.05 -0 0.65 jJ RI= 
- 0.65 - 1.05 j 
IRq = 1.746 
R2 :=F2.RvT 
R2 = [ 0.225 + 0.075 j ] 
- 0.15 - 0.3 j 
- 0.225 - 0.075 j 
IR21 = 0.474 
R3 :=F3.RvT 
R3= [ 0 ] 0.7 - 0.1 j 
- 0.1 - 0.7 j 
R4 :=F4.RvT 
R4= [~:'~=~;;il 
- 0.5 - 0.25 j J 
·'IR41 = 1.118 
R5 :=F5.RvT 
[
0.075 - 0.22.5 j ] R5= 
- 0.3 + 0.15 J 
- 0.075 - 0.225 j 
IR51 = 0.474 
R6 :=F6.RvT 
[ 
0.45 - 0.35 JJ R6= 
0.35 + ~.45 j 
IR61 = 0.806 
R7 :=F1.RvT 
[ 
0.6- 0.8 j ] 
R7 = 0.1 + 0.7 j 
0.1 + 0.7 j 
IR71 = 1.414 
R8 :=F8.RvT 
R8 = [ 0.1 +~'2j] 
- 0.2 + 0.1 J 
IRSI = 0.316 
160 
R9 :=F9.RvT R13 :=F13.RvT 
R9= [ -1.2 + ~.1! ] R13 = [ 0.55+ ~.35 j ] 1.2 -1.1J - 0.55 - 0.35 j 
IR91 = 2.302 IR13 I = 0.922 
RIO := FI0.RvT R14 :=FI4.RvT 
RIO = [0.25 ~ 0.25! ] 
0.25 - 0.25 J 
R14 = [ 0.45 ~ 0.35] 
0.35 + 0.45 j 
IRI0 1= 0.5 IR141 = 0.806 
Rll :=Fl1.RvT R15 := FI5.RvT 
Rll = [-0.6~0.8j ] 
- 0.6 - 0.8j 
R15= DJ 
IRlll = 1.414 IRI51 = 0 
R12 := FI2.RvT R16 := FI6.RvT 
[ 0.3- 0.15j ] [0.9-0.2 j ] R12 = _ 0.45 - 0.15 j R16= 
_ 0.9
0
+ 0.2j - 0.15 - 0.3 j 
IR12 I = 0.671 /RI6/ = 1.304 
The matrices shown above illustrate how the minimum value is selected as the 
valid result corresponding to the original combination of codewords. The example 
shows the correct decoding of the transmitted codewords, i.e. transmitted set 15. 
Note that the example gives a flavour of the amount of processing required. 
161 
6.4.5 BPSK combinational matrix calculations 
The calculations for the BPSK combinational I-SkPk matrices are much simplified 
due to Mathcad having the ability to calculate a real-valued pseudo-inverse 
(general inverse) directly. The following is a shortened Mathcad program to solve 
for the generalised inverse and check the result. 
Using BPSK codeword pairs (PI-P4): 
Pl:=[-:l :] GI := geninv( PI) 
n:fl :] G2:= geninv( P2) 
1 -1 
n:fl :] G3:= geninv( P3) 
-1 I 
P4:fl :] G4:= geninv( P4) 
-1 -1 
Now define the identity matrix I : 
[0.25 - 0.5 0.25] Gl= 
0.25 0.5 0.25 
G2 = [0.5 - 0.25 0.25] 
0.5 0.25 - 0.25 
G3=[0.5 -0.25 -0.25] 
0.5 0.25 0.25 
G4= 
[
1 ° 0] 
1:= ° I ° 
001 
[0.25 -0.5 -0.25] 
0.25 0.5 - 0.25 
162 
FI:=/- (Pl'GI) F3:=/- (P3.G3) 
[
0.5 0 -0.5] 
FI= 0 0 0 
-0.5 0 0.5 
[
0 0 0] 
F3= 0 0.5 -0.5 
o -0.5 0.5 
n:=/- (P2'G2) F4:=I- (P4'G4) 
. [0 ° 0] 
n= 0 0.5 0.5 
o 0.5 0.5 
[
0.5 0 0.5] 
F4= 0 0 0 
0.5 0 0.5 
The results are summarised in Table 6.3. 
I-Sk.Pk 111 11-1 
1-11 [0' 0 -0'] [" 0 0] Fl= 0 0 0 F2= 0 0.5 0.5 
-O.S 0 O.S o 0.5 0.5 
1-1-1 
rOO ] ["S 0 OS] F3 = 0 O.S -O.S F4= 0 0 0 
o -0.5 O.S 0.5 0 0.5 
Table 6.3 Test set 1 summary 
In order to check the results and operation of the system :-
gl and gz are the complex loss values in a 2 transmitter 1 receiver set-up. 
gl := 0.9 + 0.2j 
gl := 0.6 + 0.9 j 
163 
Calculate received vector Rv : 
Rv := gJ.(1 1 -I) + gdl -I I) 
Rv = (1.5 + I.lj 0.3 - 0.7j - 0.3 + 0.7j) 
Calculate the transpose Rv T : 
Rl = .3 - 0.7j r
·
5 + 1.Ij J 
0.3 0.7j 
Solving the vectors: 
R2:=F2·RvT 
R3:=F3·RvT 
R4:=F4·RvT 
[
0.9+ 0.2j ] 
Rl= ° 
-0.9- 0.2j 
[
0.6+ 0.9j] 
R4= ° 
0.6+0.9j 
I RII = 1.304 
I R21=0 
I R31 = 1.077 
I R41 = 1.53 
This illustrates that the two transmitted codewords would be correctly decoded 
when using BPSK modulation. Additional programs were written to illustrate the 
effect of varying g on the receiver decode capability and to illustrate the problems 
that arise when g varies during the length of a codeword; see Appendix 3. 
164 
6.4.6 Summary 
The digital signal processor chosen to carry out the bulk of the receive processing was 
easily capable of decoding the combined codewords from the two transmitters in the 
CV-CCMA demonstrator. The software written for the decoder's digital signal 
processor, written in Texas assembler language, was developed to a functional state 
and could be ported easily onto other, more powerful, Texas Instrument's digital 
signal processors. 
The Mathcad and Matlab programs that were written to test the 
viability of the decode algorithm were found to be useful, because they gave 
confidence in the operation of the CV -CCMA system. This was especially true during 
the initial period of the research, and gave confidence to the hardware development 
stages that followed. The Mathcad programs that were written to check system 
operation with transmission parameter variation also produced some useful results. 
The Mathcad programs that were written to calculate the matrix arrays were 
extremely useful, and saved a lot of time. 
Most of the software is written in a modular format. This will enable 
the functionality of the component parts of the CV -CCMA system to be easily 
transported to other applications. For example, a new optical asynchronous transfer 
mode system, that is being trialled by Cable & Wireless PLC, could usefully adapt the 
mUltiply and select minimum routine to its receiver system. 
Any future development of the decode software should be continued 
using Texas Instruments development tools; this would prevent the time-consuming. 
problems (particularly with addressing) that slowed CV -CCMA development. 
165 
7 RESULTS 
7.1 Introduction 
This chapter contains results obtained with the system that was constructed during the 
latter period of work undertaken at the University of Warwick. The results mostly 
take the form of recorded data and waveforms, in both the time domain and frequency 
domain, separated into sections corresponding to the component blocks shown in the 
system diagram, Figure 7.1. 
Using BPSK modulation, the system, although restricted in data rate, 
functions quite satisfactorily. The full bandwidth QPSK system worked on the bench 
with hardwire synchronisation, and with some fettling it was also possible to obtain 
reliable results over an open link. With the filters implemented, the parameters were 
too tight and some information was lost. Also, the gain and phase loss parameters are 
more difficult to interpret with a full QPSK modulation scheme using the integrated 
circuits selected. Therefore, when transmitters and receivers are hardwired together 
the g values needed to be very accurately converted before being fed into the signal 
processor. When analysing some of these factors it was found that a range of values 
can be open to interpretation. Different hardware decoding schemes would be a help 
here and further work needs to be done on this. Due to the superior reliability of the 
BPSK system most of the results quoted are for the BPSK system. A standard Hewlett 
Packard oscilloscope was used for generating the results and was fitted with a direct 
HPIB (IEEE488) output. This was used to input the data directly to the word 
processor, producing good-quality reproduction. The spectrum analyser, however, had 
no output, so the screens were printed, and then scanned. The results obtained with 
the two transmitter, one receiver system are compared with simulation results from 
other researchers, and the simulations are shown to be valid. 
166 
Audio 
input 
1 
Audio 
input 
2 
Audio 
output 
1 
Audio 
output 
2 
Sync. 
generation 
Speech 
digitisation 
Sb 
Speech 
digitisation 
Digital! 
analogue 
Digital! 
analogue 
type 1 cable output 
type 3 radio output 
Buffer + 
coder 1 
Sb 
Buffer + 
coder 2 
Floating -point 
digital signal 
processor 
r---------, 
I 
I 
Sa 
Sb 
--------.-
type 1 only 
I 
Pulse 
shaper 
Pulse 
shaper 
RF 
modulation 
Sa 
RF 
modulation 
I--
I 
I 
I 
I 
I 
'--
-----, 
MAC I 
I 
I 
I 
I 
_I 
Precision 
analogue 
digital 
conyer 'on 
RF 
de-modulation 
filtering etc. 
Sa Sa 
Sb 
Figure 7.1 CV-CCMA Block Diagram 
167 
7.2 The synthesisers 
The synthesisers were found to perfonn well, producing spectrally pure outputs at the 
designed output powers. The output spectrum ofsynthesiser 1 is shown in Figures 7.2, 
7.3 and 7.4, which illustrate the lower frequency, standard frequency and upper 
frequency respectively. The nice clean spectrum with low level sidebands may be 
observed. Table 7.1 shows the standard input programming fonnat for the 
synthesisers. The associated lock codes and lock times are shown in Tables 7.2, 7.3 
and 7.4. The output spectrum of synthesiser 2 is shown in diagrams 7.5, 7.6 and 7.7, 
with associated lock codes in Tables 7.5, 7.6 and 7.7. Note that the output spectrum is 
reduced in amplitude (approximately 30 dB down on synthesiser 1) and has a broader 
spectrum and an inferior sideband perfonnance. This was mainly due to the voltage-
controlled oscillator used, which had been damaged by excessive input voltage (on 
the control input). Also, the printed circuit board layout is much more critical at these 
higher frequencies. 
The delay in lock-up on synthesiser 2, when operating at 850 MHz, is 
due to non-linearities in the veo output, causing interactions with the loop filter. 
This shows itself as a false lock. The lock codes, etc., transmitted from the PC should 
produce an output frequency of 850 MHz. However, the synthesiser locks up at about 
840 MHz. It was resolved on the second models by forcing the VCO to output the 
correct frequency, by overloading the control input and then transmitting the lock 
codes. The solution is a new voltage-controlled oscillator. 
At the higher frequencies components were 'taking off, or self-
oscillating at different frequencies. This situation was corr~cted by inputting the 
correct eC codes whilst simultaneously setting the control voltage so that the output 
frequency was correct. 
168 
Register Pointer Bit 7 Bit 6 Bit 5 Bit4 Bit 3 Bit 2 
A 00 PD 0 IPCD X RD3 RD2 
B 01 1 0 1 PHI VCDa VCDb 
C 10 MD15 MD14 MD13 MD12 MDII MDI0 
D 11 MD7 MD6 MD5 MD4 MD3 MD2 
Table 7.1 Synthesiser programming format 
Required programming data: 
MDO-MD17 
RD3-RDO 
PD 
PCD 
= Main dividers division ratio load 
= Reference dividers division ratio load 
= Power down 
= Current pump, 0.5 rnA or 1 rnA 
Bit! BitO 
RDI RDO 
MD17 MD16 
MD9 M8 
MDI MDO 
VCO AlB = Enables two synthesisers with same address on same bus to . 
be uniquely identified. 
Note that device address = 14, sub-address 00 with auto-increment, four data bytes. 
Register Pointer Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 
A 00 0 0 1 X 1 1 0 0 
B 01 1 0 1 0 0 1 0 0 
C 10 0 0 0 1 0 1 0 0 
D 11 0 0 0 0 0 0 0 0 
Table 7.2 IlC data transmitted ( 50 MHz output) 
Programming data summary; 
10 MHz reference 11024 = 9765.625 Rd codes = 1100 
50 MHz output 15120 = 9765.625 Md codes = 000001010000000000 
169 
Register Pointer Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 
A 00 0 0 1 X 1 1 0 0 
B 01 1 0 1 0 0 1 0 0 
C 10 0 0 1 0 0 1 0 0 
D 11 0 0 0 0 0 0 0 0 
Table 7.3 12C data transmitted (90 MHz output) 
Programming data summary: 
10 MHz reference /1024 = 9765.625 Rd codes 
90 MHz output / 9216 = 9765.625 Md codes 
Register Pointer Bit 7 Bit 6 Bit 5 Bit 4 
A 00 0 0 1 X 
B 01 1 0 1 0 
C 10 0 0 1 0 
D 11 0 0 0 0 
= 1100 
= 000010010000000000 
Bit 3 Bit 2 Bit 1 Bit 0 
1 1 0 0 
0 1 0 0 
1 0 0 0 
0 0 0 0 
Table 7.4 12C data transmitted ( 100 MHz output) 
Programming data summary-: 
10 MHz reference / 1024 = 9765.625 Rd codes 
100 MHz output /10240 = 9765.625 Md codes 
= 1100 
= 000001010000000000 
170 
The 100 MHz spectrum, illustrated in Figure 7.3, shows a lower output 
level (-3.3 dBm) and worse sideband (not measured) performance; this was due to the 
voltage-controlled oscillator operating on the edge of its specified frequency range. 
The Toshiba PC with eC interface generated all synthesiser 
programming codes. The device is first addressed, then sub-addressed and finally the 
• data bytes are transmitted. Pin 15 on the synthesiser is an out-of-Iock alarm and is 
held high by an external 27 Kn resistor. The pin is latched low in the event of an out-
of-lock condition and is used in the circuit to trigger an alarm. The internal registers 
of the synthesiser can be read back into the PC via the 12C bus and checked for correct 
programming. On synthesiser 2 there was a delay in the VCO changing frequency so 
an out-of-Iock signal was latched in before the VCO had settled at the new frequency. 
A reload of the eC data cured this; a faster/more linear VCO would improve any 
production unit. 
Register Pointer Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 
A 00 0 0 1 X 1 1 0 0 
B 01 1 0 1 0 1 0 0 1 
C 10 0 0 0 0 0 1 1 1 
D 11 0 0 1 1 0 0 1 1 
Table 7.5 Synthesiser 2 12C data transmitted 
658 MHz output, no pre-scaler 
Programming data summary: 
10 MHz reference /1024 = 9765.625 Rd codes 
658 MHz output /67379.2 = 9765.625 Md codes 
= 1100 
= 010000011100110011 
171 
Register Pointer Bit 7 Bit 6 Bit 5 Bit4 Bit 3 Bit 2 Bit 1 Bit 0 
A 00 0 0 1 X 1 1 0 
B 01 1 0 1 0 1 0 0 
C 10 0 1 0 1 0 1 0 
D 11 0 0 0 0 0 0 0 
Table 7.6 Synthesiser 2 I1C data transmitted 
( 850 MHz output, no pre-scaler) 
Programming data summary: 
10 MHz reference 1 1024 
850 MHz output 1 87040 
Md codes 
= 9765.625 Rd codes = 1100 
= 9765.625 
= 0101010 1 0000000000 
Register Pointer Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 
A 00 0 0 1 X 1 1 
B 01 1 0 1 0 1 0 
C 10 1 0 1 1 1 0 
D 11 0 0 1. 0 1 1 
Table 7.7 Synthesiser 2 I1C data transmitted 
Bit 1 
0 
0 
0 
1 
0 
1 
0 
0 
( 1.12095 GHz output, no pre-scaler) 
Programming data summary: 
10 MHz reference 11024 = 9765.625 Rd codes = 1100 
1.10295 GHz output 1112,942.08 = 9765.625 
Md codes = 011011100100101110 
Bit 0 
0 
1 
1 
0 
172 
Synthesiser Frequency (MHz) Start-up lock time Lock time from 
(warm TeXO) (mS) receipt of correct 
12e code (mS) 
1 50 120 13 
1 90 120 13 
1 100 120 13 
2 658 200 19 
2 850 200 19 
2 11029.5 see notes see notes 
Table 7.S Lock times for synthesisers 
All lock times were measured with the Hewlett-Packard storage 
oscilloscope and analyser connected together on the HPIB / IEEE488 bus. The higher 
frequency output would not lock directly and required a manual input to force the 
veo to approximate the output frequency required, and then a re-Ioad of lock codes. 
The signals were captured on the pins of the synthesiser and stored on the 
oscilloscope. The stored information could then be printed directly on the HPIB 
printer, or stored on the PC as a Gerber file. 
The Hewlett-Packard spectrum analyser also had a HPIB output. This 
was used to connect to a special high resolution printer, which was specially designed 
for use with the spectrum analyser. These files were too large too be input directly, so 
the spectra were printed and then scanned. This meant that some of the fine resolution 
was lost. 
173 
kl1 1 401 07 23 FEB , 1999 
IP 
REF .0 d8m #ATiEN 30 dB 
PEAK i - """ 1
1
'" "---"r-'··_·_·r····_···· T'·-''' ·· 
, I : 
LOG ~, __ . - ,L..-.- ,_,L .. -..i., .... _--! 
" " ".'1' 
I 
10 ! ! 
dB/ i ii i i 
t, --,,1 .' I .. _ ...... L ... '. J 
I i ATTEN 
i 30 dB 
I "" ' 1 ,,_ .. T 
I ! 
1..",-_ .... r ' 
START 49.~00 MHz 
RES BW 10 kHz 
!t--- - .-. 
V8W 10 kHz 
•.. 1 
, 
.", 
,,'" ... ... j .-
'''1'-
--I- .. 
STOP 51. 000 MH: 
S'~~'P 60 m SQ 
Figure 7.2 Synthesiser 1 spectrum, minimum output frequency 
CENTER 90.000 MHz 
RES B~; 1 e kHz VBW 10 kHz 
SP r,N 2. 000 MHz 
S't'IP 60 msec 
Figure 7.3 Synthesiser 1 spectrum, operating output frequency 
174 
,11 .471 S0 
!p 
23 FEB 1999 
~1KR 100. 000 HH. 
9. CO dBIl 
Figure 7.4 Synthesiser 1 spectrum, maximum output frequency 
,12.07 : 04 23 FEB 1999 
/f!! /·1KR 658. 804 MHz 
REF 20.0 d8m AiTEN 38 dB - 14.72 dBm 
;---...... ' .... 1 ... -~- ~ - - , .--- .-...... , ------ - T~-" - - ... ,~ iN ~- - -. , -r-...... - ~ ..... r--·-···· ', ..... 'f----.... -.... -~- ' .... "'-.-
I : I ! I ~ ; : l ; 
l-- -.---+------. j-._- -.- +------.;-.. --- ... j .... , -!'+-----'1-- i- -
I ' i ! . ,i 
, ! I : i f",,--,,-. .1 L ,_ ... __ .. 1... ., •... _ .. _ 1.. __ - .... 
PEAi': 
LOG 
10 
dB/ 
..; .. 
! CEtHER 
I 658. 304 ,...lHz r.' ._. .. . , ... _ . .. L __ .
j STEP 30 kHz () 
: -T-r --r r- ... ~... , i 
~I.A, ~8Ji- -... T----'-T----- r ----- !-----'til' -- ---~ ------1------:---- '-T-- .. --.-. 
sgo~~f- -----"Ii-'--' --r----"-'l-." .... r .... '/.111-- ! r --" -\-. .+-: Ii , l' I : { I i '---[' ---"'r --.... t---- .. -[ .. - ~ -rr---'1" '·---"'-----' ... T 
l .. I l ,-d. .. __ I. _:':!- 1 I -..l._--,,-__ 
CENTEF< 658.0134 MHz SPAN 1. 967 II,Hz 
RES BW 10 kHz yaw Ie kHz SWP 59 mSQ[ 
Figure 7.5 Synthesiser 2 spectrum, minimum output frequency 
175 
li~l 11 1 ~l 2 3 FEa Hl98 
Ip 
RE. F 20.0 dam ,A.TTEN 30 dB 
MKR 850. 008 t--iHz 
-- 15.81 darn 
LOG 
10 
d8l 
l-------r.-·.-······-:··_·_···"'1"·_···-_··r · ····· .. ···1···-· .. _ .... ] .. 
"',' .- .. - - ·. · t. ·--~ , ~~t. , .. . _ .... _.~L ..... . "~ "'-"'1-- ' I 
j 
.. j, 
i 
" _ .. _,L .... 
1 i ! I' i 
I. L. ",t , 
STOP 
85~.00C MH::: 
I 
, 
Sl'OP 
1 
START 849.000 MHz 
RES BW j0 kHz VB',v lC kHz 
Figure 7.6 Synthesiser 2 spectrum, operating output frequency 
t~2 e 15z 21 
#,u" 
REF 20.0 d8m ATTEN 30 dB 
PEA;{ 
LOG 
10 
dBI 
!'''''_- -· r-·· .... · .. ··,· .. _ _ · .. ,. .. · .. -·· - r - ...... _ . . ,. .... 
i ! ii i i ~ ..  -.. , -I·· .. .. "'+---· .. 1--·---· ·'[""'· .--i -.,. 
! i t I l L ,.,,_L ... , ,. 1,. , _ ___ ."L ., .. ,."J .. " 
i 
I S TART 
1 .. 05589 
...... • .. 1 . , 
- ! 
I>!XP' 1. 
--17.88 
''' t ,· ._ .. ,_ ............ r ... .. _¥ .... " 1-'· 
Ii! 
I I 
I ........... t ... _ ...... _.M.:., 
i 
I 
i l 
.. u . ) _".~' " .... _,l. __ " ",' i 
! --'r" 
i 
. , 
.... .I. .. . __ .". L .... 
GHz 
cBm 
STOP 1. 15000 GHz START 1.05589 GHz 
RES BW 1.0 MHz' V8W 300 kHz SWP 20 mao( 
Figure 7.7 Synthesiser 2 spectrum, maximum output frequency 
176 
7.3 The transmitters . 
Firstly, the transmitters were set up individually and connected via the attenuatorl 
phasor array to the spectrum analyser. Figure 7.8 illustrates the equipment layout and 
Figures 7.9 and 7.10 illustrate the radio frequency output of transmitters 1 and 2 
respectively. The data input was generated by the EPROM board, which produced a 
continuous test pattern; this is shown in Figures 7.11 and Figure 7.12. 
The circuitry was then connected together with both transmitter 
outputs connected via the attenuators/phase-shifters to the input of the receiver. The 
frequency-translation stages were disconnected (using a bypass) so the output 
frequencies were identical (45 MHz). Test patterns were input to both transmitters and 
the resulting combined spectrum is shown in Figure 7.13. The EPROM test pattern 
generators were then switched over to the Delta modulators and the coders were 
switched to 'linear independent test set l' output, i.e. unique codes for each 
transmitter. A test tone was input to the Delta modulators at 1.5 KHz. Figure 7.14 
shows the audio input, the Delta modulator output and the coder output. The 
attenuators were adjusted such that each transmitter contributed a similar signal 
amplitude and the combined output spectrum is reproduced in Figure 7.15. 
The coders were then switched over to output 'test set 2', i.e. a 
partially shared code set, and Figure 7.16 shows the audio input, the Delta modulator 
output and the combined spectrum output for the system. The slight increase in 
bandwidth with the non-linear coders switched in may be noted. The bandwidth is 
large anyway due to the filters used in the type 1 system. Also, the larger 'ripples' on 
the slopes of the spectrum peak, may be observed, caused by the modulation applied, 
and the differences in output amplitude between the transmitters. 
177 
I2C Control and 
monitor 
1 
1 
1 
I 
I 
I 
1 
1 
1 
1 
1 
r---
1 
I 
1 
I 
I 
,--------1 
1 
I 
1 
1 
I 
1 
1 
I 
EPROM 
Pattern 
Generation 
To receiver 
Modulator 
and 
transmitter 
___ • RF output to 
spectrum analyser 
------. 
Storage 
oscilloscope 
~--------------
AUDIO 
or 
TEST TONE 
input 
I 
I 
I 
I 
I 
I 
I 
I , 
Oscilloscope 
DELTA 
Modulator 
" 
I 
I 
I 
I 
I 
I 
I 
Storage/sampling 
oscilloscope 
CODER 1 
CODER 2 
Figure 7.8 Test equipment layout (transmitter) 
Blocks indicate PCB or breadboard 
Duplicated for second transmitter 
178 
*ATTEN 20dO MKR -20.o7dE 
RL 10.OdBm 10d8 / 4S .000MH z i -'--r--I--l---"---T"" .···r·--.---1----.--
1---'---1 __ .__J_ ... _._: __ .... ___ J_ ....... .. _. 
i ~' ~ I I L. - ----. . -___ ._ .... . _ .. ___ .-. . .. ---. .--- .. ------ '--.-"'-
I CEN ER 145~O Hz I 
o t±~j _ --+---+-.-±'-~-~.- ~~==. :~=~.= 
I t- -- - I -- 1 --_n-t - ···- ....... -.--
r--- . - -r-- .-- ... --.-.. ------- .---
I I 
,-: - - r 
L __ .L __ ._L ___ ---L, __ L--_-'-_-----'-_____ ._ . .... ___ .... ___ ._ 
CENTER 4S.000MHz 
RBW 30kHz VBW 30kHz 
SPAN 2.0C 
SWP SOn 
Figure 7.9 Transmitter 1 output spectrum (test pattern 1 input) 
AT TEN 20da 
RL Odam 
MKR - S . .33dBm 
10d8/ 4S.000MHz 
--+----t----+--=---H-1-----~- --~ '~~_ ._~_T -'--- - -+- -r --------· 
. __ .----L-._ 
C E NTER 4S.000MHz 
RBW 30kHz vaw 30kHz 
SPAN 2. DOC 
SWP SOmE 
Figure 7.10 Transmitter 2 output spectrum (test pattern 1 input) 
179 
TR ~ +( .Oc iv N ORM ~M 
f-r-'.. hl.... +4 .....,.,. r...,.. ;J.~ rr ~ ~ ~ 
1-1 ............ 
......... -
~ r4 I r"' 1 rr I ,..,.... rW-r 
u, 
Rox 2V 0 2V A=l m 
Figure 7.11 Transmitter 1: input test pattern 
TR ~ +( .o( iv N ORM ~ M 
r.-... f"). ,,, ~ ~ W...,.; ~ rr t,l rrL.>, .,J,-... W-
r"" ~ rI. r" "r -.,.. J\. ,.I)\. 
~'r- ..L.., ,..... L.J.. ~ 
Row 2V 02V A i= lm 
Figure 7.12 Transmitter 2: input test pattern 
N.B. Figures 7.11 and 7.12 were captured with a Hewlett Packard storage 
oscilloscope. The top trace represents the in-phase input to the modulator and the 
lower trace the quadrature-phase input to the same modulator. The spikes are 
problems with decoupling and were removed later with extra decoupling capacitors 
and new earth rai 1. 
180 
MKR -16. 67dB ATTEN 20dB 
RL OdBm lOdB/ 45.000MHz 
----~------ ---1 -- '-'- -~---T------"l--'-'-'- .-
-..... .... --- ----!- ----1----- ---_ .. ---.--
I 
-.. -.-.- . ·---------.. T------·-- ----.. ---. 
- -------- -~---+ 
+---I------t ---- '-'---
----- ~ ----- - . --- -
CENflER 
4 ~-=._~ __ ~ C2..._ Hz 
! --~ -+ 
-·--1-- .--+---- -+- ---+----- ~-----
-----.~-- --.- ----i-----i--- -------1' .. ---·---- ---- ._-----
I I I i 
-.. ----- '----- ---t- ~-- ~+---tI+--- +-.--- . 
L __ =~:L=±_=_l_____ _=~~i=_ ~==I ___ = __~=~' 
::::ENTER 45. OOOMHz 
~BW 30kHz VBW 30kHz 
SPAt'"J 2.001 
SWP SOml 
Figure 7.13 Combined output spectrum (test pattern inputs) 
Figure 7.13 shows the combined output spectrum, with the two transmitters 
connected together and the radio frequency output amplitude levels adjusted via the 
attenuators to give similar output levels. The code patterns input are illustrated in the 
previous figures. The increase in modulation causes the curious effect whereby the 
crest of the peak 'wobbles' at a frequency related to a beat frequency between the two 
transmitter output frequencies. 
181 
~r-Q----.-.-o-r-~o k-f--'-z -N'b--R~ --.-· ... r----r-
M
--, 
, 
: 
! f\. fI fI f\. f\. f\ fI. },Il{j 
i 
~ - -HI~-rrrH-1-++r·r'-·~+~rrr~-
, 
I 
~ """-H --1'-'+1-+1 ....... H-+I<---+-H-4-+-H--++>-+-H4-+-t-t-<to--+--t-t4- -H--+to--+--t-t ! 
~ - . -----H--+-·-H-t-+H- H-/---t t--+ - tt+- tt+-- -.-
, 
f-t- - .- ·t--- 'H- ---\I 
V ~ 
r -···-· ·--·----+·-··--- -"-1-- --r----- - - - 1-- - ---
, 0 V At=lm L_._ .. _ ................ _ ....__ ............ _ ....................... __ .. ,,,, ......... _ .. . ---. ---
Figure 7.14a Audio test tone input 
Figure 7.14b Deltamodulator output 
(overdriven for clarity) 
Figure 7.14c Recovered Deltamod (top) 
Transmitted Deltamod (lower) 
TR P +( . Oc iv N ORM ~ M 
.-- I- r- r---
Ro>< 2 V 02V A 1m" 
Figure 7.14d Coder output 
182 
RL Odam 1.0dS/ 45.000MHz 
CENTER 4S.000MHz 
RBW 30kH~ VBW 30KHz 
SPAN 2. DC 
SWP 50lT 
Figure 7.15 Combined output spectrum with recorded audio inputs and code-
word set 1 (unique set for each transmitter) 
Figure 7.15 shows the spectrum of the combined signal produced by transmitters 1 
and 2 connected together through the attenuator array. The signal appears to spread 
more than with the constant test tone inputs, and the modulation peaks are even less 
pronounced than before due to the variability of the modulating signal. 
Note that all results described so far are taken with the type 1 
synchronisation system (central synchronisation). In order to make the system 
operational, as quickly as possible, the various system filters were not connected. The 
later type 3 system incorporated the filters (pulse shaping and intermodulation product 
reduction) and these results are presented in section 7.5. 
183 
r:=-;::-: - -,--:- - -.. -- -.- -.-.- -"" - -.-.-, '-
: FR Q l , O ~ Okf- z NORM ~ M 
r-----· .. ---t-·--· .-.. --- -.------- -- --- - f--.- .--
A A i A A A A A A A A 
, I i I I f-- -- 1--" -- H 
I , r ' -+4-M-..-+f-+-1-t++-t++ ... -\-++--t-rt-++ H~+t-+r--H 
I ! ~ -- ---- ; --1 __ - - ____ ~ = ___ = 
~ - ~ ....  ~.. r~ y - j------ --~ :-~: -------- 1 
___ rl _ J ...... _ L __ ...... __ ,_, ____ , ___ ,c--_..-J 
Figure 7.16a Audio input test tone Figure 7.16b Deltamodulator output 
RL DdSm 
! 
CEN/TER 
45. pOOl'-' Hz l~ 
J \ 
t ~ 
r \ 
/ \. 
~#iHJ ~ ~,I'U4" ~,..AJ." !It ~ ~~ ,~J.i·J.h '1f'41'''' "'IV' 
I 
Figure 7.16c Combined spectrum (input test set 2) 
The results obtained with the coders set to generate test set 2 codes are 
similar to the results obtained with the coders set to generate test set 1 codes, The 
spectrum was found to fluctuate, hence, when the spectrum is captured and stored this 
additional information is lost. The 'wobble' observed at the crest of the spectral peak 
is caused by the two frequencies being very nearly identical, and producing the beat 
frequency of the 'wobble', This beat, and other effects, were related to the codes used 
in the transmitters and shows up as a variation in the spectrum slope, near to the peak. 
This effect was more pronounced when using the second set of codewords, 
184 
7.4 The receiver 
Initially, the complete system was set up by connecting the individual transmitters to 
the receiver via an attenuator/phase shift array. A test sequence was input to the coder 
board from the EPROM board and the modulated and amplified transmitter output 
was monitored on the spectrum analyser (refer to section 7.3 for diagrams of the 
spectra and data signals of both transmitters and the combined output). This signal is 
then used as the input signal for the receiver and is fed directly to the demodulator, 
which was also synchronised to the main synthesiser. The fc bus is still required to 
be connected to the frequency conversion circuits, so that the internal bypass can be 
initiated by outputting the correct data string to the frequency conversion circuits. 
Refer to Appendix 15 for details. 
The de-modulated outputs from the Maxim integrated circuit (in-phase 
and quadrature) were monitored on a standard oscilloscope which was triggered from 
the divided main synthesiser output. Once set up, the demodulated signals were fed 
into a storage oscilloscope and the output printed as a record of the signals present. 
The pulse-shaping filters were removed from the initial type 1 set-up. The outputs 
were then buffered and fed to the parallel inputs of the Burr-Brown precision 
analogue-to-digital converter. In order to prevent a two's complement complication 
the inputs were restricted to the positive input range only, i.e. a maximum of +2.65 V. 
The timing of the analogue-to-digital conversion is critical to the operation of the CV-
CCMA system. The convert pulse is derived from the main synthesiser via divide 
chain 2, refer to Appendix 16 for a full set of timing diagrams. The converted digital 
output is fed to the serial port of the TMS320C31 signal processor. A timing pulse 
from the EPROM pattern-generation board was used to start the signal processor 
pr.ogram by triggering an external interrupt line (EINT3). Once running, the program 
185 
generates the timing signals necessary to recover the samples from the analogue-to-
digital converter. In the initial test set-up it was found that a buffer was required 
between the two transmitter outputs and the receiver. The outputs/inputs were 
connected together via the attenuator/phase shifter and the combined signal was input 
directly into the Maxim modulator/demodulator integrated circuit. The frequency-
translation stages were disconnected it.'l order to simplify any diagnostics required and 
the 45 MHz signal was monitored on the spectrum analyser and the sampling 
oscilloscope. The sampling scope produced the inverted figures (more black than 
white). The first implementation involved restricting the inputs to the modulator so 
that the system operated in a form of BPSK, that is each bit output is a single phase 
state. 
Figure 7.17 shows the receiver equipment layout. A copy of the output 
screen of the PC connected to the TMS320C31 is shown in Figure 7.18. The top 
screen is a scan of the PC screen during program load and the lower screen is a scan 
of the PC screen with the program running, this shows the individual recovered test 
pattern data. Figures 7.19 and 7.20 show the recovered data for the combined test 
pattern data (i.e. two transmitters and one receiver recovering the two superimposed 
signals), for BPSK and QPSK respectively. 
Figures 7.21 and 7.22 are scans of photographs of the equipment 
rooms at the two sites, University of Warwick and Cable and Wireless PLC. Some of 
the difficulties encountered whilst making the system work, particularily with full 
QPSK modulation, are discussed in Chapter 8. 
186 
Coder r-- Transmitter Transmitter r-- Coder 
1 1 
r----------, lSI. I I ampmg I , , 
: oscilloscope : 
L.----r-----.J 
, 
I , 
I ---~ 
2 2 
.------ -----""\ 
" ~, ~---\ 
Combiner :-
attenuator 
phase shifter 
~------J 
, 
, 
, 
, 
\ \ r--------I 
\1 I 
• Spectrum I , , 
,. analyser I, , , 
, L. ________ , 
"~-------..... r------------, 
Frequency 
converSIOn 
-amplify 
~-_----.J 
, 
.... 'F . b ' 
...... ast-tIme ase I 
, 
, 
, 
I , 
,. oscilloscope I 
, , I , L. ____________ , 
o I-----o;.---~... De-modulator .... .... ..... 12C control 
Master 
sync. 
... 
... 
... 
.... 
• ~-------... 
Buffer / filter 
amplify 
precision A-D -
... 
t ~-------'/ 
Digital 
signal 
processor 
..... 
... 
, 
PC 
...... r----------, 
... I I 
....... Storage , 
" , 
""" : oscilloscope : , , L. __________ .J 
DSP 
control 
PC 
D~ D~ 
Audio ... ~-.,........i demod. ...-. ... I-.i~ Shift register .i ~ demod. .i ~ 
output T'--___ --' T'--_____ --' T '--___ --' T 
Audio 
output 
, 
I 
, , ,.,L _____________ L_,-__________ ,.J _______ ~-----~ 
I I 
, Storage I , , 
: oscilloscope : L. __________ .J 
Figure 7.17 Receiver test equipment layout (type 1) 
187 
DISASSEMBLY 
80988d 
80988e 
60986f 
809890 
809891 
809892 
809893 
809894 
809895 
609896 
609697 
809896 
1
809899 
60989a 
80989b 
reset 
reset 
04040007 
72090002 
15208048 
6aOOff7a 
04050006 NEG2 
72090004 
04050007 
72090002 
15218048 
6aOOff74 
04060007 NEG3 
72090002 
15228048 
6aOOff70 
15238048 NEG4 
COMMAND 
load fast5.dsk 
CMPF R7,R4 
CALLGT NEG2 
STI RO , @08048H 
B START 
CMPF R6,R5 
CALLGT NEG3 
CMPF R7,R5 
CALLGT NEG3 
STI R1,@08048H 
B START 
CMPF R7,R6 
CALLGT NEG4 
STI RZ,@08048H 
B START 
STI R3 , @08048H 
809800 
809804 
809808 
80980c 
809810 
809614 
C31 DSP STARTERS KIT 
PC 0080989b SP 00809f03 
RO 00000000 Rl 00000001 
R2 00000100 R3 00000101 
R4 18000000 RS 10000000 
R6 08000000 R7 00000000 
ARO 00000009 AR1 00000000 
AR2 00000003 AR3 00000000 
AR4 00000000 AR5 00000000 
AR6 OOffffff AR7 00000000 
IRO 00000002 IR1 00000000 
ST 00000000 RC 00000000 
RS 00000000 RE 00000000 
DP 00000001 BK 00000000 
IE OOOOOOec IF 00000300 
IOF 00000000 _dT 00006cef 
MEMORY 
3bb7b37b 00000063 50700080 08640000 
15248040 0827992e 15278042 15278043 
0827992d 15278040 15248024 08670003 
086602c1 15268020 086500b5 15258028 
08760000 08770000 10760008 06000000 
086402c1 15248020 08770000 10760028 
F1Help F2REG40 F3FLOAT F4Srce F5Run F6DispBP F7ClrAll F8SStep F9Grow F10FStep 
DISASSEMB Y L _. . ... - -- .......... - -~. .., -- .. .... -.. ~- _ .. I,!, 
80980b 08670003 START LDI 3,R7 PC 0080980b SP 00809£00 
60980e 066602e1 LDI 705,R6 RO 00000000 R1 00000.000 
80980d 15268020 BTl R6,@08020H R2 00000000 R3 00000000 
80980e 086500b5 LDI 181 , R5 . R4 00000000 R5 00000000 
80980f 1525B028 BTL R5,@OB02BH ; R6 00000000 R7 00000000 
809810 08760000 LOOP LDI O,IE / ARO 00809f85 ARI 00809f86 809811 08770000 LDI O,IF AR2 00000000 AR3 00000000 B09812 1 0 760008 OR 00008h,IE AR4 00000000 AR5 00000000 
809813 06000000 IDLE AR6 00000000 AR7 00000000 
809814 066402e1 LOOPI LDI 705,R4 IRO 00000002 IR1 00000000 
809815 15246020 BTl R4 , @08020H ST 00000004 RC 00000000 
609816 08770000 L01 O,IF RS 00000000 RE 00000000 
809817 10760028 OR 00028h,IE OP 00000060 BK 00000000 
809818 OcBOOOOO RXLOOP NOP IE 00000004 IF 00000304 
809819 50700000 LOIU OOOOOh,OP IOF 00000000 
-
dT 00001f11 
COMMAND 
0 
load fastS.dsk 
run 
> 
CPU Running: ESC to stop, END to exit DSK3D while running 
FIHelp F2REG40 F3FLOAT F4Sree F5Run F6DispBP F7ClrAll F8SStep F9Grow F10FStep 
Figure 7.18 PC screen showing disassembly of fastS.asm 
188 
\ 
~ D . Oc \ A LIA S10 ~)M TR +( • IV 
r-. ft1 ,.. ,.. t.; 1\"1 ~ f'oI f\., 
lr-~ '~ ~ ~r.-w ~ ~~ 
',0lil ,... 
".., #-\ ~ ,., fNI ~ ~ 
~ WIA ,.iIt't IooJ ~ .-.. ~IW -" .~ ~~ .,.....- ..... If"T 
Rex 0.2 \' 2 OmV A = lm ~ 
-
Figure 7.19 Recovered test pattern data (BPSK) 
Tf! ; +( ) . 0 ( IV A ~IA A10 ~ M l 
• 
I I 
~ .LI.L 11 n .J .1 ..1 ~ .11 J. ~ J r r , I H :r r T r r 
U ~ ~ ~ ~ ~ ~ ., 
I I 
h 
"" ~ ~ ~ J 1 
II I I ~ II I I L I 
T , 1 l'f , H ! r , , rT 'n Tl '11 "ry 
Rex 0.5 \11 50mV A ~lm ::, 
Figure 7.20 Recovered test pattern data (QPSK) 
189 
Figure 7.21 Equipment set-up (University of Warwick) 
190 
Figure 7.22 Equipment set-up (Cable and Wireless PLC, Coventry) 
191 
7.5 Bit error rate performance 
In order to reduce the problems caused by electrical nOlse, (generated by the 
switching equipment at Cable and Wireless PLC), the CV -CCMA system was re-
assembled at the University of Warwick. After allowing a few days for the system to 
stabilise, the bit error rate performance was determined. 
This was to compare practical results with the simulations produced by 
. 
Ali, Chandler and Soysa in [74]. They plot information bit error-rate against signal 
energy per bit for various average fading powers. The simulations involve 2 users and 
therefore can be directly compared with the actual results obtained with 2 transmitters 
and 1 receiver. The simulation results are reproduced in Figure 7.23, which is an 
electronic scan of the original paper. The results are redrawn in Figure 7.24, to enable 
the practical results to be more easily compared with the theoretical predictions. 
The system used to obtain the results for the comparison was the type 3 
system. This was developed as a more practicable CV -CCMA system and involved 
synchronisation recovery via a separate 10 MHz channel. The system also contained 
the pulse-shaping filters and the transmitter band-pass filters. The multi-sample 
software was also implemented on the type 3 system. This restricted the data 
throughput to a maximum data rate of 1.2 Kb/s per channel, in the two transmitter, 
one receiver set-up. However, it gives the system a better tolerance to synchronisation 
impairments. Sub-section 6.6 contains some results which verify this. 
The simulations comprise 6 sets of results, 3 sets of results with space 
diversity (7-12) and 3 sets without (1-6). The CV-CCMA demonstrator did not 
include any provision for diversity, so a comparison between. the sets of results could 
not be done. Intuitively, with the additional 'information' provided by space diversity, 
the BER performance should improve, (over no diversity), as shown in Fig.2 of [74]. 
192 
EbINO.dB 
o 10 20 30 40 50 O r---T---~'--~----~' ---+--~,~ __ --~,~~,~
~ ' . . 1,2 6 
-1 '>~' ~ ~"./ L 3 "'~~';" /' 78 ' .. .';.<" ~ • ./ .,... .. • £. 
a: 2 '/ " " f~ / ~ - 1f : )c·. ;.-~ 
8'-3 I 1{ .~ .....• ': . .. .... . . ~ .. 
- 1 9 ~ ' . • ~ 
-4 ./ . . . ..... " 
.' . . .. 
-5 10 • 
Figure 7.23 Simulation results from [74] 
Plots 1 and 2 show users 1 and 2, average fading powers: user 1 = 1, user 2 = 1 
Plots 3 and 4 show users 1 and 2, average fading powers : user I = 1, user 2 = 0.1 
Plots 5 and 6 show users 1 and 2, average fading powers: user 1 = 1, user 2 = 0.00001 
Plots 7 and 8 show users 1 and 2, average fading powers: user 1 = 1, user 2 = 1 
Plots 9 and 10 show users 1 and 2, average fading powers: user 1 = 1, user 2 = 0.1 
Plots 11 and 12 show users 1 and 2, average fading powers : user 1 = 1, user 2 = 0,00001 
..... t------Bit energy received 
100KN
o 
10KN
o 
lKNo 100N
o 
I BER I 
ION 
o 
1 0 - l-f ..................... .. .......... , .................................. , ................................. , ................................. ; ....... .. 
-2 
10 
-3 
10 
-4 
10 
-5 
10 .... ... .. .... ........... ....... 10;;) ................. ............. ... .... ....................... .. .... : ......... .... ........ ...... ...... , .................... ..... ..................... . 
o 
Figure 7.24 Simulation (1) from 7.23 redrawn for comparison purposes 
N.B. Figures 7.24, 7.26, 7.27 and 7.28 are plotted with Macdraw Pro-plot with least 
squares best-fit algorithm. 
193 
The equipment test configuration comprised two transmitters, one of 
which was designated the master node (transmitter 1), and a single receiver. System 
synchronisation was set-up so that transmitter 2, and the receiver, were slaved to the 
master transmitter's synthesiser. This configuration effectively locked the three 
TCXOs together via the radio link. Trend data testers (x4) were used and connected to 
give two simplex test links. Trend data testers were selected for the testing because 
they are simple to set-up, have a direct read out of average BER, and have timers 
built-in which can be used for automatic testing. The testers connected to the 
transmitters were set-up as below:-
Rate: 
Code used : 
Sync.: 
Bit errors: 
1200 
511PlHex8 
SYNI 
NI 
DTE 
FDX 
NoP 
Selection of the 'DTE' (Data terminal equipment) setting means 
transmit data is sourced from pin 2 on the 25-way D-type connector, 'Rate' is transmit 
data rate, 1.2 Kb/s. 'Code used = (511P), is a standard test pattern and 'FDX' means 
full-duplex operation. The 'sync.' selection of 'SYNl' means synchronisation was 
derived from pins 15 and 24 on the 25-way D-type and 'NoP' means no parity testing. 
Finally, 'Bit errors = NI' means no injection of errors. The tester at the other end of 
the link was set-up in the same way, the only difference is that synchronisation was 
set to 'Recovered'. The transmit testers were timed from a feed derived from the 
synthesiser, the receive testers needed to be set to recovered timing as the DSP 
feeding the buffers was not slaved to the master synchronisation source. The testers 
incorporated one test pattern length of data in a buffer, so some tolerance was built-in . 
. , 
The voltage levels on the output of the tester are RS232 (recommended standard 232, 
194 
[121]), these were level-shifted, fcir correct matching, using a simple resistor network. 
The level was lowered to match the input of the CV -CCMA and increased to match 
the tester input at the CV -CCMA output. 
The tests were performed on the links (link 1 is tester 1 transmit to 
tester 2 receive and link 2 is tester 3 transmit to tester 4 receive) by varying the signal 
• 
strengths of the signals at the input to the combiner. Assuming that the noise 
component remains constant for the duration of the testing, this will provide an 
effective variation of signal/noise ratio, which can be used to compare with the 
simulation results from [74]. The system was configured with hardwire 
interconnection, via the combiner array, of the two transmitter outputs and the 
receiver input. This was due to the variability of the noise background at the 
University. The room used is adjacent to the lift motor room, and electrical 
interference was experienced when the motor was operating. The screening effect of 
the hardwire interconnection reduced these noise effects. Also, for each signal level, 
the results were taken over a minimum time period of one hour, to average out these 
effects. 
The phase component of the g value was not altered during the testing. 
The levels were measured using a true RMS radio frequency voltmeter and a 
calibrated active probe connected to the Hewlett-Packard spectrum analyzer. At each 
different input level, tests were performed for I-hour duration to obtain an average 
BER value from the data testers. Three tests were performed: 
i) Link 1 fixed, link 2 varied 
ii) Link 2 fixed, link 1 varied 
iii) Link 1 varied, link 2 varied 
195 
All radio frequency levels were measured using the active probe with direct read out 
from the Hewlett-Packard spectrum analyzer. The RF voltmeter was used as back up 
to give confidence in the level readings. The Trend data testers that were used give an 
average BER over the time period of the test, these are the values reproduced in 
Tables 7.9, 7.10 and 7.11. 
Figure 7.25 illustrates the test equipment set-up used to obtain the BER 
test results. The data is plotted in Figures 7.26, 7.27 and 7.28, these figures can be 
used to compare with the simulation results, which are shown earlier in Figure 7.23 
and Figure 7.24. 
Test RF level at RF level at Average Average 
no. attenuator 1 attenuator 2 BER BER 
output (dBm) output (dBm) (tester 1 - 2) (tester 3 - 4) 
i -20.0 -10.0 <10-9 <1O~ 
i -20.0 -20.0 <10-9 <1O~ 
i -20.0 -30.0 <10-9 ~1O-8 
i -20.0 -40.0 <lO-Y ~1O-7 
i -20.0 -50.0 <IO-Y ~1O-6 
i -20.0 -60.0 <10-9 ~1O-6 
i -20.0 -70.0 <10-9 ~1O-5 
i -20.0 -80.0 <10-9 >1O~ 
i -20.0 -90.0 <10-9 >1O~3 
i -20.0 -100.0 <10-9 >1O~ 
Table 7.9 BER results, link 1 fixed with link 2 varied 
196 
Test RF level at RF level at Average Average 
no. attenuator 1 attenuator 2 BER BER 
output (dBm) output (dBm) (tester 1 - 2) (tester 3 - 4) 
ii -10.0 -20.0 low power <1O-~ 
ii -20.0 -20.0 <1O-~ <1O-~ 
ii -30.0 -20.0 <1O-~ <10-~ 
ii -40.0 -20.0 ~1O-8 <1O-~ 
ii -50.0 -20.0 ~1O-7 <10-~ 
ii -60.0 -20.0 ~lO-s <1O-~ 
ii -70.0 -20.0 ~1O-4 . <1O-~ 
ii -80.0 -20.0 >10-3 <1O-~ 
ii -90.0 -20.0 >10-3 <10-9 
ii -100.0 -20.0 >lO-J <1O~9 
Table 7.10 HER results, link 2 fixed with link 1 varied 
Test RF level at RF level at Average Average 
no. attenuator 1 attenuator 2 BER BER 
output (dBm) output (dBm) (tester 1 - 2) (tester 3 - 4) 
iii -20.0 -20.0 <1O-~ <1O-~ 
iii -30.0 -30.0 <1O-~ <10-~ 
iii -40.0 -40.0 <1O-~ <10-11 
iii -50.0 -50.0 ~1O-8 ~1O-8 
iii -60.0 -60.0 ~1O-6 ~1O-6 
iii -70.0 -70.0 ~1O-6 ~lO-s 
iii -80.0 -80.0 >lO-J >lO-J 
iii -90.0 -90.0 >lO-J >lO-J 
iii -100.0 -100.0 >10-3 >10-J 
iii -110.0 -110.0 >10-J >10-J 
Table 7.11 HER results, link 1 varied and link 2 varied 
197 
Trend 108 
data tester 
1 
Level 
shifter r---------, , , 
, Storage , 
: oscilloscope : 
, , 
'-----r---- J , 
, 
, 
, 
, 
Trend 108 
data tester 
3 
Level 
shifter 
--------------------~------------------
Transmitter 1 
(master clock) 
Attenuator 
1 
r - - - - - - - - - - - -, , , 
, , 
, Spectrum , , , 
, analyser , 
, , L _____ ,. __ - ___ , 
, 
r- - -----,- - - - - - - -,-, 
, , , 
, , I 
, 
Combiner I 
, 
r - - - - - - -'- - - - - - -
, 
, I , ________ J , 
, 
, 
, 
, 
r---------, 
True 
RMS 
, 
, 
, 
, 
, voltmeter : L _________ J 
Trend 108 
data tester 
2 
--------1 
Receiver 
front-end + I1Q 
decode circuits 
-.-------
Receiver 
analogue-digital 
convert + DSPs 
. Transmitter 2 
(slave clock) 
Attenuator 
2 
Trend 108 
data tester 
4 
Figure 7.25 Test equipment layout (BER testing) 
• 
198 
Signal strength (dBm) at 
receiver input (link! 00) 
Signal strength (dBm) at 
-20 -20 -20 -20 -20 -20 -20 -20 -20 
-10 -20 -30 -40 -50 -60 -70 -80 -90 
receiver input (link2 ++.!..)+----L_-L_----'-_--L_--I_ --.J'--_L..__.L.---J 
10-3 
10-4 
Average 10-5 
BER 10-6 
10-7 
10-8 
10-9 
10-10 
Signal strength (dBm) at 
receiver input (link I + + ) 
Figure 7.26 Link 1 fixed and link 2 varied 
-10 -20 -30 -40 -50 -60 -70 -80 -90 
Signal strength (dBm) at 20 20 20 20 20 20 
-20 -20 -20 - - - - - -
receiver input (link2 xx:....) +--L_---L_-L_----'-_--L_--.J~_L..__L..___' 
10-3 
10-4 
Average 10-5 
BER 10-6 
10-7 
10-8 
10-9 
10-10 
Signal strength (dBm) at 
receiver input (linkl xx) 
Signal strength (dBm) at 
Figure 7.27 Link 2 fixed and link 1 varied 
-10 -20 -30 -40 -50 -60 -70 -80 -90 
-10 -20 -30 -40 -50 -60 -70 -80 -90 
receiver input (link2 ++.!..)+----L_-L_----'-_--L_--I_--.J'--_L..__.L.----I 
10-3 
10-4 
Average 10-5 
BER 10-6 
10-7 
10-8 
10-9 
10- 10 
Figure 7.28 Link 1 varied and link 2 varied 
. N.B. Link 1 ()---()-()--() ,Link 2 , plotted as least square fit. 
199 
When interpreting Figures 6.26 - 6.27 it is important to remember that 
the Trend data testers report an average BER. Any BER level worse than 10-3, or 1 
error bit in 1000, is treated as a failing link and reported as such. Any BER better than 
10-9 is treated as a satisfactory link. These BER values set the limits on the tests 
perfonned and restrict the range of values for the comparison. Between these limits 
the testers report the average BER over the period of the test, reporting BER to the 
nearest single bit error in 1000 bits received. 
The results clearly show that the 2 links are operating independently, 
and varying signal strengths on the first channel link (within the limits shown) does 
not affect the operation of the second channel. This confinns the simulation results. 
However, if the level was increased above -lOdBm then the demodulator would 
saturate and the links would both fail. 
The simulation results from [74] plot EblNo against log BER. Eb is the 
energy per bit and No is noise power density. By varying the received signal strength 
we are effectively varying the SIN ratio, S is signal power and N is noise power, 
assuming N remains constant for the duration of the test. The two equations are 
related as follows, where W is the bandwidth and R is the bit rate; 
EJNo = (SIN)(WIR) 
Comparing the two curves shows that the practical results produce a less smooth 
curve than the simulation results, this is to be expected due to the variability of the 
practical results. However, the general shape of the curves are similar and show that 
the simulation results vary in the same manner as the actual results. 
200 
7.6 Synchronisation . 
In order to test any improvement (of the type 3 synchronisation system) over earlier 
synchronisation systems, an experiment was set-up to test timing jitter tolerance. A 
simple delay line was built into the synchronisation feeds at the slave nodes 
(transmitter 2 and the receiver). The delay line comprised a series of high speed logic 
gates that could be switched in/out of circuh. The maximum delay that could be 
applied was 2 unit interval (VI), this equates to 2 clock pulses. 
The delay line was controlled by a signal generator, this meant a 
mobile fading enviroment could be simulated, because the delay could be cycled to 
simulate reception in a mobile vehicle. The test equipment and system layout is 
shown in Figure 6.29. Figure 6.30 is a scan of the spectrum of the received 10 MHz 
signal, used for synchronisation in the type 3 system. Figure 6.31 shows the specrum 
of the recovered combined data signals. The tests were performed with the Trend data 
testers supplying test patterns over the two simplex channels. The radio frequency 
levels were adjusted to similar levels and the data testers at the receIver were 
monitored whilst the variable delay was applied. 
The results were interesting. With delay less than 1 VI applied to the 
receiver synchronisation feed the receiver function was not impaired. Jitter 
frequencies below 1 KHz had no effect. However as soon as the delay passed 1 VI the 
receiver failed. The immediate failure at this precise point indicated a hardware limit, 
which was tracked to the sampling points at the Maxim decoder. This sets the limit on 
timing performance of the current receiver. The results show that the type 3 system is 
far more robust, from a synchronisation point of view, than the earlier systems. The 
type 1 hardwire synchronisation system, without the filters or mUltiple sample 
software, could not tolerate any jitter. 
201 
Trend 108 
data tester 
1 
Level 
shifter 
Transmitter 1 
(master clock) 
Signal 
generator 
10 MHz Timing 
bl) 
.s 
e 
E= 
~ 
0 
-
Attenuator 
1 
Signal 
generator 
r--
I 
I 
I 
I 
I 
_____ -1 
Trend 108 
data tester 
2 
I 
I 
I 
I L __ 
Combiner 
Receiver 
front-end + I1Q 
decode circuits 
Receiver 
analogue-digital 
convert + DSPs 
Trend 108 
data tester 
3 
Level 
shifter 
Transmitter 2 
(slave clock) 
Attenuator 
2 
Trend 108 
data tester 
4 
Figure 7.29 Test equipment layout (synchronisation testing) 
202 
.: 3 .. 55a 39 e 7 JUt. 2300 
ip 
~EF ,.5. 13;.11 r"A 7TE;'i lC d8 
?EA« 
" __ , ._ _ . ~ . , . .- , . - - . - -- - 1 
. Ai7t-:N 
: 11) dB 
. ' t o . 
\\'A S8 
SC FC _ 
CGRR 
, N~rNh~'+1~!}t¥/f~~~~f4 J~J.ff~~~#W~1~~~\1i\J~~: 
... - . • - j - ~ . . -
5T ':'.R7 8. 0<J<J Y.H::: 
RES B~: 31) l<H:: 
Figure 7.30 Spectrum of recovered 10MHz signal (type 3 sync) 
.1 ;'~ a es. ·j.3 07 ';UL 2ece 
/P 
REF -·73. 9 d8m "TTEN Hl dB 
PEAX f" '. '- r ' ... '''T' " r" 
LOG 
.. - - . 
~B/~. ~ . ~ , , 
~ . .;. . : . '. .( \\ . . . .. 
, " ' , 
, I ; . J 'J f l . 1 \ .j . ~~ ld ~ l, :' 
~ ____ _ ;. ___ ____ ~ __ .. __ .L ... __ • _ _ .. L ... _ ...... ·1 __ •• _ _ . • ~ _ . _ .. _ . . . .... _._ • • ••.• '- __ . .. J ..•... 
57 f,RT 09. 751)0 MH::: STep gO~ 2~~~ :· il-l: 
RES 81< 10 kH:z: VB'll 10 kH :z: S'Ii? 3<1 msa 
Figure 7.31 Spectrum of recovered data signal (type 3 sync) 
203 
7.7 Summary 
The results presented in this section show that the CV -CCMA system is a practical 
and viable multi-access system that can be implemented on current 
telecommunication systems with a relatively cheap floating-point digital signal 
processor and commercial integrated circuits. The algorithm used to decode the data 
is compendious because the softwa~e is written in Texas Instruments assembler 
language. Further development will require a professional development system, as 
already discussed in the implementation section. The software is reproduced in the 
appendices. The software will be rewritten in a higher-level language when time 
allows. This will enable the system to be modularised and allow further research. 
The results show up some weaknesses in the hardware developed for 
the initial implementation of the system. The stable frequency sources showed more 
drift than was expected and the voltage-controlled oscillators were not linear over the 
specified frequency ranges, better quality components will improve this. Problems 
with the noise and unreliability of the circuitry could be resolved by better 
implementation using a gate array or similar. 
The BER tests showed the system to be viable as a possible 
commercial system and with further development could be adapted for a number of 
service providers. Some of the simulation work done by other authors has been shown 
to be technically sound. With some circuit design and construction, the diversity 
simulations could also be checked. 
The more fundamental problems that the results showed up are 
discussed later, together with possible solutions and further work. The next chapter· 
concludes the thesis, with discussion and suggestions for future work. 
204 
8 CONCLUSIONS, DISCUSSION AND FUTURE WORK 
8.1 Introduction 
The CV-CCMA system has been shown to be a viable multi-access technique, 
theoretically and practically. The circuitry developed for the implementation of the 
system has been refined to an experimental (X) model state. Further development 
work is required before the system can be implemented over a commercial 
telecommunication network. However the techniques developed at the University of 
Warwick provide a solid basis for further work. This concluding chapter is 
subdivided in order to enable anyone requiring information, on specific areas, to be 
able to find the relevant section quickly. The enhanced CV -CCMA system, with the 
reduced restrictions on codeword generation (developed at Warwick) and the 
synchronisation recovery technique with multi-sample software, (also developed at 
Warwick), has been proven to be a viable multi-access technique. 
More theoretically, it would be useful to explore the capacity limits of 
the new system, particularly with regard to the relationship between the entropy of the 
g value and the capacity of the associated channels. It would also be interesting to 
quantify the possible improvements to the system by adding in diversity. This would 
involve a redesign of the receiver with two aerial systems which would recover the 
signal and then feed into the main signal processor. Some circuit construction would 
be required. 
The further development of ideas, using the g value to identify which 
data belongs to which transmitter, leads to possibly the most useful aspect of CV-
CCMA. This is the fact that, so long as the g value is unique, there is no requirement 
to separate users with codes, frequencies or timeslots. This could be the most 
significant advance of the CV -CCMA system, more significant than the improvement 
205 
in bandwidth efficiency (as we are getting close to the Shannon limit). Some 
experiments were performed, using the CV -CCMA demonstrator, which encouraged 
this line of research. The receiver requires to be redesigned, with some diversity built 
in (Le. multiple aerials) and the g decode algorithm needs to produce a more accurate 
result. This is one of the most interesting offshoots to the research. 
Further development work is needed on the clock recovery circuitry 
and on enhancing the multiple-sample software and filter implementations, to further 
reduce timing sensitivity. This would make the CV-CCMA system a more 
commercially viable project. 
8.2 Coding 
It should be possible to implement convolutional-type coding over this system 
without too much difficulty. Convolutional codes are used where high rates of error 
correction are required, as in a satellite link stream. However, it would have meant an 
increase in the processing required and additional buffer circuitry. The software 
algorithm written to decode the CV -CCMA codewords is relatively simple and quite 
elegant; it is easy to alter parameters and fault find. This would have been lost to an 
extent with additional coding and feedback circuitry. 
A number of fully developed systems are described in the literature 
[122], and manufacturers' data. With a more powerful processor this could have been 
implemented on the Warwick test-bed. This work will be carried out in the future 
when time and funds allow. This technique will prove to be useful to Cable and 
Wireless PLC, mainly over heavily loaded satellite links .. 
Further related work is also planned, when the new signal processor is 
running (because more memory/processing is required), to investigate the possibility 
206 
of applying a Viterbi-type recovery system within the CV-CCMA system. This would 
make the system more robust in higher noise/low signal strength situations and could 
be combined with the work already undertaken, and recorded in this thesis, on the 
codeword restrictions. With a set of correct sequences to be tracked and used for 
prediction, the recovery of codewords could be made much more robust. Intuitively, 
• 
this should bring many benefits; however, time limitations restricted these 
investigations. Further research along this route would be interesting and most of the 
system could be simulated with Mathcad, so the outlay required for equipment and 
other costs need not be too great. 
8.3 Optical systems 
Another area of possible further research would be implementation of 
a more basic collaborative system over a high-capacity optical link, as used by all 
major telecommunications companies. Current state-of-the-art systems run at data 
rates in terabits per second, with very low error rates. These systems use a process of 
wavelength-division multiplexing to pass very large amounts of data over special 
optical fibres. Very high quality lasers, with narrow beamwidth and high linearity, are 
used to prevent any crosstalk. Identifying codes are superimposed on the data streams 
to prevent self-lock problems, and make sure that only the intended receiver responds 
to the transmit laser. This optical technology is advancing very rapidly and coherent 
type systems are now being tested around the world. 
The collaborative code system could possibly be implemented to 
reduce further the problems of interference and crosstalk .. In addition, a fibre-optic 
cable could be doped to produce a defined phase shift at a specific wavelength, which 
could then be used with a CV-CCMA type receiver to recover the original transmitted 
207 
data. This work is again very interesting and would be of benefit to an operator 
running tests on high-capacity wavelength division multiplexing systems. 
Currently, research into optical radio systems is producing some useful 
results [123]. The systems are best deployed in office environments and use an infra-
red wavelength multi-access communications link to interconnect a number of 
computers; a packet-type protocol is usually implemented. The CV-CCMA system 
could be implemented over these links, reducing interference problems, and enabling 
the light-emitting diodes to operate on identical wavelengths, which would help to 
reduce costs. 
8.4 Mobile radio 
The mobile radio (operator) situation is in a constant state of flux, with revenues 
driven down to very low levels by regulatory action and by the strength of 
competition, particularly in the United Kingdom. GSM (global system mobile) has 
become the de-facto worldwide standard for current mobile radio networks and it 
defines frequencies, modulation techniques and even 'add-on's like voice mail and 
short messaging services. The main advantage of the system is the tightly defined 
standards enabling inter-network working on a worldwide basis. However, this 
stranglehold on the operation and defining technical standards has meant the GSM 
system has been slow to adapt to changes in the telecommunications environment, in 
particular the requirement for data transmission at ever-increasing rates and at ever-
decreasing costs. GSM struggles to transfer data at 9.6 Kb/s, which is not adequate 
for most requirements. One possible method of increasing the capacity of the GSM 
link would be to implement a CV-CCMA type data channel, in addition to the speech 
208 
channel, within the GSM telephone and radio base station. Some preliminary work 
has been done on investigating this. 
The problem with GSM mobile telephones is that they are quite 
complicated devices. Most of the circuitry is fully customised and it is impossible to 
physically connect to the required interface points, in order to experiment with the 
system. The earlier Philips devices have been found to be the easiest to work on as 
the CV-CCMA system can be interfaced using the 12C (inter-integrated circuit) bus, 
which is also used on the synthesiser and memory select chips of the CV -CCMA. The 
control code could be rewritten to select the CV -CCMA circuitry when switched to 
data mode. To experiment with this implementation an Ericsson radio base station 
was obtained from One20ne, the ex Cable and Wireless PLC mobile phone (GSM) 
operator in the United Kingdom. It is presently being stripped down. Work will 
continue into practical installation when time becomes available and this would make 
another interesting industrially based project. 
There are now a number of multi-standard phones on the market, 
switching between quite different systems. Future work could involve collaboration 
with a mobile phone manufacturer to tryout the system over a test network, possibly 
implementing CV -CCMA as an add-on to an existing GSM phone and using it for 
internet/data access. 
When testing the CV -CCMA system an amount of forced jitter was 
applied to the transmitted signal. Although crudely applied it showed that the system 
is not tolerant to jitter of greater than approximately 0.06 Unit Interval (ill), of any 
frequency. The later type receiver, with the synchronisation recovery circuit built in, 
was far more robust than the earlier system, tolerating nearly 1 ill. This is also due to 
the multiple sample system implemented in the later signal processor. This requires 
209 
some further work, because in a mobile situation the signal will be constantly jittered 
and would not work without much higher tolerance. This also assumes the jitter is not 
fast enough to affect the synchronisation over a symbol period, another area where 
further work is required. 
Some of the problems could be solved by adding memory into the 
channel. Gaarder and Wolf [113] giv~ a theoretical start in this direction and a lot of 
development work has been undertaken on the new spread spectrum systems to cure 
similar problems. 
The code division multiple-access (CDMA) system was investigated 
as a 'competitor' to the CV -CCMA system in the mobile telephone market. The 
CDMA system is derived from a secure military system and continues to have the 
associated advantages and disadvantages of the original system. The proposed 
worldwide broadband CDMA third generation (3G) standard was investigated and 
used as a basis for a comparative discussion; this work is recorded in Chapter 3. Quite 
a momentum has built up in the industry behind 3G mobile systems, so CV -CCMA 
would be more likely to be accepted in a more specific or unique application. Work 
could be undertaken looking into one of these. 
8.5 Low-cost radio telecommunications 
Another current project being considered is an investigation into implementing the 
CV -CCMA system over a distributed-architecture radio network. Dr Chandler and 
Rural Radio Systems have produced a system that is designed for 10caVrural access in 
developing countries [124]. The system has now been developed and tested at a 
number of locations and proved reliable and robust. The Rural Radio system 
comprises a set of nodes that are deployed throughout the area requiring service. The 
210 
system is unique in that some of the switching and routeing is done at each node 
throughout the network, rather than at dedicated switching nodes, which are one of 
the main expenses in a modem telecommunications network. The system is designed 
as a low-capacityllow-cost telecommunications network for developing countries 
with little infrastructure. The nodes are independent and may be quite isolated so 
power may be solar or some other local source. CV-CCMA could be implemented at 
the interface with the nodes and at the interconnection of the nodes. This would 
further reduce the complexity of the planning of the network as the frequencies would 
not require to be planned as in a cellular network. Effectively they could all' operate 
on the same frequency within each local coverage area, and over the wider network 
just assigned different sets of codes. 
The system is designed as a low-capacity system so each node would 
only switch and communicate with single-figure numbers of other stations. This work 
was planned for implementation in the near future; however Dr Chandler has now left 
Warwick and this would have to be carried out with the agreement of his new 
company, Rural Radio Limited. The Rural Radio system also uses Texas Instruments 
signal processors so it would not require much redesign to transfer the system across; 
however there are other issues which need to be resolved. This is another interesting, 
virtually stand-alone project that would produce benefits for both parties. 
8.6 Military applications 
The CV -CCMA system has many applications and during the research and 
development a number of. new applications have been thought of. The original 
intention was for the system to be used in telecommunication networks, particularly 
the mobile phone and satellite branches of the industry. It is possible that with further 
211 
research and development the CV -CCMA could be used as part of a secure 
communication system. At present, in this application, a weakness of the system is 
that with multi-access operating over a narrow band of frequencies it is easy for 
jamming or monitoring stations to capture the information and re-transmit modified 
information, or simply block all stations on that channel. This makes the system 
virtually unusable by the military and security services. With a redesign of the 
oscillators it should be possible to switch the system to a frequency-hopping mode in 
which the collaborative codes are transmitted as binary amplitude or phase-shift 
modulation at a series of pseudo-random frequencies which are pre-programmed into 
the transmitters and the receivers. 
To acquire synchronisation, the receiver would simply slow down its 
scanning rate of the spot frequencies until a sequence of valid codes was received, at 
which time it would speed up to recover the data. The system would offer a high 
degree of security because the scanning rate could be relatively fast - up to about 
twenty thousand hops per second. The synthesiser need not actually acquire 
synchronisation as in the current system but would be in a state of constant self-
adjustment: with each scan it would adjust its feedback loop and if a stronger signal 
was received on the next scan then it would adjust a bit further; if the signal was 
weaker then it would adjust back the other way, that is it would be like a self-servo 
system. For added security the data could be encrypted and the hop frequencies could 
be transmitted over the link and changed every few scans. 
Prototype synthesisers were simulated, but as the work did not fall into 
the telecommunications research area and really comprises a whole new project, and 
as available time was limited, the research was capped. However, some work was 
212 
done and this offshoot is interesting and could be progressed forward by somebody 
else in the future. 
8.7 Speech digitisation 
The prototype circuits used a speech-digitisation technique known as Delta 
modulation. Although this system works efficiently, the quality of the speech is poor; 
at 9.6 Kb/s it sounded very 'metallic'. When the modulator and demodulator were 
connected back-to-back the quality of the speech did not really improve until the 
output bit rate was increased to 16 Kb/s. To improve upon this requires further work 
and the testing and implementation of other speech-digitisation techniques. There are 
different versions of linear predictive type digitisers that offer reasonable quality at 
low bit rates, and these could be implemented using the DSP or another daughter 
DSP, dedicated to the audio processing of the system. The Delta modulators work and 
are reliable, though further research could be done towards improving the circuitry, 
perhaps a different system of variable slope integration. The paper by Dunn and 
Sandler [100] shows a possible line of progression. 
In order for a CV -CCMA system to interconnect with established 
telecommunications networks, it will be necessary to implement one of the standard 
speech digitisation processes, such as pulse code modulation (PCM) as specified in 
ITU standard 0711 or adaptive PCM or to implement an interface to convert between 
the standard systems. The lower bit rate schemes, such as linear predictive coding, 
could be implemented but are processor-intensive, probably requiring a separate 
processor and hence pushing the costs up. This work is more 'development' than 
'research' so was left out of the budgeted time allocation for the University of 
Warwick. 
213 
Speech digitisation is now a relatively stable subject and modern 
techniques give good quality at low bit rates. Some investigation could be undertaken 
into which would work best with the CV-CCMA system. Using CV-CCMA to 
transfer the new low bit rate video streams would also provide an interesting 
experiment. 
8.8 Filters 
There is a small amount of work remaining to be done on the filters. On the transmit 
side, root raised cosine-type filters were implemented in order to reduce the 
bandwidth of the modulated output signal. If no filters were included the transitions 
on the I and Q inputs would be sharp and hence the bandwidth occupied would be 
large, as can be seen on the spectrum diagrams in Chapter 7. The filters were 
designed with an alpha factor (steepness of cut-of 0 of 0.5. Problems were 
encountered because the filters were not matched: a slightly different delay was 
introduced on the I line to the Q line. The problem was solved by constructing a pair 
of finite impulse response (FIR) digital filters with TMS320C50 signal processors, 
and although the filters worked well (see Appendix 9 for taps and circuit), the 
additional complexity and interfacing caused some problems. Ideally the filter 
function would be incorporated in the main signal processor. Filter design is a topic in 
its own right and the design of a set of filters to optimise the performance of the CV-
CCMA system would make another interesting project/further work. 
8.9 Control 
An area requiring further work is in the generation of an automatic gain control 
signal, adding complexity to the generation of an accurate g value. At present there 
214 
are two, 16-bit conversions giving a range of 0 to 65536 or approximately 50 dB. 
This is reduced because the last two bits are lost in the noise generated and the Burr-
Brown integrated circuit gives a negative-to-positive shift, which has to be 
compensated for and reduces the accuracy of the conversion, so the range is 
approximately 40 dB in total. In a mobile situation, the amplitude range of the 
incorhing signals will be greater than this and so the automatic gain control (AGC) 
cannot be directly fed from the signal processor. Additional circuitry is required to 
control the gain of the amplifiers and report to the signal processor the strength of the 
incoming signal. Also, any phase variation in the signal will also need to be 
accurately reported. 
It is also possible that the incoming signal will be very large and so 
will require some attenuation adding in; this fact will need to be reported to the signal 
processor and used in the calculation of g. This is to try to prevent a problem that is 
similar to the near-far problem of CDMA systems, that is when a strong local signal 
swamps a more distant weaker signal, by desensitising the receiver and possibly 
overloading the front end. 
Some work was done on investigating the effect of timing variations, 
i.e. enough timing jitter superimposed on the signal to cause a 'slip' of a bit, over a 
symbol period. The papers by Poltyrev [125] and Hui I Humblet [126] derived some 
results for capacity regions of MACs with asynchronous stations. Further study is 
required of these asynchronous systems, but from a practical point of view it is very 
difficult to envisage how non-synchronised stations could be resolved at anything like 
a reasonable data rate. However, this is another very interesting area that deserves 
further work. 
215 
8.10 General 
A major enhancement to the system would be the implementation of receiver 
decoding using one of the new generation of powerful digital signal processors. This 
is underway at present and work is progressing well. Some reworking of the multi-
sample assembler code is required, which is stalling progress at the moment. The new 
processor gives an order of magnitude increase in processing power over the old 
processor (1.5 Gflops vs 40 Mflops) and it is hoped to implement most of the system 
control with the new processor. There are a number of new, low-cost, very high 
accuracy analogue-to-digital converters that have been launched recently, aimed at 
the high-fidelity audio market, they would find a ready use in the CV -CCMA system. 
Work is planned to implement these in the near future. 
The current software requires a major amount of work in order to 
make it more user-friendly, and is available from Kane Computing [128]. With the 
new processor it is planned to write code in a higher level language and use a 
compiler to produce implementable code. This did not work with the TMS320C31 as 
the code produced was too time-consuming for the system to work. The new 
processor will reduce these requirements and the system can be menu-driven from a 
PC, which can run the I2C program as a background task. The multi-sample software, 
which was developed to make the system less prone to timing problems, needs some 
further development work. On a more practical note, the circuitry would benefit from 
redesign and implementation in semi-custom silicon; the transmitters and receivers 
could then be combined and physically located in vehicles for some genuine field-
testing. This is currently beyond budget, but, in the future,. if time and funds allow it 
will be done. The work would be expensive, requiring either a grant or some 
industrial sponsorship, but would be most rewarding. 
216 
Another area requiring further research and development is in the area 
of timing and synchronisation. A number of possible improvements were 
investigated. The one which showed most promise was the separate synchronisation 
channel, similar to the synchronisation channel used in CDMA. As in CDMA it could 
be used for power level adjustment and background data traffic as well. A standard 
radio link was constructed at lOMHz and used to lock the transmitters and receivers 
together. Some problems were encountered with receiver desensitising; ideally the 
synchronisation channel frequency needs to be completely removed from the 
frequencies used in the decoders and away from any frequencies that would give rise 
to intermodulation problems. The type 3 synchronisation system was implemented by 
transmitting the PLL reference frequency (10 MHz) at one master node, and 
recovering the signal at the slave nodes. This was the simplest and most cost effective 
implementation. However, the frequency needs to moved to a licensed band to 
prevent legal problems. The hybrid receivers would need to be modified and 
improved upon. However, the system works well and is fine for laboratory use. 
Given sufficient time and resources, the recovered packet system (type 
2) would be another way of advancing the CV-CCMA as a commercially viable 
product. However, this will require substantial work. 
The original system free-runs the oscillators in the receiver and 
transmitter, assuming they will not drift out of synchronisation (1 bit) for the duration 
of the communication. This meant using quite expensive temperature-controlled 
oscillators, which would still be used, but phase-locked to the recovered 
synchronisation channel. Another solution would be to time from the GPS satellites, 
as in some CDMA systems; this requires more research. With the recovered timing 
solution (type 2) specific coding was used to maintain synchronisation, the 
217 
synchronisation was initialised by the training sequence and then maintained by the 
receipt of packets of data, and timing packets, from the master source. This did not 
cause a problem with the Delta modulators, as they would output the 'quiet' pattern 
with no input. With a data message transferred over the link it was essential to keep 
the output sequencing, in order to recover a valid clock. These problems could be 
solved with further development. 
Symbol timing, and start of message I end of message timing have 
caused practical problems getting the system to work. The initial idea of running a 
training sequence, although proven to work, takes up too much time and needs further 
work to develop better solutions. Start and stop codeword sequences need developing 
with the necessary detection circuitry. 
The idea of applying equalisation at the transmitter, to reduce 
multipath problems (and other impairments) could be further investigated. The latter 
CV-CCMA systems (developed at Warwick), would adapt most easily to this type of 
enhancement. The information required to perform the equalisation could be 
transferred over a modified timing channel, or over a specific control channel, or 
control 'packets'. This would be another interesting development to the CV-CCMA 
system and is worthy of some more research and development. 
8.11 Conclusions 
One of the main conclusions of the research has been to show the CV-CCMA system 
to be a practicable multi-access radio system. The simulations that were done at the 
start, both in Mathcad and Matiab, suggested that the. system was a realisable 
possibility. The design and construction of the new system, even with restricted 
numbers of transmitters and sets of codewords used, proved the system to be viable. 
218 
The theory behind the new less-restrictive codeword sets, which was derived and 
developed at Warwick alongside the coder design, also proved to be valid. It has been 
shown that a relatively cheap digital signal processor has sufficient processing power 
to run the CV -CCMA system. The circuitry designed for use with the system, 
especially the high stability-oscillators, will be put to good use as test-beds for future 
developments. The clock recovery circuits, developed as part of the second receiver 
circuit to reduce timing sensitivity, could be used for timing recovery from an 
independent timing channel. The first CV -CCMA system was prone to timing related 
problems, these were reduced by the implementation of the multi-sample software, 
the clock recovery system and the filters. 
The research has increased Cable and Wireless PLC's, knowledge base 
of multi-access systems and updated electronic circuit design and development 
techniques. The digital signal processor programming skills acquired will also be put 
to good use in the future. 
During the research it has been found that the information theory 
aspects of multiple-access theory have been very thoroughly investigated by a 
number of researchers, especially in recent years. Details such as channel capacity 
limits, error performance in multiple-access channels, etc., have been subject to 
rigorous mathematical treatment, often with results 'proven' by simulation. Now that 
the CV -CCMA system is working it would be interesting to try and explore some of 
these limits, particularly the relationship of g to channel capacity, discussed earlier in· 
this chapter. 
At the present time (1999-2000), Cable and Wireless PLC is 
undergoing a major reorganisation. The global network is being reconfigured towards 
an internet protocol (IP) based architecture. Large chunks of the company have been 
219 
sold and the remaining units are changing beyond recognition; even in the relatively 
short period of this research, the company has changed drastically. These changes 
mean that the' original reasons for starting the research are no longer valid; however, 
an IP-based system will still require customer access points, especially at radio 
frequencies, and the research undertaken over the last four years will be updated to 
work with these new systems as and when they start to be implemented in the 
network. 
220 
REFERENCES 
[1] G.Bennett, Pulse code modulation and Digitai Transmission, Marconi Instruments 
Publications, ISBN 0950494127, pp8-13, March 1972 
[2] ITU-T Recommendations 1998 Published by ITU, Place des Nations, CH-1211, 
Geneva 20 ,Switzerland (CD-ROM) or download from http://www.itu.int 
[3] S.Yang ,C.D.M.A. Engineering, Artech House Publications, ISBN 089006-991-3 
pp75-102, June 1998 
[4]. T.Kasami, S.Lin, S.Yamamura, 'Further results on coding for a multiple access 
channel', Conference proceedings Hungarian colloq. on Information Theory, pp 
369-391, August 1975 
[5] E.Weldon, 'Coding for a multiple access channel', Information and control ,Vol. 36, 
pp 256-274, March 1978 
[6] M.Deatt, J.Wolf, 'Some very simple codes for the non-synchronised two-user multi-
access adder channel with binary inputs' , IEEE Transactions on Information Theory , 
Vol. IT-24, No.5, pp 635-636, 1978 
[7] S.Chang, E.Weldon, 'Coding for T-user multiple access channels' IEEE Transactions 
on Information Theory ,Vol. IT-25, No.6, pp 684-691, November 1979 
[8] T.J. Ferguson, 'Generalised T-user codes for multiple-access channels' IEEE 
Transactions on Information Theory, Vol. IT-28, No.5, pp 775-778 Sept., 1982 
[9] S.C.Chang, 'Further results on coding for T-user multiple-access channels' IEEE 
transactions on information theory ,Vol. IT-30, No.2, pp 411-415, Mar. 1984 
[10] P.van der Coeberg, H.C.van der Tilborg, 'A family of good uniquely decodable code 
pairs for the two access binary channel' , IEEE Transactions on Information Theory 
Vol. IT-31, No.1, pp 3-9 ,Jan. 1985 
[11] G .H. Khachatrian, 'New construction of linear delta decodable codes for two user 
adder channel' Control and Information theory, Vol. 13, pp 275-279, 1984 
[12] J.Wilson, 'Error correcting codes for a T-user binary adder channel', IEEE 
Transactions on Information Theory ,Vol. IT-34, No.4, pp 880-890, July.1988 
[13] A.Cohen, J.Heller, AViterbi, 'A new coding techniquefor asynchronous multiple-
access communication' IEEE Transactions on Communications ,Vol. COMI9, No.5 
pp 849-855, Oct 1971 
[14] P.G.Farrell, ABrine, AP.Clark, DJ.Tait, 'Limits of radio communication-
collaborative transmission over cellular radio channels', presented at, NATO 
advanced study institute, 'Performance limits in communication theory and practical' 
II Ciosco, Italy, July 1986 
221 
[15] A.P. Clarke, F. McVerry, 'Channel estimation for a HF radio link', lEE Proc. Pt. F, 
Vol. 128, pp33-42, Feb 1981 
[16] F.R. Magee, J.O. Proakis, 'Adaptive maximum likelihood sequence estimation for 
digital signalling in the presence of intersymbol interference', lEE Trans. Vol. IT-19, 
pp 120-124, Jan 1973 
[17] R.B.J.T. Allenby, 'Linear Algebra' Modular mathematics series, published by 
Edward Arnold ,ISBN 0340610441, pp127-141 ,1998 
[18] S.Chandler, P.Thomas, 'Permissible codewords for CV -CCMA system', lEE 
Electronic Letters, Vol 33, No 22, pp 1863, October 1997, 
[19] Institution of Electrical Engineers, Savoy Place, London 
[20] Institute of Electrical and Electronic Engineers, 345 East 47th Street, New York 
NYI0017-2394, U.S.A. 
[21] Communications Society, Institute of Electrical and Electronic Engineers, 345 East 
47th Street, New York NYI0017-2394, U.S.A., www.comsoc.org 
[22] www.iee.org.uk/publish/journals/profjrnl/eleclett.html 
[23] www.iee.org.uk/publish/journals/profjmllieeproc.html 
[24] BIDS, Bath Institute Database http://www.bids.org 
[25] Cable and Wireless PLC Library Reference, 320 Westwood Heath Road, Coventry, 
West Midlands CV4 80P. also, Cable and Wireless Communications PLC Reference, 
Millars Close, Bracknell, Berks. . 
[26] www.labs.bt.comllibrary 
[27] British Telecommunications Technical Journal, BT Research Laboratories, 
Martlesham Heath, Ipswich, Suffolk, IPS 7RE 
[28] Qualcomm Inc., http://www.qua1comm.com 
[29] Hewlett-Packard Inc . • http://www.hewlett-packard.com (technology/docs) 
[30] Philips Electronics NV. , http://www.semiconductors.philips.com 
[31] Texas Instruments, Dallas, Texas, USA, http://www.ti.com 
[32] Analog Devices, One Technology Way, PO Box 9106, Norwood, MA, USA 
http://www.analog.com 
[33] Harris Electronic (Defence Systems Division) http://www.harris.com 
222 
[34] National Semiconductor, PO Box 58090 Santa Clara, California, USA http:// 
www.national.com 
[35] R.C. Sommer, 'High efficiency multiple-access communications through a signal 
processing repeater', IEEE Transactions on Communications, Vol COM-16, pp 222 
- 232, April 1968 
[36] A.I. Viterbi 'A processing satellite transponder for multiple-access by low-rate 
mobile users', Digital Satellite Communications, 4th international conference, 
Montreal, pp 166- 174, 1978 
[37] L.Gyorfi, LKerekes 'A block code for noiseless asynchronous multiple-access OR 
channel', IEEE Transactions on Information Theory, Vol. IT-27, No.6, pp 788-791, 
November 1981 
[38] I.Wolf, 'Constructive codes for multi-user communication channels' Part 2 
,Information theory, new trends and open problems, CISM courses and lectures 
No.219, Springer-Verlag, Iune 1975 
[39] Edward C. van der Meulen, 'A survey of multi-way channels in information 
theory: 1961 - 1976', IEEE Transactions on Information Theory, Vol. IT-23, No.1 
ppl- 37 ,Ianuary 1977 
[40] I.Schalkwijk, 'The binary multiplying channel, a coding scheme that operates beyond 
Shannons inner bound region' , IEEE Transactions on Information Theory, Vol. IT-
28, No.1, pp107-11O, Ianuary 1982 
[41] R.Gallager, 'A perspective on multi-access channels'J IEEE Transactions on 
Information Theory, Vol. IT-31, No.2, pp 124-142, March 1985 
[42] I.Massey P.Mathys, 'The collision channel without feedback', IEEE Transactions on 
Information Theory ,Vol. IT-31, No.2, ppI92-204, 1985 
[43] I.Massey, 'Channel models for random access systems', NATO advanced study 
institute, 'Performance limits in communication theory and practice' Castelvecchio 
Pascoli, Italy, July 1986 
[44] P.Vanroose, 'Code construction for the noiseless binary switching multiple-access 
channel' IEEE Transactions on Information Theory ,Vol. IT-34, No.5, pp 1100-1106 
September 1988 
[45] C.E. Shannon, 'A mathematical theory of communication', Bell System Technology 
Journal ,vol. 27, pp 379-423, Iuly and October 1948 
[46] C.E. Shannon, 'Two-way communication channels', Procedings 4th Berkeley Math 
Symposium, University California Press, pp 611-644, 1961 
[47] P.Bergmans and T.Cover, 'Co-operative broadcasting', IEEE Transactions on 
Information Theory, vol. IT-20, no.3, pp 317-324,1974 
223 
[48] A.Wyner, 'Recent results in the Shannon theory', IEEE Transactions on Information 
Theory, vol. IT-20, no.1, pp2-1O, Jan. 1974 
[49] Edward C.van der Meulen, 'A survey of multi-way channels in information theory 
1961-1976', IEEE Transactions on Information Theory, vol. IT-23, no.1, ppl-37, Jan 
1977 
[50] MUltiple Access Communications, foundations for emerging technologies, IEEE 
Press, edited by Norman Abrason, ISBN 0879422920, Feb. 1994 
[51] S.Verdu, 'Recent progress in multi-user detection' from <Advances in communication 
and signal processing' ,Heidelberg Press, 1989 
[52] A. EI Gamal,T.Cover, 'Multiple user information theory', Proceedings of the IEEE 
,vol. 68, no.12, pp1466-1483, December 1980 
[53] Edward C.van der Meulen, 'Capacity Limits for Multiple Access Channels',in 
'NATO advanced study institute' on 'Performance limits in communication theory 
and practice', Ciocco, Italy, 1986 
[54] W.Lee, 'Estimate of channel capacity in a Rayleigh fading enviroment', Proceedings 
of the IEEE ,vol. 79, no.12, December 1990 
[55] F.Ali, B.Honary, 'Low complexity soft decision decoder for multi access', lEE 
Electronic letters, vol. 27, no. 13, pp1167-1169, June 1991 
[56] J.Ni, B.Honary, 'State independent codes for multi-access', lEE Proceedings 1, 
Communications, Speech and Vision, Vol. 140, No.3, pp185-188, June 1993 
[57] G.Ungerboeck, 'Channel coding with multilevel/phase signals', IEEE Transactions 
on Information Theory, vol. IT-28, no.1, Jan1982 
[58] A.J.Viterbi, J.K.Omura, 'Principles of digital communication and coding', section 2, 
published by McGraw-Hill, ISBN 0-07-066626-1, pp411-423, Jan. 1979 
[59] P.G.Farrell, 'Survey of channel coding for multi-user system' in Skwirzynski J. 'New 
concept in multi user communication " Sitjhoff and Nordhoff, ppl13-159, 1981 
[60] T.Kasami, S.Lin, 'Coding for a multiple-access channel', IEEE Transactions on 
Information Theory, Vol. IT-22, No.2, pp129-137, March1976 
[61] J.Wolf, 'Coding techniques for multiple-access communication channel' in 
Skwirzynski 'New concept in multi-user communication' , Sitjhoff and Nordhoff, pp 
83-103, 1981 
[62] S.Chang, E.Weldon, 'Coding for T-user multiple-access channel', IEEE Transactions 
on Information Theory, vol. IT-25, No.6, pp 684-691, Nov.1979 
[63] E.Weldon Jr., 'Coding for multiple-access channel' Information and Control, vol. 36 
pp 256-274, March 1978 
224 
[64] J.Ni, 'Codeword synchronisation of CCMA Scheme', lEE Proceedings, 
Communications, Speech and Vision, Vol. 140, No.6, pp425-428, Dec. 1993 
[65] F.Ali ,B.Honary, 'Low complexity soft decision decoding technique for T-user 
collaborative coding multiple-access channels', lEE Electronic Letters ,Vol. 27 
No. 13, pp1167-1169, June 1991 
[66] M.Daett, J.Wolf, 'Some very simple codes for the non-synchronised two user 
multiple-access channel with binary inputs' IEEE Transactions on Information 
Theory, Vol. IT-24, No.5, pp635-636, September1978 
[67] J.Ni, B.Honary, 'On state independent unique decodable CCMA codes' lEE 
Proceedings, Communications, Speech and Vision, vol. 140, no. 3, pp 185-188, June 
1993 
[68] Y.Wu, S.Chang, 'Coding scheme for multiple-access adder channel with and without 
idle users' lEE Electronic Letters ,vol. 31, no.7, pp523-524 
[69] Y.Steinburg,' Resolvability theory for the multiple-access channel' IEEE 
Transactions on Information Theory ,vol. 44, no. 2, pp 472-487, March1998 
[70] K.Feher, 'Advanced digital communications systems and signal processing 
techniques' ,Prentice-Hall Inc., ISBN 0130111988,1989 
[71] http://www.tm.agilent.comlMasterservlet 
[72] http://www.orc.soton.ac.uk 
[73] IEEE Communications Magazine, Vol. 36, No.12, December 1998 
[74] F.Ali, S.Chandler, S.Soysa, 'Complex-valued receiver for multiuser collaborative 
coding schemes', lEE Electronic Letters, Vol. 31, No.5, pp341-342, March 1995 
[75] G.Khachatrian, S.Martorissian, 'Code construction for T-user noiseless adder 
channel' , IEEE Transactions on Information Theory, vol. 44, no.5, pp 1953-1957, 
September 1998 
[76] http://www.qualcomm.com 
[77] R.A.Scholtz, 'The Spread Spectrum Concept', IEEE Transactions, vol. 25, no.8 
pp748-755, August 1977 
[78] R.Pickholtz, D.Schilling, L.Milstein, 'Theory of spreadspectrum communications-a 
tutorial', IEEE Transactions on Communications, vol. com 30, no.5, pp 855-884 
May 1982 
[79] S.Verdu, 'Recent progress in multiuser detection', from 'Advances in communication 
and signal processing', Heidelberg Press, Jan. 1989 
225 
[80] S.Yang, 'CDMA RF System Engineering', Artech House Publications 
ISBN 0-89006-991-3, ppI49-180, 1998 
[81] A.Viterbi, 'Spread spectrum communications - myths and reality', IEEE 
Communications Magazine, vol. 17, no.3, pp 11-18, May 1979 
[82] A. Viterbi, 'Wireless digital communication, a view based on three lessons learned' 
IEEE Communications Magazine, vol. 29, no.9, pp33-36, Sept 1991 
[83] S.Moshari, 'Multi-user detection for DSCDMA communications', IEEE 
Communications Magazine ,vo1.34, no. 10, pp116-123, October 1996 
[84] F.Adachi, M.Sawahashi, H.Suda, 'Wideband DS-CDMA for next generation mobile 
communication systems', IEEE Communications Magazine ,voI.36, no. 9, pp56-69, 
September 1998 
[85] H.Habudi, T.Hasequi, Y. Makura, 'A code division multiplex using Manchester 
coded orthogonal sequences', Electronic Communications, Japan, vol. 75, no. 7, pp 
58-61 
[86] Lin, Franz and Senior, 'TMS320 signal processor' IEEE Transactions on Infonnation 
Theory, vol. 75, No.9, pp538-552, 1987 
[87] J.Bradley, 'TMS320C30 hardware applications', TI press, 1991 
[88] Randy Nestle, 'IEEEjloating point or Texas Instrumentsjloating point', TI press, 
1993, (also electronic format from website) 
[89] Rulph Chassaing, 'Digital signal processing with C and the TMS320C30', published 
by John Wiley, ISBN 0-471-57777-4, 1993 
[90] Okhay AIkin, ' Digital Signal Processing a laboratory approach using PCDSP' 
published by Prentice Hall, ISBN 0-13-328139-6, 1994 
[91] H.Sorenson, J.Chen, 'A digital signal processing laboratory using the TMS320C30' 
published by Prentice Hall, ISBN 0-13-741828-0, 1997 
[92] BT Technology Journal ,Vol. 10, No.1, January 1992 
[93] A.Williams, F.Taylor, 'Electronic filter design handbook' ,published by McGraw 
Hill, ISBN 0-07-070434-1, 1989 
[94] Z.Kostic. S.Seelaraman, 'DSP in cellular radio', IEEE Communications Magazine 
vo1.35, no.12, pp22-35, December 1997 
". 
[95] Microwave and RF Magazine, http://www.wirelessdesignmag.com 
[96] Microwave Journal, http://www.mwjoumal.com 
226 
[97] Gene Heftman, 'Changing times challenge the crystal industry' , in Microwave and 
RF Magazine, pp 31-38, November 1998 
[98] Bob Buxton, 'Measurement methods and analysis of digital radio signals', in 
Microwave and RF Magazine, pp32-47, July 1995 
[99] Liu, 'Impact of I and Q inbalance on QPSK' IEEE Transactions on 
Communications ',vol.44, no.3, pp984-989, August 1998 
[100] C.Dunn, M.Sandler, 'Fixed and adaptive sigma delta modulators with multi-bit 
quantisers' in Applied Signal Proc~ssing(UK), vol.3, no. 4, pp212-222, 1996 
[101] J.Armstrong, D.Strickland, 'Symbol synchronication using signal samples and 
interpolation' , IEEE Transactions on Communications, vol. 41, no. 2 pp318-321 
[102] TIAIEIA IS95, 'Mobile base station compatibility standardfor dual mode wideband 
spread spectrum cellular system', published by Telecommunications Industry 
Association! Electronic Industry Association, 1994 
[103] http://www.semiconductor.philips.comlI2C 
[104] H.N yquist, 'Certain topics of telegraph transmission theory', Transactions of the 
American Institute of Electrical Engineers, vol.47, pp617-644, April 1928 
[105] B.Sklar, 'Digital Communications', Publisher Prentice Hall International 
I.S.B.N. 0-13-212713X, ppI55-182, 1988 
[106] J.G.Proakis, 'Digital Communications' Publisher McGraw Hill International ISBN 0-
07-113814-5, pp127-148, 1st edition 1983, 2nd edition 1989 
[107] D.Slepian and I.Wolf, 'A coding theorem for multiple access channels with 
correlated sources', Bell system technology, vol. 52, pp 1036-1076, Sept.1976 
[108] R.Ahlswede, 'Multi-way communication channels' in proceedings 2nd International 
Symposium Information theory. ,pp 23-52, Armenia, 1984 
[109] A.Wyner, 'Recent results in the Shannon theory' IEEE Transactions on Information 
Theory, vol. IT-20, No.1, pp2-1O, Jan 1984 
[110] C.Keilers, 'The capacity of the spectral Gaussian multiple access channel' PhD 
Thesis, Department of Electrical Engineering, Stanford University, Stanford, 
California, April 1976 
[111] F.Ali, S.Soysa, S.Chandler, 'Channel capacity limits for multiple-access channels 
with slow rayleigh fading', lEE Electronic Letters, Vol. 31, No.5, pp 1435 -1437 
August 1996 
[112] G.Ungerboeck, 'Channel coding with mUltilevel/phase signals', IEEE Transactions 
on Information Theory, vol. IT28, pp55-67, 1982 
227 
[113] N.Gaarder and J.Wolf, 'The capacity region of a multiple access discrete 
memoryless channel can increase with feedback' IEEE Transactions on Information 
Theory, Vol. IT-21, No.1, pplOO-102, January 1975 
[114] J.A. Thomas, 'Feedback can at most double Gaussian mUltiple access channel 
capacity', IEEE Transactions on Information Theory, Vol. IT-33, No.5, pp711-716, 
September 1987 
[115] D.Strang, 'Linear Mathematics', section 2.5.1, ppI27-141, Publisher McGraw Hill, 
ISBN 0-34061044-1, Mar. 1982 
[116] Philips Semiconductor Division, 'ic Bus Technical Specifications and 
Implementation' , available at ftp website or datasheet published by Philips, 1990 
[117] Hewlett Packard 'Digital modulation in communications systems', Application note 
1298, pp20-32, available from HP European Marketing Centre, PO Box 999, 1180A2 
Amsteveen, The Netherlands 
[118] Forrest Barker, 'Communications electronics, systems devices and circuits' published 
by Prentice-Hall, ISBN 0-13-153982-5, ppI12-128, 1987 
[119] http://www.ti.comldev/sigproC/filter/menu.html 
[120] Burr-Brown Corporation, 6730 South Tucson Boulevard, Tucson, Arizona, AZ 
85706 (Farnell at Leeds stock all data books for B-B) 
[121] Electronic Industry Association, 'Recommended Standard 232', available from 
http://www.eia.com or ITU Geneva as equivalent V24N28 standards 
[122] Oktay AIkin, 'Digital signal processing a laboratory approach using PC-DSP', pub. 
Prentice-Hall, pp137-142, ISBN 0-13-328139-6, 1994 
[123] IEEE Communications Magazine, Special Edition, Optical Radio, Feb. 1998 
[124] Rural Radio Limited, Hill Street, Coventry, England 
[125] G.Polytyrev, 'Coding in an asynchronous multiple-access channel' Problemy 
Peradachi Informatsii. Vol. 19, No.3, July-Sept. 1983 
[126] J.Hui, P.Humblet, 'The capacity region of a totally asynchronous mUltiple-access 
channel', IEEE Transactions on Information Theory, Vol. IT-31, 1985 
******************************************************************** 
228 
[127] P.Thomas, 'Radio multi-access system aimed at the telecommunications market' 
Cable and Wireless World, Vol. 12, No.51, pp9-1O, August 1998 
[128] P.Thomas, 'Multi-access decode software' , Applications CD-ROM, Texas 
Instruments, Kane Computing, March 1999 
[129] P.Thomas,S.Chandler, 'The implementation of a multiple-access radio system' in 
proceedings of The Second Texas Instruments DSP Conference, pp 130-133, Paris, 
Sept. 1998 
[130] P.Thomas, 'The implementation of a multiple-access radio system', Cable and Wireless 
internal report, July 2000 
229 
NO 
ABM 
ACELP 
ADM 
ADPCM 
AF 
AFC 
AGC 
AM 
AMPS 
AMR 
ANSI 
ARQ 
ASIC 
ASK 
AT&T 
ATM 
BABT 
BB 
BER 
BiCMOS 
BID 
BPSK 
BS 
BSC 
BT 
BT 
BTS 
BZT 
CII 
CAW 
GLOSSARY OF ACRONYMS 
Analog to digital conversion 
Asynchronous balanced mode 
Algebraic code(-book) excited linear predictive 
Asynchronous disconnected mode 
Adaptive differential pulse code modulation 
Audio frequency 
Automatic frequency control 
Automatic gain control 
Amplitude modulation 
Advanced mobile telephone system 
Adaptive multirate (speech codec) 
American National Standards Institute 
Automatic repeat request 
Application-specific integrated circuit 
Amplitude shift keying 
American Telegraph and Telephone 
Asynchronous Transfer Mode 
British Approvals Board for Telecommunications (UK) 
Baseband 
Bit error ratio 
Bipolar complementary metal-oxide semiconductor 
Bath (University) information database 
Binary phase shift keying 
Base station 
Base station controller 
Bandwidth (B) multiplied by bit period (T) 
British Telecom 
Base transceiver station 
Bundesamt fur Zulassung in der Telekommunikation 
Carrier-to-interference ratio 
Cable and Wireless 
230 
CB 
CC 
CCMA 
CCIR 
CCfIT 
CDMA 
CELP 
CEPT 
CMOS 
CO DEC 
CPU 
CRC 
CS 
CSPDN 
CT 
CTIA 
CV-CCMA 
CWC 
D/A 
DCA 
DECT 
DFE 
DGPT 
DIL 
DISC 
DLC 
DM 
DQPSK 
DS-CDMA 
DSB 
DSP 
DSSS 
DTC 
DTE 
Cell broadcast 
Convolutional code 
Collaborative coding multiple access 
International Radio Consultative Committee 
International telegraph and telephone Consultative Committee 
Code division multiple access 
Code(-book) excited linear predictive (speech codec) 
European Conference of Posts and Telecommunications 
Complementary metal oxide semi-conductor 
Coder-decoder 
Central processing unit 
Cyclic redundancy code/check 
Coding scheme 
Circuit switched public data network 
(1) Call transfer, call completion (2) cordless telephone 
Cellular Telephone Industry Association (USA) 
Complex valued collaborative coding multiple access 
Cable and Wireless Communications 
Digital-to-analogue conversion 
Dynamic channel allocation 
Digital Enhanced Cordless Telecommunications 
Decision feedback equaliser 
Directorate General of Post and Telecommunications (France) 
Dual in line 
Disconnect 
Data link control 
Disconnect mode 
Differential quadrature phase shift keying 
Direct sequence code division mUltiple access 
Double sideband 
Digital signal processor 
Direct sequence spread spectrum 
Digital traffic channel 
Data terminal equipment 
231 
DTI 
DTMF 
DTX 
DWDM 
EPROM 
EEPROM 
EFR 
EIA 
EINT 
EMC 
ETSI 
EVRC 
FCC 
FCCH 
FCS 
FDM 
FDMA 
FDX 
FEC 
FIFO 
FIR 
PM 
FR 
FTP 
PVC 
GaAs 
GFSK 
GPRS 
GPS 
GSM 
HEMT 
RPm 
"IC 
lEE 
Department of trade and Industry, United Kingdom 
Dual-tone multifrequency 
Discontinuous transmission 
Dense wavelength division multiplex 
Erasable programmable read-only memory 
Electrical erasable and programmable read-only memory 
Enhanced full-rate speech codec 
Electronics Industry Association (USA) 
External interrupt (to the DSP) 
Electromagnetic compatibility 
European Telecommunications Standards Institute 
Enhanced variable rate (speech) codec 
Federal Communications Commission (USA) 
Frequency correction channel 
Frame check sequence 
Frequency division multiplex 
Frequency division multiple access 
Full duplex 
Forward error correction 
First in first out (electronic buffer) 
Finite impulse response (type of digital filter) 
Frequency modulation 
Full-rate speech codec; standard speech codes used in GSM 
File transfer protocol 
Forward voice channel 
Gallium Arsenide, used in high speed integrated circuits 
Gaussian-filtered frequency shift keying 
General packet radio service 
Global positioning system 
Global system for mobile communications 
High electron mobility transistor 
Hewlett Packard interface bus (high speed parallel) 
Integrated circuit 
Institute of Electrical Engineers (UK) 
232 
IEEE 
IF 
1M 
IN 
I/O 
IP 
IP3 
ISDN 
IIC 
lSI 
ITU 
IWF 
JTC 
LAN 
LAPM 
LEC 
LED 
LEO 
LFSR 
LNA 
LNB 
LO 
LP 
LPC 
MAC 
MAD 
MIP 
MLSE 
MMI 
MMIC 
MODEM 
MOS 
., MOSFET 
MoU 
Institute of Electrical and Electronic Engineers (USA) 
Intermediate frequency 
Intermodulation 
Intelligent networks 
Input/output 
Internet protocol 
Intercept point of the third order 
Integrated services digital network 
Inter Integrated Circuit (Philips 3-wire bus) 
Inter-symbol interference 
International Telecommunication Union 
Interworking function 
Joint Technical Committee (TIA body) 
Local-area network 
Link access procedure for modems, protocol for data exchange 
Local exchange centre, local switch in a PSTN or ISDN 
Light emitting diode 
Low-earth orbit 
Linear feedback shift register 
Low-noise amplifier 
Low noise block (amp. and freq. conversion) 
Local oscillator 
Linear prediction/predictive (speech coding) 
Linear predictive (speech) coding 
Medium access control 
Multiply accumulate with dynamic address (TI assembler) 
Million instructions per second 
Maximum likelihood sequence estimation 
Man/machine interface 
Monolithic microwave integrated circuits 
Modulator demodulator 
(1) metal-oxide semiconductor; (2) mean opinion score 
Metal-oxide semiconductor field effect transistor 
Memorandum of Understanding 
233 
MSC 
MSK 
MUX 
NASA 
NB 
NF 
NRZ 
NT 
NTP 
NIT 
NULL 
OA 
OQPSK 
OSI 
PA 
PACS 
PAD 
PAMR 
PBX 
PC 
PCB 
PCM 
PCN 
PCS 
PDS 
PID 
PIN 
PLC 
PLL 
PLMN 
PMR 
POTS 
. ppm 
PRBS 
Mobile services switching centre 
Minimum shift keying 
Multiplexer 
North America Space Agency 
Narrowband 
Noise figure (signal to noise i/p to signal to noise o/p) 
Non-return zero (logic signal) 
Nontransparent services or Northern Telecom 
Nominal transmitted power 
Nippon Telephone and Telegraph company 
Null information 
Originating address 
Offset quadrature phase shift keying 
Open systems interconnections 
Power amplifier 
Personal Access Communications System 
Packet assembler/dissembler 
Public access mobile radio 
Private branch exchange 
Personal computer 
Printed circuit board 
Pulse code modulation 
Personal comms. network, also referred to as DCS 1800 
Personal comms. system, referred to as PCS 1900 
Packet data on signalling channels 
Protocol identifier 
Personal identification number 
Public liability company (UK) 
Phase-locked loop 
Public land mobile network, cellular network 
(1) Private mobile radio; (2) professional mobile radio 
Plain old telephony service 
Parts per million 
Pseudorandom bit sequence 
234 
PSK 
PSPDN 
PSTN 
PTM 
PTP 
PIT 
PWT 
QAM 
QCELP 
QPSK 
RA 
RACE 
RAM 
RAND 
RDS 
REJ 
RF 
RINT 
RISC 
RLL 
RLP 
RNR 
ROM 
RPE-LTP 
RR 
RS 
Rx 
SABM 
SAPI 
SAW 
SCH 
'SDMA 
SEQAM 
Phase shift keying 
Packet-switched public data network 
Public-switched telephone network, standard wireline network 
Point-to-multipoint 
Point-to-point 
Push-to-talk 
Private wireless telecommunications 
• 
Quadrature amplitude modulation 
Qualcomm codebook excited linear predictive 
Quadrature phase shift keying 
Rate adaptation 
Research and Development of Advanced Communications 
Technologies and Services 
Random access memory 
Random value 
Radio display system 
Reject, layer 2 frame/information 
Radio frequency 
Receive interrupt (to the DSP) 
Reduced instruction set computer 
Radio local loop 
Radio link protocol, link protocol to reduce the error rate 
Receive not ready, layer 2 frame/information 
Read-only memory 
Regular pulse-excited-Iong-term prediction 
Receive ready, layer 2 frame/information 
Recommended standard (EIA standards) 
Receiver 
Set asynchronous balanced mode 
Service access point identifier 
Surface acoustic wave (ceramic-based filter) 
Synchronisation channel 
Space diversity multiple access 
Spectrally efficient quadature amplitude modulation (IS-661) 
235 
SIM 
SMS 
SNR 
SREJ 
SRTS 
SSB 
SS No.7 
TA 
TCXO 
TDM 
TDMA 
TE 
TETRA 
TI 
TIA 
TSS 
TTL 
Tx 
UA 
UCI 
UHF 
ill 
UMTS 
VA 
VAD 
VCO 
VGA 
VOGAD 
VPN 
VSELP 
WACS 
WCDMA 
··WIN 
WLAN 
Subscriber identity module 
Short message service 
Signal-to-noise ratio 
Selective reject, layer 2 frame/information 
Serial residual time stamp (used to sync real time ATM) 
Single sideband 
Signaling System Number 7 
Type approval or terminal adapter 
Temperature controlled crystal oscillator 
Time division duplex 
Time division multiple access 
Terminal equipment 
Terrestrial trunked radio (ex trans.:.European trunked radio) 
Texas Instruments 
Telecommunications Industry Association (USA) 
Telecommunications standardisation sector (part of ITU) 
Transistor transistor logic 
Transmitter 
Unumbered acknowledge, layer 2 frame/information 
Universal computer interface 
Ultra high frequency 
(I) Unnumbered information (2) user interface (3) Unit interval 
Universal Mobile Telecommunication System 
Viterbi algorithm 
Voice activity detection 
Voltage-controlled oscillator 
Variable gain amplifier 
Voice Operated Gain Adjusting Device 
Virtual private network 
Vector sum excited linear predictive (IS-136) 
Wireless Access Communications System 
Wideband CDMA 
Wireless intelligent network (usually refers to IS-41IIS-136) 
Wireless local-area network 
236 
FASTS.ASM 
; CV-CCMA main decode program. 
Appendix 1 
26 Feb 1998 
P.Thomas 
; This prog initialises the serial port of the c3Idsk,;receives the ;veetor on (3 values BPSK) a 
RINT and;multiplies by the stored ISP ;matrix, finds; the minimum Euclidean distance (no 
root=call ;fast,root=eall ;euclid<x50»; and either stores the results decodes them and stores at 
the transmit buffer.; The clocking into the DSP is derived from the 50MHz ;system clock; and 
the data is clocked out by tcklo; NB START FRAMES AT SAME TIME, sync 00 11 00 11 00 
to ;start; Serial port global control register initialisation ;first; One sample buffer only, ie 32 
bits (1=16 Q=I6) 
.start "text" ,809802h 
.start "servectl" ,809FC2h 
.start "serveet2",809FC6h 
.start "data" ,809900h 
.sect "data" ; 
All .FLOAT 0.5,0,-0.5,0,0,0,-0.5,0,0.5 
AI2 .FLOAT 0,0,0,0,0.5,0.5,0,0.5,0.5 
A21 .FLOAT 0,0,0,0,0.5,-0.5,0,-0.5,0.5 
A22 .FLOAT 0.5,0,0.5,0,0,0,0.5,0,0.5 
test B1 .FLOAT 1,2,3 
test B2 .FLOAT 0.5,2,2 
test B3 .FLOAT 0.2,1,2 
AIADDR .WORD All 
A2ADDR .WORD Al2 
A3ADDR .WORD A21 
A4ADDR .WORD A22 
;BIADDR .WORD BI 
;B2ADDR .WORD B2 
; B3ADDR .WORD B3 
OUT 1 .WORD 809BOlh 
OUT2 .WORD 809B04h 
OUT3 .WORD 809B07h 
OUT4 .WORD 809BOAh 
RV ADDR .WORD 809FDOh 
SaCRO .SET 808040h 
SPCXO .SET 808042h 
SPCRO .SET 808043h 
TGCRO .SET 808020h 
TCNTO .SET 808024h 
TPRO .SET 808028h 
SINITO .WORD OC3COC44h 
SINITl .WORD 01lIh 
DATAIP .SET 80804Ch 
DAT AOP .SET 808048h 
.sect "text" 
LDP @SGCRO 
LDI Oh,R4 
STI R4,@SGCRO 
LDI @SINITI,R7 
STI R7,@SPCXO 
STI R7,@SPCRO 
LDI @SINITO,R7 
STI . R7,@SaCRO 
STI R4,@TCNTO 
.entry START 
;location of !NT 3 int. vect 
;location of RINT int. veet 
;ISP matrix, pre-calc Mathcad 
;BPSK figures 
; Test Data 
; serial port 0 global control 
; FSXlDXlCLKX control reg. 
; FSRlDRlCLKR control reg. 
; timer 0 global control reg. 
; timer 0 counter register 
; timer 0 period register 
; 32 bit transfers, Rx ints on 
237 
START 
SLOOP 
LOOP 
LOOP 1 
RXLOOP 
Appendix 1 
LDI 3,R7 
LDI 2Clh,R6 
STI R6,@TGCRO 
LDI OBSh,RS 
STI RS,@TPRO 
LDI OO,IE 
LDI OO,IF 
OR OSh,IE 
IDLE 
LDI 2Clh,R4 
STI R4, @TGCRO 
LDI 00, IF 
OR 28h,IE 
NOP 
LDP 809AFE,DP 
LDI @DATAIP,ARO 
LDI @DATAIP,ARI 
LSH OlOh,ARO 
LSH OFFOh,ARO 
LDI ARO,RO 
LSH OFFOh,ARl 
LDI ARl,Rl 
FLOAT RO,RO 
FLOAT Rl,Rl 
ADDF3 RO,Rl,R3 
LDI OFFh,RO 
FLOAT RO,RO 
CMPF RO,R3 
BZ LOOPNEG 
LDI DP,AR5 
STF R3,*ARS 
ADDI 1,DP 
SUBI 1,R7 
BNZ LOOP 
; clear interupts and flags 
; enable ext int 3 
; data valid on EINT3,active low 
; set tcklO going 
; clear flags 
; enable RINT interupts,turn off EINT3 
;load receive ;data into arO 
; arl 
;shift left 16 ;discard upper 16 
;shift back right 16 
;store in precision reg 0 
;shift right 16 
;convert to floating point 
;BPSK code +1=00, -1=11 
;BPSK code 112 full scale convert 
;BPSKcode 
; This section performs the . multiplications,the received vectors are 
at;809AFE,809AFF,S09BOO,the result at OUT1(3)-4,decode at 80S048 ;Remember data 
output is two 16 bit words 
; First multiplication 
LDP 
LDI 
LDI 
LDI 
LDI 
809900h,DP 
@AIADDR,ARO 
@809AFEh,ARl 
@OUT1,AR2 
3,R3 
LOOPI 
LOOPJ 
LDF O,RO 
LDI 2,AR6 
MPYF3 *ARO++,*AR1++,Rl 
ADDF Rl,RO 
DB AR6,LOOPJ 
STF RO,*AR2 
ADDI I,AR2 
LDI @S09AFEh,ARI 
SUBI I,R3 
BNZ LOOPI 
238 
Appendix 1 
; the result of the first multiplications are now at 809bO 1 809b02 809b03 
; now calculate the euclidean norm 
LDF @809BOlh,RO 
LDF @809B02h,RI 
LDF @809B03h,R2 
CALL FAST 
LDF RO,R4 
; Second multiplication 
LDP 
LDI 
LDI 
LDI 
LDI 
809904h.DP 
@A2ADDR.ARO 
@809AFEh,ARI 
@OUT2,AR2 
3.R3 
LOOPK 
LOOPL 
LDF O,RO 
LDI 2.AR6 
MPYF3 *ARO++,*ARI++,RI 
ADDF RI,RO 
DB AR6,LOOPL 
STF RO,*AR2 
ADDI 1.AR2 
LDI @809AFEh,ARI 
SUBI 1,R3 
BNZ LOOPK 
; the result of the second multiplication is now at 809b04 809b05 809b06 
; now calculate the euclidean norm 
LDF @809B04h,RO 
LDF @809B05h,RI 
LDF @809B06h,R2 
CALL FAST 
LDF RO,R5 
; Third multiplication 
LDP 
LDI 
LDI 
LDI 
LDI 
809907h,DP 
@A3ADDR,ARO 
@809AFEh,ARI 
@OUT3,AR2 
3,R3 
LOOPM 
LOOPN 
LDF O,RO 
LDI 2,AR6 
MPYF3 *ARO++,*ARI++,RI 
ADDF RI,RO 
DB AR6,LOOPN 
STF RO,*AR2 
ADDI l,AR2 
LDI @809AFEh.ARI 
SUBI 1,R3 
BNZ LOOPM 
; the result of the third multiplication is now at 809b04 809b05 809b06 
; now calculate the euclidean norm 
LDF . @809B04h,RO 
LDF @809B05h,RI 
LDF @809B06h,R2 
CALL FAST 
LDF RO,R6 
; Final multiplication 
LDP 80990ah,DP 
LDI @A4ADDR,ARO 
239 
LOOPO 
LOOPP 
Appendix 1 
LDI @809AFEh,ARI 
LOI @OUT4,AR2 
LDI 3,R3 
LOF O,RO 
LDI 2,AR6 
MPYF3 *ARO++,*AR I ++,R I 
ADOF RI,RO 
OB AR6,LOOPP 
STF RO,*AR2 
ADDI 1,AR2 
LDI @809AFEh,ARl 
SUBI 1,R3 
BNZ LOOPO 
;result of the final multiplication is now at 809bOa 809bOb 809bOc 
; now calculate the euclidean norm 
LOF @809BOAh,RO 
LOF @809BOBh,RI 
LOF @809BOCh,R2 
CALL FAST 
LOF RO,R7 
; norms are in r4,rS,r6,r7 
LOI 13h,R4 
FLOAT R4,R4 
LOI 12h,RS 
FLOAT RS,RS 
LDI llh,R6 
FLOAT R6,R6 
LDI lOh,R7 
FLOAT R7,R7 
; now find the min and op the decoded data 
LOI OOOOh,RO 
LOI 000lh,R1 
LDI OlOOh,R2 
LDI OIOlh,R3 
CMPF RS,R4 
CALLLT NEGI 
CALL NEG2 
CALL NEG3 
CALL NEG4 
B SLOOP 
;Return to start and wait next EINT3, external interupt 3. Now for the subroutines 
NEG 1 CMPF R6,R4 
CALLGT NEG2 
CMPF R7,R4 
CALLGT NEG2 
STI RO,@OATAOP 
B SLOOP 
NEG2 CMPF R6,RS 
CALLGT NEG3 
CMPF R7,R5 
CALLGT NEG3 
STI R1,@OATAOP 
B SLOOP 
NEG3 CMPF R7,R6 
CALLGT NEG4 
STI R2,@OATAOP 
B SLOOP 
NEG4 STI R3,@OATAOP 
240 
Appendix 1 
B SLOOP 
; Always return to start after outputting the decoded data Txl is in 16MSB and Tx2 is in 
16LSB 
EUCLID MPYF RO,RO 
MPYF RI,RI 
MPYF R2,R2 
ADDF R2,RI 
ADDF RI,RO 
LDF RO,R3 
PUSHF RO 
POP RI 
ASH -24,RI 
ADD! I,RI 
ASH -I,RI 
NEGI RI,RI 
ASH 24,RI 
PUSH RI 
POPF RI 
MPYF O.5,RO 
MPYF3 RI,R2,R3 
MPYF RO,R2 
SUBRF l.S,R2 
MPYF R2,RI 
RND RI,RI 
MPYF3 Rl,R2,R3 
MPYF RO,R2 
SUBRF 1.5,R2 
MPYF R2,RI 
RND Rl,RI 
MPYF3 RI,R2,R3 
MPYF RO,R2 
SUBRF l.S,R2 
MPYF R2,RI 
RND RI,RI 
MPYF3 RI,R2,R3 
MPYF RO,R2 
SUBRF 1.5,R2 
MPYF R2,RI 
RND Rl,Rl 
MPYF3 Rl,R2,R3 
MPYF RO,R2 
SUBRF 1.5,R2 
MPYF R2,Rl 
RND Rl,RO 
MPYF R3,RO 
FAST MPYF RO,RO 
MPYF Rl,RI 
MPYF R2,R2 
ADDF R2,Rl 
ADDF Rl,RO 
RETS . 
LOOPNEG NEGF R3,R3 
RETS 
.sect "servectl" 
B LOOP 1 
.sect "servect2" 
B RXLOOP 
; square em up 
; squared sum is now in rO 
; now find the square root 
; square em up 
; squared sum is now in rO 
; Ext int 3 service vector 
; RINT service vector 
241 
Appendix 1 
Appendix Ib 
Disk Kernal Communications Program 
.start "vectors", Ox809FCl 
stack: 
.start "kernel", vectors-OxAB ; Use size report from DSK3A 
.start "sstack",Ox809FOO ; output to pack to end of RAM 
.entry START 
.sect "sstack" 
. word stack-l 
MMRBASE 
PRDO 
PRDl 
TSTART 
START 
· word OxOO808000 
• word OxOOOOAOOO 
· word OxOOOOA060 
· word OxOO0003C3 
ldp @START ; set up stack and other params 
ldi @stack, SP 
ldi @MMRBASE,ARO , 
ldi 3. RO ; HALT timers 
sti RO, *+ARO (Ox20) 
sti RO, *+ARO (Ox30) , 
sti RO, *+ARO (Ox24) ; lnit count registers 
sti RO, *+ARO (Ox34) 
ldi @PRDO, RO ; lnit periods 
sti RO, *=ARO (Ox38) 
ldi @PRDl,RO 
sti RO, * ARO (Ox38) , 
ldi @TSTART,RO ; Start timers 
sti RO, *+ARO (Ox30) 
b spinO 
SO_xdata 
SO_rdata. 
.set Ox808048 
.set Ox80804C 
; SP 0 Data transmit 
; SP 0 Data recieve 
XSTEP 
XFUNF 
Idf 
ldf 
ldf 
ldf 
ldf 
ldf 
ldf 
Idi 
ldi 
ldi 
Idi 
ldi 
Idi 
Idi 
ldi 
ldi 
· word Ox00320C3l 
· word Ox00320C3l 
or Ox40, IF 
or OxC4,IE 
sti IE, @_freerun 
ldi @CPUCTXT,ARO 
ldi ARO,ARI 
addi I,ARl 
ldi @SO_rdata,RO 
ldi 0, RO 
sti RO,@SO_xdata 
ldf * ARO++(IRO), RO 
*ARI++(IRO), RI + ldi 
* ARO++(IRO), R2 + ldi 
*ARI++(IRO), R3 + Idi 
* ARO++(IRO), R4 + ldi 
* ARl ++(IRO), R5 + ldi 
* ARO++(IRO), R6 + ldi 
*ARl++(IRO), R7 + ldi 
*ARl++(IRO), R7 , 
; setXINTl 
; set EXINTI 
, 
; Clear under/over conditions before exit 
. ; 0 ensures low bits duming Sp recovery 
; XSR resends - should all be zero 
load floats (exponents) 
* ARO++(IRO), RO ;load longs 
*ARI++(IRO), RI 
* ARO++(IRO), R2 
* ARI ++(IRO), R3 
* ARO++(IRO), R4 
*ARl++(IRO), R5 
* ARO++(IRO), R6 
@_ARO,ARO : load ARx ldi @IRO, IRO 
@_ARl, ARl : ldi @lRl, IRI 
@_AR2,AR2 :or @_IF,IF 
@_AR3,AR3 : Idi @_IOF,IOF 
@_AR4, AR4 : Idi @_RS, RS 
@_ARS, AR5 : Idi @_RE, RE 
@_AR6, AR6 : ldi @RC, RC 
@_AR7,AR7 : Idi @_BK,BK 
ldi @_SP, SP ; get user SP 
Idi @_PC,R5 
, 
; CPU interrupt flags 
; 10 flags 
; Repeat start 
; Repeat end 
; Repeat counter 
; Block size 
242 
SSTEP 
stf 
stf 
stf 
stf 
stf 
stf 
stf 
stf 
sti 
sti 
sti 
sti 
context 
andn Ox4, IF 
tstb 4, IF 
bnz $-3 
ldiu @_ST,ST 
or @_IE,1E 
BUD R5 
or 2000h,ST 
ldiu @_RS,R5 
ldiu @_DP,DP 
XHALT pop ARI 
pop ARO 
pop IRl 
opo R-
pop DP 
pop ST 
push DP 
ldp @_ST 
sti ST, @_ST 
sti IRO, @_IRO 
pop IRO 
sti IRO, @_DP 
pop IRO 
sti IRO, @ _PC 
sti SP, @_SP 
sti BK, @_BK 
sti IE, @_IE 
sti IF, @_IF 
sti IOF, @_IOF 
sti RS, @_RS 
sti RE, @_RE 
sti RC, @_RC 
sti IRO, @_IRO 
sti IRI, @_IRI 
sti ARO, @_ARO 
sti ARI, @_ARI 
Appendix 1 
; Clear/Poll INT2 before SSTEP or RUNF 
; restore status 
; turn on !NT's 
; restore DP 
; restore original registers before save 
; temp storage of user DP 
; DP for kernal 
; store ST 
; save user SP 
; save user PC 
; save user SP 
; Block size 
; Interal int enable 
; CPU interrupt flags 
;10 flags 
; Repeat start 
; Repeat end 
; Repeat counter 
; Keep everything <- IRO saved previously 
ldi @CPUCTXT,ARO 
ldi ARO,ARI 
addi I, ARI 
ldi 2, IRO 
RO, * ARO++ (IRO) Store floats + sti RO, * ARO++ (IRO) ; Store longs 
Rl, *ARI++ (IRO) + sti RI, *ARl++ (IRO) 
R2, * ARO++ (IRO) + sti R2, * ARO++ (IRO) 
R3, *ARl++ (IRO) + sti R3, *ARl++ (IRO) 
R4, * ARO++ (IRO) + sti R4, * ARO++ (IRO) 
RS, *ARl++ (IRO) + sti RS, *ARl++ (IRO) 
R6, * ARO++ (IRO) + sti R6, * ARO++ (IRO) 
R7, *ARI++ (IRO) + sti R7, *ARI++ (IRO) 
AR2, @_AR2 ; ARO & ARl Already saved 
AR3, @_AR3 ; sti AR4, @_AR4 
ARS, @_ARS ; sti AR6, @_AR6 
AR7, @_AR7 ; ldi 0, RO ; Freerun = 0 indicates HALT (spinO) 
sti RO, @_FREERUN 
call W_HOST 
b spinO 
spinO or 4, IE 
and 4, IE 
b spinO 
SOxdata . word 0 
GIE .set 0x2000 
; Send ACKNOWLEDGE (zero) to host 
; <- Branch is removed (spinO in inline) 
; Enable DSK31 HPI interrupt 
; Shut down all interrupts except host 
243 
Appendix 1 
_FO . word 0 ;RO + _RO . word 0 ;FO 
_FI . word 0 ;RI + _RI . word 0 ;F! 
_F2 . word 0 ;R2 + _R2 . word 0 ;F2 
_F3 . word 0 ;R3 + _R3 . word 0 ;F3 
_F4 . word 0 ;R4 + _R4 . word 0 ;F4 
_F5 . word 0 ;RS + _RS . word 0 ;F5 
_F6 . word 0 ;R6 + _R6 . word 0 ;F6 
_F7 . word 0 ;R7 + _R7 . word 0 ;F7 
_ARO . word 0 ;ARO + _DP . word 0 ; Data page 
_ARI . word 0 ;ARI + _IRO . word 0 ; Index register 0 
_AR2 . word 0 ;AR2 + _iRl . word 0 ; Index register 1 
_AR3 . word 0 ;AR3 + _BK . word 0 ; Block size 
_AR4 .word 0 ;AR4 + _SP . word stack-l ; Stack pointer 
_AR5 .word 0 ;ARS + _ST . word 0 ; Status 
_AR6 . word 0 ;AR6 + _IE . word 0 ; Internal int enable 
_AR7 . word 0 ;AR7 + 
-
IF .word 0 ; CPU interrupt flags 
_IOF . word 0 ; 110 flags 
_RS . word 0 ; Repeat start 
_RE . word 0 ; Repeat end 
_RC . word 0 ; Repeat counter 
_PC .word 0 ; program counter 
_FREERUN. wordO ; 1 = DSK is freerunning, 0 = DSK is HALT'ed 
CPUCTXT .word context 
INTx max speed 
push 
push 
push 
push 
push 
push 
ldp 
ldi 
sti 
ldi 
sti 
tstb 
bz 
call 
ldi 
addi 
ldi 
b 
COMN call 
Idi 
call 
ldi 
call 
ldi 
subi 
rets 
SR2 Idi 
Idi 
pop 
pop 
pop 
pop 
pop 
andn 
or 
ST 
DP 
RO 
IRl 
ARO 
ARl 
@JUMP 
@SO_xdata, RO 
RO, @SOxdata 
O,RO 
RO, @SO_xdata 
4,IF 
SR2 
R_HOST 
RO,ARI 
@JUMP,ARl 
*ARl,ARl 
ARl 
R_HOST 
RO,ARl 
R_HOST 
RO,IARO 
R_HOST 
RO, IRl 
l,ARl 
07FOOh,ARO 
*ARO,ARO 
ARl 
ARO 
IRl 
RO 
DP 
Ox4,IF 
4,IE 
; Push ISR variables 
; NOTE: A Halt command pops these 
values followed by a full save 
; Get address of command from JUMP table 
; Put a zero in the DXR making startup 
; Get here by driving INT2 low 
; Make sure INT2 is active 
; RO==command 
; execute command 
; data packet length 
; source address 
; source index 
; Dummy non-HPI read releases READY 
; restore ISR variables ' 
244 
INTO 
INTI 
INT2 
pop 
reti 
.sect 
b 
b 
b 
b 
b 
b 
b 
b 
b 
b 
Appendix 1 
ST 
"vectors" 
$ 
$ 
INTx 
$ 
$ 
$ 
SSTEP 
SSTEP; TRAPFIX 
$ 
$ 
$ 
; return to original code 
; Ox809FCI 
; Ox809FC2 
; Ox809FC3 
;Ox809FC4 
; Ox809FC5 
; Ox809FC6 
;Ox809FC7 
; Ox809FC8 
OxOOI 
Ox002 
Ox004 <-HPI 
Ox008 
OxOl0 
Ox020 
Ox040 <- SSTEP 
Ox080 <- ETRAP 
Oxl00 
Ox200 
Ox400 
INT3 
XlNTO 
RINTO 
XINTI 
RINTI 
Ox74000008 
TINTO 
TINT I 
DINT 
W_HOST 
push ARI 
b 
push ARO ; HPI address 
; loop counter 
; Ox809FC9 
;Ox809FCA 
;Ox809FCB 
R_HOST 
push 
push 
ARl 
ARO ; HPI address 
; loop 
counter 
push ST ; Keep flags 
push DP 
register 
Idp WSCOUNT 
Idi OxFOOO, ARO ; HPI 
Idi @WSCOUNT, ARI 
sti RO, *ARO++(l6) ; Store Isbs to HPI 
Ish @WSHIFf, RO ; shift to next Isbs 
db ARI, WH ; loop until done 
pop DP 
b COMNHST 
COMNHST pop ST 
XWRIT 
XWI 
XREAD 
XRI 
pop ARl 
pop ARO 
rets 
call COMN 
call R_HOST 
sti RO, *ARO++(IRl) 
db ARl,XWI 
b SR2 
call COMN 
ldi *ARO++(IR1), RO 
call W_HOST 
db ARl,XRl 
b SR2 
. start "JMPTBL",Ox809FF4 
.sect "JMPTBL" 
push 
push 
ST 
Rl 
ldi OxFOOO,ARO 
ldi 3, ARI 
Ish _8, RO 
ldi *ARO++, Rl 
Ish 24, Rl 
or Rl, RO 
db ARl, RH pop 
; Next 4 opcodes common to 
W _HOSTIR_HOST 
; temp 
Rl 
JUMP . word JUMP ; Ox809FF4 Jump table base address 
WSCOUNT 
WSHIFf 
· word XWRIT ;1 
· word XREAD; 2 
· word XCTXT ; 3 
. word XRUNF;4 
. word XSTEP 
. word XHALT; 6 
. word W _HOST 
· word R_HOST 
. word spinO 
. word 7 
. word -4 
; Ox809FF5 for DSK3 routines 
; Ox809FF6 
; Ox809FF7 
; Ox809FF8 
; 5 ; Ox809FF9 
;Ox809FFA 
; 7 ; Ox809FFB 
; 8 ; Ox809FFC 
; 9 ; Ox809FFD 
; Ox809FFE 
; Ox809FFF bus width parameters 
245 
IMAGING SERVICES NORTH 
Boston Spa, Wetherby 
West Yorkshire, LS23 7BO 
www.bl.uk 
MISSING PAGES ARE 
UNAVAILABLE 
Appen 
Some~ 
the reSl 
i) InpUl 
netlist 
* 
* 
>ICI 
>IC2 
Bl 
B2 
Vs 
Rl 
R2 
R3 
R4 
R5 
R6 
R7 
RS 
Cl 
C2 
C3 
C4 
C5 
C6 
C7 
CS 
C9 
* 
* 
* 
* 
8L9St'£ ooso A 
2(~ 
+out:ll -out: 0 
+out:2 -out: 0 
+out:15 -out: 17 
pl:O p2:1 
pl:0 p2:5 
pl:7 p2:S 
pl:O p2:S 
pl:O p2:12 
pl:12 p2:1l 
pl:l0 p2:13 
pl:14 p2:13 
pl:l p2:17 
pl:3 p2:4 
pl:5 p2:0 
pl:6 p2:7 
pl:S p2:0 
pl:12 p2:9 
pl:lO p2:0 
pl:14 p2:16 
pl:4 p2:6 
Probe nodes on S and 16 
Input between 15 and 17 
3~3110:l 
SS313111M II 318V:l3H~ 
M 19jrJ& 
v=lO 
v=lO 
v=lOOm Ex=Sine Fr=lk 
v=22k 
v=lM 
v=600 
v=lk 
v=100k 
v=lOOk 
v=lOk 
v=lOOk 
v=100u 
v=2.2u 
v=47u 
v=lOu 
v=.lu 
v=10u 
v=lOOu 
v=lOOu 
v=4.7n 
All references to node 0 at Ov 
Use frequency analysis on pull down menu and then plot Bode 
1 a copy of 
out: 14 
The Bode plot shows the gain falling away nicely with the amplifier unconditionally 
stable at the conditions presented. The C.V.S.D. model did not give any sensible outputs, the 
amplifier would always ramp to rail and stay there and so is not included. 
249 
ii) Level shifting stage (drive to modulators) 
netlist 
* Paul4b.cmp 
* 
>IC2 uA741 +in:S +v:4 -in:6 -v:O out: 7 
BI +out:4 -out: 0 v=12 
B2 +out: -out: 0 v=lO 
Vs +out:l -out: 0 v=S Ex=Square Fr=4k 
RI pl:l p2:2 v=47k 
R2 pl:2 p2:0 v=47k 
R3 pl:4 p2:3 v=ISO 
R4 pl:3 p2:2 v=IOk 
RS pl:3 p2:0 v=ISO 
R6 pl:13 p2:S v=IOk 
R7 pl:6 p2:0 v=47k 
R8 pl:6 p2:7 v=27k 
CI pl:S p2:0 v=3.3n 
C2 pl:3 p2:7 v=3.3n 
* probe node on node 7 
* input on node I 
* reference and ground node 0 
The diagram shows the input being overdriven, but still working. The Burr Brown 
analogue to digital converter was supplied with simulation data but again did not model well 
in the circuit configuration. The netlist is reproduced below and the timing / output diagram 
is the third plate. 
iii) Analogue to digital converter netlist 
* Paul4c.cmp 
* 
>ICI I 01 define pl:l p2:2 pS:3 p6:4 p7:50 p8:0 
>ICI 10Idefine p9:S plO:6 pll:6 p12:S p13:7 p14:7 pIS:IO 
>ICI I 01 define p16:7 p18:0 p20:8 p21:9 p22:0 p23:0 
>ICI I 01 define p24:0 p2S:0 p26:11 p27:12 p28:0 
BI +out:S -out: 0 v=S 
B2 +out:4 -out: 0 v=-S 
Vs +out:2 -out: 0 v=2.S Ex=Step Fr=IOO 
RI pl:4 p2:3 v=1O 
R2 pl:9 p2:0 v=lk 
R3 p1:8 p2:0 v=1k 
CI pl:1 p2:0 v=IOu 
C2 pl:4 p2:0 v=10u 
C3 pl:S p2:0 v=lOu 
C4 ., pl:12 p2:0 v=0.1u 
C5 pl:ll p2:0 v=10u 
250 
volts dBs (OdB=1) (27C] Phase_I 180 
[ 
17.5 I 
15 
• 12.5 
10 
7,5 
5 
2.5 
o 
I 
I 
! 
-... -.. ~-.--.--; .... ------, . .:...- -~ 
, '~., .J 160 
...... " ""' J 140 
..... ! ... ---- ------,---.-- --- ~~ .------ - t~~ 
I I ' \ " ' 
, -1 80 
\\ --- - -- . ~ 60 
\ ...j 
-. -_. -~ -------------:-------- --- ---->\ ~ ------ j :~ 
c o~--t:-~---·----- -~-:--t~~~:-~~-~=---: ___ ----·-.. ---------~-------- -------'\.~-------------_ j ~20 
-------- ~ ----- ---------: ---- - ~ ------,-"-" < ~:- ---, --- \ -40 
. _ .. __ __ . . ____ . .. ____ . _ ~ .... ____ ...... ~ , .. . ... _ '._ .. '. _. \. _______ ...• -60 
-. - .- .. ~ - - ~. t - . \ 
- ' - -. \ .- -80 
\ ... -100 
. - - - - \ - --, _ .. _ .. - - - - _." - - - - - - - - - _.'.' - - ·t··-
, 
• "1" 
\ -120 
. \ ~1 - 140 
-~, ----~------\J-160 
~ ___ . ______ -L_. ______ _ 
.. ___ .. __ .. ___ • _____ • __ J _____ • __ --'-- _________ • ___ • __ . .'~ -180 
1k 
("4" - "0') 
3k 
--("5" · "0") 
10k 30k 100k 300k 1 M 
hertz 
volts (27C] r---------, .. '-"l , .. _-_ .... -
I \ '\ 
I \ I \ 
I. / I \ I~~~L ___ \
'/ ' 1\ I I \ 
,,/ I ' I \ 
f t 1/ L~ 
I \ I \ \ I \1 
\ ' \ 
2 
o 
-1 
-2 
-3 
-4 
( 
I 
1-1----·-
._JI 
I 
I 
I 
I 
I 
I ~ \ I \ 
I \ I \ L _ ___ L ___ ... ___ -L_---.L...L ____ ..1l-___ -L 
·5 
I 
I 
_'- .... ____ ..J .. _________ -1... ___ . __ 
o 25u 50u 75u 100u 125u 150u 175u 200u 225u 
-.--- {"output" - 'GNO") --("genout" - 'GNO") s 
251 
)lls (27~1 ... . 
r::"l 's;:r;;1 r="""='-: MI_ ... 
i 
o 10u 
(==,,- .-,-. .,-._"..".r. ... ""' ..... , 
• ___________ T __ -- _.'._ - -- _ ., -
, 
20u 30u 
g>lts [27~1 
(, I .1 c__ t _. tJ!i ., 
40u 
I 
4 
7
8 rl- ___ -~--_--.--_----_----______'-~1JlJl 
_ ruu",-, __ 
--------·1 n .: I ' t I, ! I 61 .... . -... ~-- -- .-,. ----.. --,-.. ,,-~ .. -,- -," -- ... -.-._ _ __. __ . ______ ~ __ ._. __ .. ~.~ ; ... J i ) 1_ .. _ ... ' .... ___ ._. __ .. __ _ 
3 5 f-· __ .. ______ . __ J··--·-····-······------l. _________ nJlf· L ____ . ______ .... _.  ._ 
.1 J-·----L ... ____ .. ... __ .r--·----l __ ._ .. __ ........... ___ .. n .... n_.il_ .. _._ .. ... _ .. ___ I---
I I ... - .. ---··1 r--I " :---l 
2 1-- ! ' , i f j I ;; I .. . .. 
2LJl 
I fI '-11-·1 t-' '.'1 '1 " 1'1 ,', i ' .1 !1 i '.' "': ." , ! , : ' ' : I ,·'·1 1"1 i I r'" "-111 r-I ·-1 j'l' n , : , 1 \ , i ! i ll , 1 ~ I f; . i !, '; i : . : \ I ,I 
1 r-' '- '-- - ~ -.' !. t, t .: U :,i L. i .. ; i li ,. 1 i j . ! U '. I, ! .. '.,. ' __ ~_-' ,_.' : .:~ 
"~ ..J./-r~l' ,.r.r..r'J" '] _.rn nl U' _,.r-rr r-,-F·:-· ~I _,,-1 _~,---r-' _ ,,~ ! II ! _r.rf 
L ...J~ .-1 ,,_1 l J1 J ' . o .LL___ _L. _____ .c'-L... _____ •. ___ .L- _.c::: ____ . _______ L I .. _'-- __ .~_.c __ ,.L_,_. _____ , . .J 
50u 
o 
----(' x" - '0') 
100u 200u 300u 400u 500u 600u 
seconds 
252 
Appendix 5 
I2C Interface for P.C. Printer port 
DCD 
RSET 
TSET 
RSI 
VAl 
RS2 10k 
CTS2 
VA2 +5v 
25 way 
D-type 
Program to drive I2C via the parallel port. 
Program to drive the I2C bus via the printer port 
i Kbd clock on interrupt INTO P1.5 
; Kbd data on pin PO.2 
IICADD .equ 088h ; our i2c slave address 
MAXBYTES .equ 1 ; max bytes to recv or trans 
rcvdat .equ 04h ; 12C received data buffer 
xmtdat .equ 06h ; 12C transmitter buffer 
STACK .equ 08h 
flags .equ 020h ; byte used as flags 
noack .equ (flags-20h) ; 12C flags.O, ... 1, ... 2, etc 
recvd .equ (flags-20h)+ 1 ; 
sent_flag .equ (flags-20h)+2 ; 
i2c_busy .equ (flags-20h)+3 ; 
Cntrl .equ (flags-20h)+8 ; Control key flag 
Shift .equ (flags-20h)+9 ; Shift key flag 
bitcnt .equ flags+2 
bytecnt .equ flags+ 3 
adrrcvd .equ flags+4 
rwflag .equ (adrrcvd-20h)*8 ; adrrcvd.O 
+5v 
Ov 
4pin 
I2C 
SCL through 
SDA 
74LS05 
253 
tick .equ 025h ; count tOmS ticks to give Isec tick 
i2ctime .equ 027h ; i2c timeout - used on slow i2c bus 
NBits .equ 29h ; # bits read so far 
NBytes .equ NBits+ 1 ; # bytes in buffer 
lastkey .equ NBytes+ 1 ; last key was? 
key temp .equ lastkey+ 1 ; used to build the key bit by bit 
keybuff .equ keytemp+ 1 ; store the chars here 
INMAX .equ 8 ; Size of keyboard buffer 
KEYCLK .equ p 1.5 ; keyboard clock signal on ext int 0 
KEYDAT .equ 82h ; keyboard data line 
EDGEINT .equ 08ah 
.org 0 ; reset vector 
.org 0003h 
.org Obh 
.org 013h 
.org Olbh 
.org 023h 
.org 48h 
ajmp$ 
.org 50h 
start: 
; external Interrupt 0 
; counter/timer 0 
; ext int 1 
; timer 1 - i2c timeout 
; i2c interupt 
; main routine waiting for key presses 
mov rO,#Offh 
mov rt,#Offh 
movr2,#04h 
dlyt: djnz rO,$ 
djnz rl,dlyl 
djnz r2,dlyl 
reset: 
mov pO,#Offh 
mov pl,#Offh 
mov p3,#Offh 
; power supply settling time 
mov sp,#STACK ; initialise stack pointer 
setb EDGEINT ; make ext int 0 edge activated 
clr Shift ; clear keyboard shift flag 
mov rO,#NBits ; clear the input buffers 
movrl,#lOh 
movacc,#O 
clrIp: mov @rO,a ; do the clearing 
incrO 
djnz rl,clrlp 
mov xmtdat,#'.' ; transmitt buffer filled with 
mov xmtdat+ 1 ,#Offh ; $ff when empty 
mov flags,#O 
mov i2ctime,#0 
restart: 
mov I2CFG,#80h+CTV AL ;enable slave functions 
mov I2CON,#BIDLE ;place in idle state 
mov ienO,#9lh ;enable external & IIC interrupts 
main: 
mov a,NBytes 
jz empty ; if data in keybuff copy to i2c xmt buffer 
mov ienO,#Oh ;disable all interrupts temporarily 
mov xmtdat,keybuff 
mov NBytes,#O . ; clear keyboard buffer full flag 
mov ienO,#91h ;enable external & IIC interrupts 
empty: 
jnb recvd,notread ; recvd flag tells 751 to clear I2C xmt buffer 
mov acc,xmtdat ; when i2c master sucessfully reads the data 
orI a,#80h ; from the 87c751, the master writes any data 
mov xmtdat,acc ; back which will set the MSB of the data 
254 
clrrecvd 
notread: 
mov a,lastkey 
clr c 
subb a,#l1h 
jnz notalt 
nop 
notalt: 
; buffer. This is necessary to syncronise 
; the two processors. 
; reset i2c received flag 
; detect alt key for special functions 
; alt code goes here 
mov a,NBytes 
clr c 
subb a,#INMAX ; limit the input buffer to INMAX 
jc notdone 
; if data is buffered then buffer exceed 
; code goes here 
notdone: 
sjmpmain 
kbd: 
pushpsw 
push ace 
mov acc,NBits 
; go back to start 
; save regs during ISR 
; NBits = the bit number next expected 
; from the keyboard 
cjne a,#O,bitl 8 ; if not bit 0 then maybe bit 1 to 8 
bitO: -; discard bit 0 - Start bit 
sjmpbump 
bitl_8: 
cjne a,#9,$+ 3 ; CY flag is set if ace < 9 
jnc bit9 
mov c,KEYDA T ; read data for keyboard data line 
mova,keytemp ; data arrives least sig bit 1st 
rr a ; hence old value is rotated and new 
mova.7,c ; bit is or'ed to the msb 
mov key temp, ace 
sjmpbump 
bit9: 
cjne a,#9,bitlO 
sjmp bump ; parity check code would go here 
bitlO: 
mov acc,keytemp ; get next key 
cjne a,#12h,notls ; is it the left shift char? 
mov acc,lastkey 
cjne a,#O£oh,makels ; if last key was $£0 then shift is released 
clr Shift ; Next keys will be unshifted 
mov lastkey,#12h ; Copy left shift key to last key 
sjmp tidy 
makels: 
setb Shift ; Next Keys will be shifted 
mov lastkey,#12h ; Copy left shift key to last key 
sjmp tidy 
notIs: 
mov acc,keytemp ; get next key 
cjne a,#14h,notctrl ; is it a control char? 
nop ; control state goes here 
sjmp tidy 
notctrl: 
cjne a,#O£oh,notbreak ; is current key is $fO then break code 
mov lastkey,a ; if so record break code in last key 
sjmp tidy ; but don't store in the buffer 
255 
notbreak: 
mov acc,lastkey ; if last key was Sf() then 
cjne a,#Of()h,not_f() ; ignore the next scan code 
mov lastkey,#Q ; which is a break code 
sjmp tidy 
not f(): 
#ifcief buffered 
push 0 ; rO will be used as an indirect pointer 
; so save it 
mov acc,#keybuff ; copy data into keyboard 
add a,NBytes 
movrO,a 
mov a,keytemp ; get current key 
mov lastkey,a ; & copy to lastkey 
push dph ; dp required to point to translation 
push dpl ; tables. Since in ISR save dp contents 
jb Shift,shifted ; if in the unshifted state use the unshift table 
mov dptr,#Unshift 
sjmp skip! 
shifted: 
mov dptr,#shift ; else use the shift table 
skip! : 
movc a,@a+dptr ; translate the char in Acc to Ascii 
pop dpl ; retsore the data pointer 
pop dph 
cjne a,#O,NotO 
; sjmp NoSave 
NotO: 
; If data is zero discard 
; discard code goes here 
mov rO,#keybuff ; Save Ascii value into keyboard buffer 
mov @rO,a ; buffered keyboard entry 
inc NBytes 
NoSave 
pop 0 
#endif 
; restore rO 
#define unbuffered ! 
#ifdef unbuffered 
mov a,keytemp ; get current key 
mov lastkey,a ; & copy to lastkey 
push dph ; dp required to point to translation 
push dpl ; tables. Since in ISR save dp contents 
jb Shift,shifted ; if in the unshifted state use the unshift table 
mov dptr,#unshift 
sjmp skip! 
shifted: 
mov dptr,#shift ; else use the shift table 
skip! : 
movc a,@a+dptr ; translate the char in Acc to Ascii 
pop dpl ; retsore the data pointer 
pop dph 
cjne a,#O,NotO 
; sjmp tidy 
NotO: 
; If data is zero discard 
; discard code goes here 
tidy: 
mov keybuff,a 
mov NBytes,#1 
mov NBits,#O 
mov keytemp,#O 
sjmp intdone 
bump:' 
inc NBits 
; store in kbd buffer 
; mark byte read 
; clear flags ready for next keyboard char 
; inc the number of bits read so far 
256 
intdone: 
pop acc 
poppsw 
reti 
i2cint: ; i2c interrupt entry point 
setb i2c_busy ; semaphore on xmtdata buffer 
push psw ; save registers used in ISR 
push acc 
push 0 ; RO no bank switching 
elr EI2 ; make i2c ISR interruptable 
acall clrint ; execute a reti 
slave: 
mov i2ctime,#3 ; set up i2c timeout watchdog 30 mS 
mov I2CON,#BCARL+BCSTP+BCSTR+BCXA 
; clear start status 
jnb A TN,$ ; wait for next data bit 
mov bitcnt,#7 
acall recvb2 ; get remainder of slave address 
mov adrrcvd,a 
clr a.O ; mask read/write bit to check address 
cjne a,#IICADD,goidle ; idle again if not for us 
jb rwflag,read ; test for read or write 
mov rO,#rcvdat ; rO points to data bufferer 
mov bytecnt,#MAXBYTES 
rcvloop: 
acall sendack ; acknowledge the address 
acall rcvbyte ; wait for the next data byte 
jnb DRDY,exitwr ; end of frame 
mov@rO,a 
inc rO 
djnz bytecnt,rcvloop 
acall sendack ; ack last byte 
acall rcvbyte ; get but discard next one 
mov I2DA T,#80h ; send neg ack 
jnb A TN,$ ; wait till gone 
exitwr: 
setb recvd 
sjmpmsgend 
read: 
mov rO,#Xmtdat ; rO points to data buffer 
mov bytecnt,#MAXBYTES 
acall sendack ; acknowledge address 
txloop: 
mov a,@rO ; get next data byte 
inc rO ; bump buffer pointer 
acall xmitbyte ; transmit the byte to the 12C 
jb noack,exitrd ; if not acknowledged the exit 
djnz bytecnt,txloop 
exitrd: sjmp msgend 
msgend: 
jnb ATN,$ 
jb STR,slave 
goidle: 
; wait for stop or repeated start 
; if repeat start do again 
mov i2ctime,#O ; stop i2c timeout 
mov I2CON,#BCSTP+BCXA+BCDR+BCARL+BIDLE 
pop 0 ;restore state before i2c ISR 
pop acc 
poppsw 
setb EI2 
setb sent_flag ;flag to say data has been sent 
257 
ret 
xmitbyte: 
mov bitcnt,#8 
xmitbit: 
movI2DAT,a 
rIa 
jnbArn,$ 
;flag denotes exiting I2C routine 
; 12C data transmit (enter with data in ace) 
djnz bitcnt,xmitbit 
mov 12CON,#BCDR+BCXA ; switch to rev mode 
jnb Arn,$ ; wait for ack 
mov flags,I2DAT ; save ack bit 
ret 
rdack: 
acall rcvbyte 
sendack: 
mov 12DAT,#O 
jnbArn,$ 
ret 
rcvbyte: 
mov bitcnt,#8 
recvb2: clr a 
rbit: orI a,I2DA T 
rIa 
jnbArn,$ 
jnb DRDY,rbex 
djnz bitcnt,rbit 
; rdack - receives data byte then sends ack 
; 12C data recv routine - data returned in a 
; 12C ack = data low when clock pulsed high 
; rcvbyte receives byte - data returned in Ace 
; exit if not a data bit 
mov c,RDA T ; get last bit - do not clear A TN 
rIc a ; shift into byte 
rbex: 
ret 
timer!: 
mov ienO,#O fixup: 
setb CLRTI mov 12CFG,#O ; tum off i2c 
mov 12CON,#BCXA+BCDR+BCARL+BCSTR+BCSTP 
acall clrint ajmp reset ; restart program 
clrint: reti 
badint: reti 
#include attable.h 
.end 
258 
Appendix 6 
I2C Interface using the 8XC7501751 and a standard keyboard 
+5v 
Keyboard 
N/C Vee 
10k N/C N/C 10k 
N/C 8 N/C 
N/C 7 N/C 
N/C C N/C 
+5v PO.2 7 N/C 
SDA 5 intO 
SCL 1 N/C 
sda 
RST N/C 
sel 
Xl 
power 
X2 
groun~ Vss 
- -
- -
-
-
PCI AT keyboard gives a start bit, 8 data bits with the LSB transmitted first and a stop bit. When a 
key is pressed the keyboard transmits a make code and when the key is released a break code. 
These are basically the same but the break has a OFO (hex) on the front. The ASCII keyboards are 
better because controVshift keys give unique codes, on the PCI AT they give two codes which need 
to be interpreted together, care is needed. The software reproduced overleaf will capture and 
convert to ASCII the data from the PC keyboard, the look up tables will need modification 
depending upon the keyboard type, the code is then output as an I2C message 
259 
Software to drive 751 +keyboard 
BTIR EQU IOh 
BMRQ EQU 40h 
BCXA EQU 80h 
BIDLE EQU 40h 
BCDR EQU 20h 
BCARL EQU 10h 
BCSTR EQU 08h 
BCSTP EQU 04h 
BXSTR EQU 02h 
BXSTP EQU Olh 
SGO EQU IOh 
SRCVD EQU llh 
SRLNG EQU 12h 
STXED EQU 13h 
SRERR EQU 14h 
MGO EQU 20h 
MRCVED EQU 2lh 
MTXED EQU 
MTXNAK EQU 
; TIRUNbit. 
; MASTRQ bit. 
; CXA bit. 
; IDLE bit. 
; CDR bit. 
; CARL bit. 
; CSTR bit. 
; CSTP bit. 
; XSTR bit. 
; XSTPbit 
; Started Slave message processing. 
; as a slave, received a new message 
; received as slave a message which is 
; bus error detected when operating as a slave. 
; Started Master message processing. 
MTXNOSLV EQU TIMOUT EQU 30h ; TIMER! Timed out. 
NOTSTR EQU 32h ; Master did not recognize Start. 
MASCMD DATA 20h 
SUBADD BIT MASCMD.O 
RPSTRT BIT MASCMD.I 
SETMRQ BIT MASCMD.2 
DSEG AT24h 
MSGST AT: DS I ; 12C communications status. 
MY ADDR: DS I ; Address of this 12C node. 
DESTADRW: DS I ; Destination address + RIW (for Master). 
DESSUBAD: DS I ; Destination subaddress. 
MASTCNT: DS TITOCNT: DS I ; Timer I bus watchdog timeouts counter. 
StackSave: DS MasBuf: DS 4 ; Master receive/transmit buffer, 8 bytes. 
SRcvBuf: DS 4 ; Slave receive buffer, 8 bytes. 
STxBuf: DS 4 ; Slave transmit buffer, 8 bytes. 
RBufLen EQU 4h ; The length of SRcvBuf 
; Error indication. 
TogLED BIT PI. 
ErrLED BIT P 1.1 
OnLED BIT P1.3 
APPFLAGS DATA 21h 
TRQFLAG BIT APPFLAGS.O 
SErrFLAG BIT APPFLAGS.l 
FAILCNT: DS I 
TOGCNT: DS 
CSEG 
AJMP Reset ;Reset vector at address O. 
ORG lBh ; Timer I (12C timeout) interrupt. 
Timer!: SETB CLRTI 
AJMP TIISR 
ORG 23h 
; Go to Interrupt Service Routine. 
12CISR: CLR El2 ; Disable 12C interrupt. 
ACALL XRETI ; Allow other interrupts to occur. 
PUSH PSW 
PUSH ACC 
MOV A,RO 
PUSH ACC 
MOV A,RI 
PUSH ACC 
MOV A,R2 
260 
PUSH ACC 
MOY StackSave, SP 
CLR TIRUN 
SETB TIRUN 
JB STP,NoGo 
JNB MASTER, GoSlave 
MOY MSGSTAT,#MGO 
JB STR,GoMaster 
NoGo:. MOY MSGSTAT,#NOTSTR 
AJMP Dismiss ; Not a valid Start. 
XRETI: RETI 
GoSlave: MOY MSGSTAT,#SGO 
AddrRcv: ACALL ClsRcv8 
JNB DRDY, 
STstRW: MOY C,ACC.O 
CLR ACC.JC 
SRcv2: CJNE A,MY ADDR, 
MOY Rl,#SRcvBuf 
MOY R2,#RbufLen+ 1 
SJMP SRcv3 
; Save R/W- bit in carry. 
; Set receive buffer address. 
SRcvSto: MOY @Rl,A ; Store the byte 
Inc Rl ; Step address. 
SRcv3: ACALL AckRcv8 
JNB DRDY,SRcvEnd 
DJNZ R2,SRcvSto 
MOY MSGSTAT,# 
ACALL SLnRCvdR 
SJMP GoldIe 
SRcvEnd: CJNE RO,#7, 
MOY MSGSTAT,# 
MOY A,Rl 
CLR C 
SUBB A,#SRcvBuf 
ACALL SRCvdR 
SJMP SMsgEnd 
SlvTx:. NOP 
; Exit loop -end reception. 
; Go to store byte if buffer not full. 
; Handle new data - slave event routine. 
; number of bytes in ACC 
; Handle new data - slave event routine. 
STx2: CJNE A,MY ADDR,Goldle ; Not for us. 
MOY 12DAT,#O ; Acknowledge the address. 
JNB A TN, $ ; Wait for attention flag. 
JNB DRDY,SMsgEnd 
MOY Rl,#STxBuf 
STxlp: MOY A,@Rl 
INC Rl 
ACALL XmByte 
; Start address of transmit buffer. 
; Get byte from buffer 
JNB DRDY,SMsgEnd ; Byte Tx not completed. 
JNB RDA T,STxlp ; Byte acknowledge, proceed trans. 
MOY 12CON,#BCDR +BIDLE ; Master Nak'ed for msg end. 
MOY MSGSTAT,#STXED 
ACALL STXedR ; Slave transmitted event routine. 
AJMP Dismiss 
SRcvErr: MOY MSGSTAT,#SRERR ; Flag bus/protocol error 
ACALL SRErrR ; Slave error event routine. 
SJMP SMsgEnd 
StxErr: MOY MSGSTAT,#SRERR ; Flag bus/protocol error 
ACALL SRErrR· 
SMsgEnd: JB MASTER,SMsgEnd2 
JB STR,GoSlave ; If it was a Start, be Slave 
SMsgEnd2: 
AJMP Dismiss 
261 
GoldIe: 
AJMP Dismiss 
GoMaster: 
MOV Rl,#MasBuf ; Master buffer address 
MOV R2,MASTCNT ; # of bytes, to send or rcv 
MOV A,DESTADRW ; Destination address (including 
; R/W- byte). 
JB SUBADD,GoMas2 ; Branch if subaddress is needed. 
ACALL XmAddr 
JNB DRDY,GM2 
JNB ARL,GM3 
GM2: AJMP AdTxArl 
GM3: JB RDAT,Noslave ; No Ack for address transmission. 
JB ACC.O, MRcv ; Check R/W- bit 
AJMP MTx 
GoMas2: NOP 
CLR ACC.O 
ACALL XmAddr 
JNB DRDY,GM4 
JNB ARL,GM5 
GM4: AJMP AdTxArl 
; Subaddress needed. Address in ACC. 
; Force a Write bit with address. 
GM5: JB RDAT,Noslave ; No Ack for address transmission. 
MOV A,DESSUBAD 
ACALL XmByte ; Transmit subaddress. 
JNB DRDY,SMsgEnd2 ; Arbitration loss (by Start or Stop) 
JB ARL,SMsgEnd2 ; Arbitration loss occured. 
JB RDA T,NoAck ; Subadress transmission was not ack'ed. 
MOV A,DESTADRW ; Reload ACC with address. 
JNB ACC.O, MTx 
MOV 12CON,#BCDR+BXSTR; Send Repeated Start. 
JNB ATN,$ 
MOV 12CON,#. 
JNB ATN,$ 
JNB ARL,GM6 
AJMP MArlEnd 
GM6: ACALL XmAddr 
JNB DRDY,GM7 
JNB ARL,GM8 
GM7: AJMP AdTxArl 
; expecting an STR. 
; oops - lost arbitration. 
GM8: JB RDA T,Noslave ; No Ack - the slave disappeared. 
SJMP MRcv 
MTx: NOP 
MTxLoop: MOV A,@Rl ; Get byte from buffer. 
INC Rl ; Step the address. 
ACALL XmByte 
JNB DRDY,SMsgEnd2 ; Arbitration loss (by Start or Stop) 
JB ARL,SMsgEnd2 ; Arbitration loss. 
JB RDAT,NoAck 
DJNZ R2,MTxLoop ; Loop if more bytes to send. 
MOV MSGSTAT. 
SJMP MTxStop 
NoSlave: MOV MSGSTAT,#MTXNOSLV 
SJMP MTxStop 
NoAck: MOV MSGSTAT,#MTXNAK 
SJMP MTxStop 
MRcv: ACALL ClaRcv8 
SJMP MRcv2 
MRcvLoop: ACALL AckRcv8 
; Receive a byte. 
MRcv2: JNB DRDY,MArl ; Other's Start or Stop. 
MOV @Rl,A ; Store received byte. 
262 
INC Rl ; Advance address. 
DJNZ R2,MRcvLoop 
MOV I2DAT,#80h 
JNB ATN,$ 
JNB DRDY,MArl 
MOV MSGSTAT,#MRCVED 
SJMP MTxStop ; Go to send Stop or Repeated Start. 
MTxStop: JNB RPSTRT,MTxStop2 
MOV I2CON,#BCDR+BXSTR; Send Repeated Start. 
SJMP MTxStop3 
MTxStop2: MOV C,SETMRQ 
MOV MASTRQ,C 
MOV I2CON,#BCDR+BXSTP 
MTxStop3: JNB ATN,$ 
MOV I2CON,#BCDR 
; Set new Master Request if demanded 
; by SETMRQ bit ofMASCMD. 
; Request the HW to send a Stop. 
; Wait for Attention 
JNB A TN,$ ; Wait for ARL, STP or STR. 
JB ARL,MarlEnd 
ACALL MastNext 
JNB MASTRQ,MMsgEnd 
STR,MMsgEnd 
AJMP GoMaster 
MMsgEnd: 
SJMP Dismiss 
MArl: 
JNB STR,MArl2 
AJMP GoSlave 
Marl2: 
AJMP Dismiss 
MArlEnd: 
SETB MASTRQ 
AJMP MArl 
AdTxArl: JB STR,MArl 
JB STP,MArl 
CJNE RO,#O,AdTxArl2 
DEC A 
SJMP AdAr3 
AdTxAr12: 
; End of Master messages, 
; Non-synchronous Start or Stop. 
RR A ; Realign partially Tx'ed ACC 
MOV RI,A ; and save itin RI 
MOV A,RO ; Pointer for lookup table 
MOV DPTR,#MaskTable 
MOVC A,@A+DPTR 
ANL A,RI 
MOV I2CON,#BCXA+BCARL 
ACALL RBit3 
JB DRDY,AdAr3 ; Around if received address OK 
AJMP SMsgEnd 
AdAr3: AJMP STstRW 
MaskTable: DB Offh,7Eh,3Eh,lEh,OEh,06h,02h,OOh, ; Offh is dununy 
Dismiss: ACALL I2CDONE 
MOV I2CON,#BCARL+BCSTP+BCDR +BCXA +BIDLE 
CLR TIRUN 
POP ACC 
MOV R2,A 
POP ACC 
MOV RI,A 
POP ACC 
MOV RO,A 
"POP ACC 
POP PSW 
263 
SETB EI2 
RET ; Return from 12C intelTIlpt Service Routine 
XmAddr: MOV 12DAT,A ; Send first bit, clears DRDY. 
MOV I2CON,#BCARL+BCSTR+BCSTP 
MOV RO,#8 ; Set RO as bit counter 
SJMP XmBit2 
XmByte: MOV RO,#8 
XmBit: MOV 12DA T,A ; Send the first bit. 
XmBit2: RL A ; Get next bit. 
JNB ATN,$ ; Wait for bit sent. 
JNB DRDY,XmBex ; Should be data ready. • 
DJNZ RO,XmBit ; Repeat until all bits sent. 
MOV 12CON,#BCDR+BCXA ; Switch to receive mode. 
JNB ATN 
XmBex: RET 
ClsRcv8: MOV 12CON,#BCARL+BCSTR+BCSTP+BCXA 
JNB ATN,$ 
JNB DRDY,RCVex 
SJMP Rcv8 
AckRcv8: MOV 12DAT,#O 
JNB ATN,$ 
; Send Ack (low) 
JNB DRDY,RCVerr ; Bus exception - exit. 
ClaRcv8: MOV 12CON,#BCDR+BCXA 
JNB ATN,$ 
Rcv8: MOV RO,# 
CLR A ; Init received byte to 0. 
RBit: ORL A,12DAT ; Get bit, clear A TN. 
RBit2: RL A ; Shift data. 
JNB ATN,$ ; Wait for next bit. 
JNB DRDY,RCVex ; Exit if not a data bit (could be Start! 
RBit3: DJNZ RO,RBit ; Repeat until 7 bits are in. 
MOV C,RDAT ; Get last bit, don't clear A TN. 
RLC A ; Form full data byte. 
RCVex: RET 
RCVerr: MOV RO,#9 
RET 
; Return non legitimate bit count 
TIISR: CLR MASTRQ ; "Manual" reset. 
MOV 12CON,#BXSTP ; 
MOV 12CON,#BCXA+BCDR+BCARL+BCSTR+BCSTP 
Til: MOV MSGSTAT,#TIMOUT ; Status Flag for Main. 
T12: MOV A,#OFFh 
CJNE A,TITOCNT,TI3 ; Increment TITOCNT, saturating 
SJMP TI4 ; at FFh. 
TI3: INC TITOCNT 
TI4: ACALL RECOVER 
SETB CLRTI ; Clear TI intelTIlpt flag. 
ACALL XRETI 
MOV SP,StackSave 
AJMP Dismiss 
RECOVER: CLR EA 
CLR MASTRQ ; "Manual" reset. 
MOV 12CON,#BCXA+BIDLE+BCDR+BCARL+BCSTR+BCSTp· 
CLR SLAVEN ; Non 12C Timed mode 
SETB TIRUN 
MOV RI,#Ofth 
DLY5: NOP 
NOP 
NOP 
DJNZ RI,DLY5 
264 
CLR TIRUN 
SEm CLRTI 
SEm SCL ; Issue clocks to help release other devices. 
SEm SDA 
MOY Rl,#08h 
RC7: CLR SCL 
DEl 0,0,0,0,0 
SEm SCL 
DEl 0,0,0,0,0 
DJNZ Rl,RC7 
CLR SCL 
DEl 0,0 
CLR SDA 
DEl 0,0 
SETEl SCL 
DEl 0,0,0,0,0 
SEm SDA 
DEl 0,0,0,0,0; Issue a Stop. 
Rex: MOY 12CON,#ElCXA+ElCDR+ElCARL+ElCSTR+ElCSTP; clear flags 
SEm EA 
RET 
Reset: MOY SP,#07h ;Set stack location. 
CLR A 
MOY DPTR,#R_CTVAL 
MOYC A,@A+DPTR 
MOY 12CFG,A 
CLR A 
MOY DPTR,#R MYADDR 
MOYC A,@A+DPTR ; Get this node's address from ROM table 
MOY MY ADDR,A ; into MY ADDR RAM location. 
CLR OnLED 
Reset2: CLR ErrLED ; Flash LED. 
ACALL LDELAY 
SETEl ErrLED 
CLR SErrFLAG 
CLR TRQFLAG 
MOY FAILCNT,#50h 
SEm TogLED 
MOY TOGCNT,# 
MOY 12CON,#ElIDLE ; Slave will idle till next Start. 
SEm SLA YEN ; Enable slave operation. 
SETEl ETI ; Enable timer I interrupts. 
SETEl EI2 ; Enable I2C port interrupts. 
SEm EA ; Enable global interrupts. 
MOY MASCMD,#Oh ; "Regular" master transmissions. 
MOY DPTR,#PongADDR 
CLR A 
MOYC A,@A+DPTR 
MOY DESTADRW,A 
MOY MASTCNT,#Olh ; Message length - a single byte. 
PPSTART: 
PP2: 
MOY MasEluf,#OOh 
SEm TRQFLAG 
SETEl MASTRQ 
MOY Rl,#Offh 
PP22: JNEl TRQFLAG,PP3 ; Transmitted OK 
DJNZ RI,PP22 
MFAILl: DJNZ FAILCNT,PP2 
265 
ACALL RECOVER 
SJMP Reset2 
PP3: MOV RO,#Offh ; Software timeout loop count. 
PP31: MOV Rl,#Offh 
PP32: JB TRQFLAG,PP2 ; Rcvd ok as slave, go transmit. 
JB SErrFLAG,PP5 
DJNZ Rl,PP32 
DJNZ RO,PP31 
PPTO: ACALL RECOVER ; Software timeout. 
AJMP Reset2 
PP5: CLR ErrLED ; Receive error. 
ACALL LDELAY 
SETB ErrLED 
CLR SErrFLAG 
AJMP PPSTART 
LDELAY: MOV R2,#030h 
LDELAYI: MOV Rl,#Offh 
DJNZ Rl,$ 
DJNZ R2,LDELA YI 
RET 
SRcvdR: NOP 
MOV A,SRcvBuf 
JNZ SR2 
MOV MasBuf,#OIh ; It was ping-pong reset value 
SJMP SR3 
SR2: INC MasBuf ; The expected data. 
CJNE A,MasBuf,ErrSR 
INC MasBuf 
DJNZ TOGCNT,SR3 
CPL TogLED ; Toggle output 
MOV TOGCNT,#050h 
SR3: CLR SErrFLAG 
SETB TRQFLAG ; Request main to transmit 
RET 
ErrSR: SETB SErrFLAG 
RET 
SLnRcvdR: 
STXedR: 
SRErrR: JMP ErrSR 
MastNext: 
MNl: 
MOV 
CJNE 
MOV 
CLR 
RET 
RET 
12CDONE: 
A,MSGSTAT 
A,#MTXED,MNI 
F AILCNT,#50h 
TRQFLAG 
MOV A,MSGSTAT 
CJNE A,#NOTSTR,I2CDI 
DJNZ FAILCNT,I2CDI 
MOV FAILCNT,#Olh ; Too many "illegal" i2c interrupts 
CLR El2 ; - shut off. 
I2CDI: RET 
R_MYADDR: DB 4Eh 
R_CTVAL: DB 02h 
PongADDR: DB 4Ah 
END 
; This node's address 
; CTl, CTO bit values 
266 
Appendix 8 
Code generation (test) 
Ov 
7555 
Sel. 
+5v 
10k t--~ ~Ov 
0.022 
+5v 
From 
divider 
0.022 
Appendix 9 
Filter programs for the TMS320C50, the first is an audio bandpass 1kHz to 
2kHz pass program with the on board audio interface chip (DSK board) 
initialised. The second is the pulse shaping filter, 20 tap F.I.R. with roll off of 
0.35. 
Blackman filter windowing was used 
when calculating the filter's coefficients. 
; ->AIC 
.mmregs 
.ds OfOOh 
TA .word 16; 
RA .word 16; 
TAp . word 1 ; not used 
RAp .word 1;"" 
TB .word31; 
RB .word31; 
AIC_CTR .word 08h; 
Output .word 0 
Temp .word 0; 
.include "bandpass. fit" 
.ps 080ah 
rint: B RECENE 
xint: B TRANSMIT 
; TMS32C05X INIT 
.ps OaOOh 
. entry 
;OA; Serial port receive interrupt RINT. 
;OC; Serial port transmit interrupt XINT. 
* 
SETC INTM ; Disable interrupts 
LDP #0 ; Set data page pointer 
OPL #0834h,PMST ; OR the status register 
LACC #0 
SAMM CWSR 
SAMM PDWSR 
SETC SXM 
; Set software wait state to 0 
SPLK #022h,IMR ; Using XINT syn TX & RX 
CALL AICINIT ; initialize AIC and enable interrupts 
SPLK #12h,IMR; Select serial port receive interrupt 
CLRC OYM 
SPMO 
CLRC INTM 
for IDLE 
B for 
; Enable interrupts 
;------- end of main program ----------; 
RECENE: 
LDP#XN 
CLRCINTM 
LAMM DRR ; get input in ACC 
SACLXN 
; start FIR 
LAR arO,#XNLAST ; FIR data value in data 
MAR * ,arO ; Make ARI current. 
RPT #taps-l 
MACD #coefftab,*- ; Coefficients stored in program memory. 
APAC 
SACH Output, 1 
LACCOutput 
SFL 
AND #Offfch; and Is 2 bits of top 16 bits, for DAC. 
269 
SAMMDXR 
RETE 
TRANSMIT: 
RETE 
* aic initialization data 
AICINIT: 
SPLK #Olh,PRD 
SPLK #20h,TCR 
MAR*,ARO 
LACC#0008h 
SACLSPC 
LACC#00c8h 
SACLSPC 
LACC#080h 
SACHDXR 
SACLGREG 
LAR ARO,#OFFFFh 
RPT #10000; 
LACC ... ,O,ARO ; 
SACHGREG 
LDP#TA; 
SETCSXM; 
LACCTA,9; 
ADDRA,2; 
CALLAIC_2ND ; 
LDP#TB 
LACCTB,9 
ADDRB,2 ; 
ADD#02h; 
CALLAIC_2ND ; 
LDP #AIC_CTR 
LACC AIC _ CTR,2 
ADD#03h; 
;LACC #11100000b 
CALLAIC_2ND ; 
RET; 
.end 
* Pulse shaping Filter routine 
AIC_2ND: 
LDP#O 
SACHDXR; 
CLRCINTM 
IDLE 
ADD #6h,15; 
SACHDXR; 
IDLE 
SACLDXR; 
IDLE 
LACL#O; 
SACLDXR 
IDLE 
SETCINTM 
RET; 
* Output: FilteredlPulse shaped data olp, the variables are "ikf',"qkf' 
* Job: To shape the incoming diff. enc. and mapped data 
* Cycles: 19 max 
... 
* Filter Characteristics 
* 
* Sampling Frequency: 48 Khz (i/p is 12 Kbaud/s, 
* Filter type : Parks Mcllelan window FIR 
* Percent Roll-off: 35% 
* Alpha value: 
... Filter length: 20 (interpolated to a factor of 4, therefore 20/4=5 
... Coefficient Quantization : 16 bits 
... Note: The Filter characteristics are the same for both I & Q filters. 
* Hence the same filter coefficients are used for both, 
* though the filter i/p I & Q delays are different. 
... Note: The fIrst 3 interrupt routines would call Mod_fltr 
_.... and the last interrupt routine would call Modfltr to do filter 
... delays too 
270 
Mod fltr 
** .... ** .... **** Mod I-arm Filter routine ************ 
* 
rpt #coefnum ; repeat coefnum+ 1 =6 times 
; the following instruction 
mads *- ; multiply & accum., coefficients 
apac ; form result 
sach ikf,l ; save (scaled) filtered output in ikf 
********** End Mod I-arm Filter routine ********** 
************ Mod Q-arm Filter routine ************ 
rptz #coefnum ; repeat coefnum+ 1 =6 times 
; the following instruction 
mads *- ; multiply, accum. 
apac ; form result 
sach qkf,l ; save (scaled) filtered output in qkf 
call modout ; call modout in io.asm to output 
* 
* 
* 
* 
* 
* 
* 
* 
lacc 
and 
ikf 
; mod olp to 2 files named ik.dat & qk.dat 
; load ikf 
#mask ; make lower two LSBs 00 so that 
; AIC registers are not tampered 
samm dxr 
lacc qkf 
and #mask 
; send olp in data transmit register 
; load qkf 
; make lower two LSBs 00 so that 
; AIC registers are not tampered 
samm dxr ; send olp in data transmit register 
ret 
Modfltr 
; return 
rpt #coefnum ; repeat coefnum+ 1 =6 times 
; the following instruction 
madd *- ; multiply, accum. AND delay 
; (perform convolution) 
apac ; form result 
sach ikf,l ; save output 
********** End Mod I-arm Filter routine ********** 
************ Mod Q-arm Filter routine ************ 
rptz #coefnum ; repeat coefnum+ 1 = 15 times 
; the following instruction 
madd *- ; multiply, accum. AND delay 
; (perform convolution) . 
apac ; form result 
sach qkf, 1 ; save output 
call modout ; call modout 
********** End Mod Q-arm Filter routine ********** 
* lacc ikf ; load ikf 
* and #mask ; make lower two LSBs 00 so that 
* ; AIC registers are not tampered 
* samm dxr ; send olp in data transmit register 
* lacc qkf ; load qkf 
* and #mask ; make lower two LSBs 00 so that 
* ; AIC registers are not tampered 
* samm dxr ; send olp in data transmit register 
ret ; return 
**** End Modulator Pulse Shaping Filter Module **** 
**** Demodulator Matched Filter Module **** 
* Matched Filter routine 
* Input: 24 Kbaud/s mod filtered olp, the values are loaded in appropriate 
* filter i/p locations before this module is called 
* Output: Filtered mod data olp, the filtered ik sample is in ACCB & 
271 
* filtered qk sample is in Ace. 
* Job: To filter the incoming I & Q demod input data. 
* Cycles: 52 max 
* Note: The Filter characteristics are the same for both I & Q filters. 
* Hence the same filter coefficients are used for both, 
* though the filter i/p I & Q delays are different. 
************ Demod I-arm Filter routine ************ 
* Fiter coefficient locations: External Program Memory 
* Filter delays (past input samples) locations: Internal Data Memory (DARAM) 
* Implementation: FIR convolution 
DMD fltr 
rptz 
macd 
apac 
sacb 
#coeffnm ; repeat coeffnm+ 1 =20 times 
; the following instruction 
#dmdcoff,*- ; multiply, accum. AND delay 
; (perform convolution) 
; form result 
; store result in Acc into Acc Buffer (ACCB) 
********** End Demod I-arm Filter routine ********** 
************ Demod Q-arm Filter routine ************ 
* 
* Fiter coefficient locations: External Program Memory 
* Filter delays (past input samples) locations: Internal Data Memory (DARAM) 
* Implementation: FIR convolution 
* 
********************************************** 
rptz 
macd 
retd 
apac 
sbrk 
#coeffnm ; repeat coeffnm+ 1 =20 times 
; the following instruction 
#dmdcoff,*- ; multiply, accum. AND delay 
; (perform convolution) 
; return delayed 
; form result, Acc has result 
#coeffnm ; ar5=ar5-coeffnm(19) so that it points to the 
; Ik demod filter i/p location 
********** End Demod Q-arm Filter routine ********** 
272 
Appendix 10 
Maxim Data 
3V, Ultra-low-Power Quadrafure 
Modulatol'/Demodulafor 
_____ ,0.n8,..' D •• r;rlptlon 
Tl'.o •• t·\)l~':'~ ',,",,"'::05 • Qu) ~.,t'J'e mo:fl/ :.il.:.!, .lmJ 
QUilCtB1U'. 041'!K111AQlO' Vi!:'" 1l.~lljt.g cv:ilrn(ll IYH1 
(/1\r;dl).tj)l ,8 pt~ej!tII e ll f l "'O!l(llil !'!l~ IC . It op.ralOI 
rnm n ~tnDI" . 3V ~JPP'" in" c~awJ oro"" S.p,,...-. Tno 
11'",(I($u:,lor D¢Ct'PtI ..... ImJ:lilif,d tl l'd m.r(,Y.l Ii' sly,,"~1 
fllI'ot 3.:tt.tHz\Q&"'lII.Hl UIIl;I),illY.l dt:ffndl j ' 'Lru.'tir:.:> t 
tln.:J 0 t:.u,dl~"\d ci;;::;tl:: y,irIl5:e9 (1/ V\lltllOI' COIT..,'-
/I/;;fIIii.,i"" Thg IF ;"~~ I il tffllli~.lled ~th .l ","'\){1 !hn · 
• On..ctolp O.c:lII.t.of (RItOUI' ... E.d ...... 1 nmf"g 
Clrcul,) 
• UHut.,e, Input eand*ldth Up 10 ' StAHr '"" 111m tHillCO' let trll'!CtHI, I!) I!!'\ tl(lam~ If !iII A: t he 
lu.\l:I::~rd wJ;ub. WI) 1\111,' ",Pf~lf'l'Ili;); and t\a .... 1.2\'P-D 
:.ion..,1 11'o' rt;~ . l Nt rr.-odLlarOf acceptt drlM!nt.t1 I nnj 
a b 3 .obll\d 101Gf\4lt ..... ;lh omphr,,:Jt-!; up 11:1 1 . .l5'.'p ·p 
IIn::i 1:,'1'\,..,. ... ~01tl:; to 15t.llk . nrl !:,;xl".fI" .... I a (1lf!Cfl'~li 31 
IF " iJ'~'\ll n 1~ l6tAHt 10 &:;MHt '''~Q. 
• D"Dmodutator OUlpul a.ndllrldth Up 10 IIMt1l 
• 'idB DM10dul.lor VolU.,. C.AII.,. lon Gllin 
~ ~~~~~h~~A~~~~f~~~~~o~~~~~~;~ ~~,;;'~i~ 
• CMOS-Comp_llbJ_ iEnllbJCt 
• I .Om. 0P4n1"". ihlP~Y Curt.nl 
1~A Shutdown Supply C\lUt'ftt 
10;'111 rll ;," 'i lA. T-a "''''' !'I".iu 'PII " "Il' teoab.lt\(. Ih ~ 
MAIC2-tOO's onlOINI c.'Ctnl~Of " tell II! I~\etl ltu) ' i' y'a 
OlICll'!tllIUf\I\U cQ."T\IK't") r,(!o. lltn o.r-iII:L!:;l 0,'"4 ~"oc;. 
I\lort nh;r:;o ~tI~ton o,DdOIc. ",H«.r>t .. 1 I[gr..a'! t(rIl~W· 
I"~ iQ.V 6tnplill,ldo lin" tl tluc ir1"lb.'.tflcc . ~illl(J ;f\!J 
OM.r/", 'nformalton 
PAR. 
tJl,X.:!4~0CWf' 
t.I",JI2· ~'-OC{:V 
·v¥'·l:df.l~~b;lI,q,'M,l\I\'. 
,-.. motlul!l~b! SI(U~~""d ut!c.c:i:;n cI lRdSl TI,~ w x,2_s.o 
WT .•• '" 2O.p~, SO alld asaP p.acu~. 
_ _______ App;'.,..lIons 
Funct/onalOl.,ram 
Y.\'~!!!n LANt 
llI(1lffll CO:n'fl~tllt..~Or:' 
PIn C"ntlguratlon 
""""" MAXIM __ . _____ .. __ ._ .v.. .. ,Io " ".,"",I'torl~'r~" 1 
c ... " rGII tr .. f..Qoo.a9B·8BOO for tr .... mpl •• llr 1it., .. Cur •• 
3V, U,tl'a-low.Power Quadl'ature 
Modulafol'/Demodulatol' 
I~~~:~d:~~~:.::~::n J Y'f .. :,:~ - ~~.~~'~~'~:~~.- I h'1l ., ;"~/t> ... 
. "1').111:11 1\1) i..".~ i 'fI ... hl' ;~;;,; :;.'t.:!£:~·r.i.T;;;'·"M4------r-
"' .... r~""');' ~.,-".----+--,.-'!:t-, -+i f~~.:::::;;.~i;-:), ~ .~r;:;,:p7r:;'.f;.;.:.~;.-I------+--; .., r..je 
I~~~;;;;;=+:===+~(""w:,:::,"' ) .. =-.. .. . ....... ..... t==~=+~ .. ~fur,.;~ ...... _ .... _ _ 
_ UII'« ~P~1:'lt.lt:r. IIII1A1,,!T".o)' r.H5: ~· ·1 J<I :'!t!r. 
,:",,-,'1 
IIar, l : 1)~ )t~r/'c'O>~ b",.dI!~",,,,:'I!:""'''''' 
~::: ~~ ~~~ 't;:~:,:",~';'~~~~ :~~~~:~~~,ft~:'~;~'~ '~~'''~~'~~~'~; ~:;:"fl •. ":II."I!I'l~~' N 1-0;; ...... .. (qa""tI~~ 1",~ 
""c:\i'\'~ If" ("Ito: "'''~'''~):';M Ir ll., ;:~'<I ":IIIc" :. ... :t t:l:r.\..':li~"L ,"!\.T, ... !."' ,~ .. ~ 
N,ta c: U ........ c::ar. ..... "'r. ;M'1··. ·"i'l':.: ".'llry:- _ 2: !\:",,::ul ~~~"' lr ,,,. rJl.'U:"_·Il. . 
_AXIAl! _ _ _ . .. ___ . ....... . 
NUl''''' SUtfLY tw:IUt 
11. 1EItI'IUlVU 
3V, Ulfl'a-low-Powel' Quadrature 
Modulafor/Demodulatol' 
{:~..n li' ... l.'l ,." ~ ... nl(.).,,,n:t:n(l..:. It .1J'r.i 
·.' ... I1 ... ~O(~f4(1!~ ''l.~"wrc.t-::~\·. +;'I),~) ('00· .. ·' .. 
csc.' (<.111' :11\, ... 1~'1./'OC IlbalM! .1:;.>Cl .••.•••• •• . 12.'.",'.\' 
~Jp~~'lh~;; rCn,:J;IIll.l1l ftn;o f1"(; I; •• ~·c 
$1C\t;.U'" TII.n'l4' .I~lt>k"\l'" .. .. .. .;.0--0 1:1 ~ I~e'c 
l •• :l T*trpl.'·l!ll ... ffO ~J''','a 10l.c) ....... ·):;Qc 
~ ... lIrJ"JC"#"~I'T"«II."<d'!"o' -~<$o ...... ~." ,...... ~~ ~'s"..-,..; .. :-I .. =-.. · ....... I>' ,.,.~ .............. 1.'\O\. ... _ ....... w .... "'II" ... t. ~, •• ,\no. ..... ," 
... _I.cM""·,... ...... II I'.&$.¥O- .. lla'~·t.7~UyCI"o1 .·.cl o,~C"td.; I·..e-qI(lQ.."""'. l tctw"AC.·tNl,Il«.··t~1'3tl 1\3,..·~-.df .... ""'ft, ... \) 
.,.,J,,\f&J~·"'~"IIc"'dltr.F ...... _ .. ,.. .... · ~·., "'·I\oc:"1<'<·"' ... I#·," 
DC ELECTRICAL CHARACTERISTICS 
(IIcc "" LCI .• \ ·CC = l!lIK=-?'N I Cl J;S' . f.NARI. ~ ,,'iCC ' O.ol .t"-.H:l" 1 . ().G~m .. ('f~,UII" Oti ,,().N "O:"N .,. 11')11 " lo\.~" ­
OJ\:N. T .... ~O·: I;). 7.l'!:. II!.Ic<t .(l~""'u- I'(:,.(.I) 
r..,R.uunA 6rMill)t. t ON tOHg ....", TY' . loW( UNrT$ 
r ~~~::~~::.~~ nnrqo ~"~~~~::'CC ~.--i 21 " ¥·!m·~··-if.1.!-i-M··· 
:~~~:~;;~-:~~:v 'm :~~1~! ~Y:!-lf_:_? LV _¥_,,~¥_ \ 
!iH"IIl", " ,,~t'nf!rt :(11 ~ __ ..... ::~~ Va; 
, 
Eli'" L 11" I' 8 ~"'N": I 
ftUo.1lU t.?to" "~~~II \'£"l 
" 
i.:~.o7~~6~.J~~u~~I!".\ .~~~~~ 'U;;~~;;' .. ::;":::",;:':".:',,,,:-, --+-;,=-_C;,.'-t--------+-----+--l ~;c:d:'''::11 Z;:~~ 
I II 'IrtU''''p;I .. "" .. _~ 
~·:.eN:r; ~'III: ·1 
~;;~~::. &;'~J 
t-t·,;;, f' ... J~i'" 
I nr.rt :> u..U I.r.w:! IMlro (lit1l121 
..-. 
3V,- Uii;'a.low-Power Quadl'afure 
Modulator/Demodulator 
e .0 l: 
nlol"!:'-Ir-.II'(:t 
" 
,-\ 
; .! \ I 
\.1 \.J 
. ·i . .. .,7"· 'I\t(l .... ...... _ !-+ ____ I __ I_ ... i 
~ ~~. ' ~:~'I ···· .. · 
i" tt-r-r 
.. fi. 
....... .. .. ,· ...... i·_·l f--I'--l 
.. l ······ b:+r-
'- , r"""' 
\ i \ 
\ ! \ 
~, , 
""AXIAl! 
-
273 
3", Ultra.Low.Power Quadrature 
Modulafor/Demodulator 
.MAXI.JM 
"lrr'I)lM.AlV1I ''Q~KUI 
UUMMmM1IW.TCII 
n . nIollIU.l.nnu 
IIl lMOl.UlUIVOmUClIlM.Ism 
C,lVn,UaUOfAlQl/un 
" ~. 0 
! .. 
I 
f1' I . -~ . -I i 
-
; ij -:l1 , l' -t ill 
I.. I.'" 
"~"I~:/~IO.'"; 'jJI" 
DIMlEUUTCR1W1UIIDafllWfR 
.. , n W,",Ult.111 
r . 
~ ,t:,t, ="C,,==:::l:::±::j. 
3", Ultra.Low.Power Quadrature 
Modulator/Demodulator 
c-__ - --D.tall.d D".crlpflon 
1hl: la~:r"" "0 u-:tom Clf~(.f t03 ol~:h 01 lh~ lu~chf)n .nl 
:'IIX~G ,~.o",,11 in 1: ,rt FI"~I,i1·M.' (Xug.',l·n TlI~y Dis:) Itt.!1 
l~ lht l vpCi\I"~Cllc"t~n EtIOCk 0 i\!lf (l"" (F9~U ." 
lhtrnodul.'tI' 
Th" d r.rrcl1u l:IIC, CC,W;) /U " iU'I;t'o-encl(':;J-lo· a,!jf'liml li" 
cO",'1)1tr, '",0 (l ,lbnrHa,U 'm.llir:1icr:: . 1\',(1 , .... 1) Ii .... d gQI"I 
i130es. n.3 If IIOMI ,hn~ld l::o:'C r.:,uph:c: ,nIl.' IIl"lN . 
lnItJrn.'\II,. V' _IN 1~ ttlmlnllia \'.0'. ,), ·~:-cn '''$I~~t': 1(1 (1".0 ,,'In n rcvldrr.: u r;;llin 1)1 U c'!] . Ttl;" :!."1·p,I·o)d '*' $~ 
NIl IS lOa nlo tho 1 .. ,..;2 a I:r~"ml:: ID' ".'~--=d\Jbt.of'\, l1'1e 
-.. Inu':'l)I01', n'\)( tr. • • F "1j!,'1I1 'fIlt~ .no "Uh('.r~IIJ!(I '.0 '9' 
l\'II!; . III ~J/kI'iliI'bGj;~ •• ~ a s ..; ''','!., I t.:)cO'Ivef. 
IIO~ n." ~ !he mt'I:,,,t(tl ~ i.'1 13rlO, It'.tl~ ., lignals art 
Iul1h1!, "~lll!oo by 2'09 til the t!i\uh.,r?: ;:IIT4."I'Jhm~ 
lMe tMMII,"'(l1 ""'" 0 :u~tphtil!' cruir.l $'1'! DC. o!\JpllO 
Loc..,O •• llIaror 
n\CIlaca'-O~I~'.t.:Jf $ 1(;11011 1$ "'111",:1 t.V II" c:rnil"Ir ·r;mJ 
pIle d ,IfC' c: r.Jt;\1 .. ~,il . r u;,uH.' 2 sf't:ws ;he equI'I"enl 
loul~lC,lto\lOt' or~,,' \ Cl'lll:nnt;c; :On tlllltI,":Il l.C 1"0-
11:'1'.( tlL1k C(1{f:ft'ltr", t'le -=-'CIIII\,"1'1 ttO(lU(".nc't·. ;::od 11'11'1 
0 0 1 ""$ .m;nn,'In' ' I1ri: :ltf.::l1Wt O.cUil:O, OhHO 
nOISe. 1he- CGdIl~I ·.c:n fftl(ll ll.I1tf:I· ,:; e .... co) './'~ II" h'~' 
Cy. 10 Y'.a11tlO ouaaral'JrB ph~~t r.t1l'\l:r~lnl ::;'IIIr.lI~ I'MI 
!., tc:h r..$lfl ~~'.tltt ~41t>u ~:oIO"t li' O Sign", 
" ~~= ~~~:r ::Jt~~~~\CG·~:;o~:~ ~~'~:::'~~K~fJ~. 
ll! 
.• L"-WI!--'-=-":--I.l.W:J 
~ I> IX. 
l ( • .., ut,t..~ u,tl <ll ~ 
;~~,m~t~;:.;~;~ ~"!CT ~~_~."~dCT~'~b~;~~~ 
('r,: -aI o'Ipt1l "p(lI1 ;) ~r." ;'1 TANkJTANK ill H·M~ . rar til l 
<J !" " ' f).,.,d tJ !,v ~L (C: '!I'C:~ ;I" AC b'lPII$1 Catli'l(:,:(11 
(KO::J:F) Irnrr. T~" ~ CiNC, :l1I::i I>l':'. :Oul.loiJ ''''1'oK to 
tfl t 'OI.lCl 
Thl' tlu:l.!Jl -.~'O OI·.U' ~.r .. r"'or V'Clt; t·.or.: Illr.t.t\,. Ie 
~ .~·<!n IhI.!-l:cu··u~t , lalor 1!t,quf!neV b"1 :~rD . .m::J Qln(l-" 
all)ll"Ortt> prll:J \e- QfJ:'Idln.tUlI! !l 1!) '''1t~ . Ir,IO:'lt'(li 1:,.,'''''9 
:IIN)hhe:'S S".50. 01l) "O~flll' O .:'r. ... , fllumal '.~ II I1U:1111 
w;a..-... \0 c:"w me (l" t::.fI< tllIlT,' OU ':"t-o 1~ P.·"\l1) ;\ 9· 
""I (0.1 IUlrt li'l'l IIlcl1! ' OCdJl:tICN '",Qllflncy) It fUll"" 
dN,:)e(l oY lour lor ,,,. flICI~t;A'(f, '''"'1'1.1. 
~.e.'er 
Thn ,:,~ll!41 OI.':UI.t, mE_OJ1. IS t::-Jl~tre::l ilr.Qi ;YolnjJS 
"'J:lt.~!I V 11 3S'J1j·p 'I'I,tl1 " 'C~ nn!! 611 X::t::t L~ can be 
l\\. ·c:upttO t!>lhit Inplo~ at Ill,r-:.\.I('!r,;y IJ't':"lihOllit.r.f 
Nodula ' ol' 
f ro(l tr,:(1I1';'~ ;Jer.r.J!~ I all:::! a eirltltflliat bJiGo."bIlf'\:1 
1!9n:l'1. uo \.) , 35'1\.'"11 W~ ,., 'rr.~I" ·!rI ~Ul!; un II) ! 9JH.l . 
" '" '' lJa:l:llwerl$ 1h~1'J 10 II'Ie It' II0QU!!At.\'. S nCII' 1hO~ 
Inpu:~ :"" bj~MltJ J::\ltrNlUY.:lt U.II'~O ! .!>\t'. 11Ir.::l 0 $1 (:1. 
"0115 ~ 1'.:uld D(I c;~IIc;i'/"'"~'Y GnlJ/lk,d L~ 111.;t*O hi~ !\. 
."·">l~1ftCt ~ort~ (,~" cdflrOnll", -"p'J: Imr:flC'aflr.l.l i~ 
arr.:ulIi1",:ctlty 4111<11). 1M u t" l)<JS deslgr, VIOI:l5 \'c:rj 
J:: ..... O~.;hip ~hl";l. lI:IOIJ:JirllJ '. f" "~t("'t:'lt cam,, ' ty~·. 
3V, Ultra·Low·Power Quadrature 
Modulator/Demodulafor 
iF:~~Q:~ ~="~fr~.~;~ti~.= ... t~.i .~ .. ~:~,; ,r='.=:'~=:i :~:' ~~:;~~=:. ;.~a= .. o=.;;=i:;:'=' .. =. ==~,u~"~. ~ . ~~.. = .... = .... = .. _=_=._.=_= _ ~Pln := 
J . til 3Nt'I :"/I)"W 
r---i- _M" ~~~HM··~ f···~·~i.::~~·;:~~;~ ·:~r~;n;· i;~;·; " · ... . ...... ... .. ...... ............ .... .... .......  ·· ··  .. · _·~ _ .. _·.H ... H __ • __ 
I :. ·!= _ ~···~:*1 .. ···+··~·;:;·:·;,~ ·f~~~:·;:~~ii71~··,~,;r.-·_HH~ ...... _ ... _ .. ___ H __ 
! II fNA.1IJ.E' l' r .. :-.'''f:crJ ...... e.,;,-,l,...)''I 
3V, Ultra-Low·Power Quadra ture 
Modulator/Demodulator 
c::. PWt.I~'1 I\'tf'tn~'.I.:t<'r" . fI '1I11"'~:'\Ilot Il /o.<:' :'\1" '; tx>. (":o~· U\ 1'1(1;;"'" Vt,t;'-¥', I ~ AC , ...... P ··1"'\1. i l ~ I'l f"l ;l'1 , I ::':;'''''1".::''' 
~ ~cI'~h:.~t;~~~~fY~.' t~~~~~~t:~~:':~b7~j\!~;~~: 
... , cto.,pllr., (',,'p.j\f;;rt,,:\ f'~ ' IIF} if) GN(':' 
; ~~~!f'~~~~~~l~~J:':;it;~ ;~~i:;~;~;~::~! 
NlAXI.M 
IIC I:lJlt! j, r.;loI.~:I~C"~ II!' 'G\ .. ~I~ a~O\1 ::.Jh C(l c! r' .. <lt'. I/tllh fI 
aO" (liUO W OtoljJllt .11'f1r.'il •• a!(J \f.!lW(I:1) 1(1 rtrillt:; iI :~n . 
t~I~~~l~~: .!~~ ~~~:.~~~~~~ ~~~J ~t;.~~;~ v-d,", 
Till: ,.~:iII"J::'" r:ll'IlUli:'Ic.J' (; •• "1 til! c~ on~tll! Lot fIII~/"~ 
lr,g c C' ~ I ·\11 III)!!IIj)C ~'G JIlI. 
.. l" .... fer ., •• 
l11J1:1'I{1 :"Ot)r;nll ':p(l .. ~ ;i:;n. EtI(J;iI. r- l''' :uI:IIIYT~til\ i'J~KJ.'" 
~'cr; . -:-II¥ 1' ..... " Ilij 11\(' ::JJ~l:IL': 'l"lPlU 1:;.0.,' ~~ut :o 011 iN 
m.'!~ 1Of c i:"l!; ;1; .... l<!<Iu:.!:'.I/,O (, ··,;:U : .::"·/<!!'l t.::l ;"1( Iha., 
l:';;.t. 'Ihlt ~.~ iIl~ tli.;111 !~\;';I:I"\ l:'cl .. ~:.:l~" t'.;:,n ~::!~,"' :d · 
('I'!nc..j ;:t-:'lO:.:MI al"ld fI ':'TAI j;.o~n("l ".o;:"'" 10 AI)fO:JI.) 
Tl:n :f.,mllilJ·,:) (;1I'·r."~'.I)(:r4/1!.:~{. 
___ Applications Informalion 
r-iii~'1) .. \!lm'.:~ 11\: i'T· a~II'l\:l·:~':" 01 " ,.::it)t ·<lIlI .l l"~ 
Ct'CU :. r ~(! t ~C:~ C: IOI. hVO c tln«: II'}I ~l. Con: .. : I~;II \'''(1 10:; ' 
Il ll fl" I ~ 11111 ul:..:II:,t.ac'l i')sor.3r.! -;i((;'J'! ;., "<;tl'~ ·i. 1M 
ClSC;I/1\i(l1 tll)~l";(': '.y IOVI!Jllll h m-, ! :"tC:t.III.l!~ '.6QM'v . 
r;. <n·· . :o~ u ·11i1.'.l1t f \llt ·yO. ttle- ,lI clu:: \o, .f' ",(~W (:Clr:~ 
n.: :.r;lm1 "O:;lClr.:; !t<: 10 ::111 o:;::II'l':"'Y·\( tunl< ~(j! ~t. . T~ t.,'C 
lJoF C.ltlac; ~,: , :o all.,.;;: :1'>: C 01 ih r 1I} ::1>n~nl r.ut:: r: :. 
C!h::r v :!luj;,;: (Hay til:; C!"lOSO~ 10 nNt '!'o''-Icua' :"D r ~ 
('.JIleti ' ''' IU;·(1I:' '' r,);!:. 11::1.' Ihl l k U;,.,1I1" ~:<"I !'IUQ :{> "'ClOt· 
1 ':\ifI ~ 1M .".l fcilllllotlll illlQLI:,.'t~: 
~" "'" h..Ff.:·'/:'H) 
'''~11'1t1! 
c,,-:,:_ ! r 2 · c;3fnAY' 
C', r C2'" C·~; ~·~· 
;:,no t 
W~""" 1.~!'l"'''Y .,. 11;l ·:Il.jJ:G c~p~;iU(. :; oJ J'1f.( L!'. <~:"'!' .. 
Pti!81tIlC lr.;JI.GI. ,, ;.;a 
...., •• ':: r.t\' lI.:l"" ..... . ~ • .,.. . \., I\ .. ' '' .. .. · _~ ~~·.''' '' j·.''' ... ~ ... ''''''' .. .., .. ,~t><:~,.· 11 \,("-~'S'I<?I. ".,~ .... ~_" ........ :"f .... 
• ·' '' ...... hh.''' '-'' .... ., I . .,.,.V!lI,'r''':. :I.II ... "C''-:' ... -t:I''tt,fY. , .... ' ... 'I,,)., ~.f<' ... , ~ ..... 
274 
Appendix 11 
Burr Brown Data 
BURR-BROWN® 
IElE31 DSP101 DSP102 
DSP-Compatible Sampling Single/Dual 
ANALOG-TO-DIGITAL CONVERTERS 
FEATURES 
• ZERO-CHIP INTERFACE TO STANDARD 
DSP ICs: AD, AT&T, MOTOROLA, TI 
• SINGLE CHANNEL: DSP101 
• DUAL CHANNEL: DSP102 
Two Serial Outputs or Cascade to Single 
32-Blt Word 
• SAMPLING RATE TO 200kHz 
• DYNAMIC SPECIFICATIONS: 
Slgnal/(Noise + Distortion) = 88dB; 
Spurious-Free Dynamic Range = 94dB; 
THO = - 91dB 
• SERIAL OUTPUT DATA COMPATIBLE 
WITH 16-, 24-, AND 32-BIT DSP IC 
FORMATS 
Analog 
Input 1 B·Bit Sampling ADC 
Channal A 
Analog 
Input 
Channal B 
--i Aefaren"" 
, B-Blt Sampling ADC 
ChannelS on OSP t 02 Only 
DESCRIPTION 
The DSP 101 and DSP I 02 are hi gh performance sam-
pling Ilnalog··tn-di gita l converters designed for sim-
pli ci ly of use with modern dig ital sign:tI processi ng 
les. Buth nrc complete with nil interface logic for lise 
din:ctly with OSP ICs. and provide full sampling and 
conve.rsion at ratcs lip to 200kHz. 
The nsf' I 01 offers a single conversion channel. wilh 
18 bits of serial data Output. allowing the II ser to dri ve 
16-bit, 24-bil. or 32-hit DSP ports . Th(~ 081'102 offers 
(WO cornplel.e convcrsion channds , with either two 
rull [8-bit output ports, or a mode to cascade rwo 
16-bit conversions into it 32-hit POrt as one word, 
Both the nsp 101 and DSP 102 nrc pilCbgtd ill stan-
dard. low-cost 28-pin plastic DIP packages. Each is 
offered in two performance grades to match applica-
tion requiremcnt~ . 
Con .... ert 
Command 
Conhol 
LO\l ic 
Selact Sync formni 
Channol A Usc r Tag In 
Channn\ A DaUlJ 
Cascaded Data 
Sync 
Bit Clock 
.... ........ ... .. ··· · .. 1 
I 
Chanlltll B Dat8 : 
I 
CllannBI B User Tag In : 
Cosc.de 
tntemational Airport Indusllio1l Part • Mailing Address: PO Box 11400 • Tucson, AZ 85734 • Street Address: 6730 S. Tucson 81v<1 ' (utson, Al .5706 
lei: (520) 146,1111 • Twx: 910·952-1111 • Cable: BBRCORP • Telex: 000·6491 FAX: (520) 889·1510 Immedlal. Ploduct Inlo: (800) S41-li132 
" 1990 nurr~BrowTl CO'llllral lt)l 1 PUS-I068C Primed 111 U.S.A. OClohcr. IQ93 
275 
SPECIFICATIONS 
ELECTRICAL 
At T A::: O"C to 70~'C , t.2,75V input signal. sampling frequency (fo) ::; 200kHz, V A;' -:::: Vi) R> 1-5V, VA,- In - 5V. lOMH z o-xtorna{ clock on OSC1. CLKOUT hed 10 elKIN , 
6MHzdata lransier clock on XGLI<. d<l ta a nalysis bnnd-!imltod to 20kHz, lIn)oss oth(trwise specified. 
DSP101KP DSP101JP 
DSP102JP DSP102KP ,-.• - •. -.-.-1- ---1 
PARAMETER CONDITIONS MIN TYP MAX MIN TYP MAX 
RESOLUTION 18 
ANAwalNPUT 
Vollaoe Rang" i2 .7SV 
ImpedallC'9 1 
Capaell.nee 20 i 
-=T.-:HR=-o-U-a-H""::p-:UT- S- P-EE-O---+-------·!--- t---.---,-------- I------
on 
Cornpleto Cyclo AcquisWon i ' C(}tlVt}(sion 1 
- :~(J~~~~~-~6tJi;,- .----------- .--!~ .. -- ----i!-.---I------i--..... -----
::~:~~:r::::~: ~i6~~~::~liOn ) Rntio I., ~;~~:~~~rB) 83 Eo ,I -116 
SpurI01l9-Fr~8 Dynamic Ranga 1,_ = I kl~z 89 92 
Signal-to-Noise Ralio (SNR) I" = 1kH2 84 88 
DC ACCURACY I 
Gain Error is 
86 
92 
07 
-·9 1 
94 
89 
Gain Error Mismalch DSP102 Channa Is ±2 
", 'egral Uf)~a(jly 12.7!>V Input Ranae Sufficient 10 maet AC Accwtlcy SpecificaUolls 
Differontial unearitv ±2.75V Input Range Sufllciont to meet AC Accuracy Speclflc-alions 
Inlagral Linear"v Error :to.7V Inpul Range 10.003 
Diffsrtwtial Llneurlly Error 10.7V Input Range :!:(),OO2 
No Mis.inQ Codes W.7V Inpur RangG 
Bipolar Zero Error (3) 
Bipolar Zero Mismatch (J'i 
POW(-)f Supply Sansltivity 
DSP102 Challnels 
--5.26V < V,,- < --4 .7SV 
+4 .75V < V A+, Vo+ < +fi .26V 
14 
:2 
J:'l 
-60 
-60 
--89 
UNITS 
Btl. 
,tS 
kHz 
dB" ') 
dB 
dB 
dB 
dB 
dB 
% 
% 
% 
% 
Bits 
rnV 
mV 
dB 
dB 
SAMPLING DYNAMICS IIp.rlllre Delay ~ M 
Aperture Jitter 100 PS, rm5 
Transient Response 
Ovarvolla09 Rt't(.'Ovary 
I ~ 
I~OI-:::cGI~TA:-:-L-::INc:=P::::UT::::S,------+---·------· 
5 j-----j-----jf-----+ ----!---.----, -~ 
Logic Lavels (Except asc·») 
V,1. II = :11011A 0 
VII_. I,; :t ± 101lA +2 .4 'f'S OSC I Clock 74ltC Compatible 
·1·0.8 
Dala Transl.r Clock (XCLK) 
Frequency 0.1 12 • 
Duty Cycie 40 50 60 ' 
V 
V 
MHz 
MHz 
% 
FroQuency J 16 ~
Conversion Clock (ClKIN) 
1-_6_-rl_~.:..~U_~.:.~_c_re _____ __ I_----------+--~-;--+--3-3- __ ~~~ _ _ __ . _ . : .I--_M_~_l_-I 
DIGITAL OUTPUTS 
Format Sarlo I; MSB first; 16/1 a-bit and Cascaded 32·bi{ Mode 
Coding Binary Two's Complement 
Logic Levels I E,cept aSC2) I I 
vO'.. I ~ll/l.,« :.:: -lOlA 0 1·0.4-
V (.II-I ISOIJACE .:: 4rnA +2.4 +5 I 
OSC2 Ca n only btl usod to drive crystal oscillator. 
COIIversion Ciock (CLKaUT) I 
Driva Capability :t2mA 
POWER SUPPLIES ~~ I V".... +4 .75 ,t·5 +5 .25 
V ~- -5.25 -£ '-4.15 
Va +4 .75 .5 +5.25 I 
Power Consumption XCLK : ascI ~ 12MHz 250 425 
Supply Current XCLK ~ ascI ~ 12MHz 
V 
V 
mA 
V 
V 
V 
mW 
IA+ 30 45 rnA 
lA- ~8 ~5 ~ 
ID 
-TEMPERAi:URERANGE -----· ----.-.--.--.. --.. - .. ----.. -----.-. 
5 15 mA 
-.---.- -----jf--- --I-----.- .. ------- -
Specification 0 ... 70 "C 
Storage --65 ... 125 · C 
NOTES: (1) All dynamic specificat10ns are based on 2048-pomt FFTs, usmg four-t9rl1l Blackman·Hanls wmdmv. (2) All spoclhcatjom~ m dB 4.l ra ff:ltorrod to 6 fu ll, 
scaltf input, t2 .. 75Vp-p. (3) Adjustnbla to zero with exlOfllul potentiometer. 
aURR ... OROWNf' 
IEJEJI OSP101/102 2 
276 
Appendix 12 
The original front end of the receiver consisted of two amplification 
stages. The first stage is designed for minimum noise and the second stage for 
maximum gain. The transistors chosen were a matched pair of Mitsubishi 
MGF1402 GaAs FET devices. The input, output and interconnections were 
designed for an impedance of 50 ohms. 
The interconnection and matching calculations were done using 'Z-match', a 
PC based Smith chart program. The actual board dimensions were calculated 
using program 'microbas' on the PC. 
Stability Calculations; 
Stability factor 
K = [1- I SII 12 - I S22 P + I SII'" S22 - S12'" S21 I] /2* I SI21 * I SI21 
1-0.648-0.693+(0.648*0.693-0.079* 1.525) / 2*0.079* 1.525 
1.778 
The result shows that the transistor amplifier is unconditionally stable at 1 GHz 
with Vds=3v and Id=10mA. For optimum noise performance it is necessary to 
match the transistor into ro, the optimum reflection coeficient that is quoted by 
the manufacturer. 
ro = 0.42 L-160 with Vds and Id as above. 
The gain at this reflection coefficient is less than the gain achieved at a complex 
conjugate match, calculated using Masons rules; 
Gain in dB = 
= 1.214*2.313*1.924 
= 5.403 or 7.3 dB 
NB Approx only because this neglects SI2 ,first stage gain approx.7dB 
The reflection coefficient was first converted to an equivalent impedance; 
Zo(l-lr 01 2 ) + j2Zo. sin Lr 0 
2 =Zsn 
1+/rol -2Irol·cosLro 
50(1-10.421) + j2 * 50 * 0.42.sin-160 
= 
1 + 10.421- 210.421 cos-160 
= 41.48 - j14.36 = 20.949 _ '7 30 1"'\ 
1.9657 J. 3u 
277 
l 
f) 
1"; 
i:-JI:. <f "tr ?;C ANi\L yt; I!:i fI ~I -lr -Li -,i--, 1 UhF ::- 7 _ (14)(; [iF r:; c 
~~*~~ '~**W~ '~~~~'*****~* ~~~ **~*·.* *~**~· ******~* ·h ·~**.~* '~****~**~~~~*~~*~* -~~~k ~ '~ ·~~~ · ~~~~ ·~ ~.* '~ ~~~ ·w~"* -P · ~ ~.~~~*"~kW~~ ~ ~ 
r - m~o 
:; 6 O(")D+ l) t-.! 
:':' . :~::, 6D-+ OG 
5. ·1L:":D1 OD 
:j . "7 4 1 D+t)8 
6 . 01 1D+Oe 
6 .. 2 l l5D+OB 
lJ .. ~j'i 1 D+O U 
b .. 9 t J2D+ I)8 
-/ .. =::~ ' 7 O+OfJ 
'7 .. 5 b 8D+(i lJ 
7 . 9 >: 4D+I)U 
Ei .. :-.::::,.BD*, .. 08 
:J . bFl'i' O+OB 
C) . ( ,' ;-9D+(lU 
9 .. :,~*~ 7 O-I-OB 
9 . 9 76[)+ (l8 
1 • (Yf::;D+O~1 
1.I/jCI-[)4-0'i 
1 • 1 4~;o+O'/ 
1 . 199D-H)9 
1.2::;6D+09 
1 . :S15D+09 
1 . :::1'7D+09 
1. 'H 7:lJ+(" i 
1 . ~:il0 QwH)ri 
1 . :;-£1 .1 D+.) ,,) 
1 .. i~ ~:;6D H)I) 
1. "j"",'f D+(,''; 
1 • £; 1 ~;I) -H/) 
L .. ' i t) 1. D+l) C) 
1 .. l-~' I7'.l D·· .... ( JI'.;· 
:.:: .. (,n~~D+09 
:,~ .. 1 i.3~:;D+t)9 
~:: .. :; \:;~STJ+<) I? 
'_~: .. _', ',Fl.!) ·" (1(./ 
~.,*on (4'l j 
'-2 .. (,i)OO+() 1 
--, 6 .. ( '6?D+OO 
- /"). 06 ,':.!D+(H) 
--- r., . () 7 ll)+(iu 
·" 6 .. 07'7D-1 (H) 
- -{j _ 08 ~)D+OO 
--6 ~ 090 D·-t* (I () 
--c>. ()98 0+00 
-6.1 ('-/Ii + (iO 
'-6. 11 7D+i)( , 
"- 6 _ 12 BO+l)O 
-6. 14,)0+(,(1 
- ' 0 .. 1540+\)( , 
- b . 170D+OO 
-- 6. 187 D+(>(j 
- 'b . 207D+O(, 
.--t, . 22 f:li.l+OI) 
--c.) .. ~::J::D+()O 
- ·b . ::~ 79D+O~) 
-b. -309D+OO 
-6 _ ::'-'I-:3D+(h) 
-0. 380D+(lO 
·,*b .. 4 23D;'-(IO 
· .. ·6 .. Ll 7t)O+()(l 
--6 .. ~~25D+Oi) 
-6 . ~i [19 D+()U 
··-6 .. 666D+O(l 
-i:l .. 7 62D,t-(iO 
-- l:J . fJB £lD'H) I) 
... 7 .. (,J~~ lJi' {J(i 
.~:' .. :::t.:,iJ O·t ( ,(, 
"-7 .. ~6hD t-(H) 
---7 . 9B::·O+\) O 
--f3 .. ~:;5(3D+OO 
.. '} .. :' -::",,)£,..-") 1') 
"' 0 l .. 1.1: :(Il) · .. ·ul 
_~ __ -=.:: . :--,( .'; ,0 ·.-,-,1:_ .. _ ... _~:..!... :-.1.. .'~~::~ ':'~_ :~::.L __ ... ..:.w ... 
-l. 500D+01 
- _ ..... ----_.¥, 
.- t • \~j(>()D+':~ 1 
-. 
" .~--- . ..-,-, .----... -.-.--~, 
... 
'" 
-.. 
-if 
.. -
... 
1+ 
;; 
.-
... 
.. 
.. 
-.-
;;-
;. 
+. 
-;. 
... 
." 
,;. 
.. -. ~) .. O(" ,jl}+('\,l 
.-
..... -..... ' .-.-;,....;-:o-r~- -,~ 
00 
r-.... 
C"l 
Stage One 
Input 
All dimensions are 
in nun and not to scale 
substrate at 1.30Hz 
1.19 
Zo=20 
Ag = 7.278 
Eeff= 9.497 
Zo=85 
Ag= 10.905 
Eeff= 5.907 
Zo=50 
Ag = 10.278 
Eeff=6.65 
Stage One 2.37 
Output matching 
1.19 
eTwo Stag 
Inpu t matching 
1 
5 
r 
292 
I 
"'" r-:
M 
I 
2.5 5.139 
Stage Two 
Output matching 
2.37 
1.19 
2.92 
5.32 
.--------r -------------
Zo = 34.3 
Ag = 7.124 
Eeff= 9.93 
1.19 
5.139 
Zo = 25.649 
Ag = 9.692 
Eeff= 7.47 
7.269 
1.19 
5.139 
2.37 
....-_--1.. ____________ _ 
2.72 
- - 5":'139- - - - - - - - - - - - . 
...--__ _._---1.. _______ . 
0.54 
2.5 
Zo = 67.56 
Ag = 10.59 
Eeff= 6.262 
2.5 
1 
2.79 
A= 
B= 
2.72 
I 
5.139 
Zo = 31.25 
Ag =9.852 
Eeff=7.237 
1.32 
Zo = 30.3 
Ag =9.827 
Eeff= 7.274 
Zo = 57.73 
Ag = 10.422 
Eeff= 6.467 
Else as above 
2.37 
Zo =30.3 
A= Ag =9.827 
Eeff=7.274 
Zo = 57.73 
B= Ag = 10.422 
Eeff= 6.467 
Else as above 
279 
Appendix 13 and 14 
Set-up routines 
There are eight sets of registers to be initialised at the start of the decode. 
i) Global Control @ 808040 
ii) FSXlDXlCLKX @ 808042 
iii) FSRlDRlCLKR @ 808043 
iv) Data Transmit @ 808048 
v) Data Receive @ 80804c 
vi) RxlTx Timer control @ 808044 
vii) RxlTx Timer control @ 808045 
viii) RxlTx Timer period @ 808046 
i)serial port global summary 
Output Bit No. Acronym Operation 
0 0 RRDY if = 1 new data is ready edge sets RINT 
0 1 XRDY if= 1 last bit shifted out sets Xint 
1 2 FSXOUT config FSX pin 
0 3 XSEMPTY Tx shift reg empty 
0 4 RSRFULL Rx overun if = 1 
0 5 HS Handshake enabled 
1 6 XCLKSRCE = 1 internal Tx clock 
0 7 RCLKSRCE = 1 internal Rx clock 
0 8 XVAREN Fixed rate = 0 Tx 
0 9 RVAREN Fixed rate = 0 Rx 
1 10 XFSM continuous = 0 
1 11 RFSM continuous = 0 
0 12 CLKXP check polarity, 0 = active high 
0 13 CLKRP check polarity, 0 = active high 
0 14 DXP check polarity, 0 = active high 
0 15 DRP check polarity, 0 = active high 
0 16 FSXP check polarity. 0 = active high 
0 17 FSRP check polarity, 0 = active high 
1 18 XLEN Transmit length =32 
1 19 XLEN Transmit length =32 
1 20 RLEN Receive length =32 
1 21 RLEN Receive length =32 
0 22 XTINT Tx timer interupt enabled = 1 
0 23 XINT Tx interupt enabled = 1 
0 24 RTINT Rx timer interupt enabled = 1 
0 25 RINT Rx interupt enabled = 1 
1 26 XRESET Tx reset=O 
1 27 RRESET Rx reset = 0 
0 28 RESERVED Reserved 
0 29 RESERVED Reserved 
0 30 RESERVED Reserved 
0 31 RESERVED Reserved 
The other register set ups can be obtained from the software routine in the set-up. 
280 
Appendix 15 
The output sequence to bypass the converter is as follows; 
1 00 
2 f2 
3 fl 
4 ill 
5 ill 
6 ill 
7 13 
8 20 
9 40 
a 11 
b 42 
c 11 
d 54 
e 12 
f 61 
10 e2 
11 10 
12 20 
13 22 
14 06 
15 13 
16 52 
17 04 
18 92 
19 28 
la 63 
Ib 24 
lc 28 
Id 18 
Ie 00 
Then repeat the sequence 
281 
Appendix 16 
Timing Transmit Data 
Clock 1 
Clock 2 
Data 1 
--.J 1 0 0 1 1 0 1 0 0 
Ql 
Q2 
Clock 3 I 
Sample l I 
I 
Q3 i i n 
I I , , 
Q4 I : W 
I , I , 
I I I I 
Sample I , I , 
Delay ~ : I : , 
I 
I 
, 
I 
I 
, 
Output 0 1 0 0 1 
Dibits 1 0 1 1 0 
To the modulator 
Q3 and Q4 provide the input data to the modulator, sampled on the positive going edge 
of delayed clock 3, delay = O.13ms 
Input data must be clocked in using clock 2, which is derived from the main synthesiser 
282 
Appendix 16 
ReceiveTiming 
Simplified to show general relationships 
Clock 1 
Clock 2 
Sampling/ 
load 
A-DConvert 
DSP clock 
10adD.S.P. 
Process and 
Output 
I 
, 
, 
, 
, 
, 
, 
, 
, 
III I :11 II 1II11 III III I II11 III I II I111 1.1 III 
, 
, 
, , 
, , 
, , 
, , 
, , 
, , 
, , 
, , 
, , 
, , 
, , 
, , 
i i 
. , 
, , 
, . 
, , 
, , 
" 
" 
" 
" 
" 
" o, 
\ 
, 
283 
