The application of digital techniques to an automatic radar track extraction system by Spearman, Richard R.
Durham E-Theses
The application of digital techniques to an automatic
radar track extraction system
Spearman, Richard R.
How to cite:
Spearman, Richard R. (1988) The application of digital techniques to an automatic radar track extraction
system, Durham theses, Durham University. Available at Durham E-Theses Online:
http://etheses.dur.ac.uk/6401/
Use policy
The full-text may be used and/or reproduced, and given to third parties in any format or medium, without prior permission or
charge, for personal research or study, educational, or not-for-proﬁt purposes provided that:
• a full bibliographic reference is made to the original source
• a link is made to the metadata record in Durham E-Theses
• the full-text is not changed in any way
The full-text must not be sold in any format or medium without the formal permission of the copyright holders.
Please consult the full Durham E-Theses policy for further details.
Academic Support Oﬃce, Durham University, University Oﬃce, Old Elvet, Durham DH1 3HP
e-mail: e-theses.admin@dur.ac.uk Tel: +44 0191 334 6107
http://etheses.dur.ac.uk
2
THE 
APPLICATION OF DIGITAL TECHNIQUES 
TO AN 
AUTOMATIC RAOAR TRACK EXTRACTION SYSTEM 
by 
Richard R, Spearman 
The copyright of this thesis rests with the author. 
No quotation from it should be published without 
his prior written consent and information derived 
from it should be acknowledged. 
A thesis submitted in accordance with the regulations for the degree of 
Doctor of Philosophy in the University of Durham, March 1988. 
2 1 DEC 1S90 
The Application of Digital Techniques 
to am Automatic Kadair Track Extraction System 
Richard R. Spearman 
ABSTRACT 
'Modern' radar systems have come in for much criticism in recent years, 
particularly in the aftermath of the Falklands campaign. There have also been notable 
failures in commercial designs, including the well-publicised 'Nimrod' project which 
was abandoned due to persistent inability to meet signal processing requirements. 
There is clearly a need for improvement in radar signal processing techniques as many 
designs rely on technology dating from the late 1970's, much of which is obsolete by 
today's standards. 
The Durham Radar Automatic Track Extraction System (RATES) is a practical 
implementation of current microprocessor technology, applied to plot extraction of 
surveillance radar data. In addition to suggestions for the design of such a system, 
results are quoted for the predicted performance when compared with a similar product 
using 1970's design methodology. Suggestions are given for the use of other VLSI 
techniques in plot extraction, including logic arrays and digital signal processors. In 
conclusion, there is an illustrated discussion concerning the use of systolic arrays in 
RATES and a prediction that this will represent the optimum architecture for future 
high-speed radar signal processors. 
THE 
APPLICATION OF DIGITAL TECHNIQUES 
TO AN 
AUTOMATIC RADAR TRACK EXTRACTION SYSTEM 
Richard R, Spearman 
The copyright of this thesis rests with the author. 
No quotation from it should be published without 
his prior written consent and information derived 
from it should be acknowledged. 
A thesis submitted in accordance with the regulations for the degree of 
Doctor of Philosophy in the University of Durham, March 1988. 
2 1 DEC 1990 
Thanks and acknowledgements,.. 
...To Mr A. Shepherd and Dr. J.H. Miles, of the Admiralty Research Establishment in 
Portsmouth, who suggested a study of enhancements to the RATES prototype, and subsequently 
arranged funding for this research. 
.. .To my supervisor, Professor C.T. Spracklen, of Aberdeen University for introducing me to the 
complexities of modern radar systems, and for the help he has given in all aspects of the work, 
especially following his move away from Durham. I wish him continued success as Professor of 
Electronics at Aberdeen. 
.. .To my wife, Debby, for putting up with my late nights in the final stages of work on this thesis, 
and providing general encouragement throughout. 
.. .To the staff of Digitus Ltd., and in particular Peter Woolfenden, for the invaluable help given 
through the loan of an Apple Macintosh and printing facilities. Without these, this thesis would 
never have been completed. 
(CONTENT 
1 „ Principles and Evolution of Radar 
1.0 Introduction 
1.1 Early History 
1.2 Basic Principles 
1.3 Radar Developments in the 1930's 
1.4 Radar in the 1940's 
1.5 Pulsed Radar Principles 
1.6 Post-War Developments 
1.7 Future Development Areas 
2. R a d a r Signal Processing 
2.0 Introduction 
2.1 The Requirement for Signal Processing 
2.2 Detection of Targets in Clutter 
2.3 Filtering Techniques in Homogenous Clutter 
2.4 The Second Threshold Detector 
2.5 Data Reduction Through Plot Forming 
2.6 Summary 
3. The R A T E S Radar System 
3.0 Introduction 
3.1 The RATES Specification 
3.2 The Input Interface 
3.3 The Constant False Alarm Processor 
3.4 The Within Beam Integrator 
3.5 The Plot Forming Processor 
3.6 System Control and Timing Functions 
3.7 The Interface to the Computer 
3.8 Electronic Counter Measures Detector 
3.9 The Display Driver 
3.10 The Control Unit 
3.11 Filtering and Tracking Computers 
4. Introduction to V L S I Technology inRATES 
4.0 Introduction 
4.1 Deficiencies in the RATES Prototype 
4.2 Introduction to the Durham RATES 
4.3 Digital Design Approach 
4.4 A Solution in Custom VLSI? 
4.5 Programmable Logic in RATES 
4.6 Microprocessors in Radar Signal Processing 
4.7 A Summary of some other VLSI Devices 
5. Applications of Digital Signal Processors 
5.0 Introduction 
5.1 Digital Signal Processors 
5.2 DSP Design of a CFAR Processor 
5.3 The Within-Beam Integrator 
5.4 Plot Forming Processing 
5.4 Summary of DSP Applications 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. 
Contents 
(8. A Miarapr©ces§oir,"lbfflsed Tracking System 
6.0 Introduction 
6.1 The RATES Prototype Tracking System 
6.2 Development System Computer Hardware 
6.3 The Computer Interface 
6.4 A Custom DMA Interface 
6.5 Interface Design Using Proprietary Devices 
6.6 RATES Software Design 
6.7 Summary 
1. Testing & Performance of the Development System 
7.0 Introduction 
7.1 Testing the Plot Extractor 
7.2 Testing Using Recorded Radar Data 
7.3 The RATES Test Target Generator 
7.4 Test Scenarios and Results 
7.5 Interface Performance 
8. Systolic Architectures for Kadar Signal Processors 
8.0 Introduction 
8.1 The Need for a Different Architecture 
8.2 Principles of Systolic Arrays 
8.3 Systolic Arrays in RATES 
8.4 Simulation of a Systolic Plot Extractor 
8.5 Summary and Suggestions for a Practical Design 
9. Conclusions and Recommendations off Further Work 
9.0 Research Objectives 
9.1 Summary and Conclusions 
9.2 Recommendations for Further Work 
Appendices: 
A References and Bibliography 
B Backplane Connections for the Motorola 68-KDM Board. 
C RATES Development Software, Source Listing. 
D Test Target Generator, Source Listing 
E Source Listing for Systolic CFAR Simulation 
F "The Application of Systolic Arrays to Radar Signal Processing", 
(Spearman, Spracklen & Miles, Proc. I E E E Radar '86). 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. 
Principles and Evolution of Hadair 
1.0 Introduction 
In evaluating the current techniques and problems in modern radar 
systems it is considered necessary to provide an overview of previous work and 
developments in this field, presenting the concepts upon which radar detection (or 
radio-location, as it was formerly known) is based. Radar techniques from the 1930's 
and 1940's are covered in detail and an overview of more recent developments is also 
given. In conclusion some aspects of modern radar research are outlined, with 
particular reference to the type of systems involved in this thesis. 
1.1 Early History 
Radar is a system by which we are able to detect the position of an object, in space, 
without any active co-operation on the part of the object, save for the fact that it must be capable of 
reflecting radio waves. 
As early as 1888, Heinrich Hertz [1] had shown the basic principles of radio-location, 
but it was not until 1904, following successful trials on ship targets, that a British patent was 
issued to Christian Hulsmeyer on this subject [2]. In spite of these demonstrations no further 
work was carried out, although Marconi, speaking to the American Institute of Radio 
Engineers in 1922 [3], stated: 
"J should like to refer to another possible application of these (short) waves, which, if 
successful would be of great value to navigators. As was first shown by Hertz, electric waves can 
be completely reflected by conducting bodies. In some of my tests, I have noticed the effects of 
reflection and deflection of these waves by metallic objects miles away. It seems to me that it 
should be possible to design apparatus by means of which a ship could radiate or project a 
divergent beam of these rays in any desired direction, which, if coming across a metallic object 
such as another steamer or ship, would be reflected back to a receiver screened form the local 
transmitter on the sending ship and thereby immediately reveal the presence and bearing of ships, 
even though these ships be unprovided with any kind of radio." 
This suggested that the bearing of an object could be determined by reflection of 
radio-waves from a floodlighting source. To calculate its exact position, it implies that it would 
be necessary to have two receiving stations, a set distance apart, each providing bearing 
information. The transmitted beam would, of course, have to be very narrow for any degree of 
accuracy, but the principle is sound. Ideally, a system would be required which would be 
capable of determining the exact position of an object using a single combined transmission & 
reception point. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 1 
Principles and Evolution of Radair 
L2 Basic Principles 
In practice, the relative position of any object in space can be represented by 3 
coordinates: range , bearing (the term azimuth is also used), and elevation , (Figure 1.1). 
If a signal is transmitted towards an object, its bearing and/or elevation may be 
determined from the direction and angle of maximum reflection, however calculation of its 
distance requires some measurement of the time taken for the echo to return. If a continuous 
waveform were transmitted, then it would not be possible to detect an echo since the wave 
carries no unique points of identification. However, if the wave were modulated by some 
means, it would be possible to identify some significant point on the signal. Two techniques of 
modulation have been developed: frequency and pulse (amplitude) modulation and are now 
outlined in principle. 
North 
r 
0 
Fig. 1.1 : Determination of Position of Object (T) Using 3 Co-ordinates 
L2.1 Frequency Modulation 
With this technique, the carrier frequency of the transmitter is swept through a linear 
sawtooth, (Figure 1.2 : Solid line) and a reflected signal is received, delayed by a period 
proportional to the distance of the target. Since the waveforms are otherwise identical, the 
result of combining them is a beat corresponding the frequency difference at a given point in 
time and it may be noted that: 
delay time = hsaL&mmns^. 
rate of change of carrier frequency 
This method was initially used, in 1924, to measure the height of the ionosphere but was 
later discarded in favour of amplitude modulation (developed in the U.S. by Breit & Tuve) 
which simplified multiple target detections. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 2 
Principles and Evolution of Radar 
U2.2 Amplitude Modulation 
Amplitude modulation uses a combination of the carrier frequency and short r.f. 
pulses, transmitted at regular intervals. The pulse travels out to the target and is reflected 
back, enabling a direct measurement of distance from the time taken for the echo to be 
received. With careful synchronisation of the initial pulse and a linear timebase, a cathode 
ray tube ( C R T . ) may be used to give a steady picture of the returned echoes [cf: Section 1.4.1]. 
The first record of any practical observation of these techniques was in Britain in Dec. 
1931, when it was noted that an aircraft flying near a 5m (ultra-short-wave) receiving station 
induced a beat frequency which was related to the speed of the aircraft. Similar observations 
were noted in the U.S. the following year and in 1934 Young began work on the detection of 
aircraft by pulsed radio. He demonstrated a working version in December of that year 
showing that echoes could be detected, at short range, from an aircraft flying across the 
transmitter beam. More importantly, he proved that the pulse transmitter and receiver worked 
independantly with neither interference nor receiver blocking from the transmitted pulses. 
This work gave the Americans a lead in transmitter design and work was then started 
on shorter wavelengths, in the order of 150cm. In mid 1936, using a pair of directed antennae, 
high signal echoes were received from the city of Washington D.C. at 8 miles, but no aircraft 
could be detected beyond 4 miles. It was later observed that use of the same antenna for 
transmission and reception, by way of a duplexer, led to a fourfold increase in the sensitivity 
of the radar. In Spring 1937, this was confirmed when such an aerial, mounted on a 5" gun 
turret on a ship, was used to detect aircraft movements to a distance of 16 miles. With the 
introduction of more powerful transmitting tubes in 1938, the duplexer was abandoned in 
favour of spark gap switching and ship-based radar, capable of detecting ships, aircraft, buoys, 
birds and 14" shells became standard equipment in the American Navy. 
Early work in the States introduced the GAIN x RESPONSE-TIME ratio as a measure 
of the performance of a radar, and new valves were developed to cope with the higher 
frequencies and gains required. In receivers, amplitude limiting was forced on the received 
pulses in order to improve the response and recovery times, although the high voltage gains 
employed, (in the order of 10^) meant that the screen of the c.r.t. was filled with input noise. 
Frequency 
A 
Beat Frequency echo signal 
O Time 
Fig. 1.2 ; Basic Principle of FM. Radar 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 3 
Principles and Evolution of Radar 
1J$ Kadar Development in the 1930'§ 
With the approach of war in the mid 30's, these secret developments were hidden from 
other countries, who independently continued with their own research. Notably in Britain the 
development of radar followed from heightening military preparations in Germany. Sir 
Robert Watson-Watt [5] was initially asked to study the uses of radio waves to destroy enemy 
aircraft, but when calculations proved this to be impossible, suggested their use for detection of 
the enemy rather than its destruction. In Feb. 1935, he submitted an historic memorandum 
entitled "Detection and location of aircraft by radio methods" in which he discounted the 
possibilities of using noise emitted from targets but showed that reflected radiation would be of 
sufficient strength to be detected over ranges as great as 100 miles. 
1.3.1 Watson-Watt's Experiments 
Watson-Watt's proposals suggested the use of transmitted pulses and a method of 
timing the echoes on a cathode ray tube screen to indicate the distance of the target. Although 
accurate positional information could be calculated using distance measurements from three 
receiving stations, he promoted the use of a rotating beam from a single transmission and 
reception site, stressing the importance of continuing work into shorter wavelengths. He 
concluded that aircraft could also be fitted with a transponder, which would transmit a coded 
message on the same or slightly differing frequency as an interrogating radar beam, 
enabling identification of friendly and hostile targets (I.F.F.). 
O-
50' spacing H.F. 
Amplifier Mixer 
Phase H.F. 
Changer r Amplifier 
Common 
Oscillator 
JL 
Mixer It 
I.F. H Output I.F. 
Amplifier r Stage 
I.F. 
Amplifier 
Output I.F. 
Stage 
C R T . 
Fig. 1.3 : Receiver used in Watson-Watt's Demonstration 
Watson-Watt demonstrated these proposals on 26* n Feb. 1935, using a specially 
transmitted continuous wave (C.W.) signal from a B.B.C. short-wave transmitter, radiating 
lOkW on 49.8 m in a southerly direction. An aircraft flew up and down in the beam at a speed 
of 1 OOmph and the receiver combined the heavily attenuated ground wave with the reflected 
signal, successfully indicating a beat frequency on the cathode ray tube. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 4 
Principles and Evolution of Radar 
The demonstration made use of the receiving circuit shown in Figure 1.8, producing a 
small vertical line on the c.r.t. (introduced through television work) which varied in length 
according to the distance of the target. 
This initial experiment, although somewhat crude, provided the basis for future radar 
work in Britain. In the early days, receiving circuits capable of sensitive detection over wide 
bandwidths, such as the superheterodyne, were well developed from previous work in 
television so whilst transmitter and antenna design progressed apace during the early 30's, 
the techniques used to detect the returned echo did not change so rapidly. Special valves were 
developed, capable of several hundred kilowatts output for short periods of time and resulted in 
the introduction of the "Chain Home" radar network in 1937. These stations were put on 24 
hour operation in early 1938 and constituted the world's first fully operational detection 
system, playing a major part in the success of the Battle of Britain. 
L3.2 The Chain Home Radar Network 
For the Chain Home, the technique of reception remained unchanged but the display 
was modified such that the echo appeared as a glitch at some point along a timebase-driven 
x-axis. A linear timebase enabled the position of the echo to be directly proportional to the 
distance of the target from the transmitter. Precision ranging could be accomplished using a 
display which presented the ground wave and echoes on the upper trace whilst showing a series 
of calibration marks on the lower, (Figure 1.4). A portion of the x-axis, in the region of the 
ranging pip, could be selected and expanded by turning a hand wheel and a trained operator 
had only to align the left-hand edges of the two pulses in order to obtain an accurate range 
indication. Later refinements removed the calibration pips and replaced them with a 
moveable ranging spot. 
The Chain Home made use of a floodlighting bistatic radar system, i.e. separate 
transmitting and receiving sites with aerials mounted on 360' steel transmitting towers and 
240' wooden towers for receiving. This was capable of providing accurate range information 
but was not so good at determining elevation and bearing. If tracks from several receiving 
stations were associated, target bearings could be determined, however the problems 
associated with this were obvious as it was possible, for example, for site A to measure range on 
aircraft X : site B to measure range on aircraft Y and in associating it with the site A detection, 
give a range on an imaginary aircraft Z. 
In Autumn 1938, however, monostatic radar (using a single transmitting and 
receiving site) was introduced, capable of measuring range to 1km and bearing to 1.5°. This 
use of the same antenna for transmission and reception followed development of the duplexer, 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 5 
Principles and Evolution off Radar 
which was essentially a high speed switch based on spark gap and quarter-wave tube 
principles: When the transmitter was active the spark gap arced and presented a low 
impedance, i.e. a closed switch, but the end of the transmission pulse would break the arc and 
cause the "switch" to open. The quarter wave tubes enabled selective switching at different 
points in the circuitry. 
calibration pips 
Fig. 1.4 ; A-Scope Presentation of Hadar Echoes 
A network of coastal stations was established to supplement the Chain Home (The 
Chain Home Low), making use to the new technique to provide more accurate range and 
bearing data. This invention was introduced to the French in 1939, as their developments in 
radar were lagging behind at that time. The Germans, however, led the field at this point, 
having successfully deployed a large variety of ship and aircraft based radars, operating at 
V.H.F. and providing coverage from 10 nmi (for fire control) to 150 nmi (for early warning) 
and had it not been for further research in Britain, the outcome of the war would arguably have 
been different. 
U33 The Need for High Frequency Kadar 
Sir Edward Appleton had already shown the use of pulse techniques in determining the 
height of the ionosphere as early as 1925 [4], but this made use of pulses of 1ms duration which 
were highly unsuitable for detection of aircraft as a pulse could only travel 2 miles in 10 us. To 
enable accurate detection, pulse lengths of less than 10 us, combined with high power 
transmitters and sensitive receivers were essential. In addition, a solution to the problems of 
ground wave reflection at low altitudes had to be reached. Longer wavelengths incurred a 
phase change of approx. 180° upon ground reflection, so at low altitudes the ground and target 
reflected signals were almost identical, causing attenuation of the resultant signal and 
making detection of low-flying aircraft of ships difficult. With shorter wavelengths this 
problem diminished and had the added advantage of making portable radar a practical 
possibility, since an antenna with small dimensions, proportional to the wavelength became a 
reasonable proposition. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 6 
Principles and Evolution of Radar 
L4 Radar ha the 1840*s 
During the 1930's all practical radar development had been with high frequency (in the 
case of the Chain Home) or V.H.F. frequencies but these, as mentioned, incurred penalties of 
wide beamwidth, narrow bandwidth and high noise levels. Many countries had attempted to 
use microwaves as a solution but all had given up since valve techniques did not enable the 
combination of high power and frequency, however in 1939 in Britain, a new valve was 
developed by Randal and Boot [11] based on a combination of two successful high frequency 
valves - the klystron and the magnetron. The resulting "cavity magnetron" revolutionised 
centimetre wavelength techniques as it was capable of producing several hundred kilowatts 
pulse power. Waveguides were developed to carry the generated signal to the combined 
transmitting / receiving antenna, which could now have dimensions as small as 1/2 m 
diameter. 
The invention of the cavity magnetron was disclosed to the Americans in the historic 
"Tizzard Mission" of 1940, solving their immediate problems and opening up the development 
of large ground-based surveillance radars and small airborne radars, working on the 3cm 
wavelength. The smaller aerials had the advantage that they could be rotated in both azimuth 
and elevation giving a complete picture of the search area over a range of heights. 
For airborne radars, the possibilities of detecting small objects near to the ground were 
opened up by centimetre wavelengths, since lower frequency systems suffered greatly from 
wide beamwidths and reflected ground waves, which made aircraft - aircraft detection 
impossible if the target was further away than the height of the source, due to swamping by the 
ground echoes. With shorter wavelengths, smaller antennas could be used and if 
gyroscopically stabilised and rotated would provide a clear picture of the area surrounding the 
aircraft, permitting blind bombing raids during the war and introducing techniques such as 
radar navigation, making use of the differing strengths of ground reflection from land, water 
and populated areas. 
1.4.1 Advances in Display Techniques 
These new applications were of particular use in the light of the newly introduced 
display methods. The A-scope, as used in the Chain Home, provided accurate range 
determination and could be of limited use in direction finding, but it was not until 1939 that the 
Plan Position Indicator (P.P.I.) was introduced, although this revolutionary device had been 
proposed by E.G. Bowen in 1935. The P.P.I. [6] worked on the principle of rotating a linear 
range scale about its zero at the centre of the c.r.t., synchronised with the rotation of the 
directive pattern of the antenna and achieved in practice by mechanically turning the 
magnetic deflection coils of the tube using a synchronised motor. The brightness of the trace 
The Application off Digital Techniques to an 
Automatic Radar Track Extraction System. Pag© 1. 1 
Principles and Evolution of Eadar 
was modulated in proportion to the strength of the received signal, and a map could usually be 
superimposed above the display giving accurate positional information. The P.P.I. relied on a 
highly directive receiving antenna, hence its increasing importance as transmission 
wavelengths fell, with the introduction of the centimetre band. In addition, displays such as the 
Skiatron were made available, with very long persistence enabling the extrapolation of 
aircraft tracks on the surface of the screen. They could usually be erased by exposure to either 
warm air or bright light. 
L43 Radar Deployment in the Allied Forces 
Many radars were developed during the 1940's, although the German effort was 
noticibly behind that of the Allies with no equipment working in the centimetric waveband. 
The Germans cancelled further research in anticipation of a German victory, but when it was 
realised that this was not to be, their radar work was too far behind to be of use during the war. 
The Americans developed and installed a large number of radars in their aircraft, mostly 
operating on UHF and microwave frequencies, and covering a great range of applications. 
Their largest procurement consisted of 26,000 pieces capable of use in bombing raids as well as 
airborne intercept and detection of sea targets. They operated at 515MHz and transmitted 2us 
pulses at a repitition frequency of 400Hz. Other more specialised radars were developed for 
greater accuracy over shorter ranges or for long-range early warning. 
The Navy and Army also made use of radar during the war, with the Navy using 
P.P.I, displays to locate targets, then employing precision ranging to establish their distance. 
The Army, meanwhile, used it for anti-aircraft fire control, requiring a degree of prediction 
in order to determine the likely position of a target after a certain delay. Trained operators 
were capable of following aircraft, but obtaining accurate predictions was more difficult. A 
great deal of research was carried out into automatic lock-and-follow systems, which were 
capable of rotating an antenna and tracking a target once it had been identified [14]. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 8 
Principles and Evolution of Radar 
The main components of a basic pulsed radar system are illustrated in Figure 1.5, 
demonstrating the uses of the P.P.I display tube. Each pulse is actually a burst of 
high-frequency electromagnetic energy, and as such travels at the speed of light, (approx. 1 
mile / 10us). If the time is measured from the start of the transmitted pulse to the reception of an 
echo, it is therefore possible to calculate the distance of the target from the transmitter. An 
oscillator produces a synchronising pulse which triggers the transmitter causing it to emit a 
high frequency signal through the waveguides to the antenna where it is radiated into space. At 
the same time, the display starts scanning outwards from the centre of the P.P.I, tube. The echo 
is picked up by the same antenna and guided down to the receiver where it is demodulated and 
amplified before being used to modulate the intensity of the display beam. 
The rotation of the antenna and display trace are synchronised and in land-based 
radars it is usual to have a north bearing at the head of the P.P.I, display, enabling a direct 
range and bearing readout of surrounding targets. 
Modulator 
Trigger 
Pulse 
Generator 
-@> 
Drive Motor 
Rotary Joint 
Transmitter 
Parabolic Reflector 
Antenna Feed 
Synchro 
p ^ l Drive 
Transmit / Receive 
Switch 
Receiver 
Fig. 1.5 : Pulsed Badar Schematic 
L5.1 Factors Affecting Pulsed Radar Operation 
The operation of the general pulse radar can be influenced by a number of factors, 
which in turn have an effect on the signal processing needs of such a system:-
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 9 
Principles and Evolution of Radar 
(i) The maximum range of the radar is partially a function of the pulse repetition 
frequency, since a single pulse will travel 1 mile in approx. 5us. To avoid ambiguity between 
received echoes, the next pulse could not be transmitted until after a time corresponding to the 
maximum radar range, thus a range of 90 miles would permit a repetition frequency of IKHz. 
In practice this figure would be lower to allow for switching between transmit /receive modes. 
(ii) The maximum range is also a function of the wavelength used in transmission, since 
atmospheric attenuation becomes more significant at higher frequencies where the antenna 
gives the most directive characteristics. A careful balance needs to be sought between 
beamwidth and range considerations. 
(iii) The transmitted pulse width effects the range resolution of the radar since successful 
distinction of two targets on equal bearing requires a distance equivalent to 0.5 pulse widths 
separation. A system with lOus pulses could only resolve targets greater than 1 mile apart. At 
very short ranges the signal consists mainly of ground returns, requiring some form of 
attenuation to prevent them from entering the receiver or display stages. 
<... Point Target 
J ) Large Target ...> 5 
Fig. 1.6 : Bearing Ambiguity due to a Large Target 
(iv) The beamwidth affects the azimuth resolution of the radar, and considering point and 
large targets this is illustrated in Figure 1.6. For the point target, only a few pulses are 
reflected back while it is illuminated by the beam, (note that several pulses are transmitted in 
one beamwidth), so the position of the target can be accurately identified. The larger target, 
however, also returns echoes when only partially illuminated by the beam so appearing to 
extend over a larger bearing. To effectively distinguish between two adjacent targets it is 
therefore necessary to have a separation of approx. one beamwidth. 
(v) The rotation or scanning rate of a radar affects the final data rate of the system. It must 
be adapted to suit the detection requirements and is particularly important when target 
tracking is required. Rapid scanning antennae suffer from performance degradation, but 
greatly ease the process of tracking fast-moving targets whereas a slow-scanning aerial 
would work best with low velocity or stationary targets. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 10 
Principles and Evolution of Radar 
1.6 Post-War Developments 
Owing to the pressures of war, many problems encountered in radar development had 
to be left until after the war years. Research into microwave radar continued after the war but 
at a much reduced pace, primary needs being for radars with greater range and better search 
capabilities in the vertical plane. In addition some means of counteracting enemy radar had 
to be found. Many early pioneers in the field of radar systems had moved into other areas and 
a new generation of engineers took over. The MIT Radiation Laboratories in the U.S., which 
had been responsible for research during the war, published many of its discoveries [20] and 
led to the introduction of a number of theoretical concepts surrounding radar development. 
With the new threat from long-range ballistic missiles and bombers, older techniques 
in VHF and U H F radar were revived, since lower frequencies gave more reliable detection in 
the presence of rain and other atmospheric clutter especially over long ranges, and in addition 
gave better moving target indication (M.T.I.). MTI was initially studied during the war [15] 
but remained a classified theory until 1954 when signal processing techniques had improved 
sufficiently to permit its development. It made use of such properties as the Doppler frequency 
shift given to an echoed pulse by a moving object and is found in almost all modern 
surveillance radars where it enables targets to be distinguished from surrounding clutter. 
Several new transmission methods were introduced, one of the most significant being 
the phased array radar which was no longer mechanically rotated but could be steered 
electronically. The transmitted beam was capable of being scanned at will across a large 
area, either continuously or irregularly, and could be locked onto a particular target for 
tracking purposes. This was accomplished by transmitting many beams simultaneously, with 
calculated phase differences between them, which then interfered resulting in an accurately 
directed beam pattern. By varying the phase differences, the interference pattern and hence the 
beam could be steered as required. The ability of this type of radar to detect and track space 
vehicles was demonstrated in the early 1960's when it was used to follow satellites and has 
been developed considerably since then. Its success relies on another new technology from the 
60's, namely that of digital signal processing, which caused a major revolution in system 
development work which still continues. Almost all modern radar systems rely on digital 
signal processing at some stage, whether of phased array or other design. It enables a 
significant reduction in the quantity of unwanted data being presented to the operator, an 
essential factor in systems with high sensitivity and long range coverage. 
The Application off Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 11 
Principles andl Evaluation of Itadair 
1.6.1 Digital Kadar Bmcessiag 
Digital technology permitted the introduction of many new techniques which had been 
described in the theoretical work of the 1950's but had remained untested because of practical 
limitations with analogue signal processing. Emerson's M.T.I, theories [21] were a good 
example of this, since they suggested filtering the received signal using a quartz delay line or 
using a switched system which sampled the echo at successive range gates. These analogue 
designs required extra processing and were difficult to put into practice because of the high 
tolerances needed in the delay lines, but could easily be implemented using digital processing 
methods. 
Development on M.T.I, continues, benefitting from another aspect of the digital 
processing revolution, namely the introduction of the computer into radar systems design. 
1.6.2 Computers in Radar Design 
The conventional radar system is considered to operate with fixed parameters, such as 
transmitting waveform, modulation and direction or receiver sensitivity and clutter control. 
Clearly, a better system could be designed if the parameters were dynamic, e.g. permitting 
transmission at higher powers in the direction of targets or reduced power in clutter areas. 
This could also be adapted to improve reception, such that higher clutter levels could be 
accomodated in certain directions without disrupting detection performance in other 
directions. 
The phased array radar is a good example of the early use of computing techniques, 
with the computer being used to control the phase shift on each of the radiators. This has 
enabled the construction of very large phased arrays such as the Cobra Dane [7], which was 
installed in the Aleutians in the late 70's for observing and tracking inter-continental 
ballistic missiles as they re-entered the atmosphere. Many similar systems have been 
developed such as the Cobra Judy, a shipborne version of the Dane with a diameter of 7m and 
the U H F Pave Paws featuring two antenna faces each with a diameter of 30m and 2560 active 
radiators per face. These two systems are designed for ballistic missile detection, with the 
latter only becoming operational in the past year. Their operation would be impossible without 
the use of modern computer technology. 
Computers may also be used to advantage in mechanically scanned radars, where the 
rotation rate and direction of the transmission is often fixed, but other parameters are subject to 
change. Transmission frequency and waveform can be modified to increase the probability of 
detecting particular objects in differing clutter environments and the receiver and 
post-detection attributes may too be altered to improve target identification. M.T.I can be 
implemented on computers by application of Fourier transforms to the received pulses, or by 
The Application of Digital Techniques to am 
Automatic Eadar Track Extraction System. Page 1. 12 
Principles and Evolution of Radar 
analysis of filtered target coordinates, in a manner analagous to early British M.T.I, 
schemes. In considering the implementation of computer-assisted post-detection systems, 
however, it is important to study the exact nature of the problem. A careful balance usually has 
to be sought between the hardware and software and extra front-end processing is often needed 
in order to prevent overloading the data rate of the processor. This limitation is apparent in 
both large phased array systems and, more obviously, smaller portable surveillance radars. 
The introduction of computers, therefore, does not provide a complete solution to modern 
processing problems and hardwired logic and interfacing is likely to be an essential extra for 
some time to come. 
L6.3 Hecent Developments in Surveillance Badair 
In recent times the Falklands Conflict has illustrated the need for small surveillance 
radar systems, which are highly portable and capable of providing early warning of 
approaching aircraft and long range missiles especially at low altitudes. The problems 
associated with this type of coverage can be solved with the use of airborne systems, however at 
the time of the Falklands conflict the British AEW fleet had been disbanded. After the attack 
on HMS Sheffield it was decided to reintroduce this capability and rapid development work on 
the Thorn-EMI 'Seasearcher' resulted in a radar installed on a Westland Sea King helicopter 
which was able to detect long distance, low level attacks from Argentinian aircraft and give 
warning in time to scramble intercept Harriers. The radar was installed and sent down to the 
South Atlantic only 3 months after initial procurement decisions, due in part to the simplicity 
of the final design which comprised of a mechanically rotated antenna, feeding long range 
data to a monitoring and tracking processor. 
Surveillance radar developments in recent years have been influenced considerably 
by their final usage. The Seasearcher in use in the Falklands was adapted from a similar 
unit designed for the Nimrod early warning aircraft, with modifications to the signal 
processing system which removed its capability to detect and track shipping targets. 
Ground based radars tend to be the largest in current use, frequenly being phased 
array installations with coverage in certain sectors only. They often provide an ability to 
transmit on several different frequencies with varying methods of polarisation, giving 
optimum detection and immunity from interference. 
Maritime surveillance radars tend to be of the mechanically scanned variety, possibly 
with additional radiators to provide elevation coverage. A recent production model offers a 
maximum range of 250 miles using 0.7us pulses transmitted on 1 - 2GHz with a beamwidth of 
2.3°. Signal processing techniques for maritime radars are all digital and tend to have the 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 13 
Principles and Evolution of Radar 
same general characteristics, regardless of manufacturer or radar type. Suppression of clutter 
from waves is a major problem on ship based systems and almost all modern signal 
processors include some form of adaptive clutter cancelling by changing the detection 
threshold level every scan. Recent innovations include the provision of automatic tracking on 
maritime radars, this being previously restricted to ground based systems. A typical system 
might be capable of detecting and tracking up to 20 targets simultaneously and work is in 
progress in an attempt to increase this figure using faster processing methods. Maritime 
equipment is frequently restricted in both size and power requirements so compactness and 
efficiency is an important feature of any new radar system. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 14 
Principles and Evolution of Radar 
in Futuir® Development Areas 
Short-term prediction of radar developments is relatively straightforward as much of 
the current work is scheduled for operation in the next few years. Several significant research 
fields can be identified and it is expected that these will contribute to future system designs. 
° Mechanically Steered These are still very much in use, in spite of predictions in the 60's that 
Antennae phased array radars would quickly take over. This is most likely 
to be due to the prohibitively high cost of phased arrays, even after 
many years of development. 
° Clutter Reduction This is still of paramount importance as targets are rarely visible 
without interference from background clutter. Research into both 
pre and post detection methods continues, the latter being of 
particular interest as automatic tracking computers are 
introduced as they can easily be overloaded by an excess of falsely 
identified targets. Post-detection clutter control always reduces 
the sensitivity of the radar so care is needed to avoid losing 
wanted targets. 
° Signal Processing Digital technology has only been widely available for the last 15 years 
and semiconductor integration methods are constantly advancing. 
Systems designed in the late 70's with small and medium scale 
integrated components are now outdated and work is in progress to 
redesign these using current VLSI devices and new generations of 
programmable components in an attempt to improve efficiency, 
performance and reliability. 
Operator Intervention This is likely to be reduced in future systems, in terms of both 
maintenance and control functions. Automatic detection and tracking 
of targets is available on many of the larger installations and is being 
developed to a point where no operator will be required to initiate target 
tracking, even on small portable systems. 
0 Improved Target Present systems generally provide target detection details as output, 
Data although other information can frequently be calculated, such as 
physical dimensions of the target. New radars are likely to provide 
additional data to enable precise identification, possibly construction 
or surface information. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 15 
Radar Signal Processing 
2.0 Introduction. 
Surveillance radar systems have traditionally relied upon human 
interpretation of a signal which is displayed on a cathode-ray tube, however there are 
many problems associated with this approach and operators have required 
considerable training to enable them to recognise all forms of target against a variety 
of backgrounds. Additionally the speed of modern aircraft (in particular) calls for 
rapid reactions if a defensive roll is to be adopted. To overcome these problems and to 
assist the operator, systems have evolved which extract information from the 
incoming signal and re-display it in a more readily identifiable format. 
A typical modern radar system may therefore be regarded as a form of 
communications device, receiving a large amount of information, only part of which 
is required by the user. The signal processing involved in such a system is complex, 
since the desired portions of the incoming signal exist alongside reflections from 
unwanted targets and noise from transmitter and receiver circuits, and the design of 
a suitable signal processor is therefore of great importance in the overall radar 
system. 
2.1 The Requirement for Signal Processing 
The early radar systems, in use during the Second World War, relied entirely on 
manual operation, combining tracking information from the operators with reports from 
visual observers. All confirmed movements were then displayed on large plotting tables. As 
aircraft performance improved it became necessary to reduce the time taken to correlate 
radar track information and display the resulting data. In the 1950s', analogue computers 
enabled such features as electronic markers to be introduced in plot display, giving a means 
of calculating target position directly from the P.P.I display. This could be accurate to as 
much as ±0.5%, but the equipment had to be regularly adjusted to maintain this figure. With 
the introduction of digital techniques in the 1960s', it was therefore a natural decision to 
transfer the analogue signal processing developments to the new technology, thus removing 
the problems of operational drift and enhancing the accuracy of the system. 
Digital technology brings with it the power of rapid signal processing, and attempts 
have been made to completely automate radar track extraction, however the process is never 
100% reliable and so the operator remains, not in a detecting and tracking capacity, but as a 
monitor of the automatic process, adjusting system parameters to optimise performance and 
overriding false tracking decisions. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 1 
Radar Signal Processing 
2.1.1 Signal Processing: Terms of Reference 
In this thesis it is intended to consider the general purpose surveillance radar, such as 
shown earlier in Figure 1.5, as the source of the returned signals although many of the 
techniques to be described can be applied to other radars. It should be noted, however, that the 
distinguishing feature of this type of radar is the fact that it rotates continuously and therefore 
all areas of coverage are illuminated for an equal period of time. As a consequence, the time 
available to detect and process targets in one area is equal to that available in any other area. 
Continuous high speed processing is therefore a prime requirement for this type of system. 
Taking this type of radar system, the receiver circuits may be subdivided into a 
number of sections as in Figure 2.1. In this example, the received echo is mixed, amplified 
and then demodulated in an envelope detector to produce a signal which, in early radar 
systems, would be used to directly modulate the Z-axis of a P.P.I, display. The brightness of 
the trace on the cathode-ray tube would give an indication of the target's size or reflecting 
area, but this method of display required trained operators, who were able to resolve targets 
from unwanted reflections (clutter) which could often be visible at comparable brightness. 
re 
square-law signal mixer 
detector amplifier processing 
oca 
PPI oscillator 
\ 
Fig. 2.1 : Typical Receiver Configuration 
The exact definition of "unwanted reflections" is clearly dependent on the use to which 
the radar is put, but for a ship-based radar, these could be defined as land-masses, buoys, rain, 
birds (or angels) or intermittent echoing objects such as waves. 
The signal processing section, present in modern radar systems, attempts to assist the 
operator in his identification of targets, whether moving or fixed, by careful filtering of the 
unwanted clutter from the incoming echo signal, without reducing the visibility of genuine 
targets. The reduction in the number of false tracks is particularly important in a military 
environment, where time and resources can not be wasted on reacting to non-existent targets. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 2 
Radar Signal Processing 
2X2 Characteristics of & Post-Detection Signal 
In describing the operation of typical signal processing techniques, it is important to 
understand the characteristics of the echo signal received by the aerial, and it is proposed to 
discuss these in conjunction with other synchronisation data which is passed on to the 
post-detector processing. 
It should already be appreciated that the basic surveillance radar functions by 
transmitting a regular train of pulses which are modulated onto a high frequency carrier 
signal. These are radiated from their source in the form of a narrow beam, which is swept 
through 360° by way of the continuous rotation of the antenna. A pulse travels out along the 
beam at a known velocity and (ideally) is reflected back only when it encounters some object 
in its path. 
The time interval between transmitted pulses is known as the pulse repetition interval 
(p.r.i.) and its inverse (1/p.r.i.) is the pulse repetition frequency (p.r.f.). Values for the p.r.f. 
are linked to the required range and may be typically 768Hz (30-90 miles) or 256Hz (250 
miles). If the frequency is too high for the desired range, then ambiguities result from 
long-range echoes due to one sweep being mistaken for short-range ones due to the successive 
sweep. The transmitter generates a synchronisation signal as each pulse is transmitted, to 
enable accurate measurement of the echo time. 
In assessing the p.r.f., an additional parameter should be considered - the rotation rate 
of the antenna. This is directly linked to the desired range and should enable estimation of the 
number of pulses which are likely to be reflected from a target at a given range. Typical 
rotation rates are 24 r.p.m. (30 mile range), 15 r.p.m. (90 mile) and 7.5 r.p.m. (150+ miles). 
The length of the transmitted pulse is designed around the targets to be detected, but an 
important feature is that each pulse carries the full energy of the transmitter and hence 
determines the strength of the echo that may be returned. Although a longer pulse will enable a 
greater energy to be conveyed, this would be at the expense of the receiver's selectivity since 
neighbouring targets may only result in a single echo. The solution achieved by transmitter 
designers is to generate a 'wide' pulse then compress it, prior to transmission, into a single 
high-energy impulse. Using compression techniques has enabled long range (250 mile) 
radars to be designed which still produce an acceptable echo at the limit of their range. Typical 
values for pulse length (x) are in the range 0.25 - 2us. 
The width of the transmitted beam is ideally as narrow as possible, to enable a more 
selective response to echoes reflected back from a target and to counteract the effects of beam 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 3 
Radar Signal Processing 
spreading at long ranges. The disadvantages of a narrow beamwidth are the increased effects 
of the side-lobes, which result in the signal being transmitted in directions other than the main 
beam. With typical values of beamwidth being around 1 - 2.5°, it should be clear that a p.r.f. of 
768Hz and rotation rate of 15 r.p.m. gives rise to between 9 and 20 pulses illuminating a single 
beamwidth and a large number of echoes can therefore be expected from a single target. 
These parameters are summarised for the radar types discussed in this thesis in Table 2.1. 
Type P.R.F. 
Pulse 
Length 
Effective 
Range 
RATES 
Range Beamwidth 
Rotation 
Rate 
768 Hz 2 u s 96 90 1.2° 15rpm 
~T 768 Hz .5 u.§ 30 4 2 2° 24rpm 
c 700 • 1400 Hz .25 us 30 42 1° 24rpm 
D 256 Hz 2.3° 7.5rpm 
Table 2.1 : Smmrciairy of Kadar Parameters 
The signal received by the antenna will be due to a pulse originally transmitted, say, at 
time t=Q, which has been reflected back by a target encountered at and reaches the receiver at 
time t 2 , where t2 E 2 * t^ . Since the pulse is of electromagtetic nature, it is possible to calculate 
the speed of the pulse, and hence determine the distance from the aerial to the target. 
Peak due to pulse 
transmission Larger echo 
Irom target 
Small echo. 
Possible target 
System Noise Level 
/ 
_n 
Fig. 23 : Characteristics of the Eeceived Signal 
A typical received signal will have the characteristics shown in Figure 2.2. It consists 
largely of a permanent offset noise, which may be generated by the receiving circuits or 
thermal effects, and a clutter level which is due to reflections from side-lobes, ground effects, 
The Application off Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 4 
Radar Signal Processing 
waves, birds, precipitation and weather effects. Occasionally there may be genuine targets 
amongst the clutter, which usually show as peaks in the background clutter level - the purpose 
of signal processing is to distinguish these from the permanent background clutter. 
2JL3 Sourness of Clutter 
The exact definition of clutter is based upon the situation in which the radar is used: To 
a weather radar designer, both aircraft and land would be regarded as clutter, but not the 
effects of cloud or precipitation. In this thesis it is intended to discuss the application of signal 
processing to a maritime surveillance radar and in this context the desired targets are: 
o AIRCRAFT o SHIPPING 
The unwanted targets, (and hence clutter) can be identified as : 
° Wave reflections 
° Land masses 
° Local echoes 
° Precipitation 
° System and thermal noise 
° Buoys 
° Angels 
° Clouds 
0 Radio Frequency Interference 
Study of these clutter types will reveal some constant or near-constant signals, (system 
and thermal noise, land-masses, buoys) and a number of moving noise sources. An ideal 
signal processor will therefore have facilities for removing or supressing clutter from all of 
these sources, while simultaneously maintaining sufficient sensitivity to detect any genuine 
targets. 
The clutter types may be further subdivided according to the spread of reflecting 
surfaces within a group. The term homogenous is used to describe clutter which exhibits the 
same reflective characteristics, irrespective of position within a clutter area. 
Non-homogenous clutter may reflect differently at varying points in its area of coverage and 
the term Point Clutter is introduced to describe clutter over an area which is too small to be 
analysed in sections. Analysis of these three types of clutter leads to the following 
subdivisions: 
° Homogenous clutter : wave reflections, precipitation, clouds. 
° Non-homogenous clutter : echoes from land masses, 
° Point clutter : angels, buoys, discrete targets. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2. 5 
Radar Signal Processing 
SL2 Detection of Targets in Clutter 
The designer of any radar system is required to maximise the signal/clutter ratio 
(whatever form the clutter takes), to achieve the best possible results from the system. This 
cannot be achieved, however, by simply raising the power of the transmitter, since this only 
serves to increase the strength of all returned echoes including those from unwanted targets. 
In practice, the clutter rejection ability of a system is determined by the transmitted signal 
parameters and the design of the signal processor. 
2.2.1 Optimisation of Transmission Parameters 
Optimisation of the transmitted signal is carried out by matching the range/angle 
resolution cell to the size of the target to be detected. (Figure 2.3). The depth of the cell 
corresponds to the depth of field covered by the transmitted pulse at its given frequency, and for 
general detection is set between 0.1 - lus. Pulses of less than O.lus duration result in break-up 
of the target over many cells. The width of the cell is determined by the beamwidth and rotation 
rate of the antenna, although beamwidths of less than 1° are difficult to obtain due to antenna 
size requirements. Transmission frequency is carefully chosen as frequencies above 1GHz 
tend to result in a radar susceptible to interference from precipitation, wind-sheer or 
turbulence. In many radar systems, the transmitter parameters are already fixed and the 
onus of reliable target detection lies with the signal processing section. 
Beamwidth < typical width of target 
range/angle resolution cell 
n_* 
0.1ns < (range cell depth) < 1us 
Fig. 2.3 : Optimisation of the Transmitted Signal 
2.2.2 Detection of Targets in the Received Signal 
The simplest form of target discrimination is between a moving and a fixed target, 
since the principle of Doppler Shift (e.g. observed as the change in the sound of a moving object 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 6 
Radar Signal Processing 
passing a stationary observer) may be applied to the received radar signal and used to 
velocity-discriminate the echoes. This process of Moving Target Indication, (M.T.I.), is 
frequently used, having the advantage that it may precede a standard signal processing 
section as a replacement for the conventional detector.Where more selective discrimination is 
required, the subdivisions of clutter types may be used to establish standard techniques for the 
filtering of unwanted data. 
M.T.I, can often be of use in early processing stages particularly where filtering of 
point clutter is important, although its complexity may outweigh its advantages, especially as 
other techniques exist for filtering moving targets. The basic principle of MTI, however, is 
given below although it is proposed to discuss some other methods in greater detail. 
2.2.3 Moving Target Indication 
A large proportion of the clutter environment may be identified as stationary, 
consisting of targets such as land-masses, buildings, ships at anchor and navigation buoys. If 
some form of motion detector were introduced into the receiver it would be possible to remove 
all occurrences of these unwanted targets by suitable filtering. The easiest method of detection 
is to make use of the Doppler frequency shift given to a transmitted pulse by a moving target, 
requiring some means of comparing the reflected signal frequency and phase with the 
transmitted signal. This process relies on the fact that a target will usually reflect several 
pulses while illuminated by the antenna beam, enabling an indication within one scan. 
Comparator ^ > 
Filtered 
+ video 
^ A - B 
Coherent 
Oscillator 
Fig. 2.4 : M.T.L Operating Principles 
The basic principle of M.T.I, detection is illustrated in Figure 2.4, the oscillator 
generating a signal in phase with the one transmitted. The phase detector compares the phase 
of the incoming intermediate frequency signal with the generated signal and produces a pulse 
output which varies in amplitude according to the detected Doppler shift. A stationary target 
results in zero Doppler shift, so consecutive pulses would be of equal amplitude. The 
comparator declares a target indication if the magnitude of the incoming signal is different 
from that produced by the previous range sweep. 
I.F. 
Video 
Phase 
Detector 
B Delay Line 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 7 
Radar Signal Processing 
In early M.T.I systems the delay line would be implemented in analogue form, using 
a water or mercury-filled tube, but later techniques permitted the construction of quartz delay 
lines. With the advent of digital technology, and semiconductor devices in particular, it is 
now possible to use charge-coupled devices for analogue delay lines or shift-registers for a 
digital delay. The M.T.I, filter can be made more selective by increasing the number of 
stages, thus enabling certain velocity ranges to be accurately detected whilst blocking 
unwanted speeds. Limited filtering of angels or wave targets is possible by selective M.T.I, 
filtering, but difficulties arise in increasing the number of M.T.I stages as the delay lines 
have to be more accurately constructed. This problem is solved to some extent in digital 
systems, since the delay can be completely controlled by its clock frequency and does not tend 
to drift with age as is the case with analogue components. 
Although M.T.I, provides useful stationary target filtering, it suffers from a number 
of disadvantages. The frequency range that can be used to define a target's speed must be less 
than the pulse repetition frequency otherwise the radar is said to be ambiguous in Doppler, 
resulting in certain 'blind' speeds in the radar's detection capability where the Doppler shift is 
an exact multiple of the repetition frequency. Also, the transmitter frequency must not drift as 
this type of coherent processing would be impossible with an unstable frequency source. In 
these situations an M.T.I, filter would have to be replaced with an envelope detector, and some 
other method of target processing introduced. 
M.T.I. signal mixer 
amplifier F LTERING 4 0 
I 
local 
PP oscillator 
\ 
Fig. 2.5 : Inclusion of an M.T.I Filter 
The inclusion of a typical M.T.I, filter is illustrated in Figure 2.5, where it should be 
clear that this circuit replaces the receiver's square-law detector, although its output conveys 
the same positional information with respect to time. The signal amplitude is an indication of 
the Doppler shift introduced by the target's motion and hence a measure of its speed, rather than 
its reflecting area or proximity. In considering this, it would not be unreasonable to perform 
some technique of amplitude-based filtering on either type of signal, although the exact 
implications of the results would necessarily be different and an ideal signal processor will 
therefore accept data from either source, taking advantage of the features offered by each. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2. 8 
Radar Signal Processing 
2.2A Alternatives to M.TX Processing 
In certain situations, the Moving Target Indicator is either insufficient or cannot be 
adapted to handle the returned echo signal and in these instances some other form of 
processing is necessary to remove the clutter and identify the genuine targets. Under these 
conditions, processing should be regarded as occuring post-detection and it may be subdivided 
into distinct units, each performing some form of filtering on the incoming data. Additional 
processing may be provided at this stage to offer extra facilities to assist the operator such as 
automatic tracking or I . F . F . identification decoding. 
Whilst early systems handled all processing using analogue techniques, the 
advantages offered by new technology have resulted in current signal processors being almost 
entirely digital, and it is this type of design that will be considered in the coming chapters. 
2.2.5 Digital Signal Processing 
The first stage of any modern radar signal processing system, following the 
detector/M.T.I., will typically include amplification and/or digitisation of the detected video 
signal, since use of digital processing gives advantages of high data throughput with no 
drifting and an accuracy which may be set to suit the requirements of the application. 
The digitisation process involves some form of quantisation of the signal into discrete 
amplitude levels and time periods, and may be regarded as a series of samples at different 
ranges: the distance between one sample and the next forms a range cell. The size of the 
range cell, and hence the digitisation rate, is another important factor in the performance of a 
processing system, being ideally related to the transmitted pulse width. If the rate is too high, 
then an echo will cover too many range cells, whilst a low rate will result in the loss of targets 
due to poor selectivity. 
The quantisation of the signal amplitude introduces some noise into the system, as a 
result of the error between the true analogue input and its digital representation, however the 
analogue signal is usually amplified to such a level that the system noise component exactly 
corresponds to the least significant bit of the result, with the effect that weak signals are not lost 
in the digitisation process. The accuracy and dynamic range of the result is dependent on the 
number of bits used to represent it and can therefore be easily improved upon by increasing 
this parameter, subject to the constraints of background noise levels. 
Once the signal has been digitised, a number of processing options are open to the 
designer and it is proposed to discuss those relevant to the RATES experimental radar system 
in detail. In particular, various methods of clutter reduction will be discussed together with 
suggestions for their implementation within a practical design. For details of the 
implementation of the prototype system, the reader is referred to Chapter 3 and ideas for future 
consideration are discussed in Chapters 4 & 5. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 9 
Radar Signal Processing 
2,3 Filtering Techniques in Homogenous Clutter 
Study of Figure 2.2 should reveal the two separate 'noise' components which were 
described in the accompanying section. The system noise is a permanent offset to the 
remainder of the signal, fluctuating slowly with variations in atmospheric conditions, and 
could be removed by straightforward application of a fixed threshold to the input signal. The 
more dominant clutter level varies considerably and it may be regarded, as discussed 
previously, in terms of the nature of its components. 
Homogenous clutter, as typified by rain, chaff or sea reflections, tends to be evenly 
dispersed over 1 mile or more in range and would therefore be covered by as many as 45 range 
cells using the parameters in Table 2.1. With no sharp edges to this type of clutter region, the 
simplest method of extracting targets (which are visible as peaks in the surrounding mean 
level) is to establish a value for the local mean clutter level at all range cells, and then to 
compare the received video signal amplitude against this. Successful calculation of a mean, 
which adapts to changing conditions without loss of selectivity or sensitivity is one of the major 
challenges to the radar designer, as loss of genuine targets due to clutter could render the 
system useless. 
2.3.1 Cell Averaging 
Although application of a fixed threshold is sufficient to counteract thermal and 
system noise components, the use of the same technique to filter 'moving' clutter would result 
in either the loss of many targets due to a high threshold or ineffective filtering due to a low 
threshold. An ideal solution would involve some means of adapting the threshold level to 
surrounding conditions, thus enabling the detection of small targets in low clutter 
environments whilst masking the effects of areas of high clutter level. 
Range Cell Divisions 
Mean 
Clutter 
System 
Noise 
Comoonent 7 
Fig. 2.6 i Expanded Portion of an Echo Signal 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 10 
Radar Signal Processing 
Consider Figure 2.6, which shows an expanded portion of Figure 2.2 and takes account 
of the division of the incoming echo signal into range cells : If, for every cell from the left 
hand side to the right hand side of the diagram, the average level of (say) the three cells on 
either side of it is calculated, the result would approximate to the line shown as the Mean Clutter 
L e v e l . Through a binary comparison of the level in the cell of interest, with the calculated 
average, the peaks and troughs of the background clutter are reduced to the 14 target 
declarations shown in Figure 2.7a. In this diagram, the clutter level is shown as a heavy line 
against the original signal amplitude, and the resultant binary comparison shown at the foot 
of the graph. 
6 cell CFAR 
no guard cells 
niuiruuuLsnjijmimi 
(a) Time 
6 cell CFAR 
with guard cells 
H J i _ J i j n j T _ j n j T J i n j i J i r 
(b) Time 
10 cell CFAR 
with guard cells 
n_n n_n_n [-LTUTJULJ" 
, x Time (c) 
10 cell CAGO CFAR 
with guard cells 
n_n_n LJLJI n_n_n 
(d) Time 
F i g . 2.7 : Relative Performance of Typica l C F A R Processors 
(Solid line :- Mean Clutter Level) 
Although clearly not perfect, the efficiency of this method of clutter reduction has led to 
its adoption as the basis of most clutter processors. It is usually referred to as a 
"sliding-window detector" and its use always involves some means of averaging the signal 
level over a particular area surrounding each range cell in order to derive a value for the 
corresponding threshold. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 1 1 
Kadar Signal Processing 
2.3.2 The Sliding-Window Detector 
The objective of the sliding-window detector is to reduce the probability of a a clutter 
'peak' being accepted as a genuine target, down to a manageable (or zero) level at which point 
further processing circuits can take over to remove remaining unwanted targets. For this 
reason, the detector forms part of a Constant False Alarm Rate processor (or CFAR) , and the 
comparison of each cell's amplitude with a mean clutter level forms a F i r s t Threshold 
Detector. 
Much work has been carried out on the theoretical design aspects of CFAR processors 
based on mathematical models for targets and clutter situations, with particular attention paid 
to the probability of a false detection occurring or the probability of a missed detection. These 
are well documented in other sources [23, 36, 37, 38], so it is not proposed to discuss these 
theoretical aspects within the scope of this document, which will instead concentrate on aspects 
of their practical implementation. In practice, the detectors to be discussed exhibit a probability 
of missed or incorrect detection in the region of 10" ,^ which equates to approximately 12 / sweep. 
In its simplest form, the first threshold detector is entirely range based, with no 
interaction between detections on successive azimuth bearings. For every range cell on a 
given bearing, a window may be considered to exist covering a group of cells on either side of a 
particular cell of interest (Figure 2.8). Within this window, the video level in the cells is 
averaged to provide a mean value, hence this is often referred to as a Cell-Averaging (CA) 
C F A R . To give an improved performance in situations where a target is located on the 
boundary between cells, it is common practice to ignore the two cells immediately adjacent to 
the central one when calculating the threshold level. In the example quoted, this modification 
to the design would result in the mean level shown in Figure 2.7b, with the number of binary 
'hits' falling from 14 to 12, without loss of significant target data. 
Window 'slides' across 
range cells 
Guard cells 
Azimuth sweep 
direction 
Sample cell 
Fig. 2.8 : The'Sliding Window'Detector 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 12 
Radar Signal Processing 
The previous two examples have involved a window of 3 active cells on either side of 
the cell of interest. Practical implementation of this design would be relatively easy, using 
adders to evaluate the sum and PROMs or shift-registers to produce the mean, however the 
performance of the detector with this window size tends to result in a high rate of missed 
detections as it responds very quickly to changes in the original signal. The result of 
increasing the window size to 5 cells (plus guard cell) on either side of the cell of interest is 
shown in Figure 2,7c: the mean level changes more slowly over fluctuations in the received 
signal amplitude, whilst short peaks in the signal, such as may be caused by targets, tend not to 
influence the mean, thus increasing the likelihood of a detection without compromising the 
clutter-rejection capabilities of the design. If a larger number of cells is used to establish the 
mean, the resulting threshold is found to follow the clutter-level more accurately, but at the 
expense of performance in situations of closely adjacent or smaller targets. 
The cell averaging process discussed so far has assumed that clutter is distributed 
uniformly within the area enclosed by the window, and its performance is therefore degraded 
by any clutter edges which may occur in this region. A further enhancement to this process 
takes account of more realistic situations where boundaries might exist, such as at the edge of a 
coastline or weather clutter, and this has been evaluated successfully by other sources [38, 39]. 
The technique involves taking the greater of the two averages produced either side of the test 
cell, then using this as the basis for the detection threshold, and for this reason it is known as a 
Cell Averaging, Greatest-Of (or CAGO) CFAR. Its performance using the test data is shown in 
Figure 2.7d, where it can clearly be seen that the number of false target declarations has been 
reduced still further by the improved handling of clutter edges. Its performance in regions of 
uniform clutter is not so good as the CA CFAR, but it has been shown [39] that this leads to an 
decrease of only 0.3dB in the signal-to-noise ratio of the CFAR output. 
O -
Diredion of Increasing Range 
Video 
Input 
Square - law 
detector 
: Guard Cell 
t Averaging 
Greatest-of 
selection 
0 G , 
Averaging 
'1 ' : Target present 
Comparator 
Fig. 2.9 : Implementation of a CAGO C F A R 
'0 ' : No target 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 13 
Radar Signal Processing 
The expressions for the mean levels ( Z c a & Z c a g 0 ) of the CA and CAGO CFARs are 
given below. In this case, the cell averager comprises 'N' cells, each of amplitude X j , with 'M' 
cells on either side of the guard cells contributing to the mean. 
A practical application of a CAGO CFAR processor is described in Chapter 3, but typical 
implementation of such a device, using a window size of 5 cells, is illustrated in Figure 2.0. If 
the input signal was not digitised, the shift register could be realised using analogue 
techniques and the final output would still be digitised to single-bit accuracy, however the 
circuit would be difficult to design due to drifting and problems with balancing the delay 
lines. Alternatively the signal could be digitised before input to a digital shift-register, 
solving balancing problems but requiring some means of summing the outputs from each 
stage of the register. In practice, the signal output from the CFAR averager is rarely used for 
direct comparison with the test video, and is more often combined with manual offsets (to 
account for system and thermal noise) and computer-generated offsets which compensate for 
other types of clutter (Section 2.3.3). 
2.3.3 Nora-Homogenous Clutter Cancellation 
The cell averaging techniques discussed so far can be applied with success to regions of 
homogenous clutter which by definition exhibit an even distribution of clutter levels with no 
sharp boundaries. Land masses, however, can produce strong echoes without being evenly 
distributed and can often lead to sharp transitions, say between a sea and land clutter 
boundary. Elimination of this type of clutter requires some knowledge of the movements of 
strongly echoing targets, which in turn can be fed back into the clutter rejection circuits. 
In such a situation, an additional weighting factor is applied to the output from the 
threshold averaging circuits, before it is compared with the test video level. The weighting is 
typically derived from the tracking computers, which collect details of all plots which have not 
been rejected by the CFAR processors and group them according to the region they occur in. 
Any plots which do not move or show a low consistency count (i.e. do not correlate from scan to 
scan) are regarded as clutter and can therefore be filtered out, an action which is performed by 
raising the threshold level in the regions where the clutter count is high. 
In practice, it is neither possible nor desirable to provide a computer-generated 
threshold value for every input range cell, so the radar's area of coverage is divided into a 
'map' of clutter regions which are updated periodically by the tracking computers (Figure 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 14 
N 
1 
X ca 
S 1 
m N 
1 
X X M 
M caqo U 1 JoM-s.1l 
Radar Signal Processing 
2.10). The azimuth resolution of each cell approximates to that of the antenna beam, so as to 
maintain an effective area of coverage. 
Clutter Map Cell 
Range Cell 
Fig. 2.10 ; Implementation of a Clutter Map 
( Showing typical relationship between clutter map and range cell sizes) 
The map is typically held as part of the first threshold processor and is addressed by the 
current azimuth and range values. The output is scaled by a pre-determined constant and then 
added to the mean threshold to form a value which can be compared with the test video level. It 
should be noted that the clutter map is often arranged so that the area covered by each cell is 
approximately constant, allowing for the spread of the beam at greater ranges. In operation, the 
use of a clutter map can be shown to be particularly effective against weather-clutter edges or 
static clutter against a fixed level background (e.g. buildings against land clutter). 
Typical implementation of a complete CAGO C F A E with clutter map is shown in 
Figure 2.11, below. 
Shift Register 'Window' Comparator 
Binary 
Target Output r r m 11 r 11 ^ ^ 1 i111 i r m Input from f 
Detector 1 1 7/ A v e r a g i n g ^ 7 Averaging 
/ Adder ^ 
Greatest-of Selection 
Manual Scaling Factor 
Manual Offset Value 
<D 
Clutter 
Fig. 2.11 s Complete CAGO CFAR Schematic 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 15 
Radar Signal Processing 
2.3.4 Alternatives to the Basic Cell Averaging Processor 
The performance of the CA and CAGO processors in conditions of homogenous clutter 
has been shown to be adequate for most requirements, however these conditions rarely exist on 
their own in a practical situation. There is therefore a need for some alternative or 
enhancement to the basic CFAR, to enable it to process non-homogenous and point clutter. The 
map described above is capable of reacting to fixed clutter, but is too slow to react to sharp edges, 
such as occur in multiple target situations, and does not adapt readily to the type of clutter that 
may be caused by bird flocks. 
2.3.4.1 Area Thresholding 
This method of clutter supression has proved highly effective in dealing with bird 
flocks and relies on the differences in amplitude distribution between clutter and desired 
targets (such as aircraft or shipping). It is more suitable for application to post-M.T.I. 
processing, but can equally be used following a square-law detector. 
An area map is established, similar in size to the clutter-map described previously, 
and the smallest genuine target in each cell is chosen as a reference. A detection threshold is 
applied to filter the low-level clutter and then two counts are accumulated - one comprising 
those detections which exceed the reference amplitude and the other, those which exceed the 
threshold but not the reference level. If too many small targets are detected the threshold is 
raised slightly and it is lowered if there are too few, thus keeping the number of small target 
detections low enough to avoid overloading the tracking computers. The disadvantage of this 
technique is that it takes some time to establish an adequate threshold and the computation is 
such that it requires a high-speed computer to evaluate it. 
2.3.4.2 Rank Order C F A R Processors 
Range-based rank-ordered CFAR processors are intended as an improvement on the 
traditional cell-averaging CFARs, especially in situations of multiple targets or sharp clutter 
edges, and they require less computational time than the area-thresholding processors 
described in Section 2.3.4.1.. Much work has been carried out by Rohling [40,41], comparing 
their efficiency against CA and CAGO types, with the conclusion that a rank-based CFAR 
allows the use of a much larger window whilst retaining the rapid response associated with a 
much smaller window size. The function of a rank-order CFAR processor is as follows: 
Consider a threshold window of size 'N' cells (excluding the test cell), with video level 
in each cell, given by X j { i s l„ .N} . The individual values of X j are firstly sorted to give the 
sequence: 
Xi< X 2 5 X 3 S < X N 
The Application of Digital Techniques to an 
Automatic Hadar Track Extraction System. Page 2 . 16 
Radar Signal Processing 
Rohling terms this resulting sequence an Ordered Statist ic, and suggests that a value X j j is 
chosen, where k e [l,2,3.o.N], and this is used as the basis of the threshold 
level. The parameter k is dependent only on the size of the window (N) and practice suggests a 
value approximately three-quarters of N. Hence a rank-order CFAR can be described by: 
k a 3N/4 
Using the example given earlier, Figure 2.12 gives a comparison between a 10-cell CAGO and 
10-cell rank CFAR, illustrating the more rapid response to threshold peaks that is achieved 
with the rank-based processor. 
(a) 
JULJnJLJLTX^ 
Fig. £12 ; Comparison of CAGO (a) and OS(b) CFAR Methods 
(Solid Line :- Mean Threshold Level) 
As the rank-based CFAR introduces a higher average threshold level than a CAGO 
processor of similar window size, Rohling has introduced a measure of the loss (in dB) which 
is incurred by the replacing the CAGO with an OS CFAR, based on the Average Decision 
Threshold (ADT) of each. This is given by the expression: 
D[dB] = 10 log 1 0 ( A D T o s / ABTcago) 
For the test data shown in Figure 2.12, this indicates a loss of approximately 0.451 dB, which 
compares well with the results given in [41]. Variations in the value of 'K' tend to raise or 
lower the mean threshold value for the OS CFAR (Figure 2.13): a value of K=3N/5 gives 
similar threshold performance to the CAGO, whilst a value of K=9N/10 gives a high threshold 
with slow response. For the OS CFAR to function successfully, it is suggested that K should be 
greater than N/2 and the difference N-K should not be less than double the expected target depth 
(in range cells) so as to retain the ability to detect multiple adjacent targets. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2. 17 
Radar Signal Processing 
Rohling has concluded that in multiple target (equal amplitude) situations, use of a CA 
or CAGO CFAR will often result in loss of both targets due to a raised threshold. For targets of 
differing amplitude these CFARs tend to lose the one of lower amplitude, whilst the 
ordered-statistic CFAR can be shown to detect both targets regardless of their amplitudes. 
(a) 
J L F L T L J L T L J r U T T L J U 
(b) 
(c) 
f L J U L n n n r 
Fig. 2.13 i 
PerfoMmamce of a 10+10 ce! 
Esmk - Ordered CFAR, 
(a) : K = 3N/5 
(b) : K = 3N/4 
(c) : K = 9N /10 
2.3.4.3 Non-Parametric Detectors 
The Cell Averaging, CAGO and Ordered Statistic CFARs discussed previously can all 
be termed parametric detectors, by way of the methods they use to establish a mean threshold 
level. All make assumptions about the distribution of the clutter which they are required to 
filter and therefore tend not to perform well in situations where these rules are not adhered to. 
For example the CA and CAGO processors are based on an assumption of a Raleigh clutter 
distribution within the window, whilst OS types expect a certain size of target and clutter 
environment to function effectively. An alternative class of CFAR which is designed to 
function independently of the clutter distribution is termed a non-parametric detector, and a 
practical implementation of such a processor has been suggested by Mao et al [42] due to earlier 
work by Vogel [43] and Dillard [44]. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 18 
Radar Signal Processing 
The non-parametric CFAR uses the statistical ranking of a test cell's amplitude within 
a range window as the basis of a simple thresholding test, however it is important to note the 
differences between this and Rohling's Ordered Statistic CFAR which is also rank-based. 
If, for range sweep T , a window of size N cells (excluding test cell) is considered, with 
corresponding video level X J J ^ {kel.o.N} in each cell, and a test video level of X y , then the 
'rank' of the test cell (By) is given by the expression: 
From this we can deduce that the value of R y is an integer in the range 1...N, and this 
can then be used as either an input to the CA CFAR described previously or simply compared 
with a pre-determined rank number to establish a binary output. 
As with the OS CFAR, the ideal rank threshold number is dependant on the window size 
and the required false alarm probability. For a large window size, it has been discovered that 
this approximates to 0.8(N+1), however the large window introduces a slow response to 
changes in clutter level whilst a smaller window increases the false alarm probability. Mao 
suggests a window size of between 8 and 16 cells, with a calculated false alarm probability of 
0.84 *10- s for a 15 cell window. 
The suggested method of implementation is to use an analogue charge-coupled device 
as a shift-register, with output taps being fed to comparators which produce a binary output 
depending on the result of comparison with the test cell amplitude (Figure 2.14). Charge 
coupled devices currently available can easily support the clock rate required to give an 
adequate sampling rate for most surveillance radars, with an accuracy which corresponds to 
an 8-bit digitisation process. A size of at least 20 CCD cells is recommended to give adequate 
CFAR response. 
N 
c < V * i R . ks1 
where C is an operator performing the function: 
( 1 : for x>0 or (x=0 & i-j is odd) 
C(x) = | 
^ 0 : for x<0 or (x=0 & i-j is even) 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 19 
Radar Signal Processing 
The outputs from the comparators are summed in an PROM (to speed calculation) and 
the output of this gives a direct measure of the rank of the test cell. It must be remembered, 
however, that this figure must be processed further in order to evaluate a binary target 
declaration, and in the example given, the rank is compared with a manually preset value. 
The output is the same as would result from a conventional A/D converter followed by a CA or 
similar CFAR, but avoids the problems normally associated with this type of processing. 
Test cell 
i ^ G u a r d cell 
<- CCD Tapped 
Delay Line 
Analogue 
Video Input 
<- Comparators D o • • a • • • • • 
PROM Adder PROM Adder 
y 
Adder 
Preset Rank Threshold Binary Target Output 
Fig. 2.14 ; implementation of a Non-Parametric C F A R 
2.4 The Second Threshold Detector 
The clutter-elimination techniques discussed so far have mostly concentrated on the 
range ordered aspects of clutter regions, processing data that is derived directly from the 
detection stages of the radar receiver. In practice, the width of the antenna beam is such that 
several pulses will be reflected from any genuine target and it is therefore possible to look for 
correlation between pulse repetitions in order to establish the presence of a target against a 
background of range-correlated clutter. A system which will work within the scope of these 
requirements is termed a 'Second Threshold Processor' or, by way of its method of function, a 
Vithin-beam integrator'. The processor is usually coupled with a CA or similar CFAR, as 
described earlier, to form a complete double-threshold detector. Original work in this area is 
due to a number of sources [45,46] and improvements to the basic design have been suggested by 
Marcoz and Galati [47]. This latter design is particularly easy to implement and it is therefore 
proposed to discuss this solution in detail. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 20 
Radar Signal Processing 
2.4.1 The Marcm & Galati Detector 
The Marcoz and Galati (M&G) detection process consists of four basic steps which are 
evaluated for every range cell over a continuous azimuth scan. The first step is performed by a 
first-threshold processor of the type described previously or in its simplest form by comparison 
of the input signal with a fixed threshold voltage. The binary 'hits' which result from this stage 
are used to clock a counter which counts up if a hit is recorded or down if there is no hit. The 
second threshold is applied to the output of the counter such that a target is declared if the counter 
goes above a certain preset level and continues to be declared until the counter value falls below 
a second preset level. In the basic 'second threshold detector', the counter increments and 
decrements would both be set to a value of 1, whilst the Marcoz and Galati variation sees a 
larger increment before a target is declared and a larger decrement after the target has been 
declared. The following parameters are used in the evaluation of a second threshold: 
i The number of the sweep, i.e. the ith p.r.i. 
Output from the first threshold detector 
Y i Stored accumulator value 
Zj Target detection status [1 - target present, 0 - no target) 
U Upper second threshold 
L Lower second threshold 
M C Counter increment 
DEC Counter decrement 
oc.p Counter increment/decrement constants (a > P) 
The detector is initialised, at power-on, with accumulator (Y) and target detection 
status (Z) set to zero. The following algorithm can then be applied for every range cell in 
successive p.r.i. cycles: 
IF ( 2i„i = 1) THEN 
I N C = p, D E C = a 
ELSE 
I N C = a, D E C = p 
IF (Xi = 1) THEN 
Yi = Y M + I N C 
ELSE 
Yi = Y M • D E C 
IF (Yi > U ) THEN Zi = l 
IF ( Zi.i = 0 ) & ( Zi = 1) THEN 
{start of target declaration} 
ELSE 
I F ( Z i = l ) THEN 
IF (Yi > U ) THEN Yi = U 
IF (Yi < L ) THEN Zi = 0 
IF (Yj < 0 ) THEN Yi = 0 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 21 
Radar Signal Processing 
The result of applying the above algorithm to typical test data is shown in Figure 2.15. 
The effect of two increment and decrement values, with one larger than the other, ensures that 
targets are declared quickly when none are present in the azimuth window, but rapidly lost 
once first threshold crossings start to diminish. The resulting plot window is more accurately 
defined than would be achieved with a single increment value. 
Accumulator 
i 
value i 
14 r 4. i 
' Uoper second threshold l~-•>-.-: i n Ml tll l l l l 12 
tit I 10 4- r I. 1 8 
i 
Lower second threshold 6 
j t r 3 
.1 
r 
= — ^ > First Threshold 
'Hits' (input data) 
• — ' • - — ^ —^Output from Second 
Threshold Processor 
Fig. 2J.5 s 'Marcoz & Galati' Second Threshold Processor 
In the example given above, each vertical grid line represents one pulse repetition 
interval. A target is declared 7 p.r.i.s after the initial first threshold crossing, following 5 
'hits' and 2 'misses'. The increment and decrement values (3 and 1 respectively) are then 
swapped and after a further 7 p.r.i.s the accumulator count falls below the second threshold and 
the target ceases to be declared. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 22 
Radar Signal Processing 
2.5 Data-Rate Reduction Through Plot Fanning 
In general, it must be assumed that target declarations which have passed both first and 
second threshold processors have exhibited some degree of correlation in both range and 
azimuth directions and can therefore be deemed to be genuine reflectors. At this stage it is still 
not possible to evaluate their properties as desired targets, since correlating reflections could 
equally be due to bird flocks, land clutter or unfiltered moving clutter (precipitation, waves 
e.t.c). Further processing should ideally evaluate the scan-to-scan correlation of plots as well 
as their tendencies to manoeuvre in acceptable trajectories, and this would typically require 
some form of computer-based filtering because of the complexity of the tasks involved. The 
data rate of most computers is not sufficient to support the potential output rate of a within-beam 
integrator which could, in extreme conditions, produce an output for every range cell. It is 
therefore necessary to find some method of reducing the data rate to avoid overloading the 
computer, and a solution is offered by considering the type of data which is processed by the 
software. 
The computer is likely to be required to filter out all stationary plots from the incoming 
data stream, which will remove most types of land clutter, and then to track all remaining 
plots. For these functions, it would be simplest to carry out processing based on the co-ordinates 
of each plot, thereby simplifying the calculations involved in tracking manoeuvring targets, 
and this therefore provides an ideal format for data transfer from the detector to the computer. 
As genuine targets are likely to produce second threshold detections which extend over a 
number of range cells and pulse repetition intervals, a convenient method of data-rate 
reduction can be achieved by converting the range/azimuth target declarations from the 
detector into co-ordinates representing the centre of a plot. Additional logic must be included to 
ensure that plots are restricted to acceptable dimensions so that multiple adjacent targets are 
not lost. 
2.5.1 Plot Forming Procedure 
The plot forming function can be established using a number of methods, such as 
latching start and end azimuth readings as they are declared by a within-beam integrator and 
establishing their central point. A less complex method involves finding the geometric 
centroid of a window surrounding a plot which has been declared by the within-beam 
integrator. This is achieved by positioning a window of fixed range depth, but varying width, 
around an area of second-threshold detections, allowing the width to increase until either there 
is an absence of second-threshold 'hits' in the range direction or a pre-defined limit is 
reached. This limit is set such that the area of the window (in range cells & p.r.i.s) is 
approximately equal to the maximum size of likely targets. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 28 
Radar Signal Processing 
Once closed, the geometric centroid is established by weighting the second-threshold 
detections contained in the plot window, then looking for their centre of gravity. To avoid loss 
of adjacent plots, windows are permitted to overlap to a certain limited extent. 
Consider Figure 2.18: the hatched areas represent second threshold detections, and the 
window surrounding them is due to the left-most active cell. Following initiation, the 
Range 
Wmdow ormed 
around plot 
Window closed 
by absence of video 
on this p.r.i. 
Second Thresho d 
Detections Azimuth 
Active video in 
this cell initiates 
plot formation 
Fig. 2JS ; Evaluating the Centre of a Plot 
window is established with a width of one cell and the initiating cell in it centre. Reference 
co-ordinates are noted for the azimuth and range values at this point ( 0 e , R e respectively) as a 
basis for calculation of the plot centroid when it is closed. On subsequent p.r.i.s the window is 
widened to encompass further second threshold crossings until, after 5 p.r.i.s, there are no 
detections within the new range window and the plot is closed. 
On each p.r.i., the new cells are all given weightings with respect to the reference 
co-ordinates and these are accumulated for use later. For every cell, the azimuth moment (Z0) 
is calculated by multiplying its binary target status (X0 r ) by the distance (in p.r.i.s) from the 
reference azimuth. Similarly, the range moment (XR) is evaluated from the product of target 
status and distance from the reference range. A count of the total number of active cells 
(i.e. X 0 r m 1) is also accumulated (EN) and upon closure of the plot, the co-ordinates of the 
centre-of-gravity ( R c & 0 C ) are established by taking the accumulated moments and 
dividing by the number of active cells in the plot window. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 24 
Kadar Signal Processing 
Hence, if k is the number of range cells on either side of the centre of the window and 
is the width of the window , then: 
m + k 
5 > - £ ( E ( * ( * " r . ) > 
m +k 
:0 r^ -k 
J E , + k 
( E ( \ r ) 
( X „ r * ( 0 - 0 . ) 
( a c c u m u l a t e d r a n g e m o m e n t ) 
( a c c u m u l a t e d a z i m u t h m o m e n t ) 
( a c c u m u l a t e d a c t i v e ce l l c o u n t ) 
0 = 0 rs=k 
from which we can determine that: 
0 @ + E0 / SN 
R c ^ R@ * EE / E N 
{centre of plot, bearing) 
{centre of plot, range) 
Application of this algorithm to the plot window shown in Figure 2.16 would indicate the 
centre of plot as marked. A practical limit on the plot window size (for typically airborne 
targets) would be in the order of 3 to 5 range cells / p.r.i.s, although it must be remembered that 
plots are permitted to overlap by one (or two) cells in any direction. In practice, the algorithm is 
easy to implement and an example is given later in Section 3.5. With the advent of new signal 
processing techniques, the regularity of the processing lends itself to a highly compacted 
architecture [49] which will be referred to in greater detail in Chapter 8. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 25 
Radar Signal Processing 
2.6 Summary 
The importance of signal processing techniques to any radar system has been 
discussed in this Chapter, and a number of practical methods of implementation have also 
been shown. Reduction in'the number of false targets being passed to the operator is of prime 
importance since it is difficult, even for a trained operator, to extract information from 
unfiltered data on a p.p.i. display. With computers needing access to the information that is 
obtained from the radars, it is equally essential to reduce the data rate from that of raw video 
down to a manageable level to avoid overloading, and the double threshold detector has been 
shown to perform this task with efficiency. The addition of a geometric centroiding processor 
provides target data in a more acceptable form to the computers, and this reduces the data rate 
still further without loss of sensitivity. 
Variations in basic design of the CFAR processors are continuing to be developed, to 
counteract their traditional dependance on statistically distributed clutter, which rarely occurs 
in a practical environment. The statistical-rank and ordered statistic CFARs are 
comparatively new techniques, but are already being adopted due to their superior handling of 
clutter edges and multiple target situations. 
2.6.1 Effectiveness of the OS CFAR Against E.C.M. Operation 
The potential for 'programming' the threshold rank in the OS CFAR is likely to be of 
importance in an environment where electronic counter measures (E.C.M.) are in operation, 
as the rank can be chosen to ignore the high amplitudes and sharp edges associated with 
stretched-pulse or railing jamming. E.C.M is employed by targets which require some degree 
of invisibility to radar detection, and the techniques they use usually make some assumptions 
about the type of receiver which they are designed to deceive. In general, they work on a 
principle of attempting to raise the CFAR threshold artificially, so as to mask out genuine 
targets and achieve this by transmitting repeated pulses at intervals which match the detectors 
window size (railing jamming) or stretching and re-transmitting the original pulse 
(stretched-pulse jamming). 
Use of a large window size should enable a rank value to be chosen which ignores the 
effects of railing jamming, whilst the stretched pulse technique requires a rapid response 
CFAR which can overcome clutter edge effects since a portion of the reflecting target will be 
visible for the time it takes to receive and re-transmit the stretched pulse. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 2 . 26 
The RATES Radar Systemm 
3.0 Introduction 
In the late 1970's, Admiralty requirements for a compact system, capable of 
fulfilling the radiolocation and tracking needs of the Royal Navy, prompted 
considerable work on the theory of clutter suppression and automatic tracking. 
During this time research was carried out by both MoD establishments and private 
companies and resulted in a number of papers on the subject of various tracking 
algorithms and, notably, a paper by Tunnicliffe of the Admiralty Surface Weapons 
Establishment (A.S.W.E.) entitled "A Simple Automatic Radar Track Extraction 
System" [33]. This paper was presented at the 1977 International Radar Conference, 
and in it he proposed a processor which could be interfaced to a number of different 
types of rotating surveillance radar and would accumulate data on surrounding 
movements, presenting this to the ship's data-gathering computers. The design 
challenge was quickly taken up and a specification produced for the Radar Automatic 
Track Extraction prototype, later to be simply referred to as RATES. 
3.1.1 The HATES Specification. 
The basic requirement for RATES was a system which could be installed in Royal 
Navy ships and would provide target track data for the Action Information Organisation 
(AIO) computers (which essentially functioned as a centralised data gathering system). The 
front end of R A T E S required an interface capable of matching almost any rotating 
surveillance radar (providing its functional parameters fell within the tolerances of Table 
3.1), although 4 specific antennae were detailed for testing purposes. 
Pulse Repetion Frequency: 256 384 768 1536 {Hz, ±10%) 
Maximum Range: 235 data miles (P.R.F. not exceeding range capability) 
Rotation Rate: 30rpm maximum 
Pulses / Beamwidth: 16 maximum 
Range Resolution: 250ns max, & In multiples of same. 
Range Cells/P.R.I.: 4096 max. 
InterScan Dead Time: 200us minimum 
Table 3.1 s Radar Interfacing Constraints 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .1 
The RATES Radar System 
The raw video would be digitised to a minimum of 8 bits accuracy and then C F A K 
processed, using a two stage threshold processor, resulting in binary target declarations which 
would then be extracted to produce plot co-ordinates. These could then be fed into a 
computer-based stationary plot filter and finally passed out to track association software as 
likely targets ( F i g u r e 3.1). 
The output from R A T E S would ideally be a connection directly to the A.I .O. , carrying 
the following information: 
Confirmed track data (Output once per scan) 
New track date 
System control messages 
R a w video date 
A degree of feedback from the A.I .O. would also be required, most importantly the ability to 
initiate target tracking manually. The prototype would not need to provide all of these outputs 
however, although the design would need to be adaptable in terms of both hardware and 
software, so they could be added easily at a later date. 
Clutter Plot video Detector Filtering Extractor 
P.P.I. sync 
A A 
ECM Warning 
Stationary 
Plot Filter 
Test Target 
Generator VDU 
Track Raw video 
Association 
AIO 
F i g . 3.1 ; K A T E S Funct ions 
Additional facilities required by the specification included a test-target generator 
which could simulate the operation of a radar in a programmable clutter environment, a 
simple electronic counter measures (E .C .M. ) warning system and a comprehensive control 
panel so as to enable fine adjustment of parameters before choosing an optimum solution. 
Several engineering parameters were provided for the R A T E S design, notably the 
power supply and size requirements. R A T E S was intended as a replacement for an early plot 
extractor, which lacked auto-tracking features, and it was important that the new R A T E S 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .2 
The RATES Radar System 
system fitted into the space vacated by this machine. Accordingly, the designers were given 
the space of three 6' x 19" equipment racks, with a documented preference that the size be 
reduced as much as possible below this for a production version. The available power supply 
was to be a nominal 240 volts at 50Hz, to a maximum of 5 K V A with a requirement that it be 
capable of operating from a 110 volt 60Hz supply if necessary. 
3 X 2 The K A T E S Prototype 
Given the specifications of R A T E S , it is intended to discuss the various sections of the 
system in detail, so as to describe the actual implementation of the prototype. 
Technical design was undertaken by a major electronics company in the U . K . , who 
were also responsible for the construction of two identical systems for testing and evaluation 
by the Admiralty. The design made use of late 1970's technology, using small/medium scale 
integration (S .S . I . /M.S .I . ) for the majority, with limited use of large scale integration 
( L . S . I . ) components where practicable. The hardware was assembled using wire-wrap 
techniques on standard Eurocard prototyping boards, with external connections over 36 pin 
double-sided edge connectors. A total of 32 boards completed the system, most installed in one 
of the three 19" cabinets, along with the power supply. The remaining boards were fitted into a 
cabinet containing one of the Ferranti Argus computers, where they formed the other end of a 
data transfer link. 
The 32 boards which made up the R A T E S system could be divided into functional 
groups - the number of boards per group varying between one and seven. F i g u r e 3.2 (overleaf) 
illustrates the complete prototype, in terms of the boards used to build it. The areas which 
dominate the system hardware are primarily those involved in interfacing - not only the F 
and H series boards, but also the Y boards which drive the P.P.I , display. It is worth noting 
that the latter were provided mainly for testing purposes, as a production system would 
probably require that video be sent directly over the A.I .O. interface. A brief description of the 
interface has been included, however, in a later section of this chapter. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .3 
The RATES Eadar System 
A to c= O 0 ) cu cu co CQ <= CO o .!2 c <0 0 ) a. to nj <n o A A —o O Q) cu CU cu o 
<D o CU a) a> Co O 0 ) 
EC 
UJ ^ 5! cn 8 8 i a. •4 TO X CM 3Z a s cu 
0 ) 
CO T Q> CU CM CO LU 
OJ 
TO O 
- O cu 
o a> 
CC CO 
1 5 £• CO 
to CO 3 " cu cn CO cn =5- CD i a) >• .gco CO 
V 
S 5 CM 
L U CU 
8 01 
a> o <D o CO O 
3 
"8 
o C= 0) 
CO 
CO 
rsl 
CO Cu CD 
CP 
CM 
CO E 2 T O 55 CO CO CO *r CM 
CO 5 l O - ca u_ CO 
cu 
E o> 
cu c CQ H > 5 £=1 o co i- e3 
cu CM 
^ cu to >^  CO CO CO O >-co CO CO £: CU CU 
CO 
CO 5 O O CO O cu cu X CM CM 
CO CD A A cu S3. 8. 5 a? CO cu cu JS. cn CD co n: CO co 
Pig. 3.2 ; K A T E S Prototype Block Design 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Pag© 3 .4 
The RATES Radar System 
&2.1 The Input Inteifecs 
The R A T E S input comprises 6 signals, 4 of which provide necessary radar data and 
the remainder giving details of the ship's movement (it must be remembered that R A T E S was 
designed for use on board a ship, which could conceivably be moving relative to identified 
targets). The radar data inputs are detailed below :-
( i ) Logarithmic video signal (rate 20dB/V), to a maximum amplitude of 4.5V with a 
typical noise component of 0.24V. 
( i i ) Synchronisation signal - a positive 18V (±3V) pulse of 3uS duration, marking the start 
of each transmitted pulse. The signal would normally be carried by a 75Q co-axial cable. 
( i i i ) Bearing synchronisation signal - a 1:1 square wave generated as the antenna rotates. 
Normally 4096 pulses/rev, but sometimes 2048 or 1024 depending on radar type. As the speed of 
rotation of the antenna can be greatly affected by the attitude of the ship and weather conditions, 
this signal serves to synchronise the plot extractor with the true rotation of the antenna. 
( iv) North marker - an active low signal, of period equal to one of the bearing clock cycles, 
transmitted when the beam is pointing in a due northerly direction. North marker and 
bearing clock signals are sent over an appropriately terminated twisted-pair cable. 
U North Marker 
Sync 
Pulses 
video 
Input 
Fig . 3.3 t Relationship Between Pr imary Input Signals 
The ship's motion inputs: 
(v) Ship's Speed - 1 8 0 ° synchro output corresponds to 15 knots. 
(v i ) Ship's Heading - follows a 1:1 relationship with compass bearing. 
Both of these are transmitted as 3-wire 115/90V 400Hz synchro signals, combined with 
appropriate reference data. To be of use to the plot extractor they have to be converted to digital 
form in the early stages of the interface. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .5 
The RATES Radar System 
3.2.2 Vide© Interface Design 
The input interface is constructed on 3 main boards, which handle buffering and 
digital/analogue conversion of the input video and ship's motion signals. The remaining 
inputs are processed on the system timing boards ( G l and G 2 ) . Functional diagrams of 
interface boards A l and A 2 are shown in F i g u r e s 3.4a and 3.4fo. 
75Q 
Video 
4.5V max 
P Video Input CO AAAA X3 X1 X2 
3 £ 
CO 
F i g . 3.4a ; Video Interface Schematic 
The video input circuits essentially isolate the detected video signal from the voltage 
ground of the plot extractor. The signal can be attenuated i f required through use of the 
potential divider arrangement before it reaches the input of the unity gain buffer [ X I ] . This 
functions as a voltage to current converter, driving the current amplifier [X2] which with a 
gain of 1 acts as a second buffer, prior to a splitter which divides the signal to drive two 75Q 
loads. One load is the input to the high-speed A/D converter [X3], a thick film hybrid component 
which supports a conversion rate of 12MHz and performs a single conversion in 150ns. The 
voltage at this point is diode limited to approximately I V so as to prevent damage to X3, and it is 
intended that the potential divider be set such that an input of 4.5V produces a level of 1.0V here. 
The output from the converter is an 8 bit byte at lOkQ emitter coupled logic ( E . C . L . ) 
levels, plus a single 'conversion complete' signal. Al l 9 lines are buffered to convert them to 
standard T T L levels, prior to transmission to the next stage of processing. 
The other output from the splitter is taken directly to the display interface, where it can 
be selected for output to the P.P.I, display. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .6 
The RATES Radar System 
3.2.3 T h e Symchifo Interface 
The synchro converters on boards A 2 a and A 2 b function in a similar manner to the 
video interface, with the exception that buffering of the input is performed on-chip by a hybrid 
synchro-digital converter [X4]. The synchro signal is received as 3 separate phase-encoded 
inputs and an accompanying reference. The transponders for ships motion and heading both 
convey angular information, which is transmitted to the interface along these 3 wires, each 
carrying a sine wave, the phase of which is displaced from the reference by a defined amount. 
The simple operation of the synchro - measuring 3 phase differences - can easily be integrated 
onto a single device and a digital conversion applied to the result, enabling an accurate value 
to be equated to the angular displacement of the transponder. 
- C s — o jaaa to 
jQOQ CD 
- c > - > 
- Q O f l 5T c 
Reference 
- t > — > 
CO 
- c > — > GND 
a 
Fig. 3.4b s Synchro Interface Schematic 
The output from the device [X4] is a 10 bit word, at T T L levels, and is buffered prior to 
transmission across the backplane bus. The synchro information is not used at all within the 
hardware plot extractor and only the upper 6 bits of the converted speed signal are passed on to 
the computer interface, thereby enabling a single 16 bit word to convey both speed and heading 
information to the computers. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .7 
The RATES Radar System 
3.3 T h e Constant False A larm Processor 
The converted video signal is processed by the constant false alarm rate circuitry on 
the three B series boards, which implement a cell-averaging, greatest-of (CAGO) C F A R as 
described in the previous chapter [2.3.2]. The block diagram of this section is shown in F i g u r e 
3 .S - its apparent simplicity disguises an interesting circuit design and, consequently, 
detailed schematics are also shown (F igures 3.6a <§s h). 
Range 
Select 
# Range Clock 
Prescaler 
Azimuth Address 
Offset Data 
Scale Select 
Video 
Range 
Address count 
^|From Computer) 
Address 
Select 
4Kx7 
RAM 
# <- Shift reg -> 
Shift Register 
Averager 
Shift Register 
j Averager | 
Compare 
r 
Select 
Manual 
Offset 
N/K 
(V-C-M) ^ 
Adder Adder Multiplier 
V-C-M N/K 
> (V-C-MJN/K 
Comparator 
Fig. 3 J s C F A R Processor 
3.3.1 C F A R Averager 
Board B l holds the circuitry for the variable length shift registers which produce the 
pre- and post-range averages. By allowing the operator to select the number of cells used to 
derive the mean surrounding level, it is possible to tune the system to process a wide variety of 
target types and densities in differing clutter conditions. The number of cells on either side of 
a sample cell may be adjusted between 3 and 18 - and can be varied through use of a 16 byte 
R A M , addressed sequentially by a 4 bit counter, with its preset count value set according to the 
number of cells required. Thus, a preset value of 15 will result in a total delay of 3 clock cycles 
- 1 clock cycle in the R A M and 2 in adjacent latches. The input to the R A M is added to the 
previously accumulated sum in adder [XI] and the output of the R A M inverted and delayed by 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .8 
The BATES Radar System 
one clock cycle before being added to this sum to form the new accumulated sum. 
0-15 Counter 
Preset 
16 x 8 RAM 16 x 8 RAM 
\ Adder [X3] Adder X1 
\ Adder [X4] Adder [X2] 
I 
Latch [X6] Latch [X5] 
v V 
Pre-range Sum Video Sample Post-range Sum 
Fig . 3.8a ; Funct ion B l Schematic 
I f sample cell is v[t] then, with a R A M delay of n cells we have: 
- v[t*l] input to adder X2 
- vtt-s-2] output from R A M 
v[t+2+n] input to R A M & adder X I 
At time t, output from latch X5 is: 
v[t*l+n] + (v[t] + v[t*l] + v[t+2] + . . . v[t+n]) - v[t] 
thus output from adder XI is: 
v[t+2+n] + (v[t+l+n] + (v[t+l] + v[t+2] <•... v[t+n])) 
and output from adder X2 is: 
v[t+2-ra] t> (v[t-5-l+n] + (v[t+l] -s- v[t-s-2] •!•... v[t+n])) - v[t<-l] 
which may be rewritten as: v[t+2] + ... v[t+l+n] + v[t+2+n] 
or: t+2+n 
therefore at time t, the output from the pre-range sum latch (X5) is: 
t+l+n 
v [ k ] which is the sum of the n cells preceding the sample, with 
a single guard cell. 
Analysis of this output expression should indicate that the summing process takes place 
by way of an accumulator, to which is added the incoming new value while simultaneously 
subtracting the outgoing value which is delayed by (n+1) cycles. This is much faster than 
adding all (n) samples in R A M and proves easy to implement in hardware. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .9 
The RATES Radar System 
3.3.2 C F A R Memory 
Board B 3 stores the computer generated threshold levels which are used to offset those 
produced dynamically by the C F A R processor, and enables the system to mask-off areas of 
known high clutter level or electronic counter measure activity. It is capable of storing a total 
of 4096 x 7 bit values, which are updated by the computer every scan. The circuitry consists of 
address-select logic which controls access to the memory by plot-extractor or computer (the 
latter only having access during the interscan period). Clock signals, from the system 
timing circuits, are pre-scaled on B 3 according to radar type, range setting and currently 
scanned azimuth. The output from the threshold K A M is then inverted and scaled by a factor 
of 0,2, 4 or 8 times before being fed across a 9-bit bus to board B2 . 
pre & post l * * I | • 
range sums Comparator Selector 
JZ 
o « 
—1 
Fig . 3.6b s Schematic of the C F A E Detector 
3.3.3 C F A R Detector 
Board B 2 carries the circuits which evaluate the binary target declarations from 
knowledge of the pre- and post-range sums. These two outputs are compared in an 8-bit wide 
comparator, and the output used to select the greater, which is then latched to prevent timing 
problems. The detector works on the C A G O principle whereby a target is declared 
when the following condition is satisfied: 
V > I . K + C + M intheform: N . ( V - C - M ) > I 
N K 
The video sample (V) is added to the complements of the computer generated offset (C) 
(from B 2 ) & the the manual offset (M), giving the result (V-C-M) . This is retimed in a latch 
before passing to the multiplier. The expression (N/K) is evaluated by a P R O M (on G l ) , and 
this too is applied to the multiplier, resulting in the expression ( V - C • M )*N/K. After 
retiming, the result is applied to the final comparator which produces a binary 1' if it is 
found to be of greater magnitude than the greater of the pre- and post-range sums. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .10 
The RATES Radar System 
3.4 T h e Within B e a m Integrator 
The binary output from the constant false alarm rate circuit is retimed prior to input to 
the Within Beam Integrator (W.B.I.) section, firstly in a single latch, with a second output 
being delayed by a further clock cycle so as to be in synchronisation with the output of the 
W . B . I , processor. Thi s feature greatly simplifies the design of the display processor, as 
detailed later. 
The W.B.I , section works as the second half of a double threshold C F A R processor, and 
has been designed around the model proposed by Marcoz and Galati [47], described elsewhere 
in this thesis (Sect ion 2.4). In contrast to the first threshold processor, described in Section 3.3, 
which integrates over range, the W . B . I , functions by accumulating each range cell over 
bearing ( F i g . 3.7). 
F i g . 3.7 : C F A R & W B I Integration 
Analysis of this mode of operation should indicate that an important feature of the 
W.B.I , processor is a high speed memory, equal in size to the number of range cells per sweep, 
storing the accumulated sum. The old value must be read from this memory at every range 
cell and the updated value rewritten before proceeding to the next range cell. A target is 
declared if an ascending accumulator value crosses an upper threshold, and remains in this 
state until the descending value crosses a lower threshold. To sharpen the boundary between 
clutter and a potential target, the ascending accumulator value increases by *A' for every 
binary C F A R declaration and decreases by 1 for a miss. S imi lar ly the descending 
accumulator value decreases by 'A' for every missed C F A R output and increases by 1 for a 
CFAR Integration WBI Integration 
As with the first threshold integ-
rator a sum is accumulated for 
every possible range cell value 
and a further set of binary target 
declarations produced whenever 
a preset threshold is exceeded. 
hit. 
The following parameters are defined in the context of the W.B.I , processor: 
A Increment / decrement value for integrator (1...8) 
Lower level threshold value I X 
U L Upper threshold threshold (= L L +1...32) 
C F A R binary threshold for range cell V . n 
I, •n Accumulator sum for range cell'm'. 
T G T . n Target declared flag for range cell 'n\ 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 1 1 
The RATES Radar System 
3.4.1 T h e W J B X Processor 
The within beam integrator is implemented on two boards, with D l carrying the main 
control and calculation circuits ( F i g . 3.8a). 
WBI Rate Select 
CFAR Rate Select 
Thresholds 
LI, UL 
Comparator Comparator 
> WBI Rate 
Count Prescaler 
> CFAR Rate 
CountPrescaler i 
= 0 WBI Rate 
Clock 
= 0 CFAR Rate 
Clock 
F i g . 3.8a ; Within-Beam Integrator Schematic 
The output from the first threshold processor ( V n ) is used, in conjunction with the range 
cell target declaration from the previous sweep ( T G T n ) , to select the correct value of 
increment or decrement to be applied to the integrator (^AD-A,*!,-!). This is accomplished 
using a 4-line to 1-line by 4-bit wide decoder with its output connected to the adder. The 
resultant signal ( I m ) is compared with upper and lower thresholds and the results of the test 
used to determine the state of the new range cell target declaration which is stored in the latch 
along with the accumulated sum prior to output to the W.B.I , memory. 
The thresholds are read from the control panel in the form of a lower threshold level in 
the range (0...31) and an upper level offset, in the range (1...31), which is added to the lower 
level before presentation to the comparators. The maximum accumulator value is restricted to 
(+63in)> which corresponds to a six bit representation in memory, with the seventh bit holding 
the T G T flag. Additional gating is provided to prevent an accumulated value from either 
exceeding the upper threshold level or going negative, replacing the value presented to the 
latch by the upper level or 0 respectively. 
The first and second threshold outputs are both fed to count pre-scalers on the same 
board, prior to output to the count-and-display circuits of the control panel, enabling the user to 
monitor the binary outputs from the C F A R and W B I processors. Upon reception of a 
north-marker signal from board G l , the outputs of these counters are latched into the display 
decoders and the counters reset in preparation for a new set of target declarations. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .12 
The RATES Radar System 
I T h e WoBX Memory 
As mentioned previously, an important feature of the W.B . I , circuits is a high speed 
memory, which ideally should be capable of a read-modify-write cycle in one range clock 
period. From the values given in T a b l e 3.1, this would call for a complete processing cycle in 
250ns . Whilst not particularly fast by the standards of the mid 1980's, this has evidently-
provided some problems at the time the unit was designed, and to avoid the necessity for a 
large number of high-speed bipolar memories, the circuit has been modified to adopt a less 
demanding read-write cycle. Referring to the schematic of F i g . 3.8b, the mode of operation of 
the W.B.I , memory controller should become clear. 
<n & T G T n 
from processor 
WCK 
WST 
RCK 
03 
<D 
CO 
WSTa r 
WSTb 
CKa 
CKb 
InterScan 
RAMA 
4096 x 7 
RAMA 
Address Counter 
RAM B 
4096 x 7 
RAMB 
Address Counter 
F i g . 3.8b i WJB.I. Memory Schematic 
o 
T3 
CD 
CO "n & T G T n 
to processor 
The circuit uses two banks of dynamic random access memory, each arranged to 
provide a 4096 x 7 bit store and each with its own address counter. Data from the board D l , 
consisting of accumulator values ( I n ) and target declaration flag ( T G T n ) , is applied to the 
inputs of both R A M banks, but only one is enabled for writing on any given range scan. This 
is accomplished by arranging for the In terScan pulse to toggle a flip-flop, the output of which is 
fed to two data selectors, such that on the first range scan (for example) R A M 'A' would be 
selected for reading, with C o u n t e r 'A' being clocked by the pulse R C K . The output from this 
memory would also be selected for transmission to board D l for processing by the W.B.I . At 
the same time, R A M 'B* would be enabled for writing, with the write enable strobe ( W S T ) 
steered to the appropriate pins, and Counter 'B' clock by the pulse W C K 
At the end of a range scan a pulse toggles the flip-flop, and R A M 'B' is now used to read 
out the old accumulator values, with the new values being written to R A M 'A'. 
Although dynamic RAMs are used for the memory, the update rate ensures that no 
special refresh circuits are needed to prevent loss of the memory's contents, thereby saving on 
the control circuits needed for this section. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .13 
The RATES Radar System 
3.5 The Plot Forming Processor 
The plot forming section of the processor is the most complex of the R A T E S functions, 
and is implemented on 5 boards. I t carries out the f inal processing of the signal prior to 
transmission to the filtering and tracking computers, and is therefore responsible for 
reducing the data rate to a level which had be handled by the computer, achieving this by 
reducing the binary targets declarations into a set of polar centre-of-plot coordinates. Four of 
the five boards hold circuitry for performing these calculations, with the fifth acting as a 
temporary store for accumulated coordinates. 
The basic function of this unit is described in the previous chapter, however a 
summary is included here for convenience, using the terminology detailed below: 
^WBI Current W B I azimuth (12 bits) 
Reference range (12 bits) 
08 Reference azimuth (12 bits) 
Current plot width (8 bits) 
m Range moment (3 bits) 
Number of active cells this sweep (3 bits) 
10, Accumulated azimuth moment (15 bits) 
ZR, Accumulated range moment (8 bits) 
EN, Accumulated active cell count (9 bits) 
3 .5.1 Principles off the Plot Forming Operation 
The requirement of the plot forming processor is to establish the likely centre of a plot 
given a set of 'hits', from the within beam integrator, which define a likely plot area in terms 
of range and azimuth. The processor is expected to impose a maximum size on the plot, so as to 
enable it to resolve adjacent targets from what would otherwise appear as a single one. In 
practice, the maximum plot area is based on the targets to be tracked, and since R A T E S is 
intended primarily for monitoring aircraft movements, the individual plot area will tend to 
be small. Considering a typical range/bearing cross-section as shown in F i g u r e 3.9, the 
principle of the plot forming process is described as follows: 
The process is initiated by a logic 1' output from the W.B . I , circuits (cell A on Fig. 
3.9), at which point the range and azimuth of this trigger cell are recorded (the reference 
co-ordinates). A delay is then introduced to allow the cell to ripple to the centre of the plot 
window, which in this example has a depth of three range cells. The central range cell is 
taken as a fulcrum for measuring the range moment of the plot, enabling the processor to 
establish the range with the highest average W.B.I , 'hit' incidence. For a 3-cell deep plot 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 .14 
The HATES Radar System 
window, moments take the values +2, 0 & -2 and hence the central cell does not contribute to 
the weightings at this point. 
Direction of sweep 
Start Azimuth 
A x M 
Plot Depth 
Plot Reference Ce I 
i 
F i g . 3.9 : Example Plot Window 
On the next azimuth bearing a new group of cells are brought into the plot window, 
where they contribute a range moment to the plot as described above. A n azimuth moment is 
also calculated, being equal to the total number of 'active' range cells on that bearing 
multiplied by the distance (in bearing units) from the reference.The azimuth moment, 
number of active cells and range moment are accumulated over successive bearings until 
either the plot width exceeds the maximum permitted value, or there is an absence of W.B.I , 
video in the plot window, at which point the plot is closed and processing passes to the next 
stage of the extractor. The calculations performed on each bearing are summarised below: 
3R - Range moment. 
3 N - Total number of hits on this bearing 
ZNb+1 - Accumulated number of hits 
£Rfo+l - I R ^ + aR - Accumulated range moment 
* w = 0 w b i " 0 e - Current width of plot 
£ 0 b + l - Accumulated bearing moment 
Upon closure of the plot, the three accumulated values detailed above are combined with the 
reference co-ordinates to produce the centre-of-plot co-ordinates: 
0C - £0fo/ZN + 0 e - azimuth centre of plot 
R c ~ £ R t j / £ N R e - range centre of plot 
For the example in Fig. 3.9, the centre of the plot can be calculated to be cell X . 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .15 
The RATES Radar System 
3.5.2 Plot Forming Controller 
The operation of the plot extractor is described in terms of the function of each board, so 
as to give a clearer picture of the way that data is processed. F i g u r e 3.10a depicts the initial 
stage which processes data as it emerges from the within-beam integrator (board E l ) . 
Binary target declarations are passed into the shift-register, which can be set to a width 
of 3 or 5 bits to accomodate different target depths, (this variable does not affect the general 
operation of the extractor and will be assumed to be set to 5). Upon reception of the first logic '1', 
the timing circuits activate the latches to hold the current antenna azimuth (0w][jj) and the 
current range which in turn become the plot's reference co-ordinates (0 e and M e ) . The range 
is derived from the counter on board E l , which receives a range clock from the system timing 
boards, and bearing derived from a separate counter on board G 2 such that it lags behind the 
true antenna azimuth to allow for timing delays in the W B I and C F A R processors. 
After a number of range clock pulses, the initial target declaration has moved to the 
central cell of the shift register, and at this point the adders calculate the total number of 
binary T s in the shift register, and their moment about the central cell. These two "plot 
increments" (8N and SR respectively) are then output to the latches alonside the previously 
stored reference co-ordinates. 
0 wbi 
Comparator 
Range 
Clock' 
WBI 
Video 
Control 
Constants 
Range Counter | n 
Ov 
Latches 
Shift 
Register 
Comparator Circuits 
- O R j 
- £ > I R f 
- O d R 
£>dN 
Plot 
— Extractor 
Timing 
Clocks 
F i g . 3.10a i Plot Forming Controller 
The initial target declaration sets a latch within the timing circuits, such that any further 
W B I 'hits' entering the shift register are unable to initiate a new plot before the first set of 
co-ordinates and plot increments have been sent to the next processing stage (board E 5 ) . This 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 3 .16 
The RATES Radar System 
limits the maximum possible overlap between plots to 2(1) cells for a 5(3) stage shift register. 
At the end of the first scan, the In terScan pulse clears the range counter, and the timing 
circuits ensure that the reference co-ordinate details of the first plot are set up on the data bus, 
along with the total width of the plot (0pW). When a target declaration from the W B I enters the 
shift register, the timing circuits initiate a comparison test between current range and the 
reference K e , and i f they are equal (or within the permitted overlap) a latch is set to prevent 
initiation of a new plot. The adders calculate the new plot increments as usual, and these are 
then passed on to the next procesing stage. 
Formation of the plot is completed when either the incoming W B I video is unable to 
trigger the timing control (i.e. absence of W B I 'hits'), or the plot width (0pW) exceeds a preset 
maximum which is set by a combination of manual offset and radar-type setting. At this 
point, the timing circuits direct the plot-output stages to receive the data, rather than the plot 
re-circulation memory. 
3.5.3 The Plot Forming Memory 
Once a plot has been initiated, the data passes to the second stage on board E 5 ( F i g u r e 
3.10b), which serves as a storage area for the accumulation of plot information. The memory 
consists of a 256 x 56-bit R A M , arranged as two 128 x 56-bit blocks so as to facilitate the 
updating of plots, and permit the processing of up to 128 plots at any given time. A 56-bit data 
bus links the plot-forming memory with the remainder of the processing circuits, and access 
is controlled by the timing on board E l . 
This configuration of R A M allows the processor to read data from the lower 128 words, 
calculate new offsets and then return updated plots to the upper 128 words. At the end of a sweep, 
the roles are reversed and the upper block is used for reading. Additional advantages of this 
mode of operation are the ability to insert new items or delete completed plots without 
disturbing the ordering of the data, simply by adding an extra write pulse or reading an 
additional item. 
Selection of the upper or lower half of memory is performed by a flip-flop, with its 
outputs connected to the most significant input to the address select decoder. The non-inverted 
output is linked with the write counter and the inverted with the read counter, thus ensuring 
that the two counters always address different sections of memory. The flip-flop is toggled to 
the opposite state upon reception of an I n t e r S c a n pulse, which simultaneously resets the two 
address counters, ready for the next sweep. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .17 
The RATES Radar System 
Output Data Select Latch Enable 
Write Clock 
Read Clock 
1 
1 
R e 
1 
® e 
Count I M Write / Read Address t! «—J it  Address Count 
Address Select 
± 
128 x 56-bit 
RAM. 
128 x 56-bit 
RAM. 
56-bit Data Bus 
Fig. 3.10b s Plot Forming Memory 
JZ 
o t 
_ i 
j r 
o 
to 
l ' 
1 
JCZ 
u 
fa 
_ i 
La
tc
h 
La
tc
h 
f 
1 
La
tc
h 
La
tc
h 
I N 
I R c , I 0 c 
Completed 
Plot Data 
I R f l > S 0 e 
From reception of the interscan pulse, the operation can be described as follows: The 
first plot in range is addressed and read out to board E 2 , the read counter then being advanced 
to address the next plot. The plot accumulator on board E 2 handles the updating of the plot and 
the data is then sent back to E 5 to be written into memory immediately after the second plot is 
read by the accumulator. On the trailing edge of the write clock from E l , the write counter is 
incremented to address the next write address, and the unit reverts to read-mode. This process 
continues until all plots have been processed, which is signified by a reference range of 4095 
being output from the plot memory. This value is initially generated by the interscan signal, 
which forces a memory-write cycle at the end of the sweep and thereby prevents the unit from 
processing garbage data from the unused portions of memory. 
If E l initiates a new plot the data is passed back to the memory in exactly the same way 
as an established plot returning from the accumulator, with E l generating the appropriate 
timing signals to insert the new plot into the correct range order in memory. In this situation, 
the read-address counter is not incremented so the next plot in range order is still passed out to 
the accumulator/recirculator. 
If a plot is completed, then the data returns from the accumulator/recirculator as before, 
but no write clock is generated. Instead, the timing circuits generate an output latch clock, 
which latches the data into the output registers. The write address therefore remains 
unchanged and the completed plot is effectively removed from memory. It should be noted at 
this point that the two reference co-ordinates are multiplexed together as are the range & 
azimuth sums - this simplies the next stage of processing on board E 3 . 
T h e A p p l i c a t i o n of D i g i t a l T e c h n i q u e s to a n 
Automat i c R a d a r T r a c k E x t r a c t i o n System. P a g e 3 . 1 8 
The RATES Radar System 
The Plot A^colm!llila^oIt, / Keciipcolator 
The circuits on board E2 (Figure 3.10c) are responsible for the updating of existing plots 
with new increment data OR and dN) and then returning them to the memory on E g . 
[ch
 
La
i 
Ic
h 
La
i 
o 
CO 
I 
u 
CO 
1 
Jf 
0, 
K g . 3.10c : Plot Acciimulator/Recirculator 
Data transfer occurs across the 56-bit wide bi-directional data bus, which links the 
three main stages of the plot-forming circuits, with access controlled by the timing circuits on 
board E l . 
At the start of the sweep (Section 3.5.3), the first plot in range is loaded into the latches 
ready for processing.The reference bearing ( 0 e ) is negated and then added to the current 
bearing ( 0 w b j ) to give the current plot width ( 0 p w ) . The plot increments OH. & 3N), from 
board E l , are then added to the accumulated range moment and active cell counts respectively 
( S K f & SNf) . The incremental azimuth moment is then calculated by multiplying the 
number of active cells on that sweep ON) by the distance from the reference bearing 
and this is then added to the the accumulated azimuth moment (X0f). The new plot data is then 
latched and transferred back to the plot memory as described in the previous section. 
T h e A p p l i c a t i o n o f D ig i ta l T e c h n i q u e s to a n 
Automat ic R a d a r T r a c k E x t r a c t i o n System. P a g e 8 . 1 9 
The RATES Radar System 
3££ The Plot Calculator 
In the final stage of plot forming, the plot calculator (board E 3 and Figure 3.10d) 
evaluates the centre-of-plot co-ordinates from the accumulated sums and the reference data. 
1 o5 
I » 8 
o 
I R . X 0 
8x16 bit 
re Multiplier 
0> CO 
R. 0 
e e 
Plot Output 
Co-ordinates 
Fig. 3J0d : Plot Calculator Schematic 
The PROM is used to calculate the reciprocal of the accumulated active cell count, by 
way of a look-up table, and this value is then applied to the multiplier. The bearing data is 
processed first, and the accumulated bearing moment (1,0) is multiplied by the value IfLN, as 
described in Section 3.5.1.. The output from the multiplier is unsealed, and this feature is 
provided through the data-selector, which selects the outputs from the multiplier to produce a 
correctly scaled fixed-point result. This value is then added to the reference bearing ( 0 e ) to 
give the azimuth centre of plot, which is then latched in the output register. 
Under control from the plot timing, the range value is then processed in an identical 
manner: accumulated range moment (£R) is multiplied by 1/XN, the output is scaled and 
added to reference range ( R e ) and Chen latched in the output register. Further timing signals 
ensure that the final stage of the plot forming processor reads the azimuth co-ordinate before 
the range co-ordinate is latched. 
3SB PlotOutputBufiEer 
The final stage of the plot forming process involves storage of the plot co-ordinates prior 
to their transmission to the filtering and tracking computers and consequently board E 4 is 
essentially a large RAM (1024 x 16 bits) with associated address counters. The output of the 
buffer is fed, under control from the computer interface, across to the SPF computer and to 
T h e A p p l i c a t i o n of Dig i ta l T e c h n i q u e s to a n 
Automat i c R a d a r T r a c k E x t r a c t i o n System. P a g e 3 . 2 0 
The RATES Radar System 
allow for the difference in data rates the RAM is configured as two separate banks, each with 
its own address counter. This circuit therefore emulates a large First-In-First-Out (FIFO) 
buffer, and additional circuits are included to handle events such as buffer overflow and 
data-ready strobe - Figure S.lOe gives the schematic of the complete plot buffer. 
WCK 
Se
le
ct
 
int
ro
l 
WP Se
le
ct
 
int
ro
l 
READ lo
ck
 
fit
 u
O
 
Plot Input 
from E3 
CO 
o 8 
Q.CO 
• f i g — f — > Address Counter L=J L $> Address Counter jU 
1024x16 bit 
RAM 
J 
1024x 16 bit 
RAM 
g 2 o c u_ o O 
Control & 
Handshake to 
to 
oj 
o o 
, • CD 
ut
pu
 
Se
l 
o 
Plot Output 
to Computer 
Fig. 3.1Ge ; Plot Buffer Schematic 
In operation, the two counters are both cleared by the master-reset which is generated by 
the system timing boards. As with the plot-forming memory, a flip-flop selects the bank of 
memory to be used initially for writing and the other bank is selected for read-out of the 
accumulated plot co-ordinates. Plot data is then sent from function E 3 and enters one RAM 
under control of the write clocks, which increment the appropriate counter after each data item 
is written. This process continues until the circuit receives the end-of-octant marker from the 
system timing boards, whereupon the roles of the two memories are reversed, and the output 
handshake control takes over for transfer of data to the computer. 
To transfer data to the computer the Stop flag is firstly removed and, providing there is 
data available for transfer (address counter>0), the Octant Demand flag is set. This signals 
the interface circuits to transmit the header words across the data bus, and then data is 
transferred from the RAM under control of the r e a d pulses. The address counter is 
decremented after each value is transferred, and this process continues until the counter 
reaches a value of zero, at which point the Stop flag is set and the interface circuits terminate 
the data block. This RAM then remains inactive until the next octant trigger. 
If a block of RAM becomes full before the next octant pulse is received, the control 
circuits raise the Inter Octant Demand flag, which stops further plots from being written and 
requests the interface to execute a transfer. If the interface is able to accept this request, data is 
then transferred in a similar manner to a normal octant transfer, except that no header 
information is transmitted. If unable to acknowledge, then an overflow status is indicated to 
the tracking computers, and plots are lost. 
T h e A p p l i c a t i o n of D i g i t a l T e c h n i q u e s to a n 
Automat ic R a d a r T r a c k E x t r a c t i o n Sys tem. Page 3 . 2 1 
The RATES Radar System 
3.® The System Control and Timing Functions 
In order to maintain a degree of synchronisation between the various functions of the 
plot extractor, an essential feature is the provision of global clocks and timing signals from a 
central source. This feature is provided by the two G series boards, one of which handles range 
synchronisation functions whilst the other is concerned with azimuth processing. 
3.6.1 Kange Controller 
Function Gl is responsible for the global timing at range clock level, and therefore all 
the main system clocks are derived from this (the range clock frequency being the highest in 
the system). A 16MHz generator is used to provide the base frequency with 2MHz, 1MHz, 
500KHz and 250KHz being derived directly from this, through use of the divider network [X2]. 
The actual range clocks used in functions A l , B l , B2, C I & D l are derived from this master 
frequency through use of a programmable divider, since their frequency is dependant upon the 
radar type which has been selected by the operator. Programming is achieved through use of a 
PROM which supplies the preset-load value to the counter, depending upon the radar type. The 
output of the counter is synchronised to start with reception of the incoming radar sync, pulse 
(initially buffered in an opto-isolator) and re-timed it to a 1:1 mark:space ratio, before it is 
made available to the functions mentioned above. 
16MHz 
Clock 
Divider X3 
J 
Divider X4 
Radar select 
prom x6 prom x5 
Radar sync 
HE Shift Register Delay Line 
2MHz 
1MHz 
500KHz 
250KHZ 
A1CK 
B1 CK 
B2 CK 
C1 CK 
D1 CK 
SYNC 
l/P ENABLE 
INTERSCAN 
£RCK 
•YCK1 
YCK2 
•D2 WCK 
02 WST 
02RCK 
83 RCK 
S.R. INHIBIT 
Fig. 3.11a s Mange Controller Schematic 
T h e A p p l i c a t i o n of D ig i ta l T e c h n i q u e s to a n 
Automat i c R a d a r T r a c k E x t r a c t i o n Sys tem. P a g e 3 . 2 2 
The RATES Radar System 
A second PROM is used to load a range counter with the number of cells per sweep for 
the selected radar type, and this is then used to time the sweep against the derived radar clock 
pulses. Through use of gating, a further series of range clocks are produced for distribution to 
the functions E l , YS, D2 & B3. These are delayed in order to keep their destination functions 
synchronised with the video passing through them - the greatest delay occurs in the variable 
length shift register on function B l , so the delay line (the shift register array) is programmed 
to take account of this. The shift register also produces signals for Input Enable (to B l ) , 
Interscam, S I S2 & § 3 (to the display driver) and a short range inhibit for the E.C.M. function. 
Also located on board G l is a look-up PROM which decodes the value of M K for use in 
the Within Beam Integrator (Section 3.4). 
3.6.2 Azimuth Controller 
The azimuth controller ensures that the plot extractor is kept in step with the true 
azimuth of the rotating antenna, since this rarely rotates at a fixed speed being susceptible to 
the effects of wind, precipitation and ships-movement. Synchronisation is achieved through 
use of two outputs from the antenna - Aerial North and Aerial Turning Clock (see 3.2), which 
are buffered and retimed before being used. Figure 3.11b shows the schematic of function G2. 
The aerial turning clock is made up from 4096 pulses per revolution, and this is 
initially retimed so that transitions occur on an edge of the 1MHz system clock. Its output is 
then applied to a 12-bit counter, which produces the system azimuth count. To prevent problems 
with the azimuth changing during a sweep, such as may be caused by the antenna 
momentarily changing speed, the output from the counter is passed through a latch, which is 
clocked by the sync signal from board G l , before being transmitted to the rest of the plot 
extractor. The output from the latch is also taken to an adder which subtracts a value 
corresponding to the delay introduced by the W.B.I, circuits. This ensures that the targets 
declared by the within beam integrator are correctly positioned in azimuth. The delay 
approximates to (UL/A) pulse repetition intervals, and can therefore be evaluated as: 
UJLi x 30 angular units, where 30 is the change in bearing after each sweep. 
A 
One PROM is used to evaluate (UL/A) and a second to provide the increment (30) 
which depends on the radar type selected- these are then applied to a multiplier and inverter to 
give the correct value for addition (i.e. subtraction) to the antenna bearing. 
T h e App l i ca t ion of D i g i t a l T e c h n i q u e s to a n 
A u t o m a t i c R a d a r T r a c k E x t r a c t i o n System. P a g e 3 . 2 3 
The BATES Radar System 
The true antenna bearing is partially decoded to provide the octant trigger, which 
occurs 11.25° after the octant boundary, making the computerised tracking of targets easier in 
the areas surrounding the octant boundaries. The octant value is similarly extracted at this 
point, and is delayed by one octant plus 11.25° to simplify the tracking software. 
Reset MR 
reset MR Timing 
iion n rth 
o Aenau North north 
CO > Azimuth Clock Aerial Turning Octant F CO 
cb 
i 1 0> r Octant Latch 4£T Sync Trigger 
1MHz Clock 0 Aerial 
Radar Select is. 01 
CD 
0 wbi 
UL Oftset 
Fig. 3.11b : Azimuth Controller 
The north marker signal is buffered and retimed to coincide with a falling edge of the 
aerial turning clock, and its output transmitted to the rest of the system. It is also used to reset 
the azimuth counter, so that bearing is synchronised with the north marker signal. 
The azimuth controller also holds the circuit for the master reset, which is capable of 
being generated both at power-on and by way of a switch on the system control panel. The reset 
function is simply a monostable which ensures that adequate timing ( 2.5us) is allowed for a 
complete reset. 
T h e Appl i ca t ion off D ig i ta l T e c h n i q u e s to a n 
Automat ic R a d a r T r a c k E x t r a c t i o n System. Page 3 . 2 4 
The RATES Radar System 
3.7 Tfe© Interface to the Computer 
This section makes up the link between the plot extractor hardware and the tracking 
computers, and in practice is divided into 2 parts - one based in the extractor itself and the 
other in the base of one of the computers. The section based in the extractor is made up from 
four F-series boards while that in the computer consists of five H series boards; both are 
necessarily complex - a requirement of the interface standard which applies to the link to the 
computer, even though the information content and features they provide are quite limited. 
3.7 J. Component Sections of the Interface 
For clarity, the following conventions will be observed in the description of the 
interface. The Computer Interface is made up from the four F-series functions and controls 
the link from the plot extractor hardware across to the computer. The Plot Extractor Interface 
consists of five H series boards and is responsible for the link from the computer's ME62 DMA 
highway to the level of the computer interface. 
The sections communicate across a 25-bit bus, using the signals defined in F igure 
3.12a, the Computer Interface using those in Fig. 3.12b to control access to the plot extractor. 
Note that in the context of the interface controllers, the word output implies a signal sent from 
the computer, while input describes one transmitted to the computer. 
IP Block Demanded 
P.E. Reply 
Output Enable 
P.E! Input Request 
P.E. Output Request 
P.E. Output Block Demand 
Abort Output Block (P.E.) 
= Input Enable (P.E.) — 
Data Bus + Parity 
Fig. 3.12a s 
F-series <-> H-series 
Interface Connections 
Fig. 3.12b : 
F-series to Plot 
Extractor Wiring 
Octant Demand 
Interoctant demand —= 
Stop - = 
Read Rollball word 1 
Read Rollball word 2 
- Read ECM 
Read Ships Motion -
Read Multiple Plots -
Write CFAR Thresholds — 
Write Synthetics words 
Write Test Target Co-ordinates 
Input Data Bus 
Output Data Bus 
CD 
•s 
a. 
E 
In addition to the control signals which cross the link between computer (F) and plot 
extractor (H) interface, a 17-bit wide bi-directional data bus is also to be found, permitting 
16-bit data plus single bit parity transfer. The entire physical link is established using 
twisted-pair cable with suitable line drivers located in the F and H functions. 
T h e Appl i ca t ion o f D i g i t a l T e c h n i q u e s to a n 
Automat ic R a d a r T r a c k E x t r a c t i o n System. P a g e 3 .-25 
The RATES Radar System 
17J2 Operation of the Computer Interface 
Plot co-ordinates are generated by the plot-forming processor, as described in Section 
3.5.5, until either the end of an octant is reached or the plot buffer is full, whereupon the Octant 
Demand flag is raised causing the computer interface to set the Input Block Demanded line. 
The plot extractor interface replies by setting P / E Input Request, causing a status word to be 
read from the extractor. P / E Reply is then set by the computer interface and this latches the 
word into the Plot Extractor Interface buffer. 
The process of: 
P/E Input Request —> P/E Reply 
is repeated, reading more status information words followed by the accumulated plot 
co-ordinates until function E 4 raises Plot Buffer Empty, whereupon P / E Input Block 
Demanded is reset by the computer interface. The exact format of this block is shown in Table 
3.2a. If the transfer was initiated by the plot buffer becoming full during an octant, the status 
words are not transmitted and the format follows that shown in Table 3.2b. 
word data 
0 Data word count (max 1031) 
1 Octant Identifier (id bits 0-2, Octant transfer bit 7) 
2 Radar I.D. (bits 0-2 type, 3-4 C-Range 
5-6 C-Scale, 7-8 Display Mag) 
3 Roll ball X 
4 Roll ball Y 
5 ECM region 1 (bits 0-9 angle, 10-15 width) 
6 ECM region 2 ( " ) 
7 Ships Motion (bits 0-9 heading, 10-15 speed) 
8 1st Plot range 
9 1st Plot bearing 
10 2nd Plot range 
11 2nd Plot bearing 
3.3a 
word data 
0 Data word count (max 1025) 
1 Octant Identifier (id bits 0-2, Octant transfer bit 7) 
2 1st Plot range 
3 1st Plot bearing 
4 2nd Plot range 
5 2nd Plot bearing 
1025 
3.3b 
Table 3.2 
Octant Ifp Block Format (a) 
Interoctant J/p Block Format (b) 
Transfer of an input block from computer interface to plot extractor interface is usually 
followed by an output block transfer in the opposite direction. A similar method of 
handshaking is employed to perform this function, with data using the format in Table 3.3. 
The Plot Extractor Interface starts by setting P / E Output Block Demand to which the 
Computer Interface replies with Output Enable. The data is then transferred by the sequence: 
(Sutput Request sel) • g> Q Data Latched ^ 
x„( 
(Output Request clr) <0 ^ PE Raply ) 
T h e Appl i ca t ion of D ig i ta l Techn iques to a n 
Automat ic R a d a r T r a c k E x t r a c t i o n System. P a g e 3 . 2 6 
The MATES Radar System 
The first three words are stored in latches but the remainder are stored in a 1024x16-bit 
RAM in the computer interface because of the need to distribute the data amongst several 
functions during the present time period. 
word data 
0 Word count (maximum 1027) 
1 Number ol synthetics marker words (max. 512) 
2 Number ol first threshold values (max. 506) 
3 Octant identifier (bits 0-2) 
4 1st Test Target range (bits 0-11) 
5 1st Test Target bearing 
6 2nd Test Target range 
7 2nd Test Target bearing 
8 3rd Test Target range 
9 3rd Test Target bearing 
10 1st Synthetics Marker word 1 (bits 0-9 range, 10-15 character code) 
11 1st Synthetics Marker word 2 (bits 0-11 bearing) 
12 2nd Synthetics Marker word 1 
13 2nd Synthetics Marker word 2 
522 1st Threshold value (bits 0-6 data, 7-15 address) 
523 2nd Threshold value 
Table 3,3 : Output Block Format 
The 506 CFAR thresholds are transferred in bursts of 32 words during interscan, 
synthetic markers in 8 bursts of 64 words during scan and test target co-ordinates in a single 
burst of 6 words. Control of this distribution is handled by the Computer Interface itself. 
At the other end of the link, the Plot Extractor communicates with the computer using 
the resources of the ME62 Direct Memory Access (DMA) highway. Control signals for this 
connection are shown in Figure 3.13. 
(0 t a> 
as 
5 
o 
a. 
• 3-Bit 
• Control 
• Bus 
•LWRITE • 
• LRDR 
• LDEM 
•LBUSY 
Address Bus 
= Data Bus"= 
Q. 
£ 
<D 
O 
CD 
Fig. 3.13 ; ME62 Interface Connections 
T h e Appl i ca t ion of D ig i ta l T e c h n i q u e s to a n 
Automat i c R a d a r T r a c k E x t r a c t i o n System. P a g e 3 . 2 7 
T h e RATES.Madaip S y s t e m 
3.7M Operation of the Plot Extractor Interface 
Data flow for this part of the interface is under complete control of the computer which 
transmits control words across the 3-bit control bus. All transfers begin with an I n i t i a l i s a t i on 
sequence which resets the Plot Extractor Interface to a known state before an Input or Output 
transfer can take place. A t the end of the transfer the link is cleared ready for the next 
initialisation sequence to take place. 
Ini t ia l isat ion 
For a transfer to take place the computer must write either a Go-Input or Go-Output 
control word which signals the Plot Extractor Interface to set either I n p u t Enable or Ou tpu t 
Block Demanded if a transfer is not already in progress. 
Once this has been acknowledged, a start address is set up on the address highway, 
using hard-wired values in the Plot Extractor Interface, and L D E M is activated. The ME62 
replies with L B U S Y and then L R D R which clocks the address into a separate buffer in the Plot 
Extractor Interface and also into a start address store and address counter. L R D R and L B U S Y 
are then resetin turn and the initialisation sequence is complete. 
Output Transfer 
Following the initialisation sequence, the Plot Extractor Interface sends the start 
address to the ME62 once more and the computer replies with the word count for the impending 
data transfer. L R D R this time latches the count into a word counter. 
Words are then transferred one at a time to the Plot Extractor Interface using the 
L R D R / L B U S Y latch sequence. After each transfer the data is passed on to the Computer 
Interface using the P /E Output Request / P/E Reply sequence and the word counter is 
decremented. This continues until the counter reaches zero whereupon the Interface proceeds to 
the Link-Reset routine. 
Input Iransfer 
After the initialisation sequence, the Interface sets the P /E Input Request line to the 
Computer Interface, which replies with a pulse on P /E Reply and valid data on the highway. 
The pulse clears the Input Request line and simultaneously latches the data into a buffer, at 
which point the address counter in the Plot Extractor Interface is incremented so that it now 
accesses the appropriate storage location in the computer's memory. By setting L W R I T E and 
then L D E M (which the ME62 responds to through L B U S Y ) , the data is then transferred from the 
latch into the memory, ready for the next word transfer. The process continues until all data 
has been transferred, whereupon the Plot Extractor Interface clears PE Input Block Demanded, 
a signal for the Computer Interface to transmit the final data item, a word count, which is 
stored in the first location of the input data block (the actual data starts at the address following 
the word count). 
T h e App l i ca t ion of D ig i ta l T e c h n i q u e s to a n 
A u t o m a t i c R a d a r T r a c k E x t r a c t i o n Sys tem. P a g e S . 2 8 
The RATES Radar System 
Interface Reset 
In the final sequence of a data transfer, the Plot Extractor Interface activates L W R I T E 
and L . B E M so as to write a status word to a preset location in the computer's memory. The word 
contains details of the previous transfer, coded in the following format (condition true if bit set 
to logic T ) : 
Bit 0: Last transfer was an input block 
1: Last transfer was an output block 
3: Parity error detected in output block; block discarded by Interface 
4: Parity error detected between P/E hardware and Plot Extractor Interface 
5: Parity error in Start Address (Initialisation sequence); no data transferred 
After completion of this sequence of events the Interface is ready for a further data transfer, 
under control of the host computer. 
As with other sections, a brief description now follows concerning the hardware 
operation of each board, with the exception of the line drivers which are identical for both F and 
H functions. The details therefore commence with the most important function in the 
Computer Interface section: board F4. 
3.7-4 The Sequence Controller 
The heart of the Computer Interface is the sequence controller, which is responsible for 
generating the appropriate read and write signals to access both the plot extractor hardware 
and the bus linking to the Plot Extractor Interface. The schematic of this function is shown in 
Figure 3.14a and can be seen to consist primarily of a pair of 4-bit counters, which are activated 
following reception of either P E Input Request or P E Output Request from the Plot Extractor 
Interface. 
In operation, the circuit is initialised by either Octant Marker or Plot Buffer Ful l (input 
request), or P E Output Block Demanded (output request), which starts the operation of counter 
A. The output of the counter is taken to a decoder which produces the reply signal Input Block 
Demanded (input block) or Output Enable (output block), and counter B is then incremented. 
For an input block, a count of 1 in A activates counter B's decoder which enables the 
octant data onto the bus, while an output block results in a signal to F 2 to latch the "No. of 
synthetics words" value into memory. Counter A then reaches a value of 2, which produces a 
pulse on the P / E Reply line. At a count of 3, counter B is disabled and a count of 4 causes A to be 
reset back to zero in readiness for the next initialisation (as above). 
T h e A p p l i c a t i o n of D ig i ta l T e c h n i q u e s to a n 
Automat i c R a d a r T r a c k E x t r a c t i o n Sys tem. P a g e 3 . 2 9 
The RATES Radar System 
Upon receipt of the next P / E I n p u t Bequest or P / E Ou tpu t Request, the sequencer is 
activated as described above, but counter B is now incremented to a value of 2 which enables 
other data onto the input bus, or reads the "No. of threshold words" from the output bus. 
Subsequent requests read or write other data items, by activating different control lines 
dependant on the value in counter B . 
Plot Buffer Full 
1MHZ Clock-
PE Output Request 
PE Input Request 
PE Opt Block Demand-
Plot Buffer Empty-
Synchro Busy 1 
Synchro Busy 2= 
Master Reset' 
P/E Reph 
System Constant 
Word" 
Octant-
Octant Marker-
Counter 'B Counter A 
Decoder Decoder 
£ > Input & Output 
Control Signals 
OData to Bus 
Fig. 3.14a : Sequence Controller Schematic 
8.7.5 Output Data Storage 
The sequence controller ensures that the correct control signals are generated to enable 
data to be read directly from the plot extractor hardware onto the input data bus, but transfer of 
output data has to be carried out in specific time periods, and it is therefore necessary to install 
a buffer between the bus and the hardware. Function F2 provides this feature under control of 
the sequencer on F4, and its schematic is shown in Figure 3.14b. The memory provides 1024 x 
16-bits of storage and is capable of storing the maximum of 506 threshold values in addition to 
the 512 synthetics marker words and 6 test-target words. 
In operation, the sequence controller ensures that the incoming data words are 
distributed appropriately: the "No. of synthetics marker words" is loaded into S Counter, "No. 
of threshold values" into the C Counter, "Octant identifier" into the octant latch and subsequent 
data words into the memory. The RAM is addressed by the Address Counter which is 
incremented after each word is written to memory, until all values have been read from the 
data bus. 
Once transfer of the output block is complete, a comparator detects that the Address 
Counter has a value equal to the sum of "No. synthetics marker words" (S), "No. of threshold 
values" (C) and binary 5. This produces an output which instructs the sequencers on function 
T h e A p p l i c a t i o n of D i g i t a l Techn iques to a n 
A u t o m a t i c R a d a r T r a c k E x t r a c t i o n Sys tem. Page 3 . 3 0 
The HATES Radar System 
F 8 to start re-distributing the data amongst the plot extractor hardware functions. As data is 
read from the memory onto the hardware bus, the Address Counter is decremented, producing 
comparator outputs at values of and (5) until a value of zero is reached. These outputs are 
redirected to function F3 where they are used to control the destination of the data. 
coS*S=t A d d r a s s C o u<£] 
RAM Set 
RAM Write 
Data from 
CPU Bus 
Clock C 
Clock S 
hardwired binaryjff +5 Equal 
C+S+5 Equal 
S+5 Equal 
J 1 
1024 x 16-bit RAM 
g 1 rLComp 
Data to Plot Extractor 
Hardware 
Fig. 314b : Output Data Storage Function 
3.7.0 Output Bus Control 
The third main function of the Computer Interface is responsible for re-distribution of 
data from the memory on board F 2 to the plot extractor hardware. Like F4 , the controller is 
essentially a sequencer producing timing signals for latching data into appropriate 
destinations, and its schematic is shown in Figure 3.14c. 
As mentioned in Section 3.7.5, this section is triggered by the final data word being 
read into the memory on board F2, whereupon the control circuits are enabled, ready to transfer 
the threshold words to the CFAR memory. As this transfer can only take place during 
interscan periods, the control circuits are configured to enable the Threshold Burst Counter 
only when InterScan is true and thus data is moved in a maximum of 16 blocks of 32 words 
each. 
When S+5 is activated by function F 2 , the control directs the data to the synthetics 
memory in the display driver. On this occasion, the transfer can only occur during scan 
periods, so the Synthetics Burst Counter is only enabled when InterScan is false and this takes 
8 scan periods to transfer the 512 words to memory. 
Following receipt of -s-5 from F 2 , the control directs the final 6 words to the Test Target 
generator, in a single block. The control circuits are then ready to process the next output data 
block from the computer. 
T h e A p p l i c a t i o n o f Dig i ta l T e c h n i q u e s to a n 
Automat i c R a d a r T r a c k E x t r a c t i o n System. P a g e 3 . 3 1 
The RATES Radar System 
Function F3 also holds the circuits for checking the parity of data which passes across 
the bus, using a standard ODD-parity generator and checker. In the event of a parity failure, 
an indicator is illuminated on the operator's console and a signal sent to the computer to 
communicate the error. 
Computer Data Bus 
1 111 1 I J I J J L J J J i J L i 
500KHz= 
250KH* 
InterScan' 
+5 Equal 
S+5 Equal 
C+S+5 Equal-
Scanner 1 
Scanner 2-
Unbuffered 
Inputs 
Parity Check 
Parity Error 
>Thresh. Counter 
Counter 
Parity Fail 
•Write Threshold 
•Write Synthetics 
•Write Test Target 
RAM S 
RAM W 
Count up 
Count down 
Clock C 
lock S 
l/P Block Demand 
Output Enable 
PE Reply 
PE Input Request 
PE Output Request 
PE O/P Block Demanded 
•Abort Output Block 
Fig. 3.14c ; Output Bus Control Schematic 
It should be noted that the buffers on F l provide for the data bus, while those on F 3 
provide isolation for the control signals transmitted to and from the Plot Extractor Interface. 
3.7.7 The Plot Extractor Sequence Controller 
Function H I in the Plot Extractor Interface performs in the same manner as the 
Computer Interface sequence controller (F4), but controls the link between the Interface data 
bus and the computer's own ME62 interface. It's basic operation sequence has already been 
described in Section 3.7.3, and the schematic of this circuit is illustrated in Figure 8.15a. 
Function H I is controlled from a 4-bit counter which has its outputs decoded to 8 possible 
operations: 
1 Resets the control circuits to a known state 
2 Sets P /E Input Request (for an input block) 
3 Clocks the address counter on H3 (for an input block) 
4 Sets "Data Valid" on H2 and H3 
5 Activates signal I D E M to ME62 bus 
6 Clocks the address counter on H8 (for an output block) 
7 Sets P/E Output Request (for an output block) 
8 Resets the sequencer 
T h e App l i ca t ion of D ig i ta l T e c h n i q u e s to am 
Automat ic R a d a r T r a c k E x t r a c t i o n Sys tem. P a g e 3 . 3 2 
The RATES Radar System 
The counter is triggered by either "Go-Input" or "Go-Output" from the computer and 
then counts at 2MHz through the sequence given above. 
CCO— 
C C 1 = 
CC2— 
CCS3 
RDR-
P/E Reply-
BUSY= 
Output Enable-
Input Block Demand- 1 
o 
o 
08 
<b 
Counter 
^ 
Sequence Decoder 
-Enable Status 
interrupt 
-Reset 
-Enable Input 
=P/E Input Request 
' Demand 
= = P / E Output Request 
Write 
—=Load Address Counter 
=Data Valid 
Fig. 3J5a 5 Plot Extractor Sequence Controller 
8.7.8 Data Multiplexer 
The Data Multiplexer schematic is shown in Figure 3.15b, and this function is held on 
board H2 of the Plot Extractor Interface. Its primary function is to multiplex data onto or off the 
ME62 data bus: Input blocks from the Computer Interface are checked for correct parity, and the 
value of the parity flag transferred to the computer, as part of the status word, at the end of the 
block. The value of the word counter is also transferred to the computer, just before the status 
word. 
Panty Gen. 
Input Data Irom ME62 Data Bus 
o 
CO 
P ot Extractor 
1A Latch 
Control Input 
— W o r d Counter 
«5 
Output Data to 
Plot Extractor 
Panty Gen. 
Fig. 8.15b s Data Multiplexer Schematic 
For an output block, the data is first loaded into the latch under control of L R D R , and 
then on to the bus leading to the Computer Interface. Its parity is checked against that provided 
T h e A p p l i c a t i o n off D ig i ta l T e c h n i q u e s to an 
Automat ic R a d a r T r a c k E x t r a c t i o n System. Page 3 . 33 
The RATES Radar System 
by the ME62, and a single parity bit passed on to the Computer Interface. In the event of a parity 
failure, the appropriate signal (Read Stent Address Fail or Abort Output Block) is generated by 
the circuits on this board. The output block also carries the word count from the computer, and 
this is loaded into the Word Counter where it is decremented after each output word transfer. 
173 Address Generator 
This function (H3) generates both hardwired and incrementing addresses for output to 
the ME62 address bus. Its schematic is shown in Figure 3.15c, and its operation can be 
described as follows: 
The Address Counter is loaded from the data bus following an Output Data sequence, 
and this is then incremented during each word transfer to point to the next output word in 
computer memory. 
For input transfers, the board also holds the Start Address latch, which stores the 
memory address of the first input word (for use end the end of the transfer to store the word 
count). Hardwired addresses are presented to the address bus through additional buffers, and 
include the Input Start Address, the Output Start Address and the Status Word Address. 
Load Counter • 
Clock Counter — 
Data (rom Plot-
Extractor 
Load Status • 
Output Initialise • 
Block Initialise -
Data valid -
o 
O 
01 
K— 
"D 
< 
Output 
Address 
Init. 
Address 
IStart Addr. Latch 
^ 
Output toME62 
Address Bus 
Stat Addr 
Fig. 3.15c s Address Generator Schematic 
3.7.10 Control Interface 
Function H4 of the Plot Extractor Interface provides the interfacing circuits for the 
control signals of the ME62 bus. All signals are tied to +5 Volts, through pull-up resistors, and 
those which are used for control of the Plot Extractor Interface are buffered prior to 
re-distribution amongst the other functions. As this function is relatively simple, its 
schematic has not been shown. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .34 
The HATES Hadar System 
3,8 The Hecfcronic Counter Measures Detector 
Part of the RATES specification includes a requirement for some means of detecting 
the occurence of electronic counter measures (ECM) operation. In general, ECM manifests 
itself as a large area of a particularly high clutter level, and has the effect of masking 
anything which occurs at a greater range from the radar. The detection approach adopted for 
the RATES system looks for a high clutter output from the CFAR detector, which is sustained 
for a certain beamwidth and it produces co-ordinate details of this activity for transfer to the 
tracking computers. The schematic of function C I is shown in Figure 3.16, and its operation 
can be described as follows: 
The pre-range CFAR average, calculated on board B l is taken by the ECM detector and 
compared with a level threshold which is set manually from the control panel. For every 
range cell where the background average exceeds the preset value, the Down Counter is 
decremented by 1 until it either reaches zero, or InterScan is activated. Once the end of the 
sweep occurs, the Range Cell Threshold is re-loaded into the counter, ready for the next sweep. 
If the counter has reached a state of zero before the end of the sweep, the shift register 
loads a value of 1 from the left, otherwise a value of zero is loaded from the right. The 4-bit 
output of this device is masked with the Spoke Threshold and ECM activity declared if detected 
on 2, 3 or 4 successive sweeps. Once declared it remains active until a corresponding number 
of 'clear' sweeps have been detected. 
Range Cell Threshold 
Background Average 
Threshold 
Background Average' 
Input 
Clock-
InterScan' 
Spoke Threshold-
Bearing Input 
Comparator Down Counter 
Sector Width 
Output 
Sector Bearing 
Output 
Fig. 3.16 : The ECM Detector 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 . 35 
The RATES Radar System 
Initial detection of ECM latches the antenna bearing into registers, and this is 
subtracted from the current azimuth to give the width of the ECM sector. A second adder sums 
the opening and current azimuths, then divides by 2 to give the central azimuth for the sector. 
Once the sector is closed (either by close of activity, or a width of 11.25° being detected), the 
sector width and central bearing are loaded into the 64 by 16-bit FIFO buffer, to await transfer to 
the Computer Interface. 
Although straightforward, this circuit provides the operator with the ability to detect the 
most common forms of electronic counter measures, such as may be generated by dispersed 
chaff, or a high amplitude transmission. It is not intended to discuss the ECM capabilities 
further, as there was no specified requirement for enhancements to the ECM detectors and no 
satisfactory means of testing existed. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 .36 
The HATES Radar System 
3.9 The Display Driver 
The display driver is included both for testing purposes and because the target system 
would probably require some form of local monitoring, even though not detailed in the original 
specification, and a detailed description of this function now follows. 
8.9.1 Display Drives- Options and Capabilities 
The driver is designed to interface directly to the Hewlett Packard model HP1321A 
vector-graphic display, with the addition of TTL Blanking, 4-bit Z-Modulation and Long 
Persistance Phosphor options. It will, however, interface to other displays, with minor 
modifications to the original circuit (see section 4.2.1). This display requires the following 
input characteristics: 
X-Deflection : 1.5V max. into 50£2 
Y-Deflection : 1.5V max. into 50CI 
Z-Modulation: analogue IV max. into 50Q 
digital 4-bit binary, standard TTL levels. 
With this type of display, the driver can operate in any one of four modes (Table 8.4) 
with each mode displaying three separate overlays. This is done by dividing each pulse 
repetition interval into 3 distinct display phases, and allowing the operator to have a degree of 
control over what is shown in each phase. The operator is also given control over the intensity 
of each display phase, to enable comparison of the video signals resulting from each section of 
the extractor and the whole display may be magnified by 1, 2 or 4 times if required. 
Mode Rea-time Sweep Flyback Sweep Flyback Vectored 
A Raw video Compressed CFAR Synthetics video 
B Raw video Compressed WBI Synthetics video 
C CFAR video Compressed WBI Synthetics video 
D WBI video Compressed CFAR Synthetics video 
Table 3.4 s Permitted Display Modes 
The video inputs to the display section are as follows: 
1 Analogue video (from Al), 0-1V into 75Q. Up to 5MHz bandwidth. 
2 CFAR video (from B2). Bit-serial data, up to 4096 bits per p.r.i. plus strobe. 
3 WBI video (from Dl). Bit-serial data as for CFAR. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .37 
The RATES Radar System 
The driver is also capable of generating the synthetics marker characters shown in 
Table 8.5, from co-ordinates and character codes supplied by the tracking computer. The 
co-ordinates are supplied as two words, of which the first carries the 12-bit azimuth and second 
the 10-bit range and 6-bit character code. The Rollball Marker, however, is generated directly 
by the hardware which decodes the rollball inputs, and is always the last synthetic character to 
be drawn. 
Tentative Track 0 © 
Confirmed Track 1 
Plot 2 SB 
Rollball Marker 3 
SPF Entry 4 
ECM Azimuth 5 m 
Numbers 0-9 6...15 
Test Target Expected Position 17 > 
Unsmoothed Plot 18 
Friendly Airborne Target 22 
Unidentified Airborne Target 23 
Enemy Airborne Target 24 
Friendly Submerged Target 25 \J 
Unidentified Submerged Target 26 
Enemy Submerged Target 27 
Table 3.5: Synthetic Marker Characters 
The display of each type of video is marked by a synchronisation signal generated on 
board Gl , such that SI indicates the start of the analogue video, S2 the CFAR video and S3 the 
WBI video. At the start of the first display phase, one of these video signals is directed to 
modulate the Z-axis of the display while the real-time sweep generator produces a ramp voltage 
which is decoded into X and Y co-ordinates to drive the display deflection circuits. During this 
phase, synthetics marker information is loaded into a RAM from the computer, ready for 
display during phase 3, and binary video for the second display phase is logically "OR-ed" in 
groups to compress it, then stored in another block of memory. 
In the next display phase, the compressed data is read from RAM and used to modulate 
the display Z-axis while a sweep-generator produces a high speed range ramp to drive the 
display deflection. 
The final display phase reads co-ordinates from the synthetics RAM, and these are 
selected as direct input to the polar-to-rectangular convertor for subsequent output to the display 
as starting co-ordinates for the markers. The markers are generated from vectors provided by 
a look-up PROM, and these are combined with the current position of the cursor to draw the 
required symbols. 
The intensity of the each display phase is controlled by a separate digital modulation 
input to the display and a different control is activated for each individual phase. Additional 
protection against phosphor burning is provided by blanking the first 128 (programmable) 
range cells. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .38 
The RATES Radar System 
3.0.2 The X- and Y-Bisplay Interfaces 
The X and Y display drivers employ essentially the same techniques to provide the 
analogue signals for driving the P.P.I, display, and their combined schematic is shown in 
Figure 3.17a. In practice, the two boards are realised as functions Y l and Y2, and constructed 
on custom printed-circuit boards to reduce high-frequency effects. 
Integrator reset Integrator reset 
I 
o 
J2 
1 
— i CD 
O CO 
H IP H IP CO 
Display Y Display X 
Lo Lo 
L z r 
Video Select 
x4 Processed Video 
Raw Video <B 
1 as IP (0 
Z-Mod 
Fig. 3.17a i The X (left) and Y Display Drivers 
Range information is input as a 10-bit digital signal, where it then passes into a D/A 
converter with a current output. The current is amplified in the operational-amplifier which 
follows it and is output as a voltage. The gain in this stage is determined by the settings of the 
two switchable feedback resistors connected to the op-amp and allows the range output voltage to 
be divided by one, two or four to give X4, X2 and XI magnification. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .39 
The RATES Radar System 
The X and Y deflection voltages are derived from polar co-ordinates using the 
expressions: 
XsR*sin(0) Y E = R * C O S ( 0 ) 
where R is the range and 0 is the azimuth. The values of s in(0) and eos(0) are derived from 
function Y4 and input to Y l and Y2 respectively as 10-bit +sign words, where they are converted 
in a pair of multiplying digital/analogue converters to current outputs. The other input to the 
DACs is the range voltage derived from the circuit described above, and hence the outputs 
correspond to true X and Y co-ordinates. 
These functions also convert the stroke signals from the synthetics marker PROMs on 
Y5 into analogue voltages which can be combined with the deflection signals. Stroke inputs are 
4-bit plus sign, enabling a wide range of characters to be drawn, and are already formatted as 
X and Y increments. They are presented to 5-bit D/A convertors which convert them to 
currents, to be used as inputs to integrating operational amplifiers. The stroke signal for 
drawing each marker is therefore derived by zeroing the integrators, then summing the 
vectors which are output from Y5. The outputs from the integrators are combined with the 
outputs from the multiplying DACs in op-amps and then buffered in 50Q. driver amplifiers 
prior to transfer to the P.P.I, display. 
Function Y2 also includes the Z-modulation buffer which takes input from one of three 
sources: raw analogue video, processed binary video or blanking signal, under control of a 
video-select signal on function Y7. The raw video is buffered in a unity-gain op-amp prior to 
selection and the desired output is then buffered in a 50Q driver before output to the display. 
All devices used in these functions are designed for high-speed operation to give the 
necessary response to binary deflection signals. Typical slew rate for the op-amps is in the 
order of 350V/us (as compared to 0.5V/|J.s for standard devices) giving a frequency response of 
d.c to 400MHz. 
8.9.3 The Rollball Integrator 
Function Y3 contains the circuits for processing the data transmitted from the tracker 
ball, which consists of phase and quadrature signals for each of X and Y directions. The 
particular tracker ball in use on the RATES system generates 512 pulses per revolution from 
each of its outputs, and this must be integrated to establish the desired co-ordinates (Figure 
3.17b). All inputs are divided by two in pre-scalers, then the phase input is used to decrement an 
11-bit counter, while the quadrature input increments the counter. No end-stops are imposed, so 
the marker will appear to travel off the bottom of the screen and re-emerge at the top. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 . 40 
The HATES Radar System 
The X and Y counter outputs are passed to the computer interface through latches and 
also taken to data selectors which are under control of function Y7. The other inputs to the 
selectors are the values of sin(0) and cog(0), scaled to allow direct output to functions Y l & Y2. 
Phase 
Rollball X 
Quadrature = 
SIN0< 
Rollball 
Enable ' 
COS 0> 
Phase 
Rollball Y 
Quadrature — 
c Rollball X Counter 
V 
Rollball 
Y Counter • 
Rollball 
3 Co-ordinates 
to Computer 
'STN0 
>COS0 
Fig. 3.17b : The Rollball Integrator 
3.9.4 The Sine/Cosine Converter 
The co-ordinate system used throughout the plot extractor is polar, however this is 
unsuitable for the output devices which rely on Cartesian deflection co-ordinates. Function Y4 
is therefore included to convert azimuth information to a more suitable format, and its 
schematic is shown in Figure 3.17c. 
Antenna= 
Bearing 
WBI<= 
Azimuth 
Synthet ics= 
Azimuth 
Enable Synth. 
Enable WBI 
o 
T5 
oo_2> 
~ L CD 
9 cn 
~"~ ra 
c5 
o 
CO 
3E 
o 
cc 
a. 
o 
Fig. 3.17c : Sine/Cosine Converter 
>SIN0 
c 
CO 
•COS0 
The conversion to sin(0) and cos(0) is carried out using look-up PROMs which effect 
a single quadrant conversion, with sign control provided by additional gating. The 12-bit 
input is derived from either the real-time azimuth counter or delayed W.B.I, azimuth outputs 
on G2, or from the RAM holding the synthetics marker co-ordinates on function Y5. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .41 
The HATES Radar System 
3J9L5 The Synthetic Marker Generator 
Function Y5, shown in schematic in Figure 3.17d, provides storage for the synthetic 
marker co-ordinates which are generated by the tracking computers. Two words are required 
for each marker, using the format described in Table 3.3, and the RAM is arranged to hold a 
maximum of 512 such words. Data is written during the scan period under control of function 
F3, and read out again during display phase 3. As each pair of words is read from the memory, 
the range data is fed to the data selectors on function Y0 and the azimuth data to the sine/cosine 
convertor on Y4. 
Synthetics 
Data from 
Computer 
Write 
Synthetics 
Write 
Character 
Read 
Character 
Vector 
Clock 
512 x 16-bit RAM 
Counter 
Synthetics 
Bearing 
Synthetics 
Range 
X-Vector 
Y-Veclor 
Fig. 3JL7d i The Synthetics Generator 
The character code, from the RAM, is fed into the X and Y synthetics PROMs where it is 
used to select one of the 32 markers using the upper 5 bits of each PROM's address bus. The 
lower 5 bits are connected to a counter which then steps sequentially through from 0 to 31, 
allowing a total of 32 movements to generate each synthetic marker. The outputs from the 
PROMs consist of 5-bits of vector information, which are fed directly to the X and Y display 
interfaces, a binary Z-modulation signal and a stop signal which simultaneously stops the 
stroke counter, resets the integrators on functions Y l and Y2 and increments the marker 
address counter to point to the next synthetic marker in RAM. 
In operation, not all of the markers are displayed during a single instance of phase 3, 
so the generation of markers is suspended until the next occurrence of phase 3. Once all 256 
markers have been displayed, the address counter is incremented and points back at the first 
marker, ready to cycle through the sequence again. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .42 
The HATES Radar System 
3.9.6 The Range Controller 
A special function is necessary to establish range control for the display interface 
because of the requirement for a full resolution scan in display phase 1 then a compressed scan 
in phase 2, and this is provided by the circuits on board Y6. The schematic for this function is 
shown in Figure 3.17e - the large number of oscillators is due to the need for cornpatability with 
all of the six radar types in any of the 4 display modes. Three data selectors are used to derive 
signals from the clocks - one for use in scan time, one during interscan and the third for the 
compressed scan in phase 2. The outputs from the selectors are directed, through appropriate 
gating, to an 8-bit range counter which is configured by additional circuits to function as a 
10-bit counter for the duration of display phase 1. 
5.61MHz 6.0MHz 6.44MHz 5.6MHz 
1 
1 1 
1 1 1 
l 1 1 1 
1 1 1 1 1 I 
Scan Select InterScan Select Comp. scan Select 
Radar Select. 
Mode Select -
Control 
Gating 
Radar Sync -
CFAR Sync-
WBI Sync-
Synthetics= 
Range 
In 
7~h 8-bit Range Counter 
T3 
I D 
CO 
to 
Range 
=Counter 
Ouitput 
Fig. 3.17e t Range Controller Schematic 
The output from the counter is directed to a data selector which, under control from Y5, 
selects either this or the synthetics range for output to the display interface, Y l . This board also 
contains the circuits for selecting the appropriate intensity level for the digital modulation of 
the P.P.I, display, based on the currently active display phase. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .43 
The RATES Radar System 
3.9.7 The Processed Video Controller 
The last functional unit in the display interface is realised by the circuits on board Y7, 
the processed video controller (Figure 3.17f). In this unit, binary data from either the WBI or 
CFAR processors is read into the shift registers, during the first display phase, according to the 
display mode selected. The compressed video for phase 2 is derived by "OR-ing" 1, 2 or 4 of the 
shift register outputs, and the resulting video signal is stored in the RAM at the address 
determined by the address-counter. A second counter increments from zero during this period 
to provide additional timing for the display interface. 
In display phase 2, the address-counter is used to read the stored video, and the output 
from the RAM is fed into a mixer which combines binary data from this and other sources to 
produce an analogue signal suitable for transmission to the Z-modulation driver on Y2. 
During phase 2, the second counter decrements to zero whereupon it generates an underflow 
condition which halts the second display phase and starts phase 3. 
2MHz Clock-
WBI Data 
WBI Sym 
CFAR Data-
CFAR Sync-
Radar Select Shift Reg 
WBI Data-
CFAR Data-
Synthetics Data-
Range Clock- Range Count 
Address Counter 
1024 x 1 
RAM 
=Last Synthetic 
- | > Stage 2 Counter "J Stage 3 
-Enable WBI 
—Processed 
Video Output 
Blanking Select -Z-Blank 
Fig. 3.17f ; The Processed Video Controller 
Synthetics display is timed in a third counter, and the signal Last Synthetic is produced 
when there is only sufficient time left to draw one marker before phase 1 recommences. The 
function also generates the video timing signals for the rest of the display interface, and the 
blanking signal for masking the display at short ranges. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .44 
The RATES Radar System 
3.10 The Control Unit 
This feature of the RATES system needs only a brief mention to describe the facilities 
it offers to the operator. The intention in providing this facility was to enable those testing the 
system to choose the optimum parameters for normal operation; these would then be hardwired 
into the extractor to present a less complex control panel for use by the radar operators. 
The parameters controlled from this function are given below and Figure 3.18 shows 
their typical layout, used in both prototype and Durham systems. 
System Controls: 
Master Reset Generates a reset pulse for the system hardware 
Kadar Select 3-bit output of radar type (A.. .D) 
CFAR Controls: 
CFAR Scalar 'K' 
CFAR Offset 'M' 
CFAR Cell Count *f 
Computer Range 
Computer Scale 
6-bits, value 1 to 2 in 32 steps 
6-bits, value 0 to 5.76dB in 64 steps 
4-bits, sets number of cells used for background average (8...16) 
2-bits, sets range of computer offset cells to 1, 2 or 4 mile range 
2-bits, sets weighting of computer offset to 22.5,45 or 90dB 
ECM Controls: 
ECM Level Threshold 8-bits, value 0.. .255 
ECM Cell Threshold 12-bits, value 0...4095 
ECM Spoke Threshold 2-bits, sets spoke threshold to 2,3 or 4 
WBI Controls: 
WBI Lower Level 
WBI Upper Level 
'. Increment V 
5-bits, sets lower level threshold to 0...31 in 32 steps 
5-bits, sets upper level offset, in 32 steps 
4-bits, value 1...8, the integral step used in the WBI 
Plot Forming Controls: 
Plot Range Depth 
Plot Bearing Width 
1-bit, sets plot forming range depth to 3 or 5 cells 
3-bits, sets plot forming bearing width to 3,4 or 5 beamwidths 
Display Controls: 
Display Mode 4-bits, sets display combinations (see Table 3.4) 
Display Magnification 2-bits, enables xl, x2 or x4 magnification of display 
Intensity 1...3 4-bits, sets intensity of primary (secondary/tertiary) display phases 
Roll-ball X and Y phase & quadrature, for positioning of display marker 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .45 
The RATES Radar System 
In addition to the switches on the control panel, the operator is given some visual 
indication of the status of the unit, through the CFAR and WBI rate indicators and a number of 
warning lights. The displays provide a count of the number of targets declared by both CFAR 
and WBI threshold processors and hence give a measure of the performance of the two 
functions. 
CO 
CO 
0 CO CO 
CD 
CD CM 
0 CO 03 
CO 
0 CD 0 to 
0 0 Q _ 01 
• E l CO 01 
CO 
0 CD 8 0 0 CO 
CD • m CO C O GO 
111 
m m CO 
0 co S I CO Q) O 0 CO 0 • CD O CO Q . CD a CO C O 
10 CD CD CD o 553 0 L U 
01 
• 0H 0 (0 CO CO CD CO 
0 
CD 
o O 0 a: C\J 
O 
CD CO P 0 CD t o CO CB CD ecco 
Fig. 3.18 : RATES Control Panel Layout 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 . 46 
The RATES Radar System 
3.11 The Filtering and Tracking Computers 
The most important requirement of the tracking computers is their ability to accept, as 
input, genuine plot data mixed with land and sea clutter and extract the true targets, measure 
their speed and heading and keep track of them from scan to scan. From this information, the 
computer generates a display of synthetic markers on the P.P.I, display, transmits target data 
across the A.I.O. and shows status information on a separate video monitor. All of this 
processing must take place in real time, so high-speed is an essential element in the choice of a 
suitable computer system. 
3 JUL The Prototype Hardware 
When RATES was designed, there was little choice in a suitable computer for the 
prototype system: any contender had to be ruggedised to military specification (which excluded 
most microprocessors) and capable of high-speed execution. It also had to support the approved 
language: CORAL 66 and its associated run-time operating environment, MASCOT (Modular 
Approach to Software Construction, Operation and Testing) which provides high-level 
multi-tasking and process communication capabilities [34]. The prototype therefore made use 
of two Ferranti Argus 700G processors, one of which performed stationary-plot filtering while 
the other was used for target tracking. Due to difficulties surrounding data transfer between 
the computers, this configuration was later modified to use one as a fully operational system, 
while the other was used for software development. The H-series boards were installed in the 
base of the operational computer system, linking from the computer's ME62 interface bus to the 
hardware of the plot-extractor. 
As the entire plot extractor was experimental, the computers were equiped with extra 
backup and output devices, which would not otherwise be supplied with a production system. 
This gave the user the option to get a hardcopy of track parameters as tracks were built-up, plot 
confirmed tracks on an X-Y plotter, and record tracking scenarios on floppy disc for later 
replay at a chosen speed. The computer displayed status information regarding data input and 
number of existing tracks, as well as specific information on selected tracks, on a video 
console attached to it. The system could be fine-tuned during operation by use of a separate 
terminal to change the tracking parameters. 
3.1L2 Prototype Software 
The original software (RATES1) was written for the two separate processors, but the 
difficulties in getting these to communicate successfully prompted a re-write to the standard of 
RATES2A - the current implementation [35]. This has been in operation for some time now, but 
difficulties arise concerning the amount of memory it requires, and the limitations imposed 
on the number of tracks that can be handled at any one time. The MASCOT activity diagram 
for the complete filtering and tracking software is shown in Figure 3.19. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 . 47 
The RATES Radar System 
3.11.8 Description of Software Function 
The diagram shows the activities involved in the plot extractor software, linked by 
either pools (a global data area) or channels (a data stream). Activities are divided into two 
groups: the standard MASCOT input/output routines (in the section on the right of the 
diagram), and the KATES special functions. The standard functions handle interfacing with 
the disc drives, x-y plotter, printer and control terminal and are built into the MASCOT 
operating system. The special functions are described as follows: 
DMA Control receives data from the plot extractor by way of the ME62 link, and function H. It 
then passes the data on to the tracking software, under control from the DMA Commands Pool. 
The SPF & Tracking activity forms the main part of the software, and can be subdivided into a 
further three sections. The first reads the data from the DMA interface, and resets the work 
areas for a new set of calculations. The second section checks all incoming data to see if it 
associates with an existing plot. Plots that do not associate have a confidence count 
decremented while new data is used to initiate a stationary plot. All other plots have 
ships-motion correction applied to them. 
The tracking section then takes over and identifies all plots which should be active in 
the current octant. New data which associates with a non-moving track is discarded, while 
other data is assumed to come from a manoeuvring track, so the nearest target to each is 
selected. The system checks for possible ambiguities in its choices for track association then 
calculates the smoothed position of each plot, using a simplified Kalman filter [49] algorithm. 
Any tracks which do not associate, along with unassociated plots from the previous scan are 
used to form tentative tracks, providing that the clutter level in their region is low. 
The Recording section takes confirmed track data from the tracking software and then 
transfers it on to the line printer. 
The Command Interpreter accepts data from the control console and thus enables the operator to 
have some degree of control over the parameters used in the various activities. The operator is 
also able to select a target using the rollball marker, then instruct the computer to initiate a 
track for the selected item. 
The A.I.O Interface provides communication with another computer, under control of the SPF 
& Tracking Section. Data may also be routed to the monitor terminal through the V D U 
Manager, and this also displays the level of processing activity which is calculated by the 
Loading Calculation activity. Finally, the tracking section produces data for transfer back to 
the extractor, under control of the Output Controller. This includes Test Target data, Clutter 
Map Threshold Levels and P.P.I. Synthetic Display Markers. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 .48 
The RATES Radar System 
.S2 IS O < D CD CD CD CD 
CD 
O K 
•a o 
CO CO 
s z7 o a«r E 
V O CO sat: Q CD 
CD CO 
CD CO 
CO 
Q - O CD t o CD 
CO £ E 
S 5 S y o
CD 
CD 13 CD CD 
O C 
.<2 CO 
CD 
CD 
CD 
CO 
CD 
c3 
H 
U 2 h3 T 3 Q) S OJH CD 52 E 
« t CD 
CD 
CD 
t o C3 CO 
e 2 < D CO CD To E Vi 5 C J o a~ co CO CO o COcT 
CD 
c n o 
CO 
io = u . 
_ J CO CO => o 
CO CO 
coo. CO 3 CO 
to CO 
CO 
C D _CO 
CD t o o o 
CO 
t o 
CD CD 
CO I — 
CO O o 
V 
| o < g 8-eg a u- co a 
CD 
LU 
Fig. 3.19 : KATES Software, Mascot Description 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 3 . 49 
Introduction to VLSI Technology in HATES 
4.0 Introduction 
The prototype RATES unit was commissioned in the late 1970s' with the aim of 
demonstrating the viability and cost-effectiveness of an automatic radar track extraction 
system. Using the technology that was readily available at the time, namely small and 
medium scale integrated circuits, the prototype was assembled with little attention paid to the 
system's commercial potential or to the problems that could be incurred if a commercial 
design were to be attempted. Once finally operational, the constraints of the original design 
became clear, and a move was then made to redevelop the deficiencies of prototype using a 
technology that could be associated more in keeping with the 1980's. 
The Durham University RATES Development System was introduced, not only as a 
practical demonstration of what could be achieved by adapting the prototype to the latest 
technology, but also to indicate possible avenues of research using different architectures. In 
this chapter, a number of possible alternatives to the existing MSI / SSI circuit architecture are 
proposed, with consideration given to existing VLSI circuits and components. 
4.1 Deficiencies in the KATES Prototype 
To justify any study of new approaches to the design and construction of the RATES 
prototype, i t is necessary to discuss some of the failings of the original design, some of which 
may be explained by reference to the previous chapter: 
° Use of MSI and SSI logic, whilst offering high speed processing, gives a poor 
performance/size ratio. 
° Power supply requirements are excessive for the type of processing involved in 
RATES , and would present difficulties in a shipboard system. 
0 Computer hardware is now outdated and could be changed to use smaller & faster 
processors. 
0 Communications between plot extractor and tracking computer could be simplified 
without loss of performance and would probably result in a higher bandwidth. 
° Use of wire-wrap construction techniques, although adequate for prototyping 
purposes, is not suitable for a commercial design. Also, the individual functions 
(A1,A2,B1...B3, etc) do not lend themselves to printed-circuit board construction as 
they are functionally too small to warrant this design approach. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4 . 1 
Introduction to VLSI Technology in RATES 
In addition to the points mentioned above there have been a number of difficulties 
encountered with the tracking software, which may be explained by deficiencies in the design 
of the interface to the plot extractor hardware: 
s Tendancy to lose track of targets which enter regions of high clutter density, cross 
octant boundaries or rapidly change speed (e.g. helicopters). 
0 Lack of reliability when faced with overload conditions (software tends to'hang' 
and does not recover). 
0 Clutter map badly implemented, resulting in excess of targets at >90% of effective 
range. 
° Target tracking is abandoned if the target passes over the antenna. 
° No checking on realistic target speeds 
° Software code poorly optimised resulting in comparatively slow execution. 
There is clearly scope for improvement in the design of the prototype, however any 
enhancements should go beyond the point of simply upgrading components. The function of the 
various modules in the system is not questioned, as they represent standard processing 
techniques for this type of radar, but the architecture used to implement them could be 
improved. The prototype made use of MSI and SSI circuits to realise each module, and any new 
design should consider the use of VLSI techniques in their place, with the aim of improving 
performance on a smaller scale and at lower cost. 
The current design is too bulky to be of use within the confines of a ship, where the 
environment is more likely to favour a compact system which is still easy to maintain. The 
prototype system had a weight limit of 800Kg imposed upon it for this reason, and this has 
resulted in a design which is comparatively limited in its capabilities because of the weight 
penalties that would be incurred by increased functionality. One of the priorities in a new 
design should therefore be in reducing the physical size of the system, concentrating initially 
on those modules which represent the worst performance/size ratio - the computer and its 
interface. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 2 
Introduction to VLSI Technology in RATES 
4.2 Introduction to the Durham RATES 
As a guide to the type of technology that was available, it should be noted that work on 
the project began in September 1982, with a brief to study the applications of new semiconductor 
products to the existing RATES prototype. An important consideration in achieving this was to 
gain familiarisation with the existing system and a duplicate set of wire-wrap boards was 
therefore provided in July '83, covering all of the RATES functions with the exception of the 
computer and its local interface (Function H), and the ship's motion convertors (A2a/b). 
4.2.1 Hot Extractor Hardware 
With the aid of the existing wiring diagrams, a suitable casing was constructed to hold 
the boards while preserving the grouping that was introduced in the prototype. Power supplies 
were wired using a heavy braided conductor, to reduce the effects of voltage drop due to the high 
currents that were likely to be drawn by the boards and with 43-way double sided edge 
connectors to interface to each board, a backplane was built-up using wire-wrap techniques, 
following the details on the wiring diagrams. The initial development system is illustrated in 
Plate 4.1: it should be noted that the objective at this stage was simply to produce a system which 
would emulate the CFAR, WBI and plot forming functions of the prototype. Care was taken to 
make i t as easy to modify as possible as no ideas had been formulated regarding possible 
enhancements to the prototype. 
A monochrome Kratos P.P.I, display was obtained for use with the development 
system, however this did not have the same characteristics as the H.P. display used in the 
prototype, and i t was therefore necessary to design and construct an interface which could be 
installed between the output drivers (Yl & Y2) and the p.p.i.. Some extra features were 
included in the driver to enable i t to interface to another type of display (a Kratos 2-colour 
phosphor Penetron) which was used as a backup in the event of the first display failing. The 
operating parameters for the two displays are given below, and the complete schematic for the 
interface is illustrated in Figure 4.1. 
Display 
Display 
Type 
Blanking 
Input 
Deflection 
Inputs 
Video 
Input 
Colour 
Select 
Kratos 
Monochrome 
p.p.i. 
vector display 
+ 5V 
to display 
1V/1" deflection 
0.567u.s max. 
1KQ impedance 
+1V for max. 
Intensity. 
50ft impedance 
N/A 
Kratos 
C M 3 1 7 F P T 
Two colour 
(red, green) 
p.p.i. vector display 
- 2 V 
to display 
I V / 1 " deflection 
0.567u.s max. 
1KQ impedance 
+3V for max. 
intensity. OV blanks 
2KQ impedance 
Logic '0' selects one 
of 4 icolours (red, 
amber,yellow,green) 
The deflection sensitivity of the colour display was adjustable, so no further 
interfacing was included to compensate for the difference between the two displays, however it 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 3 
Introduction to VLSI Technology in RATES 
was necessary to derive the video enable signals and a suitable offset for the colour video input. 
Neither display featured digital modulation and this has been derived by converting the 4-bit 
signal to an analogue voltage which is used to offset the incoming video level. With a 
maximum input for ful l intensity of +3V for the colour display, i t was found necessary to 
provide a second offset which is added to the intensity modulation signal. Switches are 
provided on the board to enable rapid configuration for either display. 
A A A Video Output Blank Output 
rn 
, r 
in in m 
• 
CM 
CO 
HJEu i—rwi 9V1 
8 
-GEO—DID rmn- SZ CO 
rlh j-EKa- 8" 8 
in 
m DAC 0800 
c 8 
2 m 
CD CM 
CO 
8 8 in 
1 1 I w l in m Digital Z-Modulation Input CD 
Fig. 4.1 : Schematic of the PPI Display Interface 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4 . 4 
Introduction to VLSI Technology in RATES 
The video input to this interface is taken from a slightly modified version of Function 
Y2 - as 50Q buffering is not necessary prior to the interface, a signal is taken directly from the 
output of the final operational amplifier (see Figure 3.17a). The output from the interface is 
designed to drive a 50Q load directly fromthe operational amplifier, and no further buffering 
is included at this stage. 
Power was supplied to the system by a smaller unit than that specified in the prototype: 
+5V at 20 Amp and 10 Amp, ±15V at 5 Amp and -5V at 1 Amp. This was found to be satisfactory 
and showed no evidence of voltage drop or overloading. A control panel was constructed in an 
identical manner to the prototype unit described in Chapter 3, and linked to the plot extractor by 
three 50-way ribbon cables. The complete display and control panel is illustrated in Plate 
4.2. 
4.2.2 Initial Test Results 
Following initial testing of the completed development system, using the test target 
generator (Chapter 7) that was part of the original design, it became clear that the prototype 
wiring diagrams were extremely inaccurate. Checking the wiring with the circuit diagrams 
of the prototype indictated a total of 53 missed or incorrect wiring connections, which have now 
been documented and are available as a set of amendments to the original diagrams. 
Further tests using the now modified plot extractor proved successful, and 
demonstrated the clutter-filtering properties of the CFAR and WBI sections. The system was 
noted to compare well with the prototype, which had also been seen in operation demonstrating 
these features. With no computer processor attached, the plot forming and tracking facilities 
could not be studied. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4 . 5 
Introduction to VLSI Technology in RATES 
r 
^ 1 
> 
i 
v St ' 8 • c . . v 
Plate 4.1 
I 
: 
Plate 4.2 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. 
Introduction to VLSI Technology in RATES 
4.3 Digital Design Approach 
Having gained familiarity with the prototype system, it is appropriate to suggest some 
areas where improvements could be made to the basic design, in particular with respect to 
replacing MSI / SSI parts with some sort of functionally equivalent LSI alternative. Since the 
prototype was designed there have been significant advances in such areas as 
microprocessors, bit-slice processors and logic arrays, all of which could be used to some effect 
in improving the RATES design. There has also been increased scope for custom design of 
integrated circuits and in some cases this can prove cost effective even with low production 
runs 
Some aspects of improving the RATES prototype have already been proposed in a study, 
by Ferranti Computer Systems P.L.C., of the potential for VLSI in plot extractors [51], however 
this was concerned largely with the applications of Uncommitted Logic Arrays (ULAs) in a 
general purpose plot extractor.Whilst some of the findings of this report remain valid, i t 
should be noted that several aspects have changed in recent years and i t is therefore important 
to reconsider all possible semiconductor technologies for use within the RATES system. 
43.1 Applicable Semiconductor Technologies 
Ferranti's recommendations regarding applications of LSI / VLSI technology to plot 
extraction were the results of a proposal submitted in late 1981, and much of the information 
pertaining to this could be regarded as out of date by 1984, when studies began on alternatives to 
the architecture of the Durham system. Since then, a number of advances have been made and 
the following examples can be considered to be typical of available devices: 
° Microprocessors (8 - 32 bit, clock rates to 21MHz, 32-bit register addition 0.2|is, 
16x16-bit multiply 3us). 
° Bit Slice Processors (up to 16-bit slices, clock rates 12MHz, a.l.u. addition O.lus, 
multiplication 45ns). 
0 LSI and VLSI devices, various functions e.g. high speed, high capacity RAM; 
digital correlators (64 x 1 bit @ 15MHz). 
0 Custom LSI / VLSI logic, which is no longer restricted to the larger semiconductor 
manufacturers. Fairly reliable devices can be obtained with 5MHz clock rate, 
NMOS fabrication. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 7 
Introduction to VLSI Technology in RATES 
° Uncommitted Logic Arrays, also known as ASIC's, are now offered by most 
semiconductor manufacturers, often with local design facilities that can be run 
on the more advanced personal computers. Most use 1.5...2 micron gate length 
and require manufacture by the supplier. Typical gate delay 0.65ns, register 
clock rates to 170MHz. 
0 Field Programmable Logic, including PROMs (40ns access time), PALs (15ns 
delay per gate) and EEPLAs. Design tools available to run on personal 
computers. Programming by user through use of a special unit. 
4.3.2 Parameters Applicable to Determining a VLSI Solution 
In order to determine the suitability of various semiconductor processes to replacing the 
RATES functions, i t is necessary to establish some criteria which represent a worst-case plot 
extractor. By adopting this approach, i t is possible to retain the general purpose nature of the 
prototype, and should enable a final design to be easily adapted for use with any monostatic 
surveillance radar simply by changing the phase and frequency of the timing clocks. A 
summary of the RATES parameters outlined earlier in Table 2.1, together with their most 
important derivatives, is given below: 
P.R.F 
Pulse Length 
Beamwidth 
Rotation Rate 
Scan Period 
Effective Range 
Number of hits / beamwidth 
Range clock frequency 
Number of range cells 
256Hz... 1600Hz 
0.08us ... 2us 
0.75° ... 2.3° 
7.5 r.p.m. ... 24 r.p.m. 
366us ... 3.072ms 
30 miles ... 250 miles 
5...14 
500Khz...l0MHz 
256...4575 
The latter 2 parameters are based on a range sampling frequency equal to (1/pulse 
length), however i t should be noted that for long pulse lengths it is common to sample at 2 or 4 
times the implied frequency. The lower bound for the number of range cells per sweep is 
therefore likely to be much higher (around 512 ... 1024). I t should also be noted that RATES 
imposes a maximum of 4096 range cells per sweep resulting in a loss of processing at higher 
ranges, hence the effective "RATES Range" figure quoted in Table 2.1. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 8 
Introduction to VLSI Technology in RATES 
To allow for such a large variation in the number of range cells which must be 
processed in one second, a set of parameters is chosen to represent the worst case situation: 
Range Clock Frequency 4MHz 
Number of Range Cells 4096 
Pulses / beamwidth 14 
Rotation Rate 24 r.p.m. 
4.3.3 KATES Functions Suitable for VLSI Implementation 
Most of the functions described in Chapter 3 are suitable for implementation in LSI or 
VLSI form to some degree, although the ideal solution is dependent on the parameters outlined 
above. For the purposes of this thesis, the RATES functions will be considered as follows: 
CFAR Processor 
WBI (Marcoz and Galati) Processor 
Plot Forming Unit 
Filtering and Tracking Hardware / Software 
In the Durham implementation, the display driver has also been considered to a 
limited extent, although the unit is not one of the most important. Supplementary functions 
such as ECM detector, timing and test target generation are not considered as being of 
sufficient importance to warrant further study or redevelopment. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 9 
Introduction to VLSI Technology in BATES 
4.4 A Solution in Custom VLSI? 
In recent years, semiconductor design facilities have improved to the stage where a 
new design can be produced reliably and cheaply, even where low volumes are involved. For 
this reason, i t can often prove highly cost effective to design circuit functions directly onto 
silicon, especially where the circuit forms a simple 'black box', i.e. single input and output 
plus a limited number of control pins. 
4.4.1 Durham CAD Facilities 
Durham University is fortunate in having access to the semiconductor design and 
manufacturing facilities provided by the SERC, as well as its own clean room where small 
numbers of chips can be prepared on-site, and i t therefore seemed logical to investigate the 
potential of a custom VLSI plot extractor. Design exercises are traditionally undertaken by 
students reading for the M.Eng. in Microelectronics, using CAD facilities on the SERC's 
mainframes in the Rutherford Laboratories. A number of terminals are located in Durham, 
permitting on-line design and simulation using a variety of packages including HI-LO, 
GAELIC and SPICE. Designs are based on an NMOS substrate, using standard 2 micron 
rules, and when complete are sent to the SERC manufacturing facilities in Edinburgh where a 
small number of chips are produced. 
To keep costs low, a number of different designs are combined onto a single substrate 
and separated later for packaging, however the expense involved in each design restricts the 
number of chips that can be produced during the year. For this reason, and also because of the 
difficulties experienced by some M.Eng students in choosing a suitable design, i t was decided 
to offer specifications for a number of potential plot extractor-related functions to the course 
students. This had the added advantage of permitting time to be spent investigating other 
aspects of the RATES system while the designs were being prepared. 
4.4.2 Functions Chosen for VLSI Implementation 
The main constraint on any functions that were to be chosen for implementation in 
VLSI, was the design time available - a mere 12 weeks from specification to completed design. 
It was clearly not advisable to extend a design beyond this period by transfering the project to 
another student, and so a small function had to be chosen, obeying a simple algorithm that 
could easily be converted to a hardware implementation. I t practice, i t was decided 
inadvisable to attempt a complete plot extractor design on a single chip, as the cost benefits 
would almost certainly be lost through its lack of flexibility - an important factor in 
considering the adaptability and lifetime of the product. Maintenance, too, would be hampered 
by a single chip design that would necessitate discarding any defective product. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 10 
Introduction to VLSI Technology in RATES 
During a three year period of study, a total of three designs were submitted for 
implementation in VLSI. Complete reports of these implementations have not been published 
outside the University. 
4.4.3 CFAE Processor 
The first design was an attempt at the implementation of a basic CFAR processor 
algorithm, simplified to reduce design time. To achieve this simplification, the window size 
was restricted to a fixed value of 5 cells, thereby removing the need for a variable-length shift 
register. It was accepted from the start that the limitations of the design process would render 
full-speed operation impossible, so i t was decided to simply demonstrate the potential of a 
single chip CFAR albeit running at a lower clock rate. 
In practice the time limit proved restrictive and it was not possible to achieve more than 
a small part of the overall design - a parallel adder for summing the shift register contents. 
4.4.4 Polar-to-Rectangular Coordinate Convertor 
This design, which was attempted by another M.Eng student in the same year as that 
described above, was the only consideration given to a redesign of part of the display driver, 
where i t was hoped that i t would be used to replace most of functions Y3, Y4 and Y5. As with the 
first design, it was accepted that the operational speed would be below that required in practice 
but i t was hoped that the circuit would be able to demonstrate conversion of the range and 
azimuth data to X and Y digital co-ordinates. I t was also hoped that this approach might 
illustrate the potential for using raster-scan displays in place of the vector drawing P.P.I, 
displays, thereby giving the advantages of reduced power consumption, reduced size and 
improved visibility. 
4.4.5 The W.B.X. Integrator 
This was the most promising of the three designs attempted, taking advantage of a new 
process that was introduced after the first two, and offered more reliable operation at higher 
speeds than was previously possible. The design was a complete implementation of a Marcoz 
and Galati within-beam integrator, excepting the RAM used for storing the counter values. 
Input parameters were identical to those in the RATES prototype (Section 3.4) with the intention 
of reducing the WBI functions to a two-chip solution. 
Regretably, a minor design error prevented more than superficial testing of the 
production devices. Indications suggested that correction of this fault would probably result in 
successful operation, but at the expense of a further chip run. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4 . 1 1 
Introduction to VLSI Technology in HATES 
4.4.6 Summary of the Custom V L S I Approach 
It was unfortunate that the design time available for these exercises was so limited, as 
none of the designs attempted by the M.Eng. students was found to work in practice. I t was 
concluded that the lack of success in this approach confirmed earlier doubts about the viability 
of custom chip design, although the WBI processor showed potential and could possibly be made 
to work with further modifications. I t is, however, doubtful whether the cost of such an 
implementation could be justified when compared to the likely cost of, for example, a ULA 
solution to the same problem. 
In rejecting the VLSI solution, at least to the Durham system, the following points were 
also noted: 
0 The SERC process used to manufacture the chips is not wholly reliable. 
° The earlier process could not support clock frequencies greater than 1MHz for the 
first and second designs, and the new process had not been tested sufficiently at 
the time of the third design. 
0 The process was only suitable for small runs of NMOS I.C.s. For use in a 
military environment, the design would have to be re-engineered for production 
using Ferranti's bipolar process. 
0 The simulation facilities available on the SERC computers were unable to test for 
all conditions and hence there was always a possibility of design errors being 
overlooked. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 12 
Introduction to VLSI Technology in RATES 
4.S Programmable Logic in KATES 
The term 'Programmable Logic' can now be used to refer to a large number of different 
families of semiconductors, although in this instance i t will be taken to mean the two groups 
mentioned previously: 'Field Programmable devices' and 'Uncommitted Logic Arrays'. 
In general, the family of field programmable devices includes Programmable Logic 
Arrays (PLAs), Electrically Eraseable Programmable Logic Arrays (EEPLAs) and 
Programmable Read Only Memories (PROMs). The latter devices are already used to within 
RATES, mostly as look-up tables for converting manually-set parameters to some derivative. 
EEPLAs and PLAs are essentially similar - the former retaining the ability to be 
programmed to some logical configuration then electrically erased again, much in the same 
way as the more traditional E2PROMs. 
4.5.1 Programmable Logic Arrays 
PLAs have been introduced since the production of the RATES prototype, and they are 
now widely available as standard MSI logic devices. Each device consists of an array of 
(typically) 8 OR-gates, with the inputs to the gates being made up from the wire-ANDed inputs 
to the device. The device's outputs are taken from the OR-gates either directly or through a 
D-type register. The wire-AND function is performed through a set of fuse links which may be 
'blown' to achieve different logic combinations.They are programmed using a variation on 
the technique employed for PROMs, but this can be done without recourse to the manufacturer. 
The devices are produced in their own series (c.f the 74xxx TTL series), with only minor 
variations in programming requirements between manufacturers. In considering PLAs for 
use in a design, the following guidelines should be considered: 
° PLAs are intended primarily for replacing small - medium size combinational 
logic designs. They are not suitable for multi-function logic designs, although 
they may be used to implement small registered-state machines. 
0 Device delay is typically 12...30ns, for a non-registered PLA, whilst registered 
devices support a clock frequency of up to 22MHz. 
° Maximum input/output support is 22 inputs and 10 outputs. The maximum 
package size is 24 pin (the PAL22V10 family) and this capacity is achieved by the 
use of bidirectional connections (all outputs are usually bidirectional). 
0 Most PLA designs use only 50% of the possible combinational terms because of the 
restrictions on I/O and outputs often end up being used simply because they were 
available to the designer, without consideration of more economical alternatives. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 13 
Introduction to VLSI Technology in KATES 
° Devices are programmed using either a standard language, boolean expression 
(relating outputs to inputs) or using a fuse map (the lowest level). 
Taking account of these guidelines, i t can be deduced that PLAs are not suitable for 
completely replacing a module in RATES (and certainly not with a single array), but there is 
potential for using them to replace some of the more laborious combinational logic. In general, 
a PLA will replace between 5 & 12 SSI/MSI functions (with certain restrictions). In a later 
chapter, PLAs have been used to advantage in the designs suggested for a new interface to the 
tracking computer and one design is based entirely around a PLA state machine. 
Considering the individual RATES functions, there is little scope for an advantageous 
PLA design as other architectures could provide more suitable solutions. The WBI function, 
however, is essentially logic-based and could probably be reduced to a single-board function 
using memory, counters and a controlling PLA. This concept has been discussed in greater 
detail in Ferranti's report, but it is considered that current ULA devices would permit complete 
replacement of the WBI using a single device... possibly a more cost-effective solution in a 
production situation. 
4.5.2 Uncommitted Logic Arrays 
ULAs and ASICs currently show the greatest potential for implementing a 
single-board plot extractor, having advanced considerably (technologically speaking) in 
recent years. The number of manufacturers now providing facilities for designing and 
producing logic arrays has increased considerably from those originally suggested by 
Ferranti, and typical gate parameters have been similarly improved. 
Current ULAs are mostly based around a 1.5 micron gate length and implemented in 
CMOS. They achieve very high gate speeds, similar to those of lOkQ ECL (e.g. 0.65 ns through 
a 2 input NAND gate). In contrast to Ferranti's report of a maximum of only 4000 - 6000 gate 
devices by 1983, manufacturers are now offering ULAs with 41,000 gates per chip. As with all 
gate-arrays, however, only about 30% of the total gate count is available for use whilst the 
remainder is lost through implementation of bus structures and interconnections. Packaging 
is unlikely to restrict designs as pin counts of up to 257 are permitted in current devices. 
Programming is usually performed by the manufacturer, using designs prepared by 
the customer. Some manufacturers (e.g. Xil inx) are also producing low-density arrays (2000 
gates) which may be programmed in a similar manner to PLAs, but the design facilities for 
these is essentially the same as for a large PLA design and are based around the use of boolean 
expressions or fuse maps. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 14 
Introduction to VLSI Technology in RATES 
In this country, facilities for ULA design are offered by a large number of 
manufacturers. LSI Logic Corp. in particular offer a comprehensive set of guidelines to 
complement their extensive range of gate arrays, many of which include pre-defined 
macro-cells for use within a design, including functions such as memory (18...36K bits) or 
bit-slice processors (AMD2901). For these devices, programming is carried out through the 
concept of functional modules, most of which can be related directly to their 74xx series TTL 
equivalents. Using LSI Logic's guidelines, i t is possible to produce estimates for the number of 
ULA gates required to implement a particular function, for example: 
RATES WBI Module: 
DEVICE # Used GATES / DEV. TOTAL 
7400 1 4 4 
7404 3 4 8 
7408 1 6 6 
7474 2 15 30 
7485 4 44 176 
74109 1 21 21 
74153 10 14 140 
74158 1 11 11 
74161 6 60 360 
74174 1 37 37 
74240 1 26 26 
74273 1 50 50 
74283 2 59 118 
74390 6 86 516 
Total: 1503 
The WBI memory is not included in the above gate count, but could be implemented 
either externally or as a part of a gate array mega-function. For the former case, the total count 
is within the capabilities of both low-range ULAs and the Xilinx user-programmable arrays. 
This example clearly illustrates the potential of gate arrays for logic replacement. The 
result is cost-effective as development times can be significantly reduced i f a manufacturer's 
design macro-library is used and there is no redesign of the existing circuits. A study of the 
CFAR and Plot Forming modules produces similarly encouraging results: 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 15 
Introduction to VLSI Technology in BATES 
The CFAR module requires, in addition to a large number of registers, a 4096 x 7-bit 
memory for the computer threshold data and two 8-bit multipliers to calculate the threshold 
value. The latter is realised using four 2901-type ALUs, each of which can be built from 
approximately 800 gates. Excluding the memory, which must be supplied as a mega-function, 
the estimated gate count for the CFAR is only 7225 gates, which can be easily achieved using an 
array such as LSI Logic's LSA 1502. 
The plot forming module uses a total of 41 74LS374 registers, which account for a large 
percentage of its gate requirements, and i t also involves six ALU modules. I t also requires a 
128 x 56 bit memory (7168 bits) which can be implemented as a mega-function. As the total 
requirement (9241 gates + memory) is actually less than that of the CFAR, i t is estimated that 
this module could be realised using a device such as LSI Logic's LSA 1501. 
It is clear from these results that the technology exists to implement the hardware of the 
RATES plot extractor using little more than 3 gate arrays, although it is doubtful whether this 
would represent the optimum solution. Whilst compact, the design would have no flexibility 
outside that permitted by the use of the existing control panel, and future enhancements would 
be impossible without redesigning the appropriate array. For this reason, the use of gate arrays 
is not recommended for CFAR and plot forming units, although it is considered that they 
represent the best solution to the problem of a VLSI within-beam integrator (when compared 
with alternatives discussed later). 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 16 
Introduction to VLSI Technology in RATES 
4.6 Microprocessors in Kadar Signal Processing 
Historically, the plot extraction process in a radar has been performed by a dedicated 
hardware unit, tailored for the task in hand, with little flexibility or potential for redesign to 
suit another radar. One of the most important developments in VLSI techniques over the past 
few years, however, has been the growth of programmable processors and studies have already 
been carried out into applications of these devices to radar signal processing. To date, designs 
have been hampered by the slow clock rates which processors can sustain and many of the 
"microprocessor" designs thus proposed have turned out to be microcoded units based around a 
core of bit-slice processors, (simply termed microprocessors by virtue of their programmability 
from higher level instructions). 
The simplest means of introducing microprocessors, to take advantage of their low cost 
and flexibility, is to adopt the parallel architecture approach, similar to that developed by Polise 
& Moskovitz [52] and more recently by Loppnow [53]. With this type of 'bit-slice-based' 
architecture, a set of identical parallel processors act on the incoming data, processing it 
bit-wise to achieve the desired result, and achieving high throughput by way of their limited 
instruction capability. The cost of a complete unit produced by these methods may be lower than 
a discrete logic solution and flexibility similarly enhanced, but in terms of size and power 
consumption there is little difference between the two. In addition to this, the development 
times for a complex bit-slice implementation can often outweigh any advantages that may be 
gained from its programmability. 
It is suggested that an ideal, cost-effective programmable solution can only be easily 
achieved through a "single chip", serial data stream architecture using either a traditional 
microprocessor or one of the specialised digital signal processors that have been introduced in 
recent years. It is therefore proposed to discuss the potential of current microprocessor 
techniques in implementing replacement modules within RATES. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 17 
Introduction to VLSI Technology in HATES 
4.6.1 Summary of Available Microprocessors 
In his study of "Radar Data Processing Using Microcomputers", Ebert [31] drew a 
number of conclusions regarding the type of processor suitable for implementing various 
sections of an automatic tracking system. His solution used a combination of a 
special-purpose bit-slice extractor and a multi-board microcomputer for post-processing, but 
was restricted by the type of devices available at that time. He concluded that plot-extraction 
could not be performed by standard microprocessors due to speed limitations, but post-
extraction processing was within the scope of any microprocessor satisfying the following 
criteria: 
° RAM expandable to a minimum of 64K bytes 
16-bit data word & CPU 
° Large number of instructions (>60) 
° Efficient instructions (bit, byte & word processing, multiply, divide) 
° Low execution time 
° Versatile input/output interface 
° Versatile and efficient software support 
0 Design based on source code-compatible minicomputer 
At the time of his study, Ebert noted that very few devices satisfied these criteria, 
however current technology is such that new microprocessors are being announced which far 
exceed these specifications. Many new devices are being introduced as this report is written, 
and hence the objective has been to illustrate the potential of existing microprocessors, with the 
assumption that future devices will offer improved performance. 
4.6.2 Classification of Microprocessors 
Early microprocessors tended to offer a standard internal architecture, with a large 
instruction set that typically combined basic A L U operations with a variety of data addressing 
modes. In recent years, more advanced processors have appeared which retain the complex 
addressing capability but expand the instruction set to encompass higher-level operations. The 
execution speed of these devices, however, has only marginally improved and for certain 
applications the older devices can offer a better performance than more modern processors. 
This is particularly true in the case of signal processing, where the complexities of the 16-bit 
machine's instruction set are unnecessary, and has resulted in the introduction of optimised 
devices, with a small instruction set and fast execution speed. The use of these devices in the 
RATES system has been evaluated and the conclusions are discussed later. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 18 
Introduction to VLSI Technology in RATES 
Traditional microprocessors can be subdivided according to a variety of parameters, 
such as register structure, addressing capability & architecture and availability of support 
circuits to enhance the microprocessor's performance. Using Ebert's criteria as a minimum, 
a selection of devices that are likely to be suitable for use in the RATES system is shown in 
Table 4.1. 
1 
Part Number 
& 
Manufacturer 
No. Registers 
& width 
Data Width/ 
Multiplexed? 
Addressing 
Range & 
Architecture 
Mssmum 
Clock Rate 
Additional 
Details 
MC 68000 
Motorola 
8 Data 
8 Address 
2 other (32 bit) 
16-bits 4M Bytes 
Non-multiplexed Linear 
12 MHz 
add: 
multiply: 
Asynchronous data bus. 
Can use 6800 
peripherals. 
8086 
Intel 
4 Data 
6 Address 
4 other (16 bit) 
16-bits 
Multiplexed 
1MByte 
Segmented 
10MHz 
add: 
multiply: 
Operates in segmented 
or 8080 mode. I/O 
instructions using ports. 
32016 
Nat. Semi. 
1 ALU 
8 Other (32 bit) 
16-bits 
Non-multiplexed 
16M Bytes 
Linear 
10MHz 
add: 
multiply 
Requires special clock 
signals. Pre-fetch queue 
& co-processor interface 
99105 
Texas Inst. (16 bit) 
16-bits 
Multiplexed 
256K Bytes 
Linear 
6MHz 
add: 
multiply 
Stack based machine, 
using different code & 
data areas. 
UPD70116 
NEC 
4 Data 
6 Adress 
4 other (16 bit) 
16-bits 
Multiplexed 
1 MBytes 
Segmented 
10MHz 
Superset of 8086 with : 
BCD, bit, multiply & 
divide operations 
Table 4.1 ; Summary of 16-bit Microprocessors 
A study of the above details should reveal that, although representing "state-of- the-art" 
technology, the processing speed of these devices is low by comparison with bit-slice 
programmable parts. This is primarily due to the provision of large register sets which can be 
regarded as multiple A L U configurations, programmed using high level op-codes. Most of 
these processors are based on a nano-programmed instruction set, which is sequenced using 
the external clock with no internal timing generation, and hence many clock cycles are 
required to execute a single instruction. It is therefore not surprising that a 12MHz Motorola 
68000 processor takes twice as long as a 6MHz, 8-bit 6502 to execute an 8-bit Add Immediate 
instruction. Fortunately, this observation is not upheld for 16 or 32 bit operations, and the 68000 
remains a superior processor by virtue of its extensive addressing modes and high-level 
instructions. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 19 
Introduction to VLSI Technology in RATES 
4.6.3 Plot Extraction Using Microprocessors 
In considering the suitability of conventional microprocessors for use in the RATES 
plot extractor hardware, it is necessary to take account of the typical operations required by 
each of the 3 main sections described in the previous chapter (CFAR, WBI and Plot Forming). 
The cell-averaging CFAR requires two additions and two subtractions followed by a 
multiplication and a further two additions in order to calculate the average of two windows 
surrounding a test cell. Using the optimum processor from Table 4.1, this would suggest a total 
of 100 clock cycles, taking 8us at 12MHz or 4.5us at 21MHz, but not allowing for data-access 
overheads. Calculations in the CFAR must be completed within one range period, resulting in 
a maximum of 2p.s (for radar type 'A') processing time. As it is likely that radars with such a 
long pulse width will be sampled at a frequency somewhat higher than this, the use of 
conventional microprocessors in this application would not support the required data rate, and 
some alternative solution must be found. 
An alternative design could be used, based on a rank statistic such as that suggested by 
Rohling [41]. By basing this around a content-addressable data manager, there is no longer a 
requirement to continuously sum the cells in the window, however this would only marginally 
reduce the processing time, which is bound by the multiplication operation (70 clock cycles). 
In spite of the considerable reduction in bandwidth achieved through use of the constant 
false alarm rate processor, the within-beam integrator still requires a worst-case throughput of 
one detection per range cell, as it is impossible to average the detection requirements over a 
longer period of time. A typical sequence of operations to calculate increments and test against 
thresholds may require as many as 17 op-codes and would suggest an instruction cycle of some 
15ns if the faster radar sampling rates were to be accommodated. This is clearly impractical, 
as no devices exist with this specification (at present). A logical solution would seem to be 
offered by handling a number of detections in parallel, across a 16 or 32-bit data bus, but in 
practice this does not achieve any significant saving due to the complexity of the comparison 
operations which must be carried out. 
The same restrictions apply to the plot forming process, which must be able to cope with 
worst-case conditions of one detection every range cell. The only difference between this an 
other processes is that an output need only occur (at worst) once every two range cells, due to the 
restrictions placed on new plots. 
There is clearly potential for using programmable processors in an automatic track 
extraction system, if only to increase the flexibility of the design. Current microprocessors are 
still unable to handle the data rates present in the plot extractor front-end, although the rates 
are more acceptable when considering the output from the plot-forming section. It therefore 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 20 
Introduction to VLSI Technology in RATES 
seems logical to consider their use in additional filtering and tracking operations, an aspect 
which is discussed in detail in Chapter 6. 
The need for fast programmable processors is still apparent in many applications, and 
an alternative to the traditional bit-slice processor has therefore been developed. The Digital 
Signal Processor (DSP) has progressed from being a spin-off from research into speech 
processing and is now available in one form or another from most major semiconductor 
manufacturers. The potential of these devices in radar signal processing warrants a separate 
discussion in Chapter 5. 
4.6.4 Bit Slice Processor Solution 
The bit-slice processor has been available for many years, with only minor additions 
to the family during this time. They were originally intended for designing fast computer 
systems which could be hardware-optimised for the application in hand, and were therefore 
programmed at a very low level by comparison with modern microprocessors . The slices were 
typically produced in 4-bit data widths, but could be expanded to permit the use of any required 
value. Clock speeds were usually fast (10MHz minimum), but it must be remembered that 
many cycles were required to achieve the same results as a single microprocessor operation. 
Bit-slice programming is a complex and error-prone procedure which can easily absorb a 
large part of a product development cycle. 
In contrast, modern bit-slice processors offer a slightly faster clock speed, but a 
considerable increase in data width (32-bit) and instruction complexity. For some devices 
there is now little difference between a slice and a microprocessor, although much of the 
programming complexity remains. 
For a plot extraction system, the speeds available from current slices could easily 
handle the data rates required, even at the front end of the processor in the CFAR section. With 
the width of slices increasing this would be relatively easy to implement in hardware terms, 
however the software complexity would require several man-years work (judging from 
Durham experience with previous designs) and would be unlikely to result in a cost-effective 
final design. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 21 
Introduction to VLSI Technology in RATES 
4.7 A Siurttnary of some other VLSI Devices 
In addition to the devices discussed in previous sections, a number of other VLSI 
components have become available and can be considered for inclusion within the design of 
the plot extractor. The manufacturers of these devices are prominent in the field of radar 
systems, and it is therefore considered useful to draw attention to them. As these are simply 
suggestions for possible future use, no detailed designs have been provided. They are 
summarised below: 
° Plessey PBSP16330, (Pythagoras Processor): 
This device converts cartesian data to polar format at 10MHz clock rate, 
using the conventional Pythagoras algorithm: 
Z = J X2 + Y 2 and 0 = ARCTAN( ) 
The input data can be accepted in 2's complement or sign magnitude format, and 
the magnitude output can be scaled in powers of 2. The phase output represents a 
full 360°, thereby removing any ambiguities 
Plessey PBSP16401, (2-Dimensional Edge Detector): 
This may be used to determine the presence, direction and gradient 
magnitude of an edge within a 3x3 cell frame. The ability to sense and track a 
change in signal amplitude is considered to be of possible use in a variation on 
the conventional CFAR. 
Marconi MA7170, (Bit-Slice Correlator): 
A digital correlator which gives 64 stage correlation (Z^) for a 1-bit 
reference ( a j ) and 4-bit data sequence ( X j ) , at a rate of 10MHz: 
63 
\ = • Xk+i 
i=0 
It can be extended in both width and length to allow for longer 'windows' and a 
wider data path. This device was predicted in Ferranti's report, and several 
C F A E designs suggested using it, but it was not released until late 1986. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 4. 22 
Applications of Digital Signal Processors 
5.0 Introduction 
The potential for using software-programmable devices in radar signal 
processing has long been a subject of study, but until recently has been confined to 
theoretical proposals or reduced-speed demonstrations. The main restriction in the 
past has been the comparatively low clock rate that could be sustained, combined with 
restrictions on the width of the data path that was supported. Recent technological 
advances have resulted in faster components based around a different architecture 
and reduced instruction set, and aimed specifically at traditional analogue signal 
processing applications. It is therefore appropriate to consider the possible uses of these 
'digital signal processors' in RATES, with a view to their use in the plot extraction 
hardware. 
5.1 Digital Signal Processors 
The introduction of microprocessors has revolutionised circuit design over the past 
decade, but in spite of further advances in their design, they remain slow by comparison with 
hardwired logic. This restricts their use in one of the most rapidly expanding areas of interest, 
namely digital signal processing, where the advantages to be gained over analogue 
techniques have already been demonstrated in devices such as Compact Disc Players or 
Digital Audio Tape. An ideal solution to the problem would be a device which offered the speed 
of a bit-slice processor, but the instruction set of a conventional microprocessor, however one of 
the many reasons for the slow operation of a the latter is the vast instruction set that is a feature 
of this type of device. A compromise must therefore be reached between a high-level instruction 
set and a fast execution cycle, and the resulting Reduced Instruction Set Computer (RISC) 
architecture is a feature of all current digital signal processors (DSPs). 
5.1.1 Early DSP Devices 
The first DSP device was introduced by NEC in the early 1980's, and incorporated a 16 x 
16 bit multiplier on a programmable processor. This basic design was substantially improved 
upon by Texas Instruments TMS32010 processor, which appeared shortly afterwards as a 
spin-off from T.I.'s research into speech synthesis techniques. The device has remained 
popular by virtue of its advanced design, including a Harvard address architecture - separate 
program and data areas - which is now a standard feature on DSPs. 
A block diagram of the TMS32010 is shown in Figure 5.1; it incorporates a fast 
pipelined multiplier and allows for limited off-chip memory expansion. Most instructions, 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 .1 
Applications of Digital Signal Processors 
including multiply, execute in a single instruction cycle which corresponds to 160ns for the 
fastest device currently available, and is achieved through use of a 25MHz clock, divided 
down internally. The features of this device can be summarised as follows: 
16-bit instruction / data word 
32-bit A L U / accumulator performing basic arithmetic and logical operations 
0 to 16 bit barrel shifter 
1.5K words of on-chip program ROM 
144 words of on-chip data RAM 
4K words of off-chip expansion memory 
8 input & 8 output channels 
6 megabytes/sec I/O to external devices across 16-bit data bus 
The TMS 32010 supports 60 instructions, using a variety of direct and indirect 
addressing modes including such features as post-increment and post-decrement addressing. 
A limited number of basic instructions are pipelined together as additional operations, but in 
general any load operation occupies one cycle so the device is only capable of high speed 
processing in tasks which involve only a small number of data transfers. 
Program 
Controller 
1 
i T Rftfl (16) 
16x16 
Multiplier 
E,flgfl,(3a.J 
1536x 16 
Program 
ROM 
Program Bus; 
13 
Data Busi 
Shifter 0...15 
\ 32 bit ALU / 
Shifter 0,1,4 
Address Register ARO 
Address Register AR1 
I 
144x16 
Data RAM 
m 
External 
Address 
Control 
External 
Data-bus 
Control 
O 
12 bit 
; Address Bus ; 
< ) f > 
16-bit 
Data Bus i 
Fig. 5.1 : Block Diagram of TMS 32010 DSP 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5. 2 
Applications of Digital Signal Processors 
5.1.2 "Third Generation' DSPs 
The TMS 32010 can be described as a second generation digital signal processor, by 
virtue of its basic features, and it is therefore logical to note the introduction, in recent years , of 
third generation DSP devices. These typically offer enhanced address generation, twin data 
RAM areas, pre-programmed ROM look-up tables and faster execution times. The following 
are examples of third generation DSPs: 
o Hitachi HB61810 
This device is unusual when compared to other members of the DSP family for a 
number of reasons: It is (at present) the only DSP which performs floating-point 
arithmetic by default, and includes instructions to allow conversion between fixed and 
floating-point data formats. 
It has an advanced address manipulation capability, but offers no facilities for 
RAM expansion beyond its internal provisions, which would prove limiting for most 
radar signal processing applications. It is also the slowest of the DSPs with a 250ns 
instruction cycle, although this is predictable when considering floating-point 
operations. 
° Fujitsu MB8764 
The Fujitsu processor allows limited parallel processing by permitting 
simultaneous loading of data registers from the two RAM areas, but its address 
generation techniques are complex and any advantage that would be gained from the 
fast (100ns) instruction cycle could easily be lost in handling the peripheral 
requirements of an I/O bound task. The device's unusual pipelined architecture 
requires that both data and addresses are generated one instruction before they are 
needed and this results in a lower true speed of operation. 
Due to the slow execution speeds and complexities of these third generation DSPs it is 
suggested that some alternative be found for a DSP plot extractor implementation. Fortunately, 
recent 'fourth generation' devices have appeared, offering an ideal solution to the problem. 
The Application of Digital Techniques to an 
Automatic Eadar Track Extraction System. Page 5 . 3 
Applications of Digital Signal Processors 
5X3 The Motorola 58000 
The most impressive DSP specification is currently offered by a new product from 
Motorola, the DSP 56000, which can be considered as a fourth generation device due to its 
high-level instruction set, advanced parallel programming features and microprocessor-like 
design. A block diagram of the complete processor is shown in Figure 5.2. 
16 bit Address Bus: 
2048 x 24 
Program 
ROM 
Internal 
Data-bus 
Switch V' 
24 bit PIO 
: 7 bit PIO 
Host, Serial & 
Parallel 
Interfaces 
X Memory 
256x24 
RAM 
256x24 
ROM 
External Address Control 
Address 
A 
• X Data 
: Y Data 
P Data 
Global Data i 
Program Controller 
Clock Interrupt 
Y Memory 
256 x 24 
RAM 
256 x 24 
ROM 
m 
\ 24 x24 bit / 
\ MAC / 
\56 bit result/ 
External 
Data-bus 
Switch 24-bit 
Data Bus 
Fig. 5.2 : Block Diagram of Motorola DSP 56000 
The DSP 56000 offers a number of advanced features which have not previously been 
considered within the scope of digital signal procesing, including the 4 separate data buses and 
three concurrently operating execution units - address A L U , data A L U and program 
controller. The device is intended to interface easily with a host processor and can be 
configured to use a variety of standard peripherals; It allows memory expansion to 64K words 
for each of the two data memory blocks, and access can be achieved in a single cycle provided 
that both X and Y blocks do not need to access the external memory simultaneously. 
A total of 8 address registers are available on-chip, allowing for indirect addressing in 
a variety of modes: postincrement by 1 ... N, postdecrement by 1 ... N, predecrement by 1, offset 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 4 
Applications of Digital Signal Processors 
by ± N or no modification on access. Each address register (R0...R7) has an accompanying 
offset register (N0...N7) and modulus register (M0...M7), allowing address arithmetic to 
other than modulo 32768 which makes it ideal for queue or buffer processing. The remaining 
properties of this device are summarised below: 
° 100ns instruction cycle, most operations execute in a single cycle 
0 24-bit instruction / data word 
0 24 x 24 single cycle multiplier / accumulator with 56-bit result 
° Twin 56-bit accumulators (A & B), may be split into 2 x 24-bit + 1 x 8-bit (AO...A2). 
Two 48-bit (or four 24-bit) data registers (X0.X1 ,Y0,Y1) 
0 15 level stack allowing nested hardware DO Loops 
o Two independent 256 x 24-bit data RAMs 
° Two independent 256 x 24-bit data ROMs 
° 2K x 24-bit program ROM 
0 24 Programmable I/O pins which may be otherwise configured as: 
- 8-bit host microcomputer interface 
- Serial comms interface with baud rate generator 
- Synchronous serial interface with clock generator 
0 Off-chip memory expansion: 2 x 64K x 24-bit data, 64K x 24 program 
Through use of the separate internal data buses and concurrently operating execution 
units, the processor can be programmed to execute most register-based arithmetic and logical 
functions concurrently with data moves, provided that there is no conflict for any data bus. If, 
through bad programming, the software requires two accesses to the same bus the machine will 
take an extra cycle to complete the operation. It is therefore important to ensure that no 
contentions will arise as a result of concurrent data operations. 
When programming the 56000, the assembler expects four fields to specify the 
operation, e.g.: 
MAC xl,y0,a x:(R0)+,xl y:-R4,Yl ;Comment field 
This specifies a multiply-accumulate operation in which the contents of 24-bit register 
X I are multiplied by those of register YO, & the result is added to the contents of accumulator A. 
The contents of the X memory space addressed by RO are simultaneously loaded across the 
X-Data bus, as the new value of register X I , and RO is incremented. Address register R4 is 
decremented then used as a pointer to a location in Y memory space which supplies the new 
value for 24-bit register Y l . 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5. 5 
Applications off Digital Signal Processors 
To conclude discussion of current DSP devices, the properties of four typical processors 
are summarised below in Table 5.1: 
[J 
Device 
& 
Manufacturer C
yc
le
 
Le
ng
th
 
N
um
be
r o
f 
R
eg
is
te
rs
 
R
eg
is
te
r 
W
id
th
 
D
at
a 
Bu
s 
W
id
th
 
In
st
ru
ct
io
n 
W
id
th
 
D
at
a 
M
em
or
y 
P
ro
gr
am
 
M
em
or
y Memory Expansion 
Program Data 
Other 
Features 
TMS32010 
T.I. 
160ns 
2 data 
2 addr 
1 accum 
16 bit 
16 bit 
32 bit 
16 bit 16 bit 144x16 
RAM 
none 4Kx16 4Kx16 
Barrel Shifter 
2's complement 
arithmetic. 
8 I/O ports. 
Interupts. 
HD61810 
Hitachi 
250ns 
6 data 
6 addr 
2 accum 
16 bit 
16 bit 
20 bit 
16 bit 22 bit 
200x16 
RAM 
128x16 
ROM 
512x22 
ROM 
none none 
Serial I/O. 
Floating Point 
arithmetic. 
All instructions 
single cycle. 
DSP56000 
Motorola 
97.5ns 
6 data 
24 addr 
2 accum 
24 bit 
24 bit 
56 bit 
24 bit 24 bit 
2x256x24 
RAM 
2x256x24 
ROM 
2Kx24 64Kx24 128Kx24 
2 Data Shifters 
High level 
programming. 
DMA„UART & 
CODEC. 
MB 8764 
Fujitsu 
100ns 
4 data 
6 addr 
1 accum 
16 bit 
16 bit 
26 bit 
16 bit 24 bit 2x128x16 
RAM 
1Kx24 none 1Kx16 
16 bit parallel 
interface. 
Divide instruction. 
Variety of address 
modes. 
Table 5.1 : Digital Signal Processors 
Two other 'fourth-generation' DSP's which have been announced recently and may 
represent a significant challenge to the Motorola 56000 devices include: 
° The ADSP-2100 from Analog Devices is based around a similar architecture to the 
56000 and implements concurrent operations and single-cycle execution for all 
operations. 
0 The ZR36010 (also known as the VSP-325), from Zoran Corp., is a more unusual 
DSP in that it performs complex arithmetic on arrays of data. It is primarily 
intended for use in video-picture processing, but its advanced instruction set 
implements a large number of operations of use in general signal processing. It is 
due to be released in sample form in the first quarter of 1988. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 6 
Applications of Digital Signal Processors 
5.2 DSP Design of a CFAR Processor 
A study of Table 4.1 should confirm Ebert's observations that none of the traditional 
microprocessors is capable of supporting the throughput required by the hardware front-end. 
Given that the time available for processing each incoming word from the detector is equal to 
the range cell sampling rate (= pulse width), and that processing must be repeated for every 
range cell, this would allow only 250ns...2\is, depending on radar type. It is likely that radars 
with a long pulse length will be sampled at a greater rate than 1/x to improve accuracy, and 
hence design around an assumed long pulse length would be unwise. 
A CFAR solution using digital signal processors would seem more likely, due to their 
shorter cycle times and high-speed data transfer capability. The clutter map in a DSP 
implementation could be stored on the DSP device itself, the restriction being that only a small 
part of the map could be downloaded at any one time. This would have the advantage of 
simplifying map address calculation, but would require careful synchronisation between the 
source of the clutter-map and the device performing the downloading operation. Most digital 
signal processors support direct memory access (DMA) and it would therefore seem logical to 
use this approach to load the data into the DSP memory, although it would be equally possible to 
load data under control of the DSP provided this were carried out during the interscan period 
when there is no other input to the device. 
5.2.1 A DSP Cell-Averaging C F A R 
The simplest design approach is offered by considering the basic cell averaging CFAR 
processor, which calculates the average signal level in a pre-determined number of "range 
windows" on either side of a test cell. The average is then scaled and offset by both a manual 
quantity and a computer-generated "clutter-map" value, before comparison with the level in 
the test cell. If the test value exceeds the scaled average, a target is declared in that range cell. 
The sliding-window can be regarded as a form of circular buffer of length 2N + 3, 
including 2 guard cells, and where N is the number of window cells on either side of the test 
cell. By splitting this into 2 separate buffers (Figure 5.3), it should be clear that an adapted 
modulo-addressing technique permits a simple program design, which would be ideally suited 
to implementation with a Motorola DSP56000. 
The optimum configuration for the CFAR processor memory should arrange the clutter 
map in external addressing space, to take advantage of fastest download rates from the host 
computer, however there is little advantage to be gained from implementing the map on-chip as 
the software will become unnecessarily complex. The five input parameters (N, Scalar, 
Manual, C-Scale and C-Range) can all be loaded into the registers which comprise the 
DSP56000's host computer interface, thereby simplifying the data access requirements. Should 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 7 
Applications of Digital Signal Processors 
any of these parameters be changed during operation, it will be the responsibility of the host to 
ensure that the new value is passed on to the signal processor. If this approach is adopted it 
should be noted that the host data registers reside in X-memory space, which could prove 
restrictive. 
External Memory: 
Clutter 
Map 
Scalar 
j~Mm Manual 
C-Scale 
C-Range 
X - memory s 
New input value; 
Subtract from sums 
Test amplitude 
n-1 
n-2 
n-3 
n-4 
n-5 
guard 
: Y - memory: 
Add to sum 
Subtract from sum 
n-12 
n-13 
Fig. 5.3 : Memory Configuration for a 
DSP CFAR Implementation. 
Using the memory configuration of Figure 5.3 permits optimised access to the two 
"windows" through parallel loading of registers. All that is needed is to initialise the 
modulo-modifying registers to accept the appropriate buffer size. The sequence of operations 
(which must be repeated for each range cell) then becomes: 
Load new video sample into buffer and add to accumulator 
Subtract pre-test guard cell from accumulator 
Add previous post-test guard cell value to accumulator 
Subtract previous end-window cell from accumulator 
Multiply accumulated value by scalar 
Divide accumulated value by number of cells in window 
Add manual offset 
Add clutter map value 
Compare with test cell - declare target if (test) > (average) 
It is fortunate that the nature of these operations enables a high degree of parallellism to 
be programmed into the design. A suggested program to perform this sequence of operations is 
given below: 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5. 8 
Applications of Digital Signal Processors 
START: 
SUB 
ADD 
ADD 
SUB 
SUB 
REP 
MAC 
YO.B 
XO.A 
Y1,A 
Y1,A 
X1.A 
#1 
X:input, X1 
X1,(R1)+ 
X:(R1)-, X1 
X:c_scale, X1 
Xmanual, B 
Y:(R4)+, Y1 
YO, Y:(R4)+ 
X:(R1)+,X0 Y:(R4)-,Y1 
Y:(R5)+, Y1 
B, Y:output 
X1.Y1.B X:n_over_k, X1 A0.Y1 
;B is <0 if target present. X1 holds new 
;input data(n). (n-9)toY1. 
;A always holds accumulator. Add new data, 
;X1 to (n), old test value to (n-8). 
;Accumulate (n-9). Test value to XO. 
;(n-15)toY1. 
;Subtract (n-15). (n-6) to X1. Clutter 
;map value to Y1. 
;Subtract (n-6). C-Scale value to X1. 
;Manual offset to B, previous B to output 
;C-Scale * Clutter-value + Manual -> B 
MOVEP XO, YO ;Shift test cell to Y memory region 
JMP START 
This program could implement a complete first threshold CFAR processor in nine 
instruction cycles, representing a total of 877.5ns at an internal clock rate of 10.25 MIPS. 
This cycle time would permit a throughput of 1.24 million words per second, although it is 
possible that an improved memory architecture could be found which would allow faster 
operation. A short initialisation program (shown below) would also have to be run, in order to 
configure the registers in the DSP56000, although this stage would not be time-critical as no 
significant data would be flowing through the system. 
INITIALISATION: 
MOVE #8, M1 ;Load X-memory modulus register 
MOVE #8, M4 ;Load Y-memory modulus register 
MOVE #x_block, R1 ;Load R1 with address of (n) 
MOVE #y_block, R4 ;Load R4 with address of (n-9) 
JMP START ;Go execute main program loop 
It should be noted that the choice of address registers is important, as the DSP 56000 
requires that they be divided into two "files" for X and Y memories in order that parallel 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5. 9 
Applications of Digital Signal Processors 
addressing functions in single-cycle mode. In the program shown above, the memory is 
configured for use as a 6-stage sliding window (6-bits on either side of the test cell) with two 
guard cells added to improve performance. Register R l is initialised to point to the n t n video 
input, and after executing the main program loop is left pointing to the new video input cell. 
After 8 times round the loop, the modulo-8 address arithmetic ensures that the register now 
points back to the original input cell thereby maintaining a circular buffer configuration. 
The speed of currently-available devices would allow processing of long pulse-length 
signals, however it is not fast enough to permit second-threshold calculations to be performed 
by the same device. Although it is likely that a faster version of the DSP 56000 will be 
introduced, offering a greater throughput through a higher clock speed, the best alternative is to 
look for a different CFAR architecture. 
5.2.2 A DSP Hank-Statistic CFAR 
A cell-averaging (greatest-of) CFAR DSP wastes much time on loading and storing the 
incoming data, with comparatively little time spent on processing. If a different approach 
(such as the rank based detector proposed by Rohling and discussed in an earlier chapter) is 
adopted a better solution can be achieved by off-loading the storage task to a separate VLSI 
device, and then processing the stored data using a DSP. 
This solution is achieved by loading the incoming data directly into a device such as 
the AMD 95C85, a content addressable data manager (CADM) which sorts the data to form an 
array of ordered samples. The configuration of the device would then permit a particular 
sample to be extracted by the DSP, multiplied by a scaling factor and then added to a manual 
offset. The signal processor could then select the appropriate cell from a clutter map and add 
this to the accumulated value, before comparing the sum with the chosen input cell to produce a 
single binary target indication. 
The use of the CADM allows for future expansion to greater data width, as the device 
can be programmed for between 1 and 255-bit width, although its input/output port is fixed at 
8-bits. All of the signal processors described earlier have a data width of 16-bits or more, and 
hence there would be little difficulty in reconfiguring these devices to a wider data path. 
5.2.2.1 The AMD 95C85 
This AMD 95C85 is a "Content Addressable Data Manager" which consists of I K x 8-
bits of on-chip RAM which can be addressed either directly (as in a conventional RAM) or by 
content, and hence the device is capable of hardware-sorting any data that is written to it. The 
device is seen as an index file with variable length key and pointer fields, which may be 
programmed for any data width up to 255 bytes. Items written to the file may be either sorted on 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5. 10 
Applications of Digital Signal Processors 
entry or in a batch mode, but this process is effectively transparent to the programmer. The 
CADM has a 16-element instruction set which enables selection of a variety of operating 
modes. 
5.2.2.2 Using the 
The CADM would typically be used as an external peripheral to a digital signal 
processor such as the DSP56000, described in the previous section, in order to reduce problems of 
hardware design. A suitable sequence of operations for this configuration is given below. Note 
that it is still necessary to involve a circular buffer design in the DSP in order to extract entries 
from the CADM after they are out of window range, but the buffer does not need to be split as 
guard cells are not used. 
0 Set CADM to search for outgoing window value & pop off stack 
0 Set CADM for on-line sort & load new video sample into memory / buffer 
° Set CADM for direct access and read "K"th value 
° Multiply this value by scalar 
0 Add manual offset 
° Add clutter map value 
° Compare with test cell - declare target if (test) > (average) 
As with the previous design, the parallel loading capabilities of the signal processor 
can be used in order to speed execution. The complete program for implementing a DSP 
rank-based CFAR is given below, with suitable initialisation code for the processor and 
CADM coming before the main program loop. 
INIT: 
MOVE 
MOVE 
MAC 
MAC 
CMP 
Xmanual, B #LAS-K, Y:cadm 
X:c_scale, XO Y:(R5)+, YO 
XO, YO, 8 X:scalar, XO Y:cadm, YO 
XO, YO, B 
A, B A, Y:cadm 
;Set CADM for Rnd access at Kth 
•.address & load manual offset into B. 
;C-scale to XO, computer offset to YO 
;Scalar to XO, rank value to YO 
#STK+FND, Y:cadm ;Set CADM to stack mode & locate next 
;operand 
;Compare result with test value 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 1 1 
Applications of Digital Signal Processors 
It should be clear from the above program that use of the DSP is restricted largely to a 
series of data moves, and hence the processing speed of this device is lost. An improvement 
could be achieved through use of a combined DSP / CADM / custom logic solution, where the 
data load and control sequences to the CADM were generated by some programmable logic 
(Figure 5.4). This could achieve a reduction to only 5 cycles for the complete CFAK. processing 
operation, which would permit a data throughput of approx. 2 MHz - sufficient for most 
surveillance radar pulse lengths. 
Range Clock 
Timing & Control 
AMD 95C85 
r CADM 
Video Input 
-4 
Host Micro 
Interface 
Motorola 
DSP 56000 
Digital Signal Processor 
• 
Binary Target 
Output 
Fig. 5.4 : Configuration of DSP and CADM 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 1 2 
Applications of Digital Signal Processors 
5.3 The Within-Beam Integrator 
The combination of a within-beam integrator with a constant false alarm rate 
processor would be an ideal objective for a DSP plot extractor, however the two previous 
examples have shown that in spite of their short cycle lengths, these devices are still not fast 
enough to accomplish both tasks in the allotted time period (one range clock cycle). An obvious 
solution would be to divide the task between a number of signal processors, however it is 
unlikely that this approach could be justified on grounds of cost, and much of the device's 
processing power would be wasted in the WBI section. 
The basic sequence of operations required by a programmable within-beam integrator 
can be established from discussions in the previous chapter, however it should be clear from 
this that no advantage is to be gained by using a DSP due to the narrow width of the WBI data 
bus. The DSP 56000's 24-bit data bus would be largely redundant as only 5-bits are required by 
the current WBI configuration, and there would be little advantage in increasing this figure. 
The input to this section is only a single bit, and again the DSP 56000 is not suited to this type of 
data. In general, high speed operation would not be possible due to the number of conditional 
instructions and the restrictions of the DSP 56000 instruction set. As the requirement to address 
a 4K-nibble threshold memory would discount the use of all but the Motorola device, it is 
suggested that some alternative method of implementing the within-beam integrator function 
be adopted, such as the ULA solution proposed in the previous chapter. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 1 3 
Applications of Digital Signal Processors 
5.4 Plot Forming Processing 
Although constrained by the need to complete a processing cycle on at least every other 
range cell period, the extent of the calculations involved in the plot forming process make it an 
ideal target for DSP implementation. As with the within-beam integrator, difficulties arise 
due to the single-bit format of the input data and any solution will probably require a 
compromise between complex hardware and flexible (but slower) firmware. 
The basic plot forming process generates pairs of 16-bit co-ordinates, based on the 
centre of gravity of a group of binary cell "hits". As plots must be integrated both in range and 
azimuth the present design is configured to store a minimum of 128 active plots at any one 
time, although a larger number would be more acceptable. A total of five 16-bit values must be 
stored for each plot, requiring a minimum of 128 * 5 (= 640) words of storage. This is 
unfortunately out of range of the Hitachi DSP, which would have otherwise been the most 
suitable for the design due to its versatile floating-point arithmetic operations. From the choice 
of remaining devices the DSP 56000, with its parallel loading features and expandable 
external memory, seems to provide the best solution to the problem, assuming the X and Y 
memories are chosen so as to give optimum concurrent access without extra wait states. Using 
Motorola DSP instructions, a sample program for the plot forming operation, is given below: 
S T A R T : 
MOVE X:theta,X1 Y:(R4)+, Y1 ;x1=0ae, y1=0e 
S U B X 1 . Y 1 . B X:(R1)+, A Y:(R4)+, YO ;x1=Re,b=0pw,Y0=Re 
CMP #dw, B X:num,X1 ;X1=3N 
J G E Close 
ADD X I , A X:(R1)+, XO Y1, Y:(R5)+ ;store 0 e , xO=I0 
MUL X I , B X:(R1)+, X1 YO, Y:(R5)+ ;store Re, x1=IR 
ADD XO, B A, X:(R2)+ Y:weight, YO ;store I N 
ADD YO, XI B, X:(R2)+ ;store Z 0 
MOVE X I , X:(R2)+ ;store I R 
JMP Start 
Plot closure sequence 
C L O S E : 
LUA A0.N7 Y1,A ;INton7 , 
MOVE X:(R1)+, XO Y:(R7+N7), Y1 ;x1=I0, Y0=1/IN, 
MAC X 0 . Y 1 . A X:(R1)+, XO YO, B 
MAC X 0 . Y 1 . B A, X:bearing 
MOVE B, X:range 
JMP Start 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 1 4 
Applications of Digital Signal Processors 
The potential of a DSP plot extractor is illustrated by this program, which executes a 
complete plot forming sequence (regardless of whether the plot is completed or re-circulated) in 
10 cycles. It is likely that the code could be optimised still further, but in its present state is 
capable of handling most plots, which could be output directly to the host processor DMA 
interface on-chip. A study of the code should indicate that the principle of operation is similar 
to that of the RATES hardware: data is read in from one buffer and re-written (if the plot is not 
closed) to a different area. Some code would therefore be needed to switch the buffers at the end 
of each scan, but this would not be time-critical due to the length of the interscan period. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 1 5 
Applications of Digital Signal Processors 
5.5 Summary of DSP Applications 
Digital signal processors represent the most viable solution to the problem of 
implementing a programmable plot extractor, and their performance is likely to be enhanced 
still further over the next few years. The Motorola DSP 56000 has been released recently and, 
whilst not offering comparable performance with the existing RATES hardware in terms of 
speed, shows considerable potential as the basis of a feasability study into future DSP designs. 
Texas Instruments have also announced their successor to the TMS320 processor, with cycle 
times reported to be equal to those of the Motorola device, but no further information is available 
at the time of study. General Intrument Corp. have also released CMOS varients on the TMS 
32010 with on-chip EEPROM. 
In the short-term, a solution may be best achieved through use of a combined 
programmable logic / digital signal processor approach, possibly using DSPs to realise the 
CFAR and plot forming functions, with the remainder provided by the hardware. In time, it is 
likely that faster devices will be made available which would be capable of implementing a 
complete hardware plot extractor on a single chip, 
Finally, it should be noted that the programs described in this section have been based 
on advance information supplied by Motorola, without access to full programming details. 
There is therefore no certainty that programs will execute correctly, particularly when 
considering concurrent data movements, for which rules regarding legal operations have not 
been clarified. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 5 . 1 6 
A Miciropipocessoip-lbased Tracking Systsnm 
6.0 Introductiom 
The greatest potential for improving the design of the prototype system can be 
found in the tracking computers. The current design has resulted in inefficient 
software and a complex interface which is totally unnecessary when compared with 
modern design techniques. A radical redesign of the tracking system is therefore 
proposed, using an efficient interface design and optimised software. This chapter 
sets out to illustrate that a more compact interface with the plot extractor hardware can 
be achieved. The design is supported by examples of software modules which illustrate 
the advantages of a low-level approach to the problem. 
61 The R A T E S Prototype Tracking System 
The RATES prototype is designed around a hardware front-end processor feeding plot 
data into a computer, which then performs further filtering and tracking operations before 
producing target-movement predictions. These operations are described by the MASCOT 
connectivity diagram in Chapter 3 (Figure 3.19), although it should be noted that this includes a 
number of features which have been added to help assess the performance of the prototype. 
The data received by the computer consists of co-ordinates based on the 
centre-of-gravity of filtered plots. At this stage, many of these will be due to false alarms (an 
average of at least eight per revolution) but must be checked to see if they could correspond to 
any existing moving targets. Those which fail to associate with existing targets must be 
removed. 
As RATES is intended primarily for target tracking, the next stage is to filter-out 
stationary plots, to avoid wasting processing time while attempting to follow fixed targets. All 
remaining plots must therefore be either tentative or confirmed tracks and any remaining 
processing time can be devoted to calculation of target velocity, heading and expected position. 
The R A T E S design provides the user with full manual control, to enable 
operator-assisted initiation of target tracking and to adjust threshold levels to compensate for 
variations in clutter regions which have been detected by the experienced operator. It is also 
possible to select any confirmed track and obtain status information, which is then displayed 
on the operator's console. 
The additional prototype functions include a means of recording plot data to removable 
magnetic media, and allowing it to be replayed at a later date at the same speed, or faster (or 
slower) if required. In this mode, the software is capable of storing plot data to an additional 
hardcopy device, such as a printer, or drawing the tracks on a suitable plotter. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 1 
A Microprocessor-based Tracking System 
An early version of the prototype used twin Ferranti Argus 700 computers to carry out 
filtering and target tracking, but following difficulties with resource sharing this was 
abandoned in favour of a single machine. In terms of physical size, the Argus accounts for 
approximately half of the total volume and it would therefore seem logical to study the 
feasibility of replacing this machine with a single board solution, using more modern 
technology. 
6.1.1 Advantages of a Miaroproce§sor-ba§ed Tracking System 
The redesign of the RATES tracking computer, adopting current semiconductor 
technology, would offer a number of advantages, due in part to the high-speed operation of 
existing microprocessors and peripherals. 
The main interface to the plot extractor hardware, which currently accounts for almost 
one third of the total number of circuit boards, could benefit from being completely 
re-designed. The basic function of the interface is to control DMA transfer to and from the 
Argus, but a new design would permit the use of existing specialised V L S I controllers, 
especially those related to the host microprocessor family. 
The use of surface-mount and leadless chip-carrier (LCC) semiconductor technology 
would permit a single processor board solution, which could be installed alongside the existing 
plot extractor hardware and would require less power than the Ferranti Argus. If 
recommendations regarding the hardware redesign are adopted, this would increase the 
likelihood of a successful 2-board solution to the problem of automatic track extraction. 
The current tracking software is written in Coral 66, but has already been shown to 
contain a number of bugs and general shortcomings. The MASCOT design approach to the 
software has been undertaken so as to retain compatability with similar systems, but does not 
offer any advantages in terms of speed of execution. Similarly, the MASCOT approach results 
in a less optimised code, which could be substantially improved by redesigning around a 
specific processor and hardware configuration. It is probable that optimised software, written 
in assembler or a medium/high level language, would result in a substantial increase in the 
performance of the RATES tracking potential. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 2 
A Microprooessor-lbfflsed Tracking System 
6X2 Determination of a Suitable Mieroprocessoir Solution 
Ebert's microprocessor criteria (Section 4.6) are aimed primarily at automatic 
tracking and filtering functions, and can therefore be used as a basis for determining suitable 
devices to replace the existing computer hardware. Table 4.1 listed a small sample of devices 
which satisfy these criteria, providing a high level of performance which is likely to be 
exceeded by future product releases from their manufacturers. Using the product details alone, 
it is impossible to recommend a suitable replacement however, and it is necessary to take other 
factors into account and compare these with the Ferranti Argus specification, before a final 
choice can be made. 
6.1.3 The Femranti Argus 700 
The Ferranti Argus is essentially a multi-board computer which can be easily 
expanded to suit differing applications, whilst retaining a ruggedised construction, suitable 
for military use. It supports an instruction set which is similar to those of the processors in 
Table 4.1, permitting bit-wise, shift, arithmetic (*/+-), logical (AND, OR) and comparison 
operations. Typical instruction execution time provides a useful benchmark for comparison 
with other processors and some examples are given in Table 6.1, against two of the devices 
from Table 4.1 (based on fastest available clock rate). 
At this point the NEC and T.I. microprocessors have been disregarded as the former is 
essentially an enhanced version of the Intel 8086, but is not so well supported. The T.I. device 
is considered unsuitable due to its stack-orientated processing which is more appropriate to a 
mainframe-style application than the register-based RATES software. Appropriate details of 
the National Semiconductor product have not been forthcoming. 
Processor Register 
Multiply 
Register 
Divide 
Register 
ADD 
ADD 
Immediate 
-
Register 
AND 
Register 
CMP 
Subroutine 
RET 
Ferranti 
Argus 7.1us 7.8us 1.85us 2.65u.s 1.85us 1.85us 3.0us 
MC 68000 
Motorola 
<70 (cycles) 
< 5.8us 
<140 
<11us 
4 
0.3us 
8 
0.6us 
4 
0.3us 
4 
0.3us 
16 
1.3|J.s 
8086 
Intel 
118 (cycles) 
11.8US 
162 
16.2U5 
3 
0.3us 
4 
0.4jis 
3 
0.3ns 
3 
0.3us 
16-26 
1.6-2.6us 
Table 6.1 : Comparison of Processor Execution Times 
The above table clearly illustrates the dramatic improvement in speed that can be 
achieved using modern microprocessors, when compared with the Ferranti Argus. The fast 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 3 
A Microprocessor-based Tracking System 
multiply and divide times of the Argus are exceptional and can probably be attributed to a 
hardware multiplier built into the machine's CPU. These functions are usually implemented 
in microcode on traditional microprocessors. 
Working from these figures, it is suggested that a microprocessor replacement for the 
Ferranti Argus will result an improved tracking performance due to the increased speed of 
operation. Not surprisingly, this in turn will be dependent on a number of other factors such as 
choice of programming language, efficiency of compiled code and construction of a suitable 
interface to the plot extractor hardware, so attention must be paid to these areas in order to 
maintain the advantages offered by the technology. 
6.L4 Choice of Microprocessor 
If the table of sample execution speeds were used to select a suitable microprocessor, the 
advantage clearly lies with the Motorola 68000. There are, however, other factors which support 
this device as an ideal choice: 
° The MC 68000 offers the largest number of registers and addressing modes, 
thereby increasing its flexibility. 
0 Although on only a 16-bit data bus, the internal width is 32-bit and long-word 
operations can be performed with little overhead. 
° Data and address buses are not multiplexed, so address translation and 
interfacing is more straightforward. 
0 Programming is simplified by the continuous linear address space 
° The asynchronous bus will readily interface to a variety of devices, and may 
prove to be an important factor in a direct interface with the RATES hardware. 
The Motorola product range is second-sourced by a number of other manufacturers, 
including Hitachi, Thomson-CSF and Mostek and volume-supply difficulties are therefore 
unlikely to arise. Motorola offer potential for future upgrades, and it can be argued that their 
products are an indication of future trends in other manufacturer's technology. All 68000 
family microprocessors are fully code compatible and hence a solution developed using the 
'bottom-of-the-range' 68000 will be fully transportable to future products including : 
68010 - Available, but only adding a virtual memory capability to the 68000. 
68020 - Also available: 32 bit, 20Mhz processor, high performance capability. 
68030 - Announced & quoted as offering higher performance than a top-range VAX. 
As reports have suggested that the 68020 outperforms the comparable offering from its main 
competitor (the Intel 80286) it would therefore seem wise to concentrate on use of Motorola's 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6 . 4 
A Miciroproeessor-lbased Tracking System 
products for a long-term solution to the automatic tracking computer. 
From a more personal point of view, there is already considerable experience in the use 
of the MC 68000 in Durham, as this device had been chosen for a number of earlier projects. A 
cross-assembler is also readily available, based on the Northumbrian Universities Multiple 
Access Computer (NUMAC) installation at Durham, which can be used to download compiled 
code across a serial link. 
6.1.5 A Note on Other Processors 
Digital signal processors have not been considered for use as replacements for the 
RATES tracking computers. On the basis of Ebert's criteria, they are precluded by virtue of 
their limited addressing capability and instruction sets. Until recently, they could only be 
programmed in assembly language, and the complexity of DSP assembler would render this 
an unsatisfactory solution, as there would be a noticible increase in the required development 
time. 
Another family of processors which has not been used in this design is the Inmos 
Transputer range. These devices (discussed in a later chapter) offer sophisticated 
inter-processor communications which make them ideal for array-orientated processing, but 
unsuitable for the sequential program design of the automatic track extraction software. In 
this latter type of application, recent studies have noted that the Motorola 68020/68881 
combination exhibits a performance increase of 2.5 times over the top-of-the-range Inmos T800 
transputer. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8. 5 
A Microprocessor-based! Tracking System 
&2 Development System Computer Hardware 
It has been mentioned that one of the factors supporting the choice of the Motorola 68000 
processor was a degree of experience in earlier work involving this device, which had resulted 
in a number of development boards becoming available for use in the RATES project. 
Manufactured by Motorola, the boards offered space for additional user-designed circuits and 
could be customised as required. It was decided that this would enable identification of the 
ideal hardware configuration, with the aim of locating a specific single-board commercially 
available design, that would function with little or no modification in a production system. 
6.2.1 The Motorola MEX 68 KDM 
The board, the MEX 68 KDM, was originally designed for use with early production 
prototypes of the XCS 68000 chip, and was supplied with 16K-words of RAM and a small monitor 
program in ROM. The board was fitted with two asynchronous RS-232 ports, two 6821 parallel 
ports and a counter/timer chip. Based on Motorola's Exorciser bus (an 8-bit bus designed for 
the 6800 processor), the KDM board could easily be expanded to address external memory or 
devices, with a maximum addressing range of 128K bytes. A small monitor program was 
supplied with the board, capable of basic terminal control, memory modification and 
upload/download to a host computer using the Motorola standard 'S' record format. A block 
diagram of the complete board is shown in Figure 6.1. 
The restrictions of the KDM board meant that a number of modifications had to be made 
before it could be used alongside the RATES hardware. In a production system it is unlikely 
that these modifications would be applicable, as suitable hardware of the required specification 
would be more readily available. 
There was insufficient RAM to hold both the code and data for the tracking software 
(based on the data storage requirements of the prototype software), and so the 16 RAM chips 
(type 4116) were replaced with semi- pin-compatible upgrades, using Cowan's report [55] as a 
reference. After modification, the board held a total of 128K bytes of RAM, which was deemed 
to be sufficient for an initial implementation of the RATES software. 
The Motorola monitor (MACSbug), which was supplied with the KDM boards, was well 
documented but had clearly been based on an early 8-bit operating system, and took account of 
the most common non-functioning instructions in the XCS68000. As a result it was very slow 
and made little use of the extensive loop-handling and bit manipulation features of the 
MC68000. Whilst this in itself was not a problem to the RATES software, the inability to load 
Motorola 'S2' records (those with a 3-byte address) meant there was little compatibility with 
existing cross-compilers. It was therefore decided to implement a modified proprietary 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 6 
A Microprocessor-lbaseell Tracking System 
monitor in place of MACSbug, taking advantage of its use of similar device addresses. A 
small number of modifications were made, and the replacement EPROMs installed on the 
board in place of the original chips. 
2 x 8-bit 
Parallel 
Port 1; 
St ~ 
^ OO 
Q_ CO m 
2 x 8-bit 
Parallel <M> 
Port 2 
Counter^ 
Timer* 
Control::: 
Motorola 
MC 68000 
Microprocessor 
: Control: 
Data 
Bus 
• 
Bus 
Address:: 
I^Dynam 
Bus 
ic RAM Control 
16Kx 16 
(16x4116) 
RAM 
mm W 
Fig. &1 ; MEX 68 KDM Development Board Schematic 
The development board interface was comprehensive, and required little modification 
to enable it to drive external peripherals. Three pins were designated as available for 
additional bus signals, and one of these was therefore used for address line A17, enabling use 
of a full 64K bytes of external storage which did not conflict with the internal port addresses. 
The complete pin-designation diagram is given in Appendix B together with a description of 
the associated pin functions. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 7 
A Mioffoprocessor-based Tracking System 
6.2.2 Development!; Sequence 
In the timescales available for research, it is unlikely that a complete implementation 
of the RATES system with all of the features of the prototype could be produced. A list of 
development priorities has therefore been established, with the aim of offering an increasing 
degree of user-visible functionality, whilst at the same time providing some means of 
assessing the processor loading factor. This list also takes account of the constraints imposed 
by component availability, notably the floating-point hardware to assist the MC68000, which 
was not available at the time of work on the hardware. 
Stage 1 : Establish suitable interface to plot extractor hardware 
Stage 2 : User keyboard interface - establishes early control of system for operator. 
Stage 3 : Output interface software - confirm functioning output to plot extractor 
Stage 4 : Control of plot input & miscellaneous information input from extractor 
Stage 5 : Display of input plot data as synthetics characters 
Stage 6 : Filtering of stationary plot information 
Stage 7 : Update of moving track data 
Stage 8 : Update unassociated plot data 
Stage 9 : User interface - confirmed track enquiries 
Stage 10: Prototyping and "debug" facilities, e.g. hardcopy output, record / replay. 
The progression of development through these stages is evident from the discussions 
which follow. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 8 
A Microprocessor-based Tracking Systemm 
8.3 The Computer Interface 
As stated earlier in this chapter, one of the prime aims of a replacement tracking 
computer should be a redesigned interface to the plot extractor hardware. The current design 
comprises one quarter of the total number of boards in the system, and is largely dedicated to 
the specific requirements of the Ferranti Argus's direct memory access (DMA) interface. It 
also takes account of the possibility that the computer may not be situated near to the extractor 
due to space considerations, and provides for full buffering and error detection across a 
parallel link. 
A new interface can adopt one of several formats: 
° Retain the ME62 interface structure, but adapt the MC68000 board to work with the 
existing Function H boards. 
0 Redesign the ME62 interface using VLSI components, to produce a more compact 
solution along the same lines as the original. 
° Adopt a memory-mapped solution, which places the input/output sections of the 
plot extractor hardware in the memory space of the new processor and thereby 
dispenses with the need for RATES functions F and H. 
The first of these options is clearly unsatisfactory, as it results in little change to the 
existing hardware, and will only reduce the physical size of the final solution because of the 
difference in size between the Argus processor and the MC68000. This option would require 
additional circuits to interface from the existing Argus bus signals to those applicable to the 
MC68000's bus structure. The advantage of this solution would be the ability to locate the 
processor remotely from the plot extractor hardware, but with the ultimate aim of a single (or 
twin) - board RATES system, this would have little practical advantage. 
Similarly, the second option does little to address the problem of the physical size of the 
existing interface, and whilst redesigning the functions F and H may result in two single 
replacement boards, the only true advantage gained is that of the remotely-located processor 
board. If this were a requirement, then this option would be sensible, as it would enable a more 
optimised interface to the MC68000 bus to be incorporated. 
For the type of application currently under study, the third option represents the best 
solution as it would completely remove the need for any of the data acquistion and 
re-distribution functions contained on boards F and H . The processor board, however, does 
need to be located close to the rest of the hardware, to avoid problems with system noise. 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6 . 9 
A Microprocessor-based! Tracking System 
y j Application off Memory Mapping to KATES 
Early microprocessor applications communicated with external devices through 
"ports", which typically provided a buffered interface through to the data bus. Each external 
device required its own port, and each port was given its own address, which could (in some 
processors) be accessed through special I/O instructions. Communication through these ports 
often took longer than a similar memory-access cycle, but avoided the problems of buffering 
and possible damage to the processor. With improvements in semiconductor technology, the 
sink current of most integrated circuits has dropped and it is now possible to drive a large 
number of devices, even from an unbuffered processor bus. This, coupled with the increased 
addressing range of most processors, has made memory-mapping an ideal solution to the 
control of external peripherals. 
Through memory mapping, each I/O function of the plot extractor hardware is 
assigned a unique address (or range of addresses) within the computer's memory space. The 
processor can then read from or write to the function as if it were a conventional area of 
memory, without the need for specialised instructions or parallel ports adapters. The Motorola 
processor is particularly suitable for this technique due to its linear address space, which gives 
access to any memory location without the need to predefine a 64K byte working segment. The 
asynchronous data bus is another useful feature, which results in the processor being 
compatible with any speed of peripheral device. In practice, the MC68000 begins a read or write 
cycle to a peripheral in the same manner as synchronous processor, but then enters a 
continuous "wait" state until the peripheral acknowledges with a cycle-completed signal 
(DTACK). This allows the designer to choose the optimum settling time for the peripheral 
response, possibly allowing extra time for noisy or heavily-loaded data bus conditions, which 
would otherwise produce unpredictable results with a synchronous processor. 
One of the disadvantages of using memory mapping is the need for a relatively close 
proximity to the associated peripherals, in order to reduce the effects of noise on the bus. As a 
consequence, the RATES system has been re-housed in a modified cabinet which permits the 
KDM board to be inserted alongside the remaining boards, in spite of its occupying a 
double-height slot. The board's edge connector is wired into the remaining plot extractor 
hardware through a special interface, which is described in detail later. The immediate 
advantage to be gained from this approach is that the ME62 computer interface is no longer 
needed, as there is no significant distance between processor and peripherals. Similarly, there 
is no need for any logic to pack and unpack the data for transmission across the bus, as all of 
these functions can now be undertaken by the MC68000 itself. The prototype functions F1.. .F4 
and H1...H5 are therefore redundant, and the total number of boards in the system can be 
reduced from 36 to 29, including the processor and interface. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 10 
A Microprocessoif-based Tracking Systenm 
GL8.2 F i o t E x t r a c t o r I n t e r n e s Funct ions 
There are a total of 8 functions in R A T E S which require some form of input/output with 
the tracking computer. These are detailed below, along with two extra functions which are part 
of a later release of the R A T E S software. Complete data formats are given in F i g u r e 6.2. 
Constant False A l a r m K a t e processor - (Output) 
Consists of 7-bit threshold and 9-bit partial address, with the remainder of the address 
supplied directly by function G. Data transfers therefore have to be synchronised to the correct 
octant and must occur during the interscan period. 
Synthetics Display Characters - (Output) 
256 x 2 words with first word carrying 3-bit octant and 9-bit bearing information, and 
second word carrying 10-bit range and 6-bit character code. Transfers must take place during 
the scan period as synthetics are displayed during interscan. 
Test Target Co-ordinates - (Output) 
3 x 2 words, each encoded to 12-bits accuracy. F irs t word is target range, second is 
target bearing. Transfers take place during the interscan period. 
Electronic Counter-Measures Report - (Input) 
32 x 2 words, first of which is the bearing of the E C M sector, and followed by the width of 
the sector. 
Rol lba l l Co-ordinates - (Input) 
Read as 2 separate words from different locations. One is the X-coordinate, the other the 
Y-coordinate. Can be read at any time. 
Ships Motion Data - (Input) 
A single 16-bit word, with the ship's heading encoded in the lower 10 bits and ship's 
speed in the upper 6 bits. 
V B U Status Monitor - (Input/Output) - Version 3 
Five separately-addressable registers which control the operation and display of the 
status V D U which was added as part of software release version 3. This addition is discussed 
later in Section 6.6.3. 
Number of Plot Input Words - (Input) - Version 3 
A single word which represents the number of plot words transferred to RAM. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 1 1 
A Microprocessor-based Tracking System 
Constants W o r d - (Input) 
T h i s is a single word which holds information regarding the settings of 
user-selectable options, and the status of the plot extractor cycle. The following 9 parameters 
can be determined from this word: 
° Radian? Select , C - K a n g e , C-Sca le , M a g n i f i c a t i o n : Al l reflect the state of these 
switches on the control panel. In later versions of the software, Radar Select is 
bi-directional, and overrides the setting on the console. 
° O c t a n t : Is taken from Function G 2 and indicates the currently scanned W B I 
octant (which may not be the same as that being scanned by the C F A R ) . 
0 I n t e r S c a n : Active low, indicates an interscan period is in progress. 
0 N o r t h : Active low, indicates a north-marker cycle. 
° Octant D e m a n d : Active low, request from the plot forming hardware to transfer 
data into the tracking processor. 
0 S top : An active high signal which indicates that all available plots have been 
read from the plot extractor interface. 
Extracted Plot Data - (Input) 
This is an output from plot extractor function E 4 , and consists of pairs of words with the 
f irst carrying the plot bearing, and the second the plot range. Data input to the computer 
continues until the Stop flag, in the constants word, is raised. In later versions of the software, 
this feature is removed, as a more sophisticated DMA technique is employed. 
to 
ro 
tn c o o 
Inter-
Scan North 
c . „ bctant 
S , o p [Dern 
Magnification :Octant C - Scale C - Range Ratiar Setect 
Threshold Value \ Bearing ThreshoW Range \ 
o 
CL 
: Octant : : : Synthetics Bearing : : : 
Character Code : Synthetics Range : : : 
Plpt Integer Bearing 
• Plot Range • 
F i g . 6.2 ; Format of System Data 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6 . 1 2 
A Microprocessor-based Tracking System 
(8.3.8 Address Al loca t iom 
Use of memory mapping offers a significant improvement in efficiency for some of the 
R A T E S data transfers. For example, the clutter map was originally transferred as a 16-bit 
word, made up from a 7-bit threshold and 9-bit partial address. The most significant 3-bits of 
the address was supplied by the current octant value (from function G ) , requiring that 
clutter-map data transfers be synchronised to the correct octant. The mapping technique 
allows the C F A R clutter-map to be treated as a section of the processor's own memory space, 
with the threshold address being supplied directly from the RDM's address bus, independently 
of the currently scanned octant. Data transfers must still occur during the interscan period 
and some care is needed to avoid conflict with the C F A R ' s own access cycles. The control 
processor therefore monitors the state of the I N T E R S C A N signal which is obtained as the most 
significant bit of the Constants Word. 
Although similar to the above case, the synthetics character memory, E C M report buffer 
and test-target latches are not treated as blocks of memory, as their current design would 
require extensive modification to allow true memory mapping. For a production system, 
however, these changes would be acceptable and could be implemented with little difficulty. 
In designing the address map for the plot extractor, the aim was to simplify the 
interface through minimum address translation. The map for the development board is given 
below, using address space from OOOOOjg to 3 F F F F i g : 
$00000 $003FF MC68000 Ex c e p t i o n V e c t o r s ( i n RAM) 
$00400 $006FF MACSbug Vec t o r s ( i n RAM) 
$00700 $1FFFF User RAM (128K bytes ) 
$20000 $21FFF MACSbug Monitor Program (ROM) 
$22000 $2FFFF EPROM Expansion Space 
$30000 $3FEFF Spare 
$3FF00 $3FFFF On-board P e r i p h e r a l s 
To allocate a total of 11 peripheral addresses, with an 
approximately even spread of read-only and write-only locations, the most economical 
translation is obtained using a 32K-byte block, and addresses spaced at 4 K byte intervals. 
Allowing for possible future E P R O M expansion, the best solution for the development system is 
to use the block of memory from $30000 to $37FFF, and to translate only the upper 6 address bits, 
plus A l and W R I T E . This also allows for possible future peripheral expansion into the $38000 -
$ 3 F E F F region. The resulting address map is given in T a b l e 6.2. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page S . I S 
A Microprocessor-based Tracking Syetemn 
ADDRESS PLOT EXTRACTOR FUNCTION STATUS 
30000 - 3 0 F F F C F A R C l u t t e r Map W r i t e o n l y 
31000 - 3 1 F F F i i i i 
3 2 x x x S y n t h e t i c s D i s p l a y C h a r a c t e r s W r i t e o n l y 
3 2 x x x ECM R e p o r t B u f f e r R e a d o n l y 
33000 - 33004 VDU S t a t u s M o n i t o r R e a d / w r i t e 
3 4 0 0 0 R o l l b a l l X C o o r d i n a t e R e a d o n l y 
3 4 0 0 2 R o l l b a l l Y C o o r d i n a t e R e a d o n l y 
3 5 0 0 0 C o n s t a n t s Word R e a d / w r i t e 
3 5 0 0 2 N o . I n p u t P l o t s R e a d o n l y 
3 6 x x x T e s t T a r g e t C o o r d i n a t e s W r i t e o n l y 
3 6 x x x S h i p s M o t i o n Word R e a d o n l y 
37000 P l o t I n p u t B u f f e r R e a d o n l y 
Table &2 : H o t Extractor Peripherals Map 
6.3,4 Thelntei fecetotheFlotEstractoir 
The memory map allows all of the plot extractor functions to be accessed, simply by 
reading from, or writing to, a specific memory location and thereby dispenses with functions 
F and H , which were responsible for this action in the prototype. The design of the original 
hardware incorporates low-power tri-state latches for most of the addressable functions, so 
these be used to interface directly to the (buffered) input/output bus of the K D M board. 
Interfacing is, in most cases, reduced to simply providing an enable signal for these latches. 
The only complication that arises is in ensuring that those functions which latch output data 
from the computer are synchronised to the appropriate data strobes. The complete interface 
circuit is built on a single board and included in the plot extractor as Function K l . A schematic 
diagram of the board is shown in F i g u r e 6.3. 
The eighteenth address line from the K D M board is brought out to the interface on one of 
the unused pins (PWR F A I L ) , as it is not normally available for external use. Thi s is 
combined with the 5 other most significant address lines, and used as inputs to a device 
mapping P R O M . The P R O M allows the exact configuration of peripheral addresses to be 
changed at a later date, without the need to rewire the interface, or the connections to it. The 
remaining two address inputs to the P R O M are provided by address line A l and the 
Read/Write strobe line, allowing differentiation between a read-only and write-only location. 
When correctly addressed, and accompanied by an address select strobe, a 
device-select code is output from the P R O M , and used as direct input to a 3-to-8 line decoder, 
which provides the appropriate enable signal for the various plot extractor functions. The most 
The Application, of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 14 
A Microprocessor-based Tracking System 
significant bit of the output code is used to enable the decoder and is always set i f the device 
address is legal - thus there is no output from the decoder for an invalid device address. Al l 
devices which can be written-to have their enable signals gated with the upper and lower data 
strobes, since these define the timing for the write cycle. Once the strobes go high, the enable 
signal is removed and the new data latched in the plot extractor hardware. 
AS 
A17 
A16 
A15 
A14 
A13 
A12 
A1 
WRITE 
LDS 
UDS 
w o a>tr 
<Ma_ 
CO 
A3 
EO 
DO 
D1 
D2 
D3 
D4 
D5 
D6 
D7 
D8 
D9 
D10 
D11 
D12 
D13 
D14 
D15 
12 
11 
S 10 
8 I 
-g 8 
<D 5 
•S 4 
5° 3 
2 2 
1 
8 
• Spare 
• Plots 
- Ships Motion 
> Rollball Y 
- Rollball X 
>VDU 
ECM 
=TT Coords 
Synthetics 
-CFAR 
• Radar 0 
- Radar 1 
-Radar 2 
-C Range 0 
•C Range 1 
• C Scale 0 
-C Scale 1 
-Octant 0 
-Octant 1 
•Octant 2 
•Magnil 0 
-Magnif 1 
•Oct Demand 
-Stop 
• North 
•InterScan 
•DO (from 
... RATES 
•D15 bus) 
Fig . 6.3 ; Computer Interface (Kl) Schematic 
The outputs from the 3-to-8 line decoder are enabled by the AS strobe, which ensures that 
data is only passed to the computer bus when a valid address is present on the address bus. This 
strobe also controls the tri-state outputs of the data buffers. 
The data-acknowledge timing for this interface ( D T A C K ) is derived from the 
computer board and produces a cycle time which is the same as the main processor memory. 
None of the interface devices has been found to give rise to errors using this timing cycle, 
which is illustrated in F i g u r e 6.4. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 15 
A Microprocessor-basedl Tracking System 
Bus Address X 
Bus Data X 
LDS / UDS 
DTACK 
J 
\ / 
AS 
Write Cycle 
Device Strobe 
n 1 
V / 
\ 
"A n o d U w y u l U / 
Fig . 6.4 : Plot Extractor Interface l i m i n g 
For the majority of the R A T E S devices, the interfacing procedure is relatively 
straightforward: they may be read or written at any time regardless of the state of the plot 
extractor cycle. For certain devices, however, access is limited to either a scan or interscan 
period to prevent conflict with internal cycles. During the operation of the plot extractor 
hardware, the following transfers must take place as indicated: 
S c a n Period: 
Synthetics character data. 
InterScan Period: 
C F A R threshold data 
Test target coordinates. 
In addition to these restrictions, it should be noted that plots can only be transferred 
following receipt of an O c t a n t D e m a n d signal, or in overload conditions an I n t e r o c t a n t 
D e m a n d . Thi s limitation is due to the peculiar double-buffering arrangement of the plot 
extractor interface, and results in a somewhat inefficient operation of the plot output process. 
In practice, the synchronisation of the data transfers to the plot extractor hardware is 
left to the software in the tracking computers, whilst correct device activation and cycle timing 
remains under the control of interface function K l . 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6 . 16 
A Microprocessor-lbased Tracking System 
The P R O M on this board (type 82S129, 256x4-bit) is programmed with a code which 
corresponds to the device which must be activated at a given address. For the 11 devices listed, 
the codes are given below, in T a b l e 6.3. 
C F A R 01 S Y N T H E T I C S G2 
T E S T T A R G E T 03 E C M 04 
V D U M O N I T O R 05 C O N S T A N T S OS 
No W O R D S m R O L L B A L L X 03 
R O L L B A L L Y GS> S H I P S M O T I O N OA 
I N P U T P L O T S OB ( I N V A L I D A D D R E S S ) CO 
Address 0 1 2 3 4 5 6 7 8 9 A B C D E F 
00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
10 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
20 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
30 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
40 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
50 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
60 1 1 1 1 2 0 5 5 0 0 0 0 3 0 0 0 
70 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
80 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
90 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
AO 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
B0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
CO 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
DO 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
E0 0 0 0 0 4 0 5 5 8 9 6 7 A 0 0 0 
F0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
Table 6.3 : Interface P R O M Programming Codes 
It should be remembered that the above table decodes addresses based on the upper six 
most significant address lines from the processor, the least significant address line (Al) and 
the write status strobe. The use of the P R O M allows future devices to be added simply through 
reprogramming, without the need to rewire any of the interface. I t is analagous to the address 
decoding PROMs on the M E X 68 K D M board, which were also reprogrammed to take account of 
the changes in use of the 68000 address space (Cowan, [55]). 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 1 7 
A Microprocessor-based Tracking System 
a 3 J The P lo t Ou tpu t I n t e r n e e 
The interface linking the plot extractor hardware to the tracking computer presents the 
greatest potential for bottlenecks during processing, as the original design has made a number 
of assumptions concerning the volume of plot data passing through this point. Function E 4 has 
been designed around a maximum of 512 plots per octant, with provision made for occasional 
overflow conditions, (which cause an interoctant transfer to be initiated). 
Plot data is collected by function E 4 in one of two F I F O buffers, and when one buffer 
becomes full they are switched and the computer requested to handle a transfer into its 
memory. The buffer switch is essential to avoid loss of plot data while the computer responds to 
the request. Whilst this remains a viable option for the redesigned tracking system, the 
inefficiency of the double-buffer configuration draws the conclusion that some improved 
interface should be attainable. 
Considering the operation of the plot extractor (functions E 1 . . . E 3 , E 5 ) , it has been noted 
from observations of the prototype system that there is little difference between the 3 and 5 cell 
plot depth options during plot forming. The latter allows for a guard zone of 2 range cells before 
another plot can be started, and it can therefore be established that there must be a minimum 
delay of 2 range cell periods between output plots from function E 3 . 
Taking the worst-case parameters defined in Chapter 4, this would imply that the 
maximum rate of plot transfer directly from the plot forming section would be one plot every 
three range cells, corresponding to a frequency of 1.3MHz. With typical memory access times 
of only 250ns, a viable solution would be to transfer data directly from function E 3 into the 
tracking computer memory. To this effect, the following two solutions are proposed: 
e Design a customised interface which permits D M A transfer between the plot 
forming processor and the tracking computer, using discrete logic or 
semi-custom devices. 
° Implement a general purpose interface, using a proprietary D M A controller and 
associated control circuitry. 
A third option, to implement a DMA interface between the existing function E 4 and 
the computer shall not be considered, as it does little to alleviate the problem of slow data 
transfer rates. The other two options both have advantages, and are now discussed in detail. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 1 8 
A Microprocessor-based Tracking System 
6.4 A C m t o m D M A Interface 
A custom DMA interface represents, potentially, one of the most economical solutions 
to the problem of transferring data from the plot extractor hardware to the tracking computer. 
In theory, it would allow a dedicated link between the output of function E 3 and the memory on 
the processor board, and could be optimised for a fast response. The scale and complexity of the 
design is determined by the timing requirements of both sides of the interface: should these be 
too complex, it is unlikely that the best solution can be achieved through custom logic. 
6.4.1 Interface T i m i n g Considerations 
The interface timing is dictated largely by the 68000's bus request sequence, but must 
be initially under control of the plot extractor hardware. The plot forming controller E l 
generates timing signals which are distributed to the other functions in this group. Of these the 
signal W P is the most important, causing a word to be written from the plot calculator to the 
buffer. It has a worst-case period of 1 range-clock pulse, and it is therefore necessary to achieve 
a response from the processor during this time. Fortunately, the plot extractor guarantees that 
no plots will overlap by less than 2 range periods and hence the following conditions apply: 
Maximum period to alert processor to transfer: 250ns 
to transfer plot output: 500ns 
A study of the M C 68000 timing diagrams will indicate that the worst-case response to 
a bus request is during a processor bus cycle. In these conditions, the processor still responds in 
3 processor clock cycles which, for an 12MHz part running at full speed, is equal to the 
worst-case W P period. 
A complete timing diagram for the bus arbitration and output sequence is given in 
F i g u r e 6.5 - the exact sequence is as follows: 
1) Plot forming hardware issues W P pulse, approx. 250ns duration, active low. 
2) Bus Request ( B R ) issued from interface to processor, to acquire control of bus. 
3) Processor responds with Bus Grant ( B G ) , acknowledging availability of bus. 
4) After short period of time, interface replies with Bus Drive (BD) & takes control of bus. 
5) On rising edge of Plot Latch Clock ( P L C ) , address is latched onto data bus, address 
counters are incremented. 
6) Data and write strobes go low, as P L C goes high to allow bus to settle. 
7) On rising edge of S T R O B E S , azimuth data is latched into memory on processor board. 
8) Range Select ( R S ) goes high, latching range data into plot forming output buffer. 
9) P L C goes high again, putting new address onto address bus, and incrementing address 
counters. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 19 
A Microprocessor-based Tracking System 
10) After 1 clock period, S T R O B E S go high latching range data into processor board memory. 
11) After 1 further clock period, Bus Drive goes high and bus is released back to processor. 
12) Interface cycles, waiting for second W P pulse. Once this goes high, the interface is 
effectively reset back to the initial state, waiting for an active low pulse on W P . 
«^T_jTj^jiJij^-rLn_rLrLJiJ 
WP (from E1) ] ~ ~ 
Bus Request (to processor) 
Bus Grant 
1 _ 
(from processor) 
Bus Drive (to processor) 
UDS/LDS 
~ u _ r 
(to processor) 
WRITE (to processor) 
Plot Latch Enable (to function E3) 
Range Select (to function E3) 
F i g . 8.5 : Interface T iming Requirements 
It should be clear from these details, that timing is critical for this process to succeed: If 
the interface timing clock is too fast, the memory cycle (address setup to write strobe) may be 
too short and data lost. I f the clock is too slow, the interface may not be fast enough to cope with 
the incoming plot rate. The speed of response of the plot forming hardware is not a limiting 
factor however:- it uses low-power Schottky devices, with a typical response time of 10's of 
nanoseconds. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 20 
A Microprocessor-based Tracking System 
6.4.2 Design of a D M A State Machine 
The implication that the DMA interface for the plot forming function is based around a 
specific set of t iming parameters, rather than simple boolean expressions, draws the 
conclusion that the interface design can best be achieved using a state machine representation. 
Using this technique, the DMA process is described as a sequence of operations, with specific 
outputs at each stage, and a set of defined inputs which cause the process to advance to the next 
stage. 
The previous section has already discussed the inputs and outputs relevant to the 
operation of the interface, and by equating similar outputs this may be summarised as follows: 
I N P U T S O U T P U T S 
W P (Write Pulse) B R (Bus Request) 
B G (Bus Grant) B D (Bus Drive) 
S T R O B E ( U D S / L D S & W R I T E ) 
P L C (Plot Latch Clock) 
R S (Range Select) 
The state machine is described by allocating an initial state (1) then defining the input 
conditions which cause a switch to state 2, and the corresponding change in output as a result. 
The DMA interface is described in full, using this technique, in F i g u r e 6.6. 
The initial state numbers are allocated randomly from 1, although they may not represent the 
ideal choice for a hardware design and may be changed later. The state changes are described 
as cause and effect, for example the expression: 
OX/010 
linking state 1 to state 2 implies that while the machine is in state 1, an input of 01 or 00 will 
cause a change to state 2, and the output will then become 010. 
For the DMA interface, the input is specified in the form: 
W P . B G / 
and output as: 
B R . B D . D S . R S . P L C 
An X in the input condition implies that a binary value of 1 or 0 from this signal will satisfy the 
part-expression. 
The Application off Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 2 1 
A Microprocessor-based Tracking System. 
A study of the state machine description will indicate that it entirely satisfies the 
conditions expressed in the timing diagram ( F i g u r e 8.5). 
DC'111 
OX/010 
1X/111 
OX/111 
8 
00/000 
OX/111 1X/110 
3 01/010 
7 1X110 
XX 100 
© 
XX/110 yxx 
XX/100 XX/100 
6 5 4 
F i g . 6.6 ; D M A Interface State Machine 
The D M A interface requires only 8 unique states to realise its cycle, and it is therefore 
possible to represent this machine using a 3-bit binary counter. Whilst the entire design could 
be achieved using small-scale integrated logic, the best solution to a practical implementation 
is to design around a conventional programmable-logic array ( P L A ) . T h i s solves the 
problems of an otherwise complex gate-logic design, and allows other features to be included to 
improve the overall operation of the interface. 
Current P L A devices al l conform to a set of standard definitions, regardless of 
manufacturer, and the one which represents the best solution to the DMA interfacing problem 
is the 16R4 (16 I/O pins, 4 D-type latches). The registers are totally independent, and it is 
necessary to include programming logic for the counter which describes the internal states. To 
optimise the device for high-speed glitch-free operation, the counter should work around a 
modified Gray code and the following sequence is suggested (with reference to F i g . 6.6): 
011(1), 001(2), 000(3), 010(4), 110(5), 100(6), 101(7), 111(8) 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 22 
A Microprocessor-based Tracking System 
The sequence is somewhat arbitrary, and is chosen after a certain amount of trial-
and-error in establishing the solution which results in the simplest set of boolean expressions. 
The state diagram can now be converted to tabular format, expressing next-state and output as 
a function of present state and input. The result is given below in T a b l e 6.4: 
Present State 
QO Q1 Q2 
Input 
0 1 1 
0 0 1 
0 0 0 
0 1 0 
1 1 0 
1 0 0 
1 0 1 
1 1 1 
0 0 
001/01100 
000 / 00100 
010 / 10001 
110/10110 
100/ 10001 
101/10100 
111/11100 
111/11100 
0 1 1 
001/01100 
001/01100 
010 / 10001 
110/10110 
100/ 10001 
101/10100 
111/11100 
111/11100 
Input is: WP. BG 
Output is: BR. BD. DS. RS. PLC 
011/11100 
101/11100 
010/ 10001 
110/10110 
100/ 10001 
101/10100 
101/11100 
011/11100 
1 1 
011/11100 
101/11100 
010/ 10001 
110/10110 
100/ 10001 
101/10100 
101/11100 
011/11100 
Key: 
NEXT STATE / OUTPUT 
Table 6.4 : D M A Interface State Table Description 
This state table allows a set of descriptions to be drawn-up, defining the output signals 
and the inputs to the D-type latches in terms of the current value of the state counter and the 
input signals to the P L A . Although not strictly necessary for a P L A design, these can then be 
simplified using Karnaugh Map techniques. The results are programmed into a P L A 
compiler / programmer using a standard set of programming rules. 
This stage of design requires several important points to be noted: 
1) The device is programmed in terms of its output and input pins. 
2) Registered gates are programmed in terms of the state of their output pins, 
following the next positive clock-edge input. 
3) Outputs are inverted. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 23 
A Microprocessor-based Tracking System 
6.4.3 D M A H a r d w a r e Des ign a n d F ^ g r a m m i n g 
The complete program takes account of these rules, and a listing is given below. The 
format is a standard P L A programming language and can be interpreted by reference to any 
suitable manual. To simplify programming, the pins are assigned mnemonic names on the 
5th (pins 1 to 10) and 6th (pins 11 to 20) lines of the program. 
PAL16R4 
RATES P l o t e x t r a c t o r i n t e r f a c e PLA, inplementing DMA functions 
R.R.S 9/8/84 
CLK BG WP RCO CK2 FULL POR AS P9 GND 
OE RS STR BR Q2 Ql QO PLC BD VCC 
/Q0:= /QO * /Ql + ; REGISTER OUTPUT 0 
/Q2 * Ql + 
/QO * Q * BG + 
/QO * Ql * Q2 * /BG * WP + 
/POR + 
/QO * Ql * Q2 * /AS 
/Ql:= /QO * /Q2 * /WP + ; REGISTER OUTPUT 1 
/QO * /Ql * WP + 
/QO * /Ql * Q2 * /RCO + 
/QO * /Ql * Q2 * FULL + 
QO * Q2 + 
/POR 
/Q2:= POR * QO * /Ql + ; REGISTER OUTPUT 2 
POR * /QO * /Q2 * /WP + 
POR * /QO * Ql * WP + 
POR * QO * /Q2 
/BR:= /QO * /Ql * Q2 * /WP * /FULL * RCO + ; BUS REQUEST 
/QO * Ql * Q2 
I F (VCC) BD = QO * Ql * Q2 + ; BUS DRIVE 
QO * /Ql * Q2 + 
QO * /Ql * /Q2 + 
QO * Ql * /Q2 
I F (VCC) PLC = /QO + ; PLOT LATCH CLOCK 
QO * /Ql * Q2 + 
QO * Ql * /Q2 
I F (VCC) STR = QO 
QO 
Ql * Q2 + 
/Ql * /Q2 
STROBE (write / enable) 
I F (VCC) RS = /QO + 
/Q2 + 
QO * Ql Q2 
; RANGE SELECT 
DESCRIPTION 
P2 i s bus grant; P3 i s write pulse; P4 i s buffer f u l l ( a c t i v e high) 
P5 i s same as CLK; P6 i s buff e r lock ( a c t i v e low); P7 i s power-on r e s e t 
P8 i s address strobe; P9 i s unused; P10 i s GND; P l l i s output enable (low) 
P12 i s range s e l e c t ; P13 i s strobe; P14 i s bus request; 
P15-P17 are s t a t e counter outputs (not normally used) 
P18 i s p l o t l a t c h clock; P19 i s bus drive ; P20 i s VCC. 
The Application of Digital Techniques to an 
Automatic Eadar Track Extraction System. Page 6 . 24 
A Microprocessor-based Tracking System 
I t should be noted that a number of additional inputs have been included to ensure that 
the state counter starts in a pre-defined state (power-on reset), the number of plots that can be 
transferred is limited to the maximum address range of the address counter (RCO) and the 
D M A is stopped at the end of an octant while the word count is read ( F U L L ) . These could have 
been defined in the original state diagram, but their limited effect means that it is simpler to 
add them by a process of inspection and deduction. 
The programmed P L A is included into the complete interface circuit, as shown in 
F i g u r e 6.7. This is based around the general interface shown earlier (Figure 6.3), but includes 
the address generation and DMA control circuits as well. 
S P A R E 
SHIPS MOTION 
ROLLBALL X 
ROLLBALL Y 
VDU 
ECM 
V R I T E 
U D S _ 
- T T C O O R D S 
S Y N T H E T I C S 
r 
RADAR 0 
RADAR 1 
RADAR 2 C RANGE 0 
C RANGE 
C SCALES 
C SCALE 1 
OCTANT 0 
OCTANT 
OCTANT 2 
MAGNF1 
OCT. DEMAND 
STOP 
NORTH 
INTERSCAN 
} 74LS374 74LS374 
CLK — 
BO — 
WP 
D
A
 
H4
 
p18 
pi » - pig 
p2 p » 
p3 
P8 p13 
— < j cdf 
74LS590 
ccten 
< G 
74LS590 
• BD 
• BR 
. RS 
• STR 
Fig . 6.7 : Custom D M A Interface Schematic 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 25 
A Microprocessor-based Tracking System 
The interface can be connected directly in place of the original function E 4 , and has 
been extensively tested using a logic analyser to detect unexpected logic states, such as may 
arise from plot overload conditions. The circuit gives rise to the timing diagram shown in 
F i g u r e 6.8, which may be explained as follows: 
State 1: 
Default (inactive) state: waiting for write pulse from function E l , following from completion 
of a plot forming operation. 
StateS: 
Interface has received write pulse from E l , and provided that the previous octant's word count 
has been read ( R C Q is low) and the address counter is not full ( F U L L is low), the machine has 
proceeded to state 3 and B u s Request has been issued. 
BusReq. 
BusGrant 
BusDrive 
Data Strobe 
Range Select 
Plot Latch Clk 
F i g . 6.8 ; P L A T i m i n g Cyc le 
State?: 
Host processor has responded with B u s G r a n t , and the transfer cycle is started. I f W P goes high 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 26 
A Microprocessor-based Tracking System 
before B G is received, the transfer cycle is aborted. In state 7, the PLA activates the Bus Drive 
signal, which simultaneously connects the data strobes onto the processor bus, and takes the 
memory write signal low. The first address is output to the global address bus, and this counter 
value latched into the word count buffer (rising edge of P L C ) . The data strobes go low and after 
a single cycle settling time, the data is latched into the processor memory on the rising edge of 
the strobe signal. The address counters are incremented to the next address. 
State 5; 
The sequencer issues a pulse on Range Select, to latch the range data on function E 3 into the 
output latch. 
State 4: 
As in state 7, the next address word is output to the address bus and the data written on the rising 
edge of the data strobes. The address counters are incremented to the next address. 
State 6: 
The Bus Drive and memory write signals remain low for a final cycle, to allow the bus to 
settle. 
State 2: 
B u s Drive goes high, and the bus is released back to the host processor. The cycle is not 
complete, as the interface operates considerably faster than the original plot extractor timing 
sequence and there is a second write pulse due from function E l . 
State (h 
WP is received from E l , and the interface enters a loop, awaiting the completion of this cycle. 
State Is 
The interface is reset to its original state, awaiting a write pulse following completion of a plot 
forming operation. 
If the counters reach their maximum permissible value during data transfer, the ripple 
carry output is fed back into the PLA, and further transfers are inhibited as the interface is 
held in state 1. This condition is reset by reading the data-word count buffer, which also resets 
the address counters to zero. Successive octants transfer data to one of two areas of memory, 
depending on the value of the address line A13, which is toggled upon receipt of the Octant 
signal from timing function G2. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 27 
A Microprocessor-based Tracking System 
6.4.4 Interface Testing and Reliability 
The tests on this interface have shown that the design is generally reliable in terms of 
transferring data out of the plot extractor hardware but, as may be expected from the above 
description of operation, shows failings when transferring to a heavily loaded host 
microprocessor. This may be explained by one of two (independent) reasons: 
1) Under certain conditions, the MC68000 does not respond with an inactive address strobe (AS) 
within the permitted time period - the sequencer therefore assumes an abandoned request and 
the data is lost. To allow for this possibility would require more logic states and would take the 
design beyond the complexity of current 20-pin PLA devices. 
2) The design of the DMA unit blocks data transfer for a short period at the end of an 'octant', 
whilst the old word count is read from the latches by the host microprocessor. Again this 
reduces the complexity of the interface, and in practice should only lead to loss of plot data 
within the guard-ring surrounding the antenna. If the processor is heavily loaded, however, 
this operation may be delayed and local data may be lost before the DMA interface recovers. 
With this design, it should also be noted that the unit is unable to respond to inter-octant 
transfers, as buffer-switching is under the control of the Octant Request input to the J-K 
bistable. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 28 
A Midropiwjisessoir-bfflsodl Tracking System 
BJa Interface Design rasing Proprietary Devices 
The interface described in the previous section was an early attempt to solve the 
problems of direct data transfer into the MC68000's address space. Its advantages of low cost 
and high speed operation, coupled with the lack of availablity (at the time) of any suitable 
alternative indicated that this form of DMA transfer remained the optimum solution to the 
problem, in spite of the restrictions of flexibility and the limitations discussed earlier. 
With the introduction of a proprietary DMA controller, the Motorola 68450, it seemed 
logical to study the applications of such a device in replacing the custom DMA interface, with a 
view to enhancing the performance and removing the limitations of the earlier design. 
6J>J. The Motorola 68450 
The Motorola 68450 is intended as a flexible solution to traditional DMA interfacing 
problems, and has been designed to afford a maximum of functionality from a single chip. 
With more high speed devices becoming available, requiring rapid block transfer into 
processor memory, the limits of a single DMA channel are obvious and this device therefore 
offers four such channels. Each may be programmed using on-chip registers, allowing a large 
number of operating modes and ensuring compatibility with earlier 6800 devices - an 
important point which enhances Motorola's standing through its provision of "future-proof 
devices. 
The MC68450 is designed around a 16-bit bus, which carries the multiplexed data and 
upper address buses. It is capable of addressing memory in the same range as the MC68000 
itself, and can accomplish either memory<->memory or memory<->device operations using 8, 16 
or 32 bit operands. The device can be configured to start transfer following an external signal, 
or under software control, and the transfer can then take place using cycle-steal techniques or 
by complete bus control. Additionally, the source and destination addresses can be 
programmed to increment or decrement independently during transfer operations. 
The large number of operating modes suggests that this device will offer the ideal 
solution to the problems of DMA transfer from plot extractor to tracking computer. A study of 
the appropriate data sheets for the MC68450 will indicate a wide variety of timing cycles, and it 
is therefore important to choose the right operating conditions for the device to ensure 
successful operation with the timing requirements discused in Section 6.4.1. The timing 
diagram for the interface to Function E 3 (Figure 6.4) still applies, as the same signals can be 
used to generate and control the transfer request (i.e. requests will be initiated through WP 
from Function E l ) . The transfer of both range and azimuth data must be completed within a 
worst-case cycle time of 500ns, which corresponds to 6 cycles at 12MHz clock rate. The fastest 
transfer mode available with the MC68450 permits 4 cycle operation, but will only allow a 
The Application of Digital Techniques to am 
Automatic ffiadar Track Extraction System. Page S. 29 
A Midroprocessoir-basecl Tracking Systemm 
transfer using 16-bit operands (not long word) in this mode. The complete plot transfer must 
therefore take place as two separate single word operations, each initiated by its own WP write 
pulse. 
At present, the only commercially-available version of the MC68450 runs at a 
maximum of 8MHz and it is therefore impossible to demonstrate full speed operation under 
worst-case conditions. The plot extractor interface can, however, be designed around any of the 
slower radars to illustrate the potential of this device should faster components be released onto 
the market. With this in mind, the interface has been constructed and tested up to maximum 
plot transfer rates: 
6.5.2 Harfwara Integration and Operation 
The MC68450 has been designed to work with an MC68000 host processor using a 
minimum of additional interfacing circuitry. The majority of the interfacing connections 
are either tri-state or bi-directional and can therefore be wired directly to the counterparts on 
the KDM development board, and for this reason the DMA controller and associated 
components have been assembled on the prototyping area that is provided on this board. The 
device has been wired on the unbuffered side of the bus, with address and control lines 
connected to the outputs of the appropriate processor signal buffers. The data lines are 
connected in place of the (removed) parallel i/o chips. With this configuration it is important 
that the direction of the complete bus is not reversed when the DMA controller is bus master. 
Additional integrated circuits are included to separate the multiplexed address and data buses, 
but subsidiary logic makes use of spare gates in the existing memory expansion circuit as 
much as possible. The complete circuit (including memory expansion logic) uses a total of 7 
integrated circuits and is illustrated in Figure 6.9. 
The device is capable of being triggered by an active signal on any of the K E Q inputs, 
but is configured to use only channel 0 for the plot forming interface. All other request inputs 
are tied high through resistors. The three lines carrying bus exception codes (BEC0. . .BEC2) are 
derived from the modified control interface (Function K l ) , which normally holds these inputs 
high unless some form of error occurs during data transfer. Peripheral control lines 
(PCLO. . .PCL2) are not used, as the interface is under control of the output from ACKO which 
goes low for the duration of the data transfer. This signal is used to control the direction of 
certain KDM data-bus signals without reversing the entire bus, as would have happened prior 
to modifying the KDM board. The system clock is derived from the same source as the host 
processor, such that both parts operate at a nominal 8MHz. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6. 30 
A Micropifocessoif-basenl Tracking Systesm 
D3 64 63 
01 01 33 DM 34 
System Da 19 35 Ox* DB 
38 
on 37 +5» D3 
38 
03 
39 
<0 co D7 41 
PI 
R5S 43 
R 44 RE01 IT •3 45 REOO 
<8 
47 
48 
POT 
co AI7 AO OO Pa.1 AS CO 8 PCLO 
CO AB 
LO All 
s AO A3 
CO 29 
^ i 28 BUS CONTROL 27 B E C 2 
80 
AT SO 
fa 
63 
Al 
•sera 23 Al 55 
24 Al 58 
25 ACKI 57 
ACKO 
14 A S 
TBI 13 
HAS1 
12 
15 A S 
A7 UM2 7 A15 DMA SELECT BUSDfl 
wiiw i 
USDS 
A17 
inn 
DELAY 
BGMX Memory expansion control 
Fig. 8.9 : 68450-basedL DMA Controller Schematic 
The signal, B U S C O N T R O L , is used to force the KDM board address and control 
buffers into a high impedance state whenever the DMA controller is bus master. The lower 8 
DMA address bits are bidirectional and can therefore connected directly to the outputs of the 
corresponding processor signals. 
The remaining part of the interface is a modified version of that used in the 
custom-designed Funct ion K l . The sequencing logic in the PLA is no longer required, 
however a PLA design is used to simplify the enable logic for the various interface functions. 
The word counters are also retained to provide a measure of the accuracy of the DMA 
controller's transfer mechanism, as they will count every pulse on WP, regardless of whether 
a DMA transfer takes place. The schematic of this circuit is shown in Figure S.10. 
The circuit can be split into two parts : the address mapping control and the DMA 
transfer logic. The 82S126 is programmed as described in Section 6.3.4 (Table 6.3), with the 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6. 31 
A Biioinopnoicessor-basedl Tracking Systems 
exception that the address translation for input plots is no longer required. The PROM 
produces mapping codes that are used as selection inputs to the 4-to-16 line decoder (74LS154). 
The decoder is enabled by a combination of an active address strobe (AS) and an active input 
from either of the data strobes. The logic for this operation is included in the PLA, making use 
of spare output capacity within this device to avoid the need for extra SSI devices. 
SPARE 
SPARE 
SHIPS MOTION 
ROLLBALL X 
ROLLBAU Y 
VOU 
ECM 
TT COORDS 
SYNTHETICS 
CFAR VRITE 
RADAR 0 
RADAR 1 
RADAR 2 
CRANGE 0 
GRANGE 1 
C S C A L E O 
C SCALE 1 
OCTANT 0 
OCTANT 1 
OCTANT 2 
MAGNFO 
MAGNF1 
SPARE 
SPARE 
SPARE 
HTERSCAN 
74LS590 74LS590 
DMA REQO 
RETRY 
R E L S E 
»5V 
OCTANT 
IRQ 
5 « c A2 
NORTH 
no 
Fig. 8.10 s Function K l : DMA <-> Plot Forming Interface 
The constants word can still be enabled onto the data bus although the Stop signal is no 
longer required. Octant Demand and North signals are also ignored, as this modified 
interface is more suited to interupt-driven timing control in place of the polling techniques 
used in the Function E4-based design. Both signals are re-timed to a fixed period instead of 
being dependent on the rate of the range clock. 
The DMA control side of the interface is still based around input pulses from Function 
E l which are used to request a DMA transfer to take place. The additional logic in the PLA is 
The Application off Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6. 32 
A Microprocessor-bases! Tracking System! 
used to limit transfers to certain conditions and prevent overflow of the processor memory. 
Following a power-on condition, the interface looks for an active low signal on WP. When 
this is received, the word counter is incremented and a request signal generated on 
DMA_Request. The DMA controller responds by transferring a single word from Function E3 
to the processor memory. The plot forming controller generates the plot latch signal to latch the 
azimuth data in the output buffer, then sets WP low again to transfer the second word. 
This process continues until either 2048 words have been transferred in a single octant 
(in which case further DMA_Requests are inhibited), or Octant Trigger is activated by G l . At 
this point, OctantJLRQ is activated and pin 5 of the PLA goes high inhibiting further DMA 
transfers. The interrupt causes the processor to reprogram the DMA controller with a new base 
transfer address, then to read the word count from the interface. The read signal clears the 
Octant Trigger latch and pin 5 of the PLA is taken low again following receipt of the next 
interscan signal. This process ensures that the interface should be reset in only one whole 
transfer period, with minimum loss of data. The L I N E signal allows the entire DMA interface 
to be disabled under external control. 
The PLA also includes logic to encode a number of potential bus error conditions onto 
the three bus error control lines ( B E C Q . . . . B E C 2 ) , although only the reset option (from 
power-on-reset) is used in this implementation. Programming details are given below: 
PAL16L8 
RATES Pl o t e x t r a c t o r i n t e r f a c e PLA c o n t r o l l i n g 68450 DMA. 
R.R.S 3/1/85 
HLT BER RTR REL INH WPI LIN LDS UDS GND 
WRT FUL DEN CEN REQ POR BE2 BE1 BEO VCC 
I F (VCC) DEN 
I F (VCC) CEN 
I F (VCC) REQ 
I F (VCC) BE2 
/LDS * /UDS 
INH + FUL + LIN 
WPI + INH + FUL + LIN 
POR * /HLT + 
POR * /BER + 
POR * /RTR + 
POR * REL 
; Decoder enable s i g n a l 
; Word counter enable 
; DMA request s i g n a l 
; BEC2 
I F (VCC) BE1 = POR * /HLT + 
POR * BER * RTR 
; BEC1 
I F (VCC) BEO POR 
POR 
HLT * /BER + 
HLT * RTR 
; BECO 
DESCRIPTION 
PI i s Bus Halt; P2 i s Bus E r r o r ; P3 i s Bus Retry; P4 i s Bus Release 
P5 i s Transfer I n h i b i t ; P6 i s WP; P7 i s LINE; P8 i s Lower Data Strobe 
P9 i s Upper Data Strobe; P10 i s GND; P l l i s Write; P12 i s Max. Word Count 
P13 i s Decoder Enable; P14 i s Counter Enable; P15 i s DMA Request 
P16 i s Power-on Reset; P17 i s BEC2; P18 i s BEC1; P19 i s BECO; P20 i s VCC. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6. 38 
A Micffopirocessoir-based Tracking System 
6.5.3 DMAPrograimmiigConsideratioms 
For successful operation, the DMA controller requires careful programming of each of 
its control registers. For each DMA channel there are 12 8-bit, 2 16-bit and 3 32-bit registers 
which allow programming of a variety of options. For full details of all registers it is 
important to study the appropriate manufacturer's technical literature, however brief details 
are given below to justify programming methods. The registers are selected by supplying an 
8-bit address and activating the chip-select input. 
7 0 
Channel Status Register (CSR) 
Channel Error Register (CER) 
Device Control Register (DCR) 
Operation Control Register (OCR) 
Sequence Control Register (SCR) 
Channel Control Register (CCR) 
Nornal interrupt Vector (NIV) 
Error Interrupt Vector (EIV) 
Channel Priority Register (CPR) 
Memory Function Codes (MFC) 
Device Function Codes (DFC) 
15 Base Function Codes (BFC) 
Memory Transfer Counter (MTC) 
31 Base Transfer Counter (BTC) 
Memory Address Register (MAR) 
Device Address Register (DAR) 
Base Address Register (BAR) 
For identification of parameters, the DMA nominally transfers data between a device 
and a block of memory. There is no restriction, however, on the device simply being another 
block of memory. The start-transfer memory address is programmed into the 32-bit Memory 
Address Register (MAR). If data is to be transferred from an addressable device (rather than 
one with an acknowledge line), the corresponding device address is programmed into the 
Device Address Register (DAR). The base address register is only used in chained operations, 
which are not applicable to this design. The plot forming interface is not addressable, however 
all other devices in the plot extractor are addressable. 
A count of the total number of words to be transferred is programmed into the Memory 
Transfer Counter (MTC), which is then decremented after each word transfer. When it 
reaches zero no further transfers are permitted on that channel. For plot transfers, this is 
loaded with a value of 2048, permitting a maximum of 1024 plots to be transferred per octant. 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6. 34 
A MidFoprocessor-ljasedl Tracking Systemn 
The Device Control Register (DCR) is programmed with information about the device, 
and the type of DMA operations to use. The plot interface is treated as a 16-bit device with 
Acknowledge. The peripheral control line is unused and left as a status input. The channel is 
configured to run in cycle steal mode without hold, thereby ensuring that transfers do not affect 
other processing. The remaining information about the transfer is programmed into the 
Operation Control Register (OCR), which allows definition of a device to memory transfer 
using 16-bit operands, initiated by an active signal on the REQ line. The Sequence Control 
Register (SCR) is programmed to allow the memory address to count up by the appropriate 
amount following each transfer. 
The other registers in the device do not play an important part in the plot interface, with 
the exception of the Channel Control Register, which is used to start or suspend data transfers. 
Transfers commence when bit 7 of the register is set, and thereafter continue according to the 
rules programmed into the other registers. 
The speed of operation of the 68450 makes it ideal for performing a number of memory 
transfer operations. In particular, the device is also used to clear blocks of memory by 
defining the "device" as a single word in memory set to zero, then setting the appropriate 
counter value and running the channel as a 16-bit 68000 compatible interface with maximum 
rate auto-request in burst mode. Large blocks of memory can be cleared in this manner in a 
fraction of the time that the host processor would take. A number of other techniques are also 
used in the experimental RATES software which is described in the following section. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page ®. 3S 
A Microprocessor-basedl Tracking System 
SJ8 B A T E S gofffcwair© BssigBi 
To reduce development timescales, the Durham RATES software has been based 
around that used in the prototype design. The important difference in the new system is the 
lack of a multi-tasking operating environment and the need to address the interface functions 
at a low level. The use of a high level language for programming is dependent upon a suitable 
compiler for the MC68000, and equally importantly one which has been designed around the 
KDM development board. Careful research revealed only a PASCAL compiler, which was 
restricted to integer arithmetic and produced stack-orientated code. For such a time-critical 
system, the coding needs to make full use of the registers in the MC68000, and it has therefore 
been necessary to adopt MC68000 assembler as the programming language. 
Only basic concepts have been adapted from the prototype design, as a direct translation 
from CORAL to assembler would not produce a highly optimised code, which is part of the 
advantage of using a low-level programming language. The disadvantage of this approach is 
the increase in the development timescale, due to the problems of debugging and testing at such 
a low level. The result of this has been a breakdown of the system software into manageable 
modules, each of which can be seen and tested to have results on the overall operation. 
S.Sol A Note on Release Versions 
The software release versions have been based around the modules mentioned above, 
with significant enhancements forming a major release. Version 3.4 source code is listed in 
Appendix C. 
The first release version of the software established operator control, implementing 
input and output of system commands via a control terminal, using the command sequences 
permitted in the prototype system. 
The second release established the interface with the plot forming function and the 
remainder of the plot extractor functions. It allowed output of certain synthetic characters and 
basic control of plot extractor functions. 
The third (and currently the latest) release implements elementary filtering of plot 
data, and display of general plot statistics on the plot extractor status display. For reasons 
given later, there has been no further development of the RATES software, although the results 
clearly illustrate the potential of the microprocessor-based approach. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6. 36 
A Micifoipircocessor-ltfflsed. Tracking System 
6.6.2 The User Interfec© 
It was decided from an early stage of development that a useful starting point for the 
RATES demonstration software would be some form of user interface, ideally duplicating the 
functions available in the prototype system. The interface would allow operator control of the 
main tracking parameters, and would also be responsible for control of data flow between the 
plot extractor hardware and the tracking computer. In establishing the control features at an 
early stage, it should be possible to build up various modules as required. 
The low level operation of the redesigned tracking computer requires considerable 
care in the design of the interface to various functions, in order to minimise the time spent on 
non-effective processing operations. For this reason, the optimum solution is to use interrupts 
to control routines which arise from an external stimulus - the user interface routines are only 
called when a character is input from the console. To further increase efficiency, the interface 
operates in a buffered mode and data is only passed on for interpretation when a line 
terminating character is received. 
The flowchart describing the user interface function is shown in Figure 6.11, and 
illustrates the 3 main modules this can be subdivided in to. 
Routine R e a d C h a r is called whenever a character is received from the operator 
console. It reads the character and carries out one of several actions as a result. ASCII 
printable characters are inserted directly into the input buffer and also echoed to the operator's 
output display. Backspace (Ctrl-H) and delete-line (Ctrl-X) characters are interpreted as would 
be expected, erasing the previous character or the entire buffer. Only a line-terminating 
character has any other effect, causing routine Interpret to be called to process the complete 
buffer. 
The buffer is initially scanned to isolate one of the 21 available commands. The 
commands are hardcoded as string constants, and the parser locates one of them by matching 
as many characters as are typed with the nearest lexical equivalent. For example, the 
'SetValue' command can be chosen simply with keyletter 'S', whilst the third test target 
requires the full command name TT3'. The index value of the chosen command is used as an 
offset to a table of function addresses, from which the routine appropriate to that command is 
called. 
Many of the user control routines simply set or clear bits in a variable, turning display 
and I/O options on or off. Some routines affect the tracking parameters, and require additional 
parameters which are read from the input buffer by the routine concerned. If a command 
cannot be deciphered, or if there is an error in the supplied parameters, the command is 
ignored and an error message raised. If a system parameter is changed with a resultant effect 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6. 37 
A Midfopifoososoif-baQenl Tracking Syetenm 
on other parameters, the routines B e r i v e F i x and DeirivePars are called to recalculate the 
variables. This is the worst-case action resulting from a command string - under most 
conditions the main processing functions will be resumed with little noticible effect. 
Keyboard 
Input IRQ 
ReadChar 
Interpret 
Parse buffer to 
isolate command 
and parameters. 
Take appropriate 
action for chosen 
command. 
Read character 
from serial port 
& insert into buffer. 
Is this 
command 
valid? 
Has line 
terminator been 
rcvd 
No 
Return from 
interrupt 
Error 
no Print 
Error Message 
on console & reset 
buffer. 
" Return from 
interrupt 
Return from 
interrupt 
Fig. 6.11 ; User Interface Flow Diagram 
The Application off Digital Techniques to aim 
Automatic Radar Track Extraction System. Page 6. 38 
A Miciroprooessor-baseell Tracking System 
6.6 .8 Status Monitoring and Display 
Within the concept of a software development environment, the monitoring of system 
status and performance is an important requirement in order to assess the potential 
performance under a full range of operating conditions. The prototype system uses a 
conventional C.R.T. display, offering a 25 line by 80 column format. The large physical size 
of the display is unnecessary considering that its only real purpose is to assist in monitoring 
the performance and would therefore be largely ignored under normal operating conditions. 
The development system addresses this problem by replacing the C.R.T. with a liquid crystal 
(L.C.D.) display of similar display area. 
The use of an LCD display represents a low-cost solution, which compares favourably 
with a less robust CRT (similar cost) and a plasma display (very high cost). The display 
allows the added flexibility of mixed graphics and text as a possible future option to assist 
performance measurement. Its disadvantage is poor contrast and reliance upon critical 
lighting conditions to maintain visibility, although this problem is largely removed when 
considering the use of the backlit super-twist LCD displays that are now available. 
The development system makes use of the Hitachi LM225 display, which is addressed 
as two separate displays each of 25 line x 40 character format. Each side of the display has its 
own controller (a Hitachi 61830), wired such that the left-hand display can be addressed as a 
low-order byte and the right as a high-order byte. Careful design of template formats can 
therefore make use of word-transfers to perform simultaneous updates on both sides of the 
display. The basic template used by both prototype and development systems is shown in Figure 
0.12 and (for the current release) only makes use of the LCD's text mode. 
Although the screen is fully addressable, the speed of update and possibility of 
modifying the hardware at a later date to allow the DMA controller to perform updates has 
resulted in the use of a processor-RAM based template to hold the display image prior to 
transfer. ASCII data for display is written directly into this template (which is initially 
downloaded from the system constants area). Routine VduMapUp ensures that the upper and 
lower byte distinction is maintained, especially when copying a string that has been derived 
from an integer parameter by function IntToAsc. 
When all required parameters have been converted to their ASCII equivalents, a 
second routine ( V D U O u t ) is called to transfer the contents of the template to the 
display-controller memory. This is accomplished in a block of 640 words with an initial 8 
word header. The speed of update results in little or no 'flicker' being visible to the user. 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6. 39 
A Microprocessor-based Tracking System 
The VDU is initialised by routine ImitVDU, which copies a set of parameters from the 
system constants area to the controller status registers during initialisation of the tracking 
software. This routine also copies the initial template from the system constants area into the 
local (dynamic) template store. The location of the fields within the template is stored as a set 
of offsets at address "VduOffset*. Even offsets correspond to a field on the right of the display, 
while odd offsets indicate a field on the left. 
DISPLAY No Rev Number: 
TRACK No Loading: 
Ownship H S 
ALONG SPEED R o l l b a l l R B 
CROSS SPEED 
F i l t e r Input : 
MEASURED R 
MEASURED B S t a t i o n a r y P l o t s : 
FORECAST R F i l t e r Output: 
FORECAST B 
T r a c k I n i t i a t i o n : 
SMOOTHED R 
SMOOTHED B 
T e n t a t i v e T r a c k s : 
SPEED 
HEADING Conf irmed T r a c k s : 
Missed Looks R B S H 
ALONG N T T 1 
ACROSS N T T 2 
TT3 
Fig. 8.12 : Status Display Template 
The current version of the software (3.4) only makes use of the right-hand display, as 
the tracking module has not yet been implemented. This portion of the display gives sufficient 
information to determine some performance characteristics for the system, based on the plot 
counts and loading factor. Values for these are updated upon receipt of the north marker signal 
and remain on static display for the duration of one revolution. 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6. 40 
A Microprocessor-based Tracking System 
6.6.4 ILnterfecimg to the Plot Ejdbractar 
The software interface to the plot extractor can be broken down into a number of subsets 
according to the time-dependence of certain functions. For example, output from the tracking 
computer to the synthetics character memory can only take place during the scan period as 
these characters are written to the display during interscan. The table given below illustrates 
the time dependencies of the various functions: 
Test Target 
CFAR thresholds 
Synthetics data 
Completed plots 
Constants word 
Ships motion data 
6 words output 
512 bytes output 
512 words output 
2 words / plot input 
1 word input 
1 word input 
Tjrae_SIoj; 
interscan 
interscan 
scan 
scan (by default) 
not time critical 
Data transfer is based around a 16-bit data bus and hence there is no time advantage to 
be gained through byte transfer (CFAR thresholds) - this will be accomplished in the same 
period as a similar word transfer. The transfer could (with additional logic) be undertaken by 
one of the channels in the DMA controller, however the small size of the data blocks indicates 
that the transfer could be accomplished by the host processor with only limited affect on the 
available processing time per octant. Unfortunately, transfer rates are not fast enough to 
support a complete block move during either one scan or one interscan period, and hence it is 
necessary to split the operation so as to handle a number of smaller blocks. Transfers can be 
controlled by monitoring the status of the scan input, which is conveyed as bit 15 of the 
Constants word. 
Considering the requirements for each transfer operation: 
InterScan Transfer: (CFAR thresholds) Cycles 
LOOP MOVE.B (Table_address)+, DO 10 
M O V E . W DO, (Device_address)+ 8 
DBRA Dn, LOOP H 
= 32 
Scan Transfers (Synthetics data) 
LOOP M O V E . W (Table_address)+, $Dev_addr 20 
DBRA Dn, LOOP H 
= 34 
Each loop must be repeated 512 times, giving a total of 16384 cycles for an interscan 
transfer and 17408 cycles for a scan transfer. 
The Application of Digital Techniques to aim 
Automatic Radar Track Extraction System. Page 6 . 41 
A Microprocessor-based Tracking System* 
For an 8 MHz processor, this corresponds to times of 2048 and 21?6ms respectively (1365 
& 1450us for 12MHz). Scan and interscan times, according to radar type, are given below in 
Table (8.5. Based on these times, it is possible to calculate the optimum transfer block size for a 
given radar, or alternatively to choose a suitable worst-case block size. The results (for an 
8MHz CPU) are also given in Table 6.5. If a 12MHz processor is used, the compromise block 
sizes may be doubled, with the number of transfer blocks correspondingly halved. It should be 
noted that these calculations assume an access delay of 150 - 200ns; longer delays will require 
a decrease in the transfer block size. 
Radar Type InterScan Seam InterScan Scan Compromise 
Period Period Byte Txfr Word Txfr Slock Transfer 
A 205u.s 1097us 16x32 4 x 128 16b x 32w 
B 790us 512us 4 X 128 8 x 6 4 8b x 64w 
C 936ns 366|iS 4 X 128 8 x 6 4 8b x 64w 
D 834U.S 3072us 4 x 128 1x512 4b x 128w 
Table 6.5 : Scan & InterScan Timing 
In practice, the E A T E S software assumes the worst case value for the block size, 
resulting in a data transfer of 16 blocks x 32 words. At the end of each block, the processor uses 
a polling technique to test the status of the InterScan signal so as to maintain synchronisation 
with the plot extractor hardware. 
Synchronisation of data transfers in the prototype system was largely undertaken by 
the interface hardware, but relied on data being transferred to holding buffers a set period in 
advance. The low level interface adopted in the new hardware permits a more rapid response 
and transfers can now be accomplished immediately after scanning has been completed for a 
given octant. To assist in timing control, the hardware produces the Octant Demand and 
Aerial North signals, which are passed to the tracking computer as interrupts. 
One of the main failings of the prototype version was its inability to handle more than 
4096 input plots per revolution. This was due to the input plot processing sequence being 
incomplete when the next Octant Demand signal was received, and resulted in the processor 
"crashing" as its working data space was overwritten by incoming data. The new system 
avoids this problem by forcing termination of octant processing as soon as an Octant Demand 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6. 42 
A Micropjrocessor-baoesl Tracking Systemm 
signal is received (Appendix C.19). The stack pointer is simultaneously restored to an initial 
state, ensuring integrity of the processing environment. 
The important timing characteristics of the system can be detailed with reference to 
Figure 6.13 and the flow charts in Figure 6.14. 
True octant divisions. 
Octant Demand 
boundaries. Next Octant (0) 
Previous Octant ( 6 ) " - . 
Octant 7 
Second Octant On (1) 
Second Previous Octant (5) 
Fig. 6.13 s Octant Timing Control 
Only the north marker is output on its true boundary : the Octant Demand signal is 
actually delayed by approx. 120ms from each octant boundary to prevent conflicts with north 
marker processing. The octant output from the Constants word lags behind the scanned octant 
number by one, so as to simplify processing in the prototype system. This feature is no longer 
necessary in the development system as the interrupt-driven octant processing is capable of 
reliably maintaining its own octant count, however it is retained to assist synchronisation 
with the system hardware. 
When started, the system waits for the octant output from the timing circuits to reach a 
count of 5 (the penultimate octant) before enabling north marker and keyboard interrupts to the 
processor. The first north marker to be received after this causes the system to enter a 
"warm-up" state, where data is received from the plot extractor hardware, but there is no 
corresponding output until a certain number of aerial revolutions have elapsed. The software 
from this point is entirely interrupt-driven, with all other processing functions being called as 
subroutines from one of the interrupt handlers. 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 6. 43 
A Microprocessor-based Tracking System 
The keyboard interrupt processing has already been discussed (Section 6.6.2), and the 
flow diagrams for the other two functions are shown below in Figure 6.14. 
f Octant "\ 
y Demand IRQ J 
DataOut 
Transfer data from 
previous octant 
to threshold & 
synthetics functions. 
ResetOctant 
Clear next octant 
clutter cell buffer & 
regenerate octant 
numbers. 
MipDa 
Reset DMA controller 
to address new buffer 
and start new 
plot transfer. 
Is this 
first octant 
demand? 
yes 
FirstTrack 
Print 
"Tracker Initiated" 
string. 
ClutterOut 
Calculate clutter cell 
values for new "octant" 
and output incoming plot 
co-ords to PPI display 
ThreshOut 
Calculate threshold 
values for new 'octant' 
based on static & 
clutter cell values. 
North 
Marker IRQ 
VDUMapUp 
Update status VDU 
and increment 
rev. number 
read 
warm 
CheckConst 
Test to see if console 
controls have changed 
& derive new params. 
H appropriate. 
VDUOut 
Transfer status VDU 
template to 
LCD display 
controller. 
(ResetOctant) 
Clear all filter and 
tracking parameters 
to zero, (actually done 
on octant boundary) 
Fig. 6.14 : Octant and North Marker Processing 
North marker processing initially calls a subroutine to update the LCD status display 
The Application off Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 44 
A Microprocessor-based Tracking Bystsm 
(VDUMapUp), taking values which have been accumulated in the status table and converting 
them to their ASCII string representations. The strings are copied directly into a RAM-based 
template which contains all static text for the display. This greatly simplifies the transfer to 
the VDU controllers, as there is no need to specifically address areas of the display during the 
update procedure. 
The interrupt subroutine then calls another routine which checks to see if any of the 
console switches, which affect the software operation, has been changed. If necessary the 
derived system variables are then re-calculated. 
The final operation is to transfer the data from the VDU template to the display 
controllers, and this is accomplished by a simple peripheral data transfer to left and right 
display memories (640 data words plus configuration information). The north marker 
processing is thus completed, and the processor freed to continue any tracking calculations. 
Approximately 120ms after each true octant boundary, the timing functions generate 
an octant-demand signal. The first instance of this signal causes a message "Tracker 
Initiated" to be printed on the console, but after this the octant boundaries are totally 
transparent to the user. 
The first function of this interrupt handler (DataOut) is to transfer the newly 
calculated threshold values and synthetics characters to the plot extractor hardware, using the 
blocked- transfer techniques discussed earlier. It should be noted that these values are obtained 
from the second-previous-octant relative to that which caused the interrupt - the previous 
octant's data is now considered complete and available for filtering and plot association. In 
preparation for this all appropriate clutter cell values are reset and (if this is the north-most 
octant) the revolution status counters are cleared. 
Once these operations have been completed it is possible to restart the DMA transfers 
from the plot forming circuits, and function MipDa does this by setting a new base transfer 
address and word count, then enabling the DMA channel. 
Data is transferred from the plot forming function using a cycle-steal mode, and is 
therefore transparent to the processor operation. The software is able to make use of the full 
power of the processor from this point, to carry out all necessary filtering and tracking 
operations. Subroutine ClutterOut is called to generate the clutter maps from the density of plots 
in a given area, optionally generating synthetics characters for each of the incoming plots if 
required. From the clutter maps, function ThreshOut derives the new threshold levels for 
output to the CFAR processor, according to the settings of the C-Scale and C-Range switches on 
the operator's console. A constant radius around the radar is set to maximum threshold to 
mask-out the local echoes, whilst other areas can either be under manual or automatic control. 
The computer-generated offset involves relatively little processing but helps considerably in 
maintaining a constant false alarm rate in areas of particularly high clutter. 
The Application of Digital Techniques to an 
Automatic Madar Track Extraction System. Page 6. 45 
A Microppocessor-based Tracking System 
6.7 SiHKanaury asad KecoHameadatioiis 
The functions available in version 3.4 of the development software have been chosen to 
give an indication of the performance of a basic tracking computer, and some indication of its 
potential as a replacement for the original Ferranti Argus system. Development of the 
software has not been continued towards the stage of a complete tracking system for a number 
of reasons, in spite of the success of the software implementation to date. 
It must be considered that a successful tracking computer implementation should 
primarily be cost-effective, but must also take account of maintenance and future 
enhancement. If the development time for release 3.4 of the Durham system were extrapolated 
to determine the likely development period for a complete system, it is unlikely that the 
implementation could be justified. The use of assembly language for system programming 
also decreases the portability of the solution, and increases the problems of maintenance and 
enhancement. 
In considering the possible options for further development work, it is concluded that 
the optimum path lies in the production of a £/m"#-like kernel structure, composed of low-level 
(assembly language) device drivers and a high-level controlling application. The RATES 3.4 
software (with the exception of the threshold and clutter generators) forms the basis of a 
device-driver suite. The filtering & tracking software forms the controlling application, and 
it is recommended that this be written in a high level language to reduce the development time 
to an acceptable level. 
Since the commencement of development work on the RATES software, the number of 
langauge compilers for the 68000 series processors has increased, and it would now be most 
realistic to consider the use of a language such as 'C for the application level software. The 
requirement that military software systems make use of the ADA language could also be 
considered, increasing the flexibility of the 'kernel' approach. 
There are other advantages to be gained from the use of a high-level language for 
application development in this system. The low-level drivers which make up the majority of 
the RATES 3.4 software modules are essentially I/O bound, with their speed restricted by the 
access times of the peripherals they communicate with. Conversely, the application software is 
computationally bound and is therefore affected By7directly by the speed of the processor and (in 
this system) its ability to perform fractional arithmetic. The use of differing precisions for the 
system variables (see DeriveFix) is an attempt to reduce the time spent in performing more 
complex calculations, but introduces a number of problems when considering the design of 
portable software. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6. 46 
A Microprocessor-based Tracking System 
The ideal solution is achieved through use of standard variable types (e.g. Float, 
Integer, Character) and provision of a high speed calculations module to handle the more 
complex of these types - notably the floating point values. Since the development of RATES 3.4 
software, Motorola have released a floating-point co-processor (the MC68881) which provides 
an extension to the standard MC68000 instruction set allowing manipulation of floating point 
operands at a speed many times that of similar software routines. The device is fully 
compatible with the MC68020 processor (which offers faster operation than its predecessors but 
maintains code compatibility). 
It is evident from these discussions that the recommended solution to future software 
development will take account of the following points: 
° Use of low-level assembly language for the 'device-drivers', including the user 
interface and communications with the plot extractor hardware. 
° Development of the filtering and tracking software in a high level language. From 
studies of commercial software tendancies, it is recommended that the 'C 
programming language be used, with ADA as the second choice. This is based on the 
following observations: 
'C is the main language available for the Unix operating system, which is the 
current MOD & Government -preferred O/S. 
'C is the most rapidly developed language, and new compilers are issued more 
quickly in the light of hardware developments than other languages (eg 
PASCAL, CORAL etc). This would be important if the use of the new MC68030 
processor and MC68882 co-processors were to be considered. 
ADA is given secondary preference as the 'MOD-recommended' language for 
new software projects. In view of its complexity, size and overheads it is not a 
prime choice for development as many of its features are unnecessary in a 
system of this type. 
0 Modern compilers allow different optimisation strategies, and it is probable that fast 
execution could be available as one option. 
° The use of a high level language will greatly simplify enhancements and 
maintenance due to its increased readability, and its tendancy towards a more 
modular approach. This will ai^ o also promote a proven testing strategy, resulting in 
a more reliable product. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 6 . 47 
Testing & Performance of the Development System 
7.0 Intaoduction 
The RATES development system has been tested using a number of 
techniques, but there has not been any attempt to provide a statistical analysis of the 
performance of the complete plot extractor. The test methods have involved visual 
comparison of results obtained using the prototype and similar data obtained from the 
development system, and also an analysis of the speed of the new processor and its 
interface. 
This chapter describes the techniques used to generate the test data and gives 
the results of testing the new hardware and software. The successful operation of the 
new system is clearly illustrated and some predictions are given for operation of a 
complete tracking system. 
7.1 Testing the Plot Extractor 
The objective of the Durham RATES development system was to derive a practical 
implementation of a plot extractor, which could be shown to remove clutter from a genuine 
input signal, rather than a simulation based on hypothetical approximations to input 
signals. With this in mind, testing has been accomplished using data from one of three 
sources: 
1) Real-time, Radar Data 
2) Video-recorded Radar Data 
3) RATES Test Target Generator (Function 2). 
The test generator and video recorder both provide data compatible with a particular 
set of radar characteristics, so that tests cannot be influenced by choice of antenna and 
timing parameters. The radar in question is a 2-dimensional surveillance type, intended 
primarily for marine applications. Its parameters are summarised in Table 7.1. Function Z 
is capable of simulating the other radar types, however the prominence of the chosen test 
radar in likely field applications has resulted in much of the testing being based around this 
unit. Unless otherwise mentioned, all test results have been achieved using timing 
parameters applicable to this radar. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 1 
Testing & Perfonmauac© of the Development System 
P.R.F. Pulse 
Length 
Maximum 
Range 
RATES 
Range 
Beamwidth Rotation 
Rate 
1 768Hz 2 us 96 miles 90 miles 1.2° 15 r.p.m. j 
Video Signal 
Turning clock 
Sync, pulse 
North marker 
Log @ 20dB/V or Linear, 4.5V maa., noise 0.24V rms 
4096 pulses / rev, 1:1 ratio 
15V ± 3V, 3us width at start of each p.r.l. 
Logic '& at due north, 1ms duration 
Table 7.1 ; Summary of Test Badar Parameters 
13, Testing Using Becorded Radar Date 
Much of the system testing has been accomplished using data from a test radar which 
was recorded onto a standard video recorder, giving the advantages of a repeatable input 
signal which accurately reproduced a real environment. The video recorder used for testing is 
a Sony model EV-310CE reel-to-reel unit, which is used in conjunction with a Thorn-EMI 
model RR100 radar data recording adapter. The video recorder uses one inch tape and is able 
to record one video channel and two audio channels on this, giving approximately 70 minutes 
recording time from a 750m tape. The data adapter takes the 4 outputs from the radar receiver 
and merges them to enable them to be stored onto the recorder. The turning clock is input either 
as a 115/90V synchro signal or a 50£2 analogue signal and is combined with the north marker 
before being recorded on the first audio channel. Video data is merged with the 
synchronisation signal and these are recorded onto the video channel. The second audio 
channel is made available for recording ships heading and speed information, but these 
features have not been used during system testing. 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 7. 2 
Testing & Performance of the Development Systema 
7.2.1 Hardware Interface to fixe Vide© Player 
On replay, the data is separated but north marker and turning clock signals need 
re-timing and buffering before they can be applied to the RATES plot extractor. The turning 
clock emerges from the RR100 as a 2048 pulses/rev signal and this frequency needs to be 
doubled before it can be used. The RATES prototype used the spare processing capacity of one of 
the tracking computers to achieve this task, however the development system, with only one 
processor, was forced to use the hardware converter shown in Figi&re 7.1 to produce the signal. 
Additional buffering is supplied because the 50Q inputs on Function G2 require a 12mA input 
current, which is beyond the drive capability of the TTL monostables. 
+5V 
100R 
North Marker 
Input 22n 
5 V 
North Marker 
8K 
Turning Clock On 
Input 
(2048 pulses/rev) 
>- Turning Clock 68R 68K (4096 pulses/rev) 
10n 
n Monostables: 74LS123 
f > Buffers: 75110 
Fig. 7.1 ; KadarKecorder Interface Schematic 
The north marker signal is retimed in a monostable using a 100i2 resistor / 22nF 
capacitor combination (approx. 1ms) and then buffered in part of a 75110 line driver. The 
aerial turning clock is input as a 500Hz 1:1 signal and is presented to two monostables, one 
positive edge triggered and the other triggering on a negative edge. Both monostables 
generate a pulse of 0.5ms duration, and when combined in a NAND-gate, this results in the 
required lKHz turning clock. 
The Application of Digital Techniques to an 
Automatic Eadar Track Extraction System. Page 7. 3 
Testing & Performance off the Development System 
7.2.2 Recorded Kadair Scenarios 
Two scenarios were available for testing purposes, one from a land-based 
installation at Portsmouth and the other from a radar based on a ship which was involved in 
exercises off the coast of N.E. Scotland. Both tapes last for approximately 1 hour, but the 
quality of recording is such that breaks occur quite frequently during this period. Use of the 
tape counter has enabled testing to commence at a pre-determined point, so maintaining 
consistency between input data sets. 
The Portsmouth tape features little meteorological clutter, but by nature of its 
location shows considerable effects from land clutter. The Isle of Wight can be seen clearly 
just south of the centre of the display, with Southampton Water to the west. Helicopter tracks 
are present around Portsmouth and to the north-east of the display are tracks from Gatwick 
airport. This scenario provides an excellent situation for target tracking as aircraft are 
visible on take-off and landing flight-paths around the airport. The effects of sea clutter are 
largely masked by the CFAR processor and most detections of shipping are largely removed 
by the stationary plot filters. 
The tape from the ship was used initially for the RATES prototype performance 
evaluation, and there is already documentation on the results of these tests. Unfortunately, 
the development system (with version 3.4 software) has been unable to provide significant 
results from this tape, and data plots have not been included in the set of results. 
The Application off Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1.4 
Testing & Performance of the Development System 
13, The KATES Test Target Generator 
The test target generator was designed as one of the functions to be included in the 
prototype system, although it is capable of acting as a stand-alone unit since all timing 
signals are generated independently of those on Function G. The test generator provides the 
user with the following components, which may be merged or rejected as required: 
1) Random noise signal 
2) Random clutter 
3) Beam-correlated clutter 
4) Fixed Targets, number appearing can be pre-programmed 
5) Moving Targets, 3 available at any one time 
As it has not already been covered in Chapter 3, it is proposed to discuss the implementation of 
Function Z, with attention given to each of the four boards which make up this unit. 
7.3.1 Timing and Interface 
Board Zl carries the circuits for controlling the timing parameters of the test target 
generator, and its schematic is shown below in Figure 7.2a. An 8MHz oscillator generates 
the master frequency from which all other signals are derived, through use of programmable 
dividers. This is initially divided by 163 in X2, to give a 50KHz reference which is further 
divided in X3 to give either 256, 768 or 1536 Hz for use as a range synchronising clock. When 
active, this signal also enables the 3us monostable (X4) which outputs a radar sync pulse to 
the plot extractor. 
The 50KHz signal is also divided down in X5 to produce the azimuth clock and 
aer ia l turning signals. The latter is buffered in a standard RS232 driver, before 
transmission to the plot extractor. The azimuth clock is fed into a 12-bit counter to give the 
antenna azimuth count, which is then incremented by 8 before distribution to the remainder 
of the test target generator. The carry output of the counter is also buffered in the line driver 
and transmitted to the extractor as the north marker signal. 
The range clock is derived from the 8MHz oscillator, divided down in 
programmable counter, X6. This is then distributed to the other functions which make up the 
test target generator. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 1. 6 
Testing &. Performance of the Development System 
Range Sync. 
8MHz } +163 (X2) 0(1) RADAR SYNC 
sin 
f Divider (X4) Ae TURNING Azimuth Clock <s 0) 
Ae NORTH 8 
ESQ Adder 
j> Divider 
0 + 8 
t _ & 
Range clock 
Fixed Target 
hi Data FT level TEST VIDEO buffer 
Moving Target 
Data 
WIT level 
Beam-correlated 
Cutter 
BCC level 
Random Clutter 
T nose RC eve 
Fig. 7.2a % Test Target Interface & Timing 
Function Zl also contains the mixing circuits for the 5 video inputs: fixed & moving 
target data (from Z2) and beam-correlated & random clutter (from Z4) are buffered then 
mixed in a series of preset resistors. Random white noise is generated by a Z5J noise diode, 
then amplified before joining the mixer. The composite signal is passed through a 
high-speed operational amplifier then buffered in a line driver before being transmitted to 
the plot extractor as test video. 
7.3 .2 Clutter Generation 
Random and beam-correlated clutter is generated by function Z4, and the schematic 
of this circuit is shown in Figure 7.2b. The range clock from Zl is used to advance a 22-bit 
shift register, which together with a feedback network forms a random bit generator. The 
output of this is sampled at a rate which can be programmed between (range clock / 2) and 
(range clock / 256) to provide a variable random clutter density. When an active sample is 
detected, it is latched in a second register which is clocked at half the range clock frequency, 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7. 6 
Testing <& Performance of the Development System 
and the output from this is taken to function Zl. Any clutter will therefore last for a duration 
of two range cells. 
The output from the random bit generator is divided by 16 and then again by between 
4 and 256 to provide a clock for a second random generator. The output from this is sampled 
in a similar manner to the random clutter generator, to provide clutter hits of two range cells 
duration, and then presented to the beam-correlated clutter section. 
4096 x 4 
RAM a) 
O Beam-correlated 1 
Clutter Output 
•> Address Counter Range 
Clock 
[ Shift Register Divider 
Tmnr 
5? 17. 7. 
{1 Divider Shift Register <D O _T 
• Random 
Clutter Output 
Fig. 12b i Test Clutter Generator 
An important feature of this circuit is a 4096 x 4-bit RAM, which is addressed by a 
counter clocked by the range clock. Each nibble therefore corresponds to a unique range cell, 
between zero and the maximum range count for a sweep, and on every range count the 
corresponding data is read-out, latched and then re-input. Each nibble starts with a value of 
zero, and when an output from the random bit generator is detected, this forces a decimal 15 to 
be loaded into the RAM at that range location. On subsequent bearings this count value is 
re-addressed, latched then decremented and re-input. Clutter is declared for as long as the 
value remains positive, but as soon as a negative value is reached, this forces a zero to be 
reloaded and the clutter region to cease. An random area of beam-correlated clutter is 
therefore described, having a depth of 2 range cells and width of 15 pulse-repetition 
intervals. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7 .7 
Testing & Performance off the Development System 
7.8.3 Fixed and Moving Target Generators 
The fixed and moving target generators are realised by functions Z2 and Z3, and 
their combined schematic is shown below in Figure 7.2c. The fixed target generator produces 
hits at regular range and azimuth intervals, giving rise to a spokewheel display of targets. 
Range ordered hits are produced by dividing the range clock by between 2 and 4096, in powers 
of two, to generate a trigger for the range co-ordinates of the target. Similarly, the azimuth 
clock is divided to allow targets to be generated from once every 32 turning-clock pulses to 
once per revolution. In a manner similar to the clutter generator, the range pulse is stretched 
to cover two range cells and the azimuth pulse is used to load a 4-bit counter which proceeds to 
count for the next 15 bearing clock pulses before being halted. The range and azimuth data is 
gated to detect coincidence and the output is a set of fixed targets, 2 cells deep and 16 cells 
wide. 
0 + 1 6 
clock" 
0+8 -
Write, 
clock ~ > Latch Address 
Azimuth Counter 
Azimuth 
Comparators 
I 
•9 
CM 
« 
CO Range 
Comparators 
I 
Range 
clock } Range Counter 
Range Counter | 
Fixed Target 
Output 
Moving Target 
Output 
Fig. 7.2c s Fixed and Moving Target Generators 
Up to 3 moving targets can be displayed from the test target generator, but the 
responsibility for calculating their positions rests with a separate processor. The hardware 
latches range and bearing co-ordinates as they are generated by the computer, and then tests 
for coincidence with the currently scanned range and azimuth. Once triggered, the range 
depth is stretched to 2 cells and, like the fixed target generator, a 4-bit counter is loaded to 
extend the target width to 16 cells. The range and azimuth declarations are then merged to 
provide a single target plot. 
The Application of Digital Techniques to an 
Automatic Badar Track Extraction System. Page 7.8 
Testing & Perfbiiroianc© off the Development System 
In the RATES prototype, the test targets are generated by the tracking computers, 
however this has the disadvantage of increasing the load on the tracking software and 
makes the test target generator dependent on the plot extractor hardware. With no tracking 
computers in the early development system, a requirement arose to generate a full range of 
test targets using function Z, and it was therefore necessary to derive an interface and 
software to enable targets to be generated on a general purpose microcomputer. 
7-3.4 Target Generation Software 
The software for the moving target generator is designed to run on a Cifer model 
2684 microcomputer, using the CP/M-80 operating system. The machine is equipped with an 
8-bit parallel output port, which is ideal for transferring data to the test target generator since 
no feedback is required. The strobe signals associated with the port's handshaking are used 
to clock the latch address counter to point to the next byte store. 
RATES 992 TEST TARGET GENERATOR 
NUMBER RANGE BEARING S P E E D HEADING 
TT1 -
TT2 120 46 300 22 
TT3 
Fig. 7.3 ; Moving Target Generator Screen Display 
The program is intended to be simple to use, and presents the operator with a clear 
display, making use of the Cifer's enhanced display facilities (Figure 7.3). To activate or 
change a test target, the operator keys the number (1...3) of the desired target and is then 
prompted to select, in sequence, values for initial range, bearing, speed and heading. A 
range of zero cancels generation of that target, any other invalid inputs are rejected. The 
program can be terminated by keying an escape in place of a target identity code. The 
program is written in ADA, and a full listing is supplied in Appendix D, however it is 
proposed to discuss the basic algorithm in the section which follows. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7. 9 
Testing & Performance ©IT the Development System 
7.3.5 Target Generation Software Algorithms 
The complete operation of the test target generator software can best be described 
through use of a flowchart, as shown below. For clarity, the visual-display routines are not 
included: their operation simply achieves the type of presentation shown in Figure 7.3. 
START 
Initialise 
Output 
Display 
as 
a key (1...3) 
been 
pressed? 
as 
orth Marker 
been received 
from P.E 
Read new params. 
for chosen target 
& initialise it 
set counr = 1 
target[ 'count' 
active 
Calculate new 
position of target 
& reverse if needed 
next value of 
count' 
Update coordinates 
& output to 
plot extractor 
Have all 
targets been 
rocessed? 
Following initialisation of the screen, subroutine "SET_CONSTANTS" is called to 
initialise the trigonometric functions look-up table, which holds values of sin(0) between in 
the range -1...+1. Program control is then transferred into an infinite loop, where the first 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.10 
Testing & Performance of the Development System 
action is to test for keyboard input ("GET_TARGET_NUMBER"), using an operating 
system direct input request. The 'Esc' key causes the program to terminate, while any input 
in the range T...'3' transfers control to "READ_DATA" and then "SETTARGET". Other 
inputs are ignored. 
"READ_DATA" sequentially reads integer values for each of the target's initial 
parameters: range, bearing, speed and heading. If a range of zero is chosen, generation of 
that target ceases and no further parameters are requested. 
"SET_TARGET" is then called to calculate the new target's component vectors in 
the directions along and across the chosen line of azimuth. Range is converted to plot 
extractor range-units, bearing to angular units and speed to 'range-units travelled in one 
scan'. Knowing the difference (p) between target heading and initial bearing, the along and 
cross vectors are easily derived from sin(P) and cos(|5) (Figure 7.4). 
Heading north 
A 
New Range 
'Along' vector 
P 
TARGET 
Current Range 
Bearing 
Fig. 7A i Calculation of Test Target Co-ordinates 
Once the 'North Marker' signal from the plot extractor has been detected (by 
monitoring the output port handshaking lines), the routine "OUTPUT_TARGETS" is called 
to update each active target's position. The new range is given by Pythagoras' theorem, with 
the 'cross' vector forming one side of the triangle and the sum of current range and 'along' 
vector forming the other. Through use of a polynomial approximation, a value is also 
obtained for the change in bearing and hence the new azimuth value. Data is written to the 
plot extractor as 12 6-bit words, range first followed by bearing, for each of the three targets. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.11 
Testing & Perfbrmamce of the Development System 
1A Test Scenarios and Mesults 
Two sets of results have been derived as a result of testing the Durham RATES 
hardware and version 3.4 software. The main plot extractor hardware is functionally 
similar to that of the prototype, despite the considerable reduction in the number of boards 
which make up the complete system. This has been achieved through careful redesign of the 
interface to the tracking computer and subsequent modifications to the plot forming 
hardware. The tracking computer has undergone the most radical change within the system 
and no longer occupies a 19" cabinet adjoining the rest of the hardware. The ability to install 
the processor board within the main card rack has led to the success of the interface and 
permitted the introduction of faster DMA techniques. This, in turn, has resulted in a higher 
performance than could be achieved using the original Ferranti Argus and ME62 interface. 
7.4.1 Study of Processor Utilisation 
The main test results have been compiled from studies of the processor, whilst 
running the version 3.4 software. Unlike the prototype, the new design does not take up 
valuable processing time during DMA transfers from the plot forming buffer (E4) to the 
computer memory. The prototype system performed transfers in burst mode, during which 
time it copied a block of up to 1024 words into processor RAM. The development system makes 
use of the MC68450's cycle-steal mode of operation to transfer words during periods when the 
bus is inactive, and hence the transfers are totally transparent to both host processor and 
speed of operation. 
To maintain system operation within reasonable levels, the maximum number of 
plots which can be transferred during a single octant has been both programmed and 
hardwired (on K l ) to 1024. This allows a total of 2048 words to be transferred during this 
period - twice the capacity of the prototype system and with no possibility of program 'crash' 
due to the end-of-octant recovery techniques mentioned in the previous chapter. The new 
hardware does not permit inter-octant transfers, however the overload condition is less 
likely to occur due to the higher normal plot limit. There were indications that the prototype 
system could not successfully handle these transfers without substantial loss of data. 
Provisional test results indicate that the limit on the number of plot transfers could 
be raised to accommodate larger numbers of input plots during each octant, although 
discussions with potential buyers of such a system have indicated that an upper level of 
around 8000 input plots (including stationary targets and angels) is considered acceptable. 
Without implementing a complete system, it would be difficult to establish more accurate 
figures for the performance of the new design, although certain enhancements could be 
introduced to further improve the speed and capacity of the tracking computers. 
The Application of Digital Techniques to an 
Automatic Madap Track Extraction System. Page 7.12 
Testing & Performance of the Development System 
r A2 Comparison of Processor Types 
To establish a suitable basis for evaluating the performance of the tracking 
computers, the RATES 3.4 software should be considered as a set of functions. The user 
interface functions are independent of the plot input, filtering and display routines and these 
are not included in the calculations. The approximate execution time for each function has 
been calculated, based on the assumption of similar source code regardless of processor type. 
For the Ferranti Argus, processor times are based around those given in Table 6.1. 
The times used for the Motorola 68000 and Intel 8086 calculations are based on clock rates of 
8MHz and 6MHz respectively. It has been assumed that 68000 and 8086 systems do not make 
use of hardware co-processors to perform arithmetic functions. 
A study of the RATES software will indicate that the main processing is a function 
of the Octant Demand interrupt. In the verion 3.4 software, only one main function is 
dependent upon the number of input plots, and hence the relationship between total execution 
time and number of plots is linear. The processor loading factor is expressed as a percentage 
based on the total processing time against the total available processing time. The statistics 
do not take account of bus access times, which are likely to be similar for all processors. For 
the Argus, the time to transfer the data block from the plot forming hardware into the 
computer is not included either. 
fe9 
I 
MS 
20 
10-
200 
- e - Ferranti Argus 
-®- Intel 8086 
-t> Motorola 68000 
1 -
400 800 600 
Number of Input Hots 
1000 1200 
Fig. 73 i Loading Factor vs Input Plots for Different Processors 
Figure 7.5 gives the results of processor loading against number of input plots for each 
of three processor types. These preliminary results indicate the success of the Motorola 68000 
approach. Not only is the zero-input plot processor overhead significantly less than that of the 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Page 7.13 
Testing & Perfbraaamc® of the Development System 
other processors, but the rate of increase in processing time is substantially less than its 
competitors. The functions called in this software release make use of all major processor 
operations and it is therefore considered that the use of the MC68000 could lead to a significant 
improvement in performance over the Argus. 
It is particularly important to note from these results that the input plot limit imposed on 
the prototype system (512 input plots) still results in a processing time well in excess of that 
required by the 68000 to process 1024 input plots. This gives further weight to the suggestion that 
the maximum input plot threshold could be raised, although this could result in a more 
substantial increase in time spent in target tracking. Tracking procedures are unlikely to 
involve a simple relationship to the number of input plots, as a small increase in input plots 
may require a large number of association tests to be performed. 
The relative performance of the three processor types is summarised in Figure 7.6, 
which compares the average times for each to process data in a single octant. 
19.12% 
45.27% 
H Ferranti Argus 
M Intel 8086 
Motorola 68000 35.61% 
Fig. 7.6 : Comparison of Mean Processing Times 
From a comparison of processor execution times for typical instructions, the 
performance graphs shown above are somewhat predictable. The Argus however is noticibly 
faster than the other two processors when performing multiplication or division operations. 
In a computationally intensive program, featuring a large number of these operations, it is 
possible that the performance of the 68000 will be degraded to below that of the Argus and for 
this reason the redesign of the computer hardware, using Motorola 68010 or 68020 parts is 
strongly recommended; (this observation is partially confirmed by the results in Fig. 7.8). 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.14 
Testing & Perfonnance of the Development System 
7AM Overall Peifoarmmmce of the MCS80QQ 
Figures quoted in the previous section have assumed the use of the Type 'A' radar, 
which has average processing requirements. This has a rotation rate of 15 rpm, and 
therefore completes one octant every 0.5 sees. From Table 2.1, the rotation rates of the 
different types of radar give rise to a range of loading factors for the processor, which are 
summarised in Figure 
1 5 t 
10 
CO 
m No Input Plots 
8 M 1000 Input Plot 
Type A Type B Type C Type D 
Radar Type 
Fig. 7.7 i Processor l a d i n g for Different Radar Types 
It is still interesting to note that the worst-case loading, which results from 1000 input 
plots and a 24 rpm radar, is still lower than the processor loading for an Argus with only 512 
input plots. 
The final confirmation of the performance increase that could be achieved through use 
of the new design of tracking computer and interface is given below in Figure 7.8. This 
illustrates a predicted performance for each of three processor types, derived from a study of the 
execution times of one of the existing computationally-demanding functions (DerivePar). 
This estimation is based on the assumption of a certain minimum number of complex 
operations on each input plot. While not based on genuine execution times, it is hoped that this 
will give some indication of more realistic performance figures for the Motorola processor. 
The graph illustrates the improvements that can be achieved through use of this 
processor, even with more computationally intensive tasks. The threshold for processor 
loading occurs around the 750-input plots per octant mark (for the Ferranti Argus) whilst the 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.15 
Testing & Performance of the Development System 
68000 does not Teach the threshold until after the limit of 1000 input plots. It is suggested that use 
of a suitable co-processor could further improve these results, as many of the present processing 
bottlenecks are due to difficulties in handling a mixture of binary fractional arithmetic 
formats. The present system employs both 16-bit and 10-bit fractions when dealing with 16-bit 
word lengths and some care is needed to maintain the correct scaling of the variables. A more 
adaptable system would make use of a standard format (eg single precision floating point) and 
then use hardware to alleviate the extra processing requirements. 
150 
63 
Max. processing load 100 
Ferranti Argus 50 
- O - Motorola 68000 
800 200 400 600 1000 1200 
Number of Input Plots 
Fig. 7.8 j Overall Performance tor Heavy Processor Loading 
The results discussed in previous examples can be confirmed by monitoring the 
processor loading factor which is displayed on the status VDU. This display also shows the 
number of input plots for a given octant, and can therefore be used to produce practical 
confirmation of the graphical results illustrated in this section. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.16 
Testing & Performance off the Development System 
1J5 Interface Perfonnaiice 
The performance of the new interface is difficult to assess quantitatively due to the 
random nature of the input data which may be applied to it. For the purposes of testing its 
qualitative performance, two sources have been used to generate the input to the plot extractor 
hardware. Plots are formed in function E , then transferred across the DMA interface to the 
processor memory. The co-ordinates are initially used to calculate PPI display data and 
clutter-cell updates, then are output across the second serial interface to a minicomputer. 
The data is received as <bearing> <range> pairs, with bearing being represented 
by a number in the range 0 ... 32768, and range as a number between 0 and (ideally) 4096. In 
practice, the range often exceeds 4096, as this figure is the limit of RATES range, rather than 
display range which is some 8% more. From this point the data can be processed as required, 
without the requirement of programming in assembler. 
The test target generator (discussed earlier) is used to provide an output of 2 fixed 
targets per octant, each on the true octant boundary. The signals are mixed with a high level 
of random clutter and a lower level of beam-correlated clutter, most of which is filtered-out 
by the CFAR and WBI processors. The resulting plots are illustrated in Figure 7.8. 
By applying a small amount of filtering to the data, it is possible to remove all 
out-of-range plots (i.e. range > RATES range). If a confidence count is applied to each 
incoming plot and attempts are made to associate it with existing plots, those which exhibit a 
high confidence count after a certain period may be deemed stationary. Removing all plots 
which do not reach the required count leaves a selection of 'stationary-target' co-ordinates, 
as illustrated in Figure 7.9. 
The Portsmouth recorded scenario is also used as an input to the system, illustrating 
the interface performance with more realistic data. The tape section is too short to show the 
existence of tracks, but successfully illustrates the effects of beam-correlated clutter, 
interference and ground effects. The plot data is shown in Figure 7.10. 
When the stationary-target filtering process is applied to the data, the results are not 
so well defined as the previous example. Figure 7.11 shows the stationary plots remaining 
after a confidence count of 2 is applied. The ground effects over the period are too random to 
convey a definite pattern (e.g. The Isle of Wight) and the only significant features which 
emerge are the interference due to another radar and a minor helicopter track (005°). An 
alternative form of processing would be to filter all stationary plots, leaving only targets 
with a mid-range consitency count (i.e. 'moving targets'). The results from this are poor 
and no significant features can be identified. 
The Application of Digital Techniques to am 
Automatic Kadar Track Extraction System. Page 7.17 
Testing & Performance of the Development System 
0/ I — CI h • 
UJ L J 
LU O 
CD W 
w 
U j 
CD 
< -o I 
I — 
L j J 0 
h— 
z 
a) 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.18 
Testing & Performance of the Development System 
en 
a: LLi 
Z o LXJ Q 
h- c 
"II a 
CL in LU 
1 
0 I — 
* 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.19 
Testing & Performance of the Development System 
U J O 
'.0 'Ji 
a -a 
; • 
• a. i n w 
•"•"V r 
41 
< 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7. 20 
Testing & Performance of the Development System 
L Z J 
U J Q 
i n * 
n 
0 
I D ^ 
% ** 
< 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 7.21 
Systolic Architectures in Radar Signal Processing 
8.0 Introduction 
The arguments and principles discussed so far have been based around the 
use of conventional serial architectures for radar signal processing. Whilst this 
traditional approach has been shown to work satisfactorily, the design remains 
modular and would be difficult to implement in a single-chip form. There is 
clearly scope for a more efficient architecture to be employed and in particular one 
which will lend itself to a VLSI implemenation. In this respect, Systolic Arrays can 
be shown to function well when performing many common filtering tasks and 
these are therefore recommended for further research in the area of radar signal 
processing. The topics discussed in this chapter have been summarised in a paper 
presented at the I . E . E . E Radar '86 Conference [49]. 
8.1 The Need for a Different Architecture 
One of the earliest aims of research into the RATES design was to study the possibility 
of implementing single-chip or highly integrated solution. In earlier chapters, a number of 
techniques have been discussed which could lead to the development of a VLSI-based plot 
extractor: 
° Use of commercial V L S I circuits : has the advantage of low development costs but 
would not necessarily result in a compact solution. The design would require 
hardware modifications to realise future enhancements. 
° Use of custom V L S I : Development costs are high and the final product would not 
be particularly flexible. Enhancements may require redesign of the complete 
chip. 
° Digital Signal Processors : Potentially low development costs and considerable 
flexibility with regard to future enhancements. Unlikely to be a suitable 
architecture for a V L S I single-chip approach due to the complexity of each 
processor, and would therefore have to remain as a multiple-module design. 
° Microprocessors : Extremely flexible but (within the next few years) unlikely to 
reach a sufficiently fast operating speed to handle, for example, one detection 
every 500ns. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8. 1 
Systolic Architectures in Radar Signal Processing 
° Bit-Slice Processors : Have the flexibility of microprocessors and DSPs due to 
their programmable design, combined with the speed of most commercial VSLI 
custom circuits. The limited logical function of typical bit-slice parts means that 
a highly efficient hardware architecture can be adopted without loss of 
adaptability to future enhancements. The disadvantage of bit-slice processors is 
the complexity involved in programming, as all possible gates and inputs have to 
be programmed. 
The bit-slice processor is an ideal hardware standard for VLSI implementation, as the 
functional blocks used in each slice may be easily replicated and connected together. To make 
them viable from a development viewpoint however, it is essential to reduce their 
programming needs. One technique would be to increase the number of fixed hardware links 
between functions, thereby removing the need to programme the links. A better approach would 
be to design and programme the architecture to incorporate a number of units which 
functioned in an identical manner but on different data inputs. The units could perform one or 
more operations on each data stream before outputting them to other stages. The instructions, 
however, would be supplied from a common source and fed simultaneously to each unit. 
This technique would satisfy the requirements for a reduction in the programme 
development time and would simplify the hardware design as a unit could be developed as an 
individual function and then replicated as needed. The operation of such a machine may be 
termed a "Single-instruction stream, multiple data stream" (SIMD) processor and from 
existing studies [59] can be shown to be based around a Systolic Array architecture. 
In the discussions which follow, it is intended to show how the concept of systolic arrays 
can be applied to radar signal processing, with particular reference to the functions 
implemented in the RATES design. Although the systolic array has been viewed as a mainly 
theoretical approach, a number of more recent developments have meant that systolic arrays 
can now be realised in hardware and hence the importance of the systolic array should not be 
ignored. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 .2 
Systolic Architectures in Radar Signal Processing 
8.2 Principles of Systolic Arrays 
The emergence of the systolic array concept has been largely due to the pioneering 
work of H.T. Kung [56], [S7] at Carnegie-Mellon University and is based around neural 
computing techniques, where a very large number of simple cellular logic units interact with 
their neighbours. 
Kung's proposals have arisen from studies into the design of low-cost, high-speed 
architectures for computationally intensive tasks. Recent years have seen a dramatic 
reduction in the cost of implementing VLSI systems and a corresponding increase in the 
number of semiconductor gates that can be incorporated on a single chip. The speed of these 
components, however, has changed little. This is particularly well-illustrated by bit-slice 
processors which have seen very little change in speed of operation since their introduction 
several years ago. To achieve a significant improvement in speed from current VLSI circuits 
requires the use of a different design architecture, relying on increasing the number of 
processing units on a chip rather than trying to boost the speed of a single unit. 
To gain full advantage from increasing the number of processing units, it is important 
to take account of the cost-effectiveness of the final design. The most profitable solution can be 
achieved through replication of a restricted number of logic cells, since every cell type added to 
the repertoire adds to development costs. The replication of cells can be easily achieved through 
use of computer-aided design methods which take advantage of a modular structure to simplify 
design. The only development overhead comes about through the need to connect the processing 
units together in the most efficient manner for the system in question. The processor network 
which results from such a design can be shown to have a high throughput, provided that the 
computations are chosen to make best use of the structure. 
There are a number of problems to be considered in the design of a processor, 
regardless of the operations it is desired to perform. It would clearly not be worthwhile 
designing a high speed architecture if the data source is unable to match the input bandwidth of 
the processor. In this situation the system would be termed 110-bound. The converse is the 
Computationally-bound system, where the input rate may be greater than the speed at which 
processing can be completed. In this situation, it is clearly essential to ensure that the 
processing speed is raised either by use of faster components or some method of splitting the 
computational tasks amongst several processors. The systolic array approach allows the 
designer to match the speed of processing to the input data rate. The design is such that a higher 
input rate can often be handled simply by increasing the number of processing elements -
clearly a useful advantage. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 .3 
Systolic Architectures in Radar Signal Processing 
8.2.1 The Systolic Element 
Kung defines a systolic array as a set of interconnected elements, each of which is 
capable of performing some simple operation. The connections between elements are usually 
simple and reflect a definite pattern thereby simplifying both design and implementation. 
This is in contrast to multi- or parallel-processor architectures where the interconnections are 
often complex. 
The term "systolic" is derived from the pattern of data flow between elements, which is 
rythmic: Data flows between elements at regular intervals, as defined by a global clock. This 
is analageous to the flow of blood in the body as regulated by the heart. The clock pulse also 
defines the execution of instructions in each element, with typically one operation per element 
being executed at each pulse. 
Kung likens the systolic concept to a car assembly line, "where different people work 
on the same car at different times, and many cars are assembled simultaneously". The car 
assembly line may be regarded as a linear systolic array, with the periodic movement of cars 
from one assembly phase to the next. In this case, it is obvious that the assembly operation is 
faster when the operation is split into phases than if one worker attempts the complete 
operation. The assembly operation, however is computationally bound and restricted because 
only one set of parts goes into the system at a time. To speed up the process, it is necessary to 
introduce a parallel sequence of operations so that more than one completed car can be output at 
the end of the phases. 
One of the key features of the systolic architecture is the ability to use the same data item 
several times as it passes through the structure: the car assembly line would be inefficient if, at 
the end of each phase, the partly-assembled car were put into a store to await the start of the next 
process. The only communication with the array is at its boundaries with the outside world., 
although the cells may involve any regular pattern of communication amongst themselves. 
The efficiency of the data flow in a systolic array is illustrated by Figure 8.1. Consider the 
( *x *n + y ) + z + m 
Data Input 
at time [t] 
Proc. 
element Output at 
time [t+kj 
•n + y + m 
Data Input 
at time [t] 
Proc. Proc. Proc. Proc. Proc. 
element element element element element 
Output at 
time [t+k] 
Fig. 8.1 t Principle of a Systolic Procesor 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 .4 
Systolic Architectures in Radar Signal Processing 
case of the single processing element, which performs five operations with each taking one 
processing cycle. The single processor produces an output after 5 cycles and is then ready to 
read the next data item. 
Contrast this with the case of the 5 element processor, where each processor performs a 
simple task, again in one cycle, and then passes the data to the next element. The data still 
emerges after 5 cycles, but the throughput is increased by a factor of 5 as the first element is 
ready to accept the next data item after only one cycle. 
The pipelining of operations between simple processors is an important feature of the 
systolic array, but it is equally important to provide a synchronous data path through the 
system, or the systolic concept is lost. 
8.2.2 A Systolic Processing Example 
To illustrate the principle of a systolic array processor, consider the trivial case of a 
matrix - vector multiplication: 
x l l X 12 X 13 A l A 1 X 1 1 + A 2 X 1 2 + A 3 X 1 3 
X21 x 2 2 X 23 * A 2 ~ A 1 X 2 1 + A 2 X 2 2 + A 3 X 2 3 
X31 X 32 X 33 A 3 A 1 X 3 1 + A 2 X 3 2 + A 3 X 3 3 
To perform the above calculation in software would require 9 steps, if the following 
algorithm were used: 
FOR i = 1 TO 3 DO 
BEGIN 
FOR j = 1 TO 3 DO 
Y± = Y i + X i j * Aj 
END 
By mapping the procedure onto hardware, and in particular a systolic array, we can arrive at 
a solution which produces a result after 5 cycles, yet uses only 3 processor elements. All that is 
required is that the data be presented in a specific order to the array. Figure 8.2 illustrates the 
solution. In this example, each cell performs two simple operations when sequenced by the 
global clock: 
Y = Y + X i n * A i n 
Aout = A i n 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 .5 
Systolic Architectures im Radar Signal Processing 
Following each clock pulse, the vector is rippled through the processor array, and new 
input values read from the matrix. The first result appears from processor (3) after only 3 clock 
cycles, but a further 2 cycles are needed to accumulate the result in processor (1). 
X[33] 
X[32] 
X[31] 
X[23] 
X[22] 
X[21] 
X[13] 
X[12] 
X[11] 
Y = Y + Ain * Xin 
Aout => Ain 
xin 
yin 
(1 ) 
xin 
/out yin 
( 2 ) 
Pi 
xin 
/out yin hs£— A1 • . A 2 - - A 3 
( 3 ) 
Fig. 8.2 : Example of a Systolic Matrix * Vector Processor 
The two examples given so far have concerned linear processing arrays. In practice, 
there is no restriction on the structure or shape of the array. Kung even proposes a hexagonal 
array [57] to perform rapid matrix multiplication, where banded matrices are involved. In this 
situation, the operands and partial products are inputs to 3 sides of a hexagonal element, whilst 
the remaining 3 sides are used as 'ripple' outputs. 
Although the simplest systolic arrays involve only one type of element, this is not a 
mandatory requirement for the systolic concept. It must be remembered, however, that the 
arrays become easier to implement as element complexity decreases and the number of 
different types of element is also reduced. In practice, this increases the likelihood of a radar 
signal processing design based around a systolic version of the RATES functional units and 
ultimately paves the way for a single-chip design. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 .6 
Systolic Architectures in Radar Signal Processing 
8.3 Systolic Arrays in KATES 
In many respects, a radar signal processor meets many of the pre-requisites for 
consideration of systolic architectures. The processing is often computationally intensive and 
frequently restricts the overall system bandwidth. The data input is regular, determined by the 
range clock which drives the analogue-to-digital convertor. Finally, the functions themselves 
are repetitive and each operates more than once on the data as it flows through the system. 
To establish the optimum approach to a systolic radar signal processor, the RATES plot 
extractor hardware is to be considered as 3 modules: CFAR., WBI and Plot Forming. With 
careful design of each stage, it should be possible to merge the three modules to form a 
single-chip soltuion. Two types of CFAR processor will be considered - the Cell Averaging 
and Ordered Statistic approaches. 
8.3.1 The Cell-Averaging CFAR Processor 
As discussed in Chapter 2, the principle of the cell averaging CFAR is that of a window 
which slides over an array of range-cells. The amplitudes of the cells are averaged to 
determine a mean clutter level and after scaling this is compared against the amplitude of a 
central test cell. A target is declared if the amplitude of the test cell is greater than the mean. 
If the video amplitude of the test cell is X t then the mean value for N cells (using 2 
guard cells) is given by: 
X~ -. ( I ( X t + 1 . . . X t + N / 2 ) + I ( X t . 1 . . . X t . N / 2 ))/(N-3) 
A target would be identified by the CFAR if the condition: 
St S ( Z ( X t + 1 . . . X t + N / 2 ) + £ ( X w . . . X t _ N / 2 ))/(N-3) * K <• M 
where K is a manually-input scalar quantity and M is due to a computer generated and(/or) 
manually input offset. We note the simplification: 
S ( X t + 1 . . . Xt+N/2) = Z (Xt + 1 . . . X t + N / 2 ) -J- X<; - X t + N /2_i 
As an example, consider Figure 8.3, which shows a sliding window with 12 active cells, 
and one guard cell on either side of the test cell. By expanding terms in the above equations, it 
is possible to arrive at an expression for the final mean amplitude against which the amplitude 
in the test cell can be compared. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 7 
Systolic Architectures in Radar Signal Processing 
Range Cell 
Input 
O 4 
Pre -
Range Average Test Cell 
Post 
Range Average 
Fig. 8.3 : Example Sliding Window Detector 
To establish whether a target is present in the cell of amplitude X j , we test for the 
condition: 
X t / K - M > ( X ( X t t 2"^t+7> + £ ( X t . 2 . . ^ . 7 ) ) / N 
To maintain greatest flexibility with this test, N can either be set to the number of active 
cells in the whole window (12) or we can expand the expression to allow use of "greatest-of' 
selection, in which case N takes the value 6. This is a particularly efficient expression to 
transform into a systolic design and one possible solution is illustrated in Figure 8.4. 
I 1 1 
M ' K xit+ai / N Xlt+91 / N X|l+I0]/N L_I X[I+1I]/N 
-C) •. x|t* aj / K 
(-M); |-X|M]/K+C I (X[M|, X(i+5i) / mmm •- x (XM, X M ) ' N £ (XIM],X[I+9D / N 
i. (X[l+3]... X|t.6|) / N = I (X|k7),X|t*eD ' N 
X [ l ] / K - C - M 
I(X[t-2]...X[l-7])/N I(X[t+2]...X[t+7])/N 
Fig. 8.4 : Example of a Systolic CFAR Processor 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 8 
Systolic Architectures in Kadar Signal Processing 
This design makes use of only two types of element (Figure 8.5) to produce the pre- and 
post- range sums and makes use of the need for built-in delays to generate a scaled value for 
the test cell amplitude. Three values are therefore output from the array: 
Xfc / K - M. - C (where M & C represent Manual and Computer-generated offsets) 
( Z ( X t + 2 . ^ - ? ) ) / N 
( I ( X t . 2 „ . ^ ) ) / N 
As stated previously, a conventional Cell-Averaging CFAR can be obtained by using a value of 
N = 12 and adding the two sums. For a CAGO processor, a value of N = 6 is used and the 
function MAX( ( I ( Xt+2...Xt+7 ) )/N , ( X (Xt-2...Xt-7 ) )/N ) applied. 
Xout = Xin 
Vout = Xin* Zin 
Am 
Bin 
S o u 
Sout 4 
Sout = AIn + Bin 
Figure 8.5 : Cells Used in the Systolic CFAR Processor 
The operations indicated in Figure 8.5 are all executed following a single clock pulse. 
Data inputs can be considered to be latched on the rising edge of the pulse and the calculation 
performed & the output latched on the trailing edge. The array structure imposes a delay of 
only 4 cycles on the time that would be taken by a non-latched discrete logic solution. 
Results of a simulation of the performance of this processor are given later. 
Should a larger window size be required the array can easily be expanded, provided 
that the general shape is maintained (as this ensures that time delays are upheld). The 
structure has been chosen so that all terms appropriate to a calculation are presented 
simultaneously at the boundary cells. 
Zin 
Xin Xout 
Yout 
T 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 9 
Systolic Architectures in Radar Signal Processing 
8.3.2 The OS CFAR Processor 
The ordered-statistic CFAR processor is not so well suited to a systolic design as it has 
no need for registers and a global clock. To extract a rank value (Xj^ ) for use as a threshold, it 
is simply necessary to sort the elements in order of amplitude then extract the k4*1 item from the 
resulting array. The sorting procedure can be performed by asynchronous logic, as a steady 
state solution will eventually be reached. For completeness, an example of a systolic sort 
routine is illustrated in Figure 8.6. 
<3-
X t 
Bin Am 
Xout Youl 
Kth element extracted 
at this level. 
Fig. 8.6 s Example of a Systolic QS-CFAR Processor 
The design uses two types of processor element: The upper row work as latches, whilst 
the 'diamond' elements perform the following operation: 
Xout = MAX(Ain, Bin) 
Yout = BUN (Ain, Bin) 
The result appears after N cycles, where N is the number of cells in the window. At this 
point the He**1 item can be extracted and used to calculate the rank value. The test cell should be 
delayed to bring it in step with the output from the sort routine before attempting to evaluate a 
target presence. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 10 
Systolic Architectures ira. Radar Signal Processing 
8.3.3 Systolic Approach to Withim-Beam Integration 
The problem of within-beam integration is similar to that posed by the case of the 
ordered-statistic CFAR, in that a satisfactory solution can be shown using asynchronous logic. 
Detailed studies indicate that it would be extremely difficult to implement a second threshold 
processor using a true systolic architecture, due to the fact that the algorithm relies on a series 
of logical tests to determine its outputs. 
Earlier work on the idea of a systolic plot extractor [49] resulted in the suggestion of a 
high-level processor for the WBI function. It was based around the following algorithm (also 
given in chapter 4): 
Let the accumulated integrator count be Yy for scan i and range cell j . 
Let the binary output from the WBI at this time be Wy. 
The WBI is configured to use increment (INC) and decrement (DEC) values of '1' & P, as 
selected by the algorithm. Thresholds for upper (U) and lower (L) levels apply. 
if Xj j = 1 then 
{ 
Y i j = Y M j + I N C 
) 
else 
{ 
Y i j = Y i . i j - D E C 
1 
if Y i j > U then 
{ 
W y = h Y y = MIN(Yi j , U ) ; 
} 
if ( W m j = 0 ) & ( W i j = 1 ) then 
( 
INC = 1; D E C = p 
} 
else 
{ 
if ( Y i j < L ) then 
( 
= 0; INC = p; D E C = 1 
) 
} 
Y y = MAX(Yi j , 0 ) 
It is concluded that no satisfactory solution exists to implement this algorithm in a true 
systolic form and it is therefore recommended that, in the event of a single-chip solution being 
attempted, a conventional logic solution be adopted (such as proposed in chapter 4). 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 1 1 
Systolic Architectures in Radar Signal Processing 
3.3.4 The Systolic Plot Forming Processor 
The systolic concept can be used to advantage in the evaluating the centre of a plot, 
providing that sufficient input is made available through use of time delays. Taking the plot 
forming procedure as illustrated in Figure 8.7, a window is established around a plot area and 
the weighting of each cell calculated. Unlike the original RATES design, this is a continuous 
process but its output is only accepted if certain conditions are satisfied. 
A 
a> 
§ 
Incoming range 
cell data. 
Video in this cell 
initiates plot 
Fig. 8.7 : The Plot Window 
=D> Increasing azimuth 
Each cell in the window is assigned a weighting, based on its range and bearing 
relative to one particular cell. For a window 5 bearing units wide (as shown) and 3 range cells 
deep, the maximum bearing weight would be 5 and maximum range weight would be 3. In 
general, for a cell of bearing i and range j relative to a corner cell the weight is given by: 
Range Weight n (cell amplitude) * j 
Bearing Weight = (cell amplitude) * i 
The cell amplitude in the plot forming processor is a binary value of either '1' or '0' depending 
on whether or not a target has been declared by the WBI. Calculating the weights of all cells in 
the window, then summing them gives a figure for the total range and bearing moments. If 
this is divided by the sum of the cell amplitudes, the result is the centre of the plot relative to the 
chosen origin. 
Using this principle, we are able to design a systolic plot forming processor which 
produces absolute co-ordinates for the centre of the plot. The functional diagram of such a 
system is given in Figure 8.8. Only two types of cell are involved, each performing a large 
number of (albeit simple) operations. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8. 12 
Systolic Architectures in Radar Signal Processing 
Range Cell Inputs 
Xi-3,j-3] X[i-2,j-2 Xfi-1j-1] 
Aoul AIn 
Raul Rin ® ® ® ® ® Nout 
Xoul 
CO 
Ain FCn rai Xh 
S Aoul Ail a> 
® Rout RJi ® ® ® ® ® Nail 
Aoul Rout Nout 
Xout 
Xh 
Ail Aout 
© Rout Rji ® ® ® ® ® Kn Nout 
Xout 
Azimuth Weights ^ V V V 
Test Cell Accumulated Moments 
Fig. 8.8 : Systolic Plot Weight Calculator 
The Type A elements calculate the following: 
Aout - Ain -s- q * Xin 
Bout - Bin + p * Xin 
Nout ~ Nin -t- Xin 
X a Xin 
Xout 3 Xin 
The extra delay in the value of X that is passed to the next cell is to allow for 
synchronisation of sums arriving at the Type 6 elements. As with the example given for the 
C F A R processor, data is read in on the rising edge of the global clock and the calculation 
performed on the trailing edge. The Type 6 elements perform only 3 operations in order to 
evaluate accumulated range and bearing weights and the sum of the active cells: 
Aout = Ain <• S 
Bout - Rin + T 
Nout = Nin + V 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 13 
Systolic Architectures in Radar Signal Processing 
With these accumulated values, the absolute co-ordinate of the plot centre can be 
established. Additional logic is necessary to determine whether an output plot is valid (i.e. 
there is active video in the cell corresponding to range weight=2, bearing weight=l). It is also 
necessary to calculate the plot co-ordinates using the formulae: 
Range = I R W / I N •¥ R 0 
Bearing - Z B W / I N + B 0 
Where I N is the sum of active cells in the window, I R ^ is the sum of range moments, I B W is 
the sum of bearing moments and R Q , B Q are the absolute co-ordinates of the cell where Range 
weight - Bearing weight - 1 . 
In a practical design, it is estimated from performance of the existing RATES 
hardware that a window size of 3 x 5 cells is sufficient although this can be increased by adding 
more elements into the systolic array. The important feature of this design is that an entire 
window is implemented in Type 5 elements, thereby simplifying the calculations and storage 
requirements. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 14 
Systolic ArcMtectares im Madar Signal Processing 
8.4 Bimialatiom of & Systolic Plot Extractor 
To test the validity of the systolic processor designs, a number of simulations have been 
carried out and results compared against those that would be predicted using conventional (i.e. 
non-systolic) algorithms. Two simulations have been written, using a version of PASCAL 
running on an Apple Macintosh™ computer. One is for the cell-averaging CFAR design 
discussed in section 8.3.1, and the other for the plot weight calculator described in section 8.3.4. 
The source listing for the CFAR simulation is given in Appendix E . 
The data used for the CFAR simulation is the same as used earlier in chapter 2, and 
this therefore provides a means of comparison with results generated by more conventional 
techniques. It should be noted that, not surprisingly, the numerical results that can be obtained 
from the systolic processor of Fig. 8.4 are identical to those that can be obtained by averaging 
the 6 cells either side of the guard cells. A graph of the threshold level against the test video 
level is shown in Figure 8.9 and clearly illustrates the points at which a target could be 
declared. 
50n 
-S 55 40 
«3 30 
e 
i \ Test video 20 s i Threshold 
c i 0 •a 
I 
0 2 0 4 0 6 0 80 100 120 
Time 
Fig. 8.9 s Systolically-generated CAGO Threshold 
The plot forming processor has been tested using a series of simulated input plot 
windows and then checking to see if the calculated plot centre is correct. For example, the 
sample window shown in Figure 8.7 generates a total bearing weight of 24 and range weight of 
17. Since there are 8 active cells, the processor evaluates the plot centre to coincide with the 
centre of the window. If the balance of active cells in the window is shifted, the centre can be 
seen to move accordingly. 
The Application off Digital Techniques to an 
Automatic Badar Track Extraction System. Page 8 . 15 
Systolic Architectures in Radar Signal Processing 
8.5 Logic Simulation of Plot Extractor Functions 
With initial results from the logical simulation of the plot extractor functions appearing 
encouraging, it was decided to obtain further confirmation of the viability of the systolic 
approach through more detailed simulation techniques. 
The simulations described so far have confirmed several approaches to the design of a systolic 
replacement for the RATES plot extractor, but have made no attempt to assess the potential 
throughput of such a device. This has been remedied by taking each of the proposed systolic plot 
extraction functions and converting it into a detailed design based around standard 
74LS-series logic (with some use of MSI and LSI components where available). Each design is 
then simulated at gate level, giving rise to timing diagrams for each systolic element and for 
each complete function. The designs are then merged to give a detailed prediction of the 
timing performance of a complete systolic plot extractor. 
8.5.1 Simulation Software 
The 8 gate-level simulations have been performed by custom-written software, running on an 
Apple Macintosh computer (since suitable proprietary software was not available at the time). 
The software provides a "black-box" simulation of standard 74LS-series TTL devices, based 
on average signal propagation times as quoted in semiconductor manufacturers' literature 
(National Semiconductor, in this case). Whilst the implied accuracy of this simulation is to 
the nearest nano-second, a more realistic figure would be ±10% owing to the limitations of 
precision of the figures in the data sheets. The simulation software takes full account of the 
setup and hold times on data inputs and is capable of identifying output glitches and potential 
race conditions. 
Each circuit is configured to the simulator through an ASCII text file, in which each device is 
given a unique numeric reference and connections are made by linking inputs to an output 
device reference and pin number. A typical circuit definition file, together with the output it 
produces, is illustrated in Figure 8.10. 
A single clock provides synchronous clocking for the systolic elements, at frequencies of 50, 
25, 20,10, 5 and 1MHz and also 500KHz. Ten separate triggers are provided, capable of starting 
at a known time with either a finite or infinite period. The triggers can also be used as sources 
for external data, their outputs changing on either rising or falling edges of the system clock. 
Standard output from the simulator is a timing diagram, although additional features have 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 16 
Systolic Architectures in Radar Signal Processing 
been programmed to provide confirmation of the correct operation of the circuit whilst 
simulation is in progress. 
3>> ai 
1 1/1 a, S 
in 8-
(9 
• • • • • • 
CM 
C s l 
C M 
C M 
in 
©5 
! 
i 
E 
i n 
• C M <-> 
linn 
a N 
Dfl 
tn to 
BIS 
22 
a d 
-rf *4 * i «l 
o • '•ana 
T j o n g c o - g o a b u g c c H ^ 
X1H9 
K 3 
- • D a d * 
B D D l ! i 
Figure 8.10: 
Logic Simulator Input File and Sample Output 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 17 
Systolic Architectures in Radar Signal Processing 
8.5.2 Simulation of the Rank-Ordered CFAR 
The discussion of systolic CFAR processors has identified two potential architectures for such 
a device. Whilst the systolic cell-averaging CFAR provides the closest approach to the existing 
RATES design, the Rohling Rank Ordered CFAR exhibits a number of advantages, 
including: 
0 faster response, without loss of selectivity 
° greater suitability towards systolic implementation. 
The critical element in this design is the maximum/minimum data selector, which outputs the 
greater and lesser of two inputs. The basic design has been simulated for two possible 
approaches. The first assumes a fully systolic element, as shown in Figure 8.11. A double 
output latch is required in order to eliminate potential race conditions, due to variations in 
device speed. By using a single output from the 74LS85 (rather than less-than and 
greater-than outputs) to select the required latch data, the design ensures that an output is 
produced from both latches, even in the case of "A=B". 
Inputs'A' Inputs'B' 
74LS85 
W > •B' 
• 
System 
Clock 
'A' Data Inputs B' 
74LS298 
Outputs 
Sol 
Ck<s 
Latch InpuK 
74LS 173 a . * 
MIN( -A". B ' ) 
S d 
5=Ck 
'A' Data Inputs 'B' 
74LS298 
Outputs 
Latch Inputs 
, C k 74LS173 
MAX( 'A', 'B") 
Figure 8.11 
Systolic 4-bit Sorter Element 
The timing diagram of this single element is illustrated below (Figure 8.12), with the clock 
frequency set to 20MHz. Whilst a slightly higher clock frequency could probably be accepted, 
the propagation delays due to the latched elements, combined with the need to utilise both rising 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 18 
Systolic Architectures in Radar Signal Processing 
and falling edges of the system clock, result in this frequency being the maximum 
recommended for this element before the possibility of race conditions arises. The inputs 
applied to the element are illustrated on the diagram, with trigger data being loaded at 25ns 
(value = 3) and 75ns (value = 10). 
0 25 50 75 100 125 150 175 200 225 250 
j i i i ' i ! • ' i L n s 
0 
1 
2 
3. 
4 
E clock 
A < B (74LS85) 
0 3 10 Oulput B 
0 3 Output A 
0,0 0,3 10,3 Inputs 
Figure &12 
Single Sort Element - Timing Diagram 
This basic element is replicated 31 times in the implementation of a 9-cell CFAR window, as 
illustrated in Figure 8.13. 
System dot* 
Dab Input 
2 
CFHH Output 
Figure 8.13 
Complete Systolic Kank-Ordered CFAR Design 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 19 
Systolic Architectures in Radar Signal Processing 
Because of the regularity of the design, a larger (or smaller) window could be accomodated 
simply by increasing (or decreasing) the dimensions of the array. The output of the central 
test cell does not contribute to the evaluation of the rank statistics. The output of the sorter is 
applied to a bank of comparators, and a simple data selector used to isolate the "K^h " element 
target status. 
This design utilises a total of 174 standard TTL gates of medium complexity - it does not take 
account of cell scaling or offset as it is considered that these extra calculations are essentially 
sequential and do not contribute to the overall systolic simulation (however Figure 8.13 does 
indicate where the required logic should be placed). 
Load window - o Sorter delay <4 
0 100 200 300 400 500 600 700 800 900 1000 
' ' ! I I ! I I ! ' i n s 
[union Clock 
E 
E 
Sorted 
jQutput Data 
Figure 8.14 
Timing Diagram for Rank-CFAK Sort Output 
The timing diagram for the window and sort logic is illustrated in Figure 8.14, taking account 
of the response from the start of a new p.r.p (when the window is initialised) to the appearance 
of the first valid output data. The data used as input to this simulation is loaded on the rising 
edge of the system clock, and consists of the following values: 
° 3 5 7 9 2 4 6 8 10 
At a time (t), the window consists of the above 9 values, with '10' being the most recent input. 
The value '2' is in the centre of the window and therefore does not contribute to the sorted output, 
which appears at time (t+7), as described below. 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 20 
Systolic Architectures in Radar Signal Processing 
The final outputs, represented in the timing diagram, along with the intermediate outputs at 
times (t-2) ... (t+6), consist of the following values: 
« maximum ... minimum » 
° 10 9 8 7 6 5 4 
(The value '3' is not displayed as the simulator is limited to a maximum of 8 concurrent 
timing displays). 
At a frequency of 20MHz, the load takes a total of 9 clock cycles (450 ns, although the first value 
is preloaded and the simulation only shows 400ns) with the sorted output appearing 7£ cycles 
later (another 375ns). Thereafter sorted data appears every 50ns, shortly after the trailing edge 
of the system clock pulse. 
The output from the "K^ 1 . element selector" is not included in the timing diagram, which 
simply attempts to illustrate the operation of the systolic sorter. An estimate of the additional 
delay due to the selector and comparators would suggest that the final target declaration 
appears 36ns after the sorter output - some 20ns after the rising edge of the system clock. From 
this, it is proposed that the trailing edge of the system clock be used to latch the CFAR output, 
prior to the output being passed to the within-beam integration circuit. 
An alternative approach to data sorting is to design the array to be asynchronous. Data is 
clocked through the window as before, but the sorted output appears after it has rippled through a 
number of asynchronous sort elements. Differences between the propagation times of the sort 
elements will result in the final output changing many times before a state of equilibrium is 
reached, and it is the time taken to reach this state which defines the maximum rate at which 
data may be clocked through the window. Figure 8.15 illustrates one attempt at assessing the 
maximum clock speed of such an approach- the circuit is largely unchanged from the previous 
design, although those elements which perform a dummy compare-and-latch operation are 
now replaced with direct connections. The sample cell output is taken from the centre of the 
window and then used for comparison against the sorted data. 
The data used in this simulation are the same as for the synchronous sorter, with a new value 
being loaded on each rising clock edge. In the example shown, the result of the sort operation 
does not match that due to the synchronous design, as the clock frequency is too high, resulting 
in race conditions in the component devices. To achieve satisfactory results, the clock 
frequency must be reduced below the 20MHz illustrated overleaf. 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8. 21 
Systolic Architectures in Radar Signal Processing 
The difficulties of matching a suitable clock frequency and latch time clearly conflict with the 
supposed advantages of the systolic approach, and hence it is proposed that the systolic 
rank-ordered CFAR of Figure 8.13 be retained in preference to the asynchronous version 
described above. 
0 100 200 300 400 500 600 700 800 900 1000 
j ' ' ' ' I o l 1 1 1 n s 
tjinnjipjiiii] n r 0 „ , = J 
1 a 
r 
Figure 8.15 
Timing Diagram of an Asynchronous Rank-CFAR 
8.5.3 WBI Simulation 
As discussed earlier, the within-beam-integration function cannot be readily adapted to 
systolic processing without some compromise or pseudo-systolic design, as the basic WBI 
function is entirely sequential - there is little or no advantage to be gained from forcing a 
parallel architecture upon it. For the purposes of this simulation exercise, however, the 
original RATES design has been refined to give a much simpler implementation path - the 
proposed circuit is illustrated below in Figure 8.16. The circuit remains sequential, with key 
elements clocked on the rising or falling edges of the single system clock pulse. To maintain 
compatibility with the preceding CFAR processor, the incoming target declarations are 
assumed to be latched on the falling edge of the system clock, which is supplied, inverted, to the 
WBI RAM address control logic. The function of the WBI has been analysed as two distinct 
operations: 
° Selection of the increment/decrement value 
° Calculation of the new sum and target status. 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 22 
Systolic Architectures in Radar Signal Processing 
The increment/decrement value is dependent only upon the previous target status and 
incoming status, hence the value is derived through a l-of-4 selector. Given the Marcoz and 
Galati choice of (+A, -1, +1, -A) and parameters T"^(previous target status), Z (new target 
status), this choice is selected from the combination ( Z~T~*, ~Z T"l, ZT"-^, ~Z ~T"1 ). 
The new threshold sum is calculated from the sum of previous threshold and the above 
increment/ decrement, modified by the conditions described in earlier sections. The target 
status is evaluated from the new threshold (X), previous status (T"^) and upper and lower 
threshold limits (U, L) as: 
T = (X < U ) + ( T 1 . ( X < L ) ) 
In evaluating the performance of this WBI processor, it should be clear that the performance is 
clearly limited by the response time of the RAM, which should be chosen to be a device 
optimised for a rapid update cycle (read-modify-write). The use of fast dynamic RAMs in this 
situation is not precluded as all active cells are guaranteed to be read-refreshed at least once 
during the normal refresh period (2ms). 
A B C D 
CFAR 
Input 
System 
3 h i 
Figure 8.16 
Basic Circuit of the Optimised WBI Processor 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 23 
Systolic Architectures in Radar Signal Processing 
The principle of operation is as follows: 
° The falling edge of the clock signifies the start of a read cycle from the RAM 
(trace 0) 
° The previous cell count and target value are read from the RAM (trace 1) 
° An increment or decrement value is selected, based upon the previous target 
value and incoming target status (trace 2) 
° The increment/decrement is added to the cell count (trace 3) 
° The new cell count is evaluated to establish whether a target exists (trace 6) or if 
an overflow or underflow has occured (trace 5). 
The address generation logic has not been included in the simulation, as this is clearly a fixed 
overhead, independent of RAM speed. Without this logic, the timing diagram (Figure 8.17) 
indicates that a clock speed of 10MHz can be supported, whilst still leaving approximately 35ns 
in which to generate the RAM address (an acceptable period). This would assume that the new 
values of cell count and target status are clocked into the RAM on the rising edge of the 
inverted system clock (also signifying the start of the next read cycle, with the first operation 
being address generation). 
0 25 50 75 100 125 150 175 200 225 250 
1 1 1 1 1 1 1 1 1 1 1 n « » 
0 
read / write 
1. 
2„ 
3 . 
4 . 
RAM output 
inc/dec select 
adder 
upper threshold comp 
5 
upper threshold output 
6 
target dec 
< Start of read cycle 
= < Latch data, start next read 
Figure 8.17 
WBI Timing Diagram with 10MHz clock 
In contrast to the 10MHz simulation, the effect of doubling the clock frequency is illustrated in 
Figure 8.18. A 20MHz frequency cannot be supported without the use of multiple clock phases or 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 24 
Systolic Architectures in Radar Signal Processing 
separate input and output memories, as the propagation delay through the circuit results in the 
new data becoming available after the start or the next read cycle. A circuit being operated at 
this frequency would have to rely on known propagation delays in order to avoid race 
conditions. 
0 25 50 75 100 125 150 175 200 225 250 
1 1 1 1 1 I 1 1 1 1 1 n e 
read / write 
RAM output 
inc/dec select 
adder 
upper threshold comp -
upper threshold output 
target dec 
Start of RAM re ad cycles 
<-- Minimum WBI cycle -> 
Figure 8.18 
WBI Timing Diagram with 2GMHz clock 
The conclusion from this set of WBI simulations is that an effective single-cycle, 10MHz WBI 
processor could be implemented using the proposed design, although the choice of suitable 
components would be critical. There are a large variety of RAMs now available, offering 
access times from 15ns (e.g. AM10470, 4K x 1), which could be used to achieve the desired 
response. Alternatively, the use of fast-TTL logic would enable a longer RAM access time to be 
permitted, whilst still maintaining a 10MHz operating frequency. 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8. 25 
Systolic Architectures in Radar Signal Processing 
8.5.4 Plot Forming Processor Simulation 
The plot forming processor forms the third core component of the "RATES-based" systolic plot 
extractor. The simulation makes use of the design proposed in section 8.3.4, with additional 
support logic where necessary. 
As discussed, the design comprises two basic element types: 
° Type 'A' - each element represents one cell within the plot window 
° Type 'B' - each element serves to partially-accumulate the moment of the window. 
8.5.4,1 Simulation of the Type 'A' element 
The Type 'A' module is implemented as illustrated below (Figure 8,19), using LSI multiplier 
components to reduce complexity. Through this enhancement, the plot forming circuit 
becomes the least complex of the three plot extractor modules. Latches are included to hold the 
results of the operations, provide the correct timing delays and remove the risk of race 
conditions. They also serve to transform an otherwise sequential element into a systolic one, 
driven by a single global clock. 
0.. .X.. .3 0 . . . Q . . . 3 0. . . N... 3 0 . . . A . . . 3 CLOCK 
-- -
m i -
1 
1 
1 
1 
1 
1 
I 
1 MM r J - , 
qO q1 q2 q3 
AM29516 
(multiplier) 1 
1 
1 
1 
1 
1 
I 
1 
AO Al A2 A3 
74LS283 
1 
1 
1 
1 
1 
1 
I 
1 
CO 
1 
1 
1 
1 
1 
1 
I 
1 
1 
1 
1 
1 
1 
1 
I 
1 
NO N1 N2 N3 
74LS2S3 
A* n « 
-- - — 
- -
H*X*p • J , -
(multiplier) 
AM28516 
oO D1 D2 o3 
* P 
74LS283 
Rfl Rt R2 R3 
V) 
1 
1 1 1 1 
- 4 -
- -
1 
1 
1 1 1 1 
1 
1 1 1 1 
-
1 
1 
1 1 1 1 -
1 
1 1 1 1 
1 
1 
1 1 1 1 
Oi 
1 
1 1 1 1 
1 
1 
1 1 1 1 
1 
1 1 1 1 
1 
1 1 1 1 
3 
B 
0.. . P. . . 3 0 ... R ... 3 
Figure 8.19 
Plot Forming 'A' Element Schematic 
Using the components identified above, the complete element can be driven at a frequency of 
10MHz with a generous allowance for extra delays. It should be noted, however, that the 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 26 
Systolic Architectures in Radar Signal Processing 
multiplier chosen for this circuit is one of the fastest currently available. From the results 
given in the timing diagram (Figure 8.20, below) a component with a longer propagation delay 
could be used in place of the AM29516 without impact on the performance, providing the 100ns 
total cycle time for multiplier, adder and latch data setup could be maintained. 
In common with the outputs from the WBI processor, input data is loaded and the output latches 
clocked on the rising edge of the global clock. Double buffering (as used in the CFAR 
processor) is not implemented in this design owing to the lengthy propagation delays which 
ensure that race conditions are unlikely to arise. 
As with other designs, a 4-bit data path is illustrated for the sake of clarity. Simulations have 
been undertaken using either 4 or 8-bit data pathes where appropriate, although the systolic 
principle is upheld in that the data word size can be increased by a parallel combination of 
elements without impact on the speed of operation or other performance criteria. 
0 25 50 75 100 125 150 175 200 225 250 
1 1 1 , 1 1 I ' i 1 L n s 
1 clock 
2 X * Q 
7 9 X * Q + A 
9 ( X * Q + A) latched 
4 X * P 
6 (X * P + R) latched 
>. 3cr—«: .1.. JI. . .11 .-y-T=t.'-'iTr¥¥ir¥nrTnri mill i inn m m 
9 X + N 
9 (X + N) latched 
Figure 8.20 
Timing Diagram for Type 'A' Element 
In the case of the timing diagram illustrated above, the following data are used as input to the 
element: 
X: 1 Q: 2 P: 4 
N : 8 A: 7 R: 2 
All data are presented to the element at time (t = 50), proceeding through the asynchronous 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 27 
Systolic Architectures in Radar Signal Processing 
elements to the output latches, where they are loaded on the next rising edge of the system clock, 
to appear as outputs at time (t = 155). 
As can be seen from the timing diagram of the function (X * Q + A), there is a clear 40ns 
between the output from the adder and the same data being latched, hence a slower multiplier 
could be used as discussed above. With further allowances for delays between cascaded 
functions, it is suggested that any device with a propagation delay of less than 65ns could be 
used in place of the high-speed AM29516. 
The outputs from the two delay latches, illustrated in Figure 8.19, are not shown in the timing 
diagram as it should be clear that these components do not present a risk to the time-critical 
operation of the element. 
1.5.4.2 Simulation of the Type TB' Element 
The type 'B' element can be implemented very easily using standard T T L components, as 
illustrated, in part, in Figure 8.21. This diagram shows one of the three identical addeT 
functions of element 'B', implemented using the full eight-bit data path (a 16-bit data path 
could be used but is considered unnecessary due to the limitations placed upon the size of the 
plot window and the consequent limitation on the maximum moment that can be accumulated 
within it). Even using cascaded 4-bit T T L adders, followed by a data latch, the timing 
diagram of Figure 8.22 indicates that this element can function well within the desired 10MHz 
minimum throughput, and could sustain a 20MHz system clock if required. 
Systsm d o * 
0 
A <-> 
n 
0 £ 
s 
C4 
7 8 
CXI 
!3 
V 
Data output 
Figure 8.21 
Plot Forming TJ' Element Schematic (part) 
The use of the 74LS283 T T L adders provides a useful guide to the performance of this adder, as 
these are industry-standard parts which have been optimised for cascaded operation to enable 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 28 
Systolic Architectures in Eadar Signal Processing 
addition of rc-bit operands. Each adder therefore includes a high-speed look ahead carry 
generator which produces a carry-output after only 12ns. Taking account of carry signals, an 
8-bit addition can be performed by a pair of devices in 25ns (assuming use of the 74LS283 and 
2KD., 15pf loading). Typical performance characteristics are illustrated in Figure 8.22 
(assuming a 10MHz clock rate). This gives the response of the circuit to the following data, 
applied at a time (t ~ 55): 
° Low order, input 1: 12 
° Low order, input 2: 7 
° High order, input 1: 3 
° High order, input 2: 2. 
0 25 50 75 100 125 150 175 200 225 250 
j I i i I ! i 1 1 ' L n s 
0. 
clock 
1 
3 low-order 4 bit output 
2 
1 carry 
3 
6 high-order 4 bit output 
4 
99 8 bit latch output 
5 
Data input to latch 
Figure 8.22 
Timing Diagram for 8-bit Plot Forming Adder (part) 
This timing diagram confirms manufacturers' predictions concerning the performance of a 
cascaded adder, with a stable output appearing after 25ns. The output data from each adder is 
merged into the 74LS374 and latched on the next rising edge of the 10MHz clock pulse. 
85.45 The Complete Plot Forming Module 
The complete plot forming module comprises as many Type 'A' elements as there are cells in 
a plot window of maximum width and depth. A limit must be imposed on the size of the window 
in order to produce meaningful results in the case of two or more closely adjacent targets - the 
example illustrated in Figure 8.8 is a 5 x 3 window. The window is bounded on one side by as 
many Type 'B' elements as the window is deep. 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 29 
Systolic Architectures in Radar Signal Processing 
In operation, three sums appear from the outputs of the final Type 'B' element, some 15ns after 
the rising edge of the system clock pulse. The centre of the plot window is then evaluated 
(sequentially) from the total number of cells and the moments along each of the axes of the 
window. This process consists of one inversion (performed by PROM lookup) and two 
multiplications (35ns each, in parallel) and adds a further clock cycle delay to the calculation 
of the centre of gravity of the window. The operation of the plot forming processor cannot be 
illustrated by the logic simulator, but using the results from other simulations, the following 
can be deduced: 
If a WBI target declaration enters the window at time (t), the centre of gravity 
which can be attributed to this value is output at time (t -4- w + 2), where (w) is the 
width of the plot window. 
The existing design of the plot extractor does not present an optimum approach to integrated 
manufacture. From Figure 8.8, it can be seen that a delay of (range_cells + 1) must be provided 
between the inputs of adjacent vertical groups of Type 'A' elements. The WBI processor, 
however, generates a similar delay through its method of operation. It would therefore seem 
logical to combine the two functions and take advantage of this inherent delay. The resulting 
module has been termed a "WBI Slice", and is discussed in greater detail in the next section. 
8.5.5 The WBI Slice 
The WBI slice is illustrated in Figure 8.23. The WBI section has identical timing 
characteristics to the conventional WBI processor, although the operation of the RAM is 
handled differently. The output of the WBI is applied (with only a short delay, where required) 
to the input of one vertical slice of Type 'A' plot forming processors. 
The resulting device appears little different to the designs proposed so far, however the 
advantage of such an architecture can be seen if each slice were considered to be one integrated 
component (say, manufactured on a small gate array - the complexity is too great for a 
conventional PLA). A plot window of any desired width can be built-up simply by connecting 
devices in parallel, using the specified connections to cascade devices. The window is 
terminated by a single device which appears as a modified version of the elements discussed 
in sections 8.5.4.2 and 8.5.4.3, serving to accumulate the moments and calculate the centre of 
gravity of the entire plot window. With only a single cycle delay due to the WBI, a CFAR 
target declaration entering the WBI processor at time (t) produces a result at time (t + w + 3), (w 
defined as above). As with previous examples, all synchronous elements receive the same 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 30 
Systolic Architectures in Radar Signal Processing 
basic clock frequency, deemed to be the highest frequency that all component modules 
capable of supporting (in this case, lOMhz). 
Address 
Count* 
- 4 
<it) 
74LS153 « 2 
X M - 1 74LS173 
MLS 263 
741SS5 
74LS157 
74LS85 
74LS 57 
74LSS5 
74LS04 
74LS04 
74LS0S 
74LS32 
74LSI73 
Ain Aoul 
f&i Rout 
Nout 
Kn 
P-' P 
xp-3] q 
Figure 8.23 
Suggested Design of a "WBI Slice" 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 3 
Systolic Architectures in Radar Signal Processing 
The principle of operation of the WBI slice is straightforward: Each slice expects, as input, the 
target status: 
(where values of (n) in the range 0 ... ( window width - 1 ) apply). From this information, it is 
established that the primary target status of any slice can be generated from the target output of 
the adjacent slice, and the extra delay added by the slice's latches serves to ensure that the 
correct values are applied to the plot forming components. 
The following differences should also be noted, between the modules described earlier and 
those used above: 
An adder is also included to perform the function "q = q + 1". This generates the 
correct weighting through the depth of the plot window (bottom to top). 
A latch is included at the output of the WBI section - this is needed to ensure 
correct "systolic" operation of the WBI function although it was not shown on 
earlier diagrams. 
This proposed method of implementing the WBI and plot forming functions combines the two 
modules in a more realistic manner than previously proposed. Each slice is fully expandable 
and can be cascaded with any number of neighbouring units, provided a terminating slice is 
included. This slice is similar to the slice described above, but excludes any connection 
between the WBI and plot forming components, which themselves are replaced by the Type 'B' 
adder elements. The target input to this terminating slice is forced to zero to comply with a 
closure of the plot sequence. 
The timing characteristics of all component elements are as for the individual cases 
discussed in section 8.5.4 of this document. 
X [ t - n * ( r - l ) ] and generates the modified target status X [ t - (n + l ) * ( r - l ) l 
o An adder is included in each Type 'A' module to perform the function "p = p + 1". 
This generates the correct weighting across the width of the plot window (right to 
left). 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 32 
Systolic Architectures in Radar Signal Processing 
8.6 Summary of Simulation Results 
In considering the results of these simulations, it is important to consider the advantages 
which may be gained from pursuing a systolic approach to the design. These have been 
regarded as follows: 
° Greater integration of components, with the potential goal of a single board or 
(ideally) single-chip plot extractor. 
° Greater throughput, due to reduction of interconnects between components and 
removal of the need for a backplane, plus the ability to use faster devices. 
° Improved design architecture which can be readily adapted to test new techniques 
and which has built-in capabilities for future expansion. 
The second of these points can be regarded as the most important for any new system, and it is 
this feature which is often quoted as being the key advantage of the systolic approach. The 
simulations which have been performed have set out to illustrate the potential for improving the 
throughput of the existing RATES system by adopting a systolic approach. A feature of these 
simulations has been to retain the basic modular approach (A-D conversion, CFAR, WBI and 
Plot Forming), whilst adopting different architectures where appropriate for each of the 
functions. The very nature of this approach has resulted in a number of problems in devising 
a design which meets the criteria of a "systolic system", as several functions (or parts of 
functions) have not proved suitable for implementation as true "systolic arrays". 
The result of this work has been a design which achieves its primary objective by offering a 
throughput of more than twice that of the existing RATES design. All elements have been 
shown to function successfully at a clock speed of 10MHz, all supporting a single clock cycle 
between successive outputs. This effectively satisfies the requirements of a "systolic system" 
although the term is taken in its broadest context here, as the only true systolic arrays are those 
of the CFAR sorter and the plot calculator/accumulator. The advantage of the single clock 
frequency is clear - all elements are clocked at the frequency of the range sampling clock, and 
hence there is no need to derive intermediate frequencies to produce calculation results. 
Moreover, the delay due to the WBI and CFAR processors can be quoted as an exact offset from 
the time of the incoming data, and compensation included if it is desired to display all three 
outputs coincidentally (something which is not easily achieved in the current RATES design). 
As the accuracy and resolution of radar equipment improves, the need for frequencies above 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 33 
Systolic Architectures in Radar Signal Processing 
the 10MHz, which has been proven with this systolic design, will arise. The proposed design 
will cater for these requirements without extensive modification, as the following points 
should be noted when considering a practical design: 
° The simulations have assumed the use of 74LS series T T L components throughout, 
with only brief mention of other devices. The 74LS, whilst offering low power 
consumption, sacrifices speed of operation in return. If higher frequencies were 
required, most components could be replaced with 74S, 74H or 74HC alternatives 
with a considerable increase in throughput (for example, the 74S283 has a 
lookahead carry generation delay of 6ns, compared with 11ns for its 74LS 
equivalent). 
0 Where other families of device have been used, a range of operating speeds-has 
been quoted: the multipliers used in the plot forming section could have a 
propagation delay of up to 65ns without affecting the operation of the circuit. 
Similarly, the WBI RAM will support access times of up to 50ns in its proposed 
configuration. By splitting the RAM into two switched banks, used alternately for 
reading and writing (as in the present RATES design), it would be possible to use 
memories with a longer access time. 
° Any likely practical implementation of this systolic design would probably aim 
for an integrated approach, based around a gate array or similar device. The 
propagation delays due to standard cells can be equated more with emitter-coupled 
logic than conventional T T L , and hence greater throughput could probably be 
achieved simply by implementing on silicon rather than using discrete devices. 
° It should also be added that simulations have been performed using times based on 
those quoted by the manufacturers, with some bias towards the worst-case figures. 
To conclude, the simulation results have proved the viability of a systolic plot extractor, based 
around the existing RATES modules but using new architectures offering an improved 
performance and increased throughput over the previous design. The use of standard 
"off-the-shelf components has left considerable scope for improving the timing 
characteristics of the design through use of faster equivalents or a VLSI-based custom (or 
semi-custom) design. The availability of low-cost gate arrays should render this latter 
solution the prime target for the next phase of RATES development, based around the proposed 
systolic CFAR and "WBI Slice" modules. To quote Inmos: "Such concurrent systems unlock 
the processing potential of VLSI for fifth generation applications...". 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 34 
Systolic Architectures in Radar Signal Processing 
8.6.1 A Note on Other Systolic Architectures 
Although it was initially stated that this work was only intended as a theoretical discussion, 
there have been a number of important developments since (a) the start of research into systolic 
array designs and (b) the paper "The Application of Systolic Arrays to Radar Signal 
Processing" was written. Most importantly a family of high-speed processors directed 
specifically at systolic or array-processor applications has become generally available from 
Inmos Ltd. The Inmos Transputer range (of which an example is described below) are well 
suited to a systolic design, but are not considered sufficiently cost-effective for the proposed 
designs. Although they represent an acceptable price/performance ratio, they offer a much 
higher processing capacity than is required of conventional systolic elements. As such, they 
could only be used to advantage if a number of operations were merged into single processor. 
The use of the Transputer has not been included in the range of simulations owing to its 
complexity. 
Another device worthy of further study is the NCR45CG72 Geometric Arithmetic Parallel 
Processor, which is described as a "CMOS systolic array with 72 processors per chip", but uses 
a SIMD architecture with single-bit data path. This is clearly unsuitable for a function such as 
the CFAR processor, where a byte-wide data path is essential and the use of multiple devices is 
to be avoided, however it may be more applicable to later stages of plot extraction where binary 
target data is the norm. 
8.6X1 Summary of Transputer Features 
The Inmos Transputer family is based a 1.5 micron CMOS architecture with a 16- or 32-bit data 
bus and typical minimum execution speed of 10 MIPS. The first product in the family was the 
IMS T414, a 32-bit processor which can best be summarised by Figure 8.24. 
In common with the other members of the family, the T414 offers a reduced instruction set 
(RISC) architecture and its own specialised programming language (OCCAM). The language 
compiles directly to a highly optimised machine code which takes advantage of the features of 
the processor, but has recently come in for some criticism due to some deficiencies when 
compared with other high-level languages. As a result there are now several other languages 
available for the transputer, including ' C and PASCAL. 
The essential hardware features of the transputers, which are compatible at both pin and 
software levels, are as follows: 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 35 
Systolic Architectures in Radar Signal Processing 
2K bytes of internal RAM, accessible in 50ns across a 32-bit bus. 
External memory expansion to 4G bytes with 150ns access time. Fully 
programmable, on-chip DRAM controller. 
Full DMA and interrupt driven interfacing. 
Four 10M bits / sec serial interfaces, supporting full-duplex communication 
between transputers. 
Misc. 
System 
Controls 
2K bytes 
RAM 
(50ns access) 
External 
Memory 
Interface 
32-bit 
processor 
Serial Link 
Serial Link 
jj Serial Link 
Serial Link 
Event Handler 
<3-
SO-
<3-
-e> 
- o 
10 MBits/s I/O 
10 MBits/s I/O 
10 MBits/s I/O 
10 MBits/s I/O 
s$> 32-bit data bus 
Figure 8.24 
Architecture of the T414 Transputer 
The ability to communicate at high-speed with other transputers is one of the key features 
which would permit a systolic array processor to be designed using these devices. Without this 
feature, the processors are less attractive and the T414 in particular exhibits a poorer 
performance that existing microprocessors. Transputer development, however, is ongoing 
and the current top-of-the-range T800 shows a greatly improved performance. This device 
features a hardware floating point capability which outperforms the Motorola 68020/68881 pair, 
provided that the true transputer-array concept is used to advantage. 
In common with other major semiconductor manufacturers, Inmos have recently released a 
further addition to their product line - the IMS A100 digital signal processor. Primarily 
intended for applications which rely on high-speed multipliers, the A100 offers an array of 32 
16x16-bit multiplier accumulators and may be cascaded with other DSPs to increase its 
performance. Whilst not appropriate to the architectures discussed in this research, the A100 
offers a performance level which may be suited to future design studies. 
Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 8 . 36 
Conclusions amdl Suggestions for Further Research 
9.0 Reseauneh Objectives 
The research work involved in the production of this thesis has concentrated on a 
little-publicised area of radar technology, namely post-detector signal processing. To date 
there has been a large amount of time and effort devoted to research into new transmission and 
reception techniques at the expense of further work in signal processing. Design methods used 
in this area have failed to keep pace with advances in semiconductor technology and a number 
of commercial designs have failed as a result (e.g. Nimrod). 
The initial aim of this research was to establish the possibility of a single-board 
implementation of a radar processing, filtering and tracking unit, using custom-designed 
integrated circuits. The system would be based around a prototype surveillance radar plot 
extractor with substantial modifications to take account of more modern semiconductor 
technology. Continuously-rotating surveillance radars are still used widely in both military 
and commercial installations, in spite of predictions that they would be replaced by 
phased-arrays, as they are relatively cheap (compared with phased-array antennae) and have 
lesser signal processing demands. They can be initially interpreted using square-law or MTI 
detectors, although the former approach is the more attractive for a low-cost radar 
implementation. The post-detector radar video and synchronisation signals would be used as 
input to the plot extractor, whilst the output would be a series of plots (time histories of 
established targets). To achieve this conversion the input signal would be filtered through a 
double-threshold detector, weighted to establish the absolute co-ordinates of a plot then passed 
into a computer to be associated with previous plots. 
In the course of this work, the shortcomings of the prototype system would have to be 
established and suitable solutions designed and tested. The important feature of these 
requirements would not be the replacement of small isolated modules with VLSI equivalents, 
but a detailed study of the functions, with a view to establishing an improved design based on a 
different architecture. 
The research which resulted from these initial requirements can be divided into a 
series of specific phases: 
° Familiarisation with the prototype system 
0 Construction of a duplicate hardware system 
° Study of computer processing requirements 
° Re-design of computer and interface hardware 
° Programming of test software 
° Study of individual hardware functions, with a view to replacement using: 
- DSP techniques 
- VLSI semi-custom designs 
- Systolic processor arrays 
The Application of Digital Techniques to an 
Automatic Eadlar Track Extraction System. Page 8.1 
ComcMsiomis and Suggestions for Fmrtlieir Keseareli 
All of the above phases have been achieved (to a greater or lesser extent) and have been 
fully documented in this thesis. Conclusions have been drawn at each point, and have been 
discussed in detail where appropriate. They are summarised in the section which follows. 
9.1 Sinmmmry and Conclusions 
A study of the prototype plot extractor revealed a number of deficiencies in both 
hardware and software. One of the main disadvantages of the system was the requirement for 
an oversized computer tracking sytem which had clearly failed to keep pace with modern 
semiconductor technology. The plot extractor hardware also suffered in a similar fashion 
and, being based around SSI and MSI logic, required large amounts of power and board 
space. It was clearly important to concentrate on removing redundant modules from the 
design and improve the performance of the tracking computer. 
The Durham RATES system was constructed from a duplicate set of plot extractor 
boards, with the computer and its interface omitted. Following investigations into suitable 
alternative processors, the Motorola 68000 was adopted as the replacement for the original 
tracking computer, and a number of interfaces designed and tested. A small software suite 
was developed, partly emulating the user and hardware interfaces of the prototype and 
allowing the performance of the new system to be assessed. 
This design addressed many of the problems in the prototype, concentrating in 
particular on the outdated performance of the tracking computer and its associated interface. 
As a result of the new design, clutter cancellation is more flexible than it was before and could 
be used to advantage if the CFAR processor were to be enhanced. Plot forming too benefits from 
a direct interface to the filtering and tracking computer, and earlier problems of 'lock-up' due 
to input overloads have now been remedied. 
Tests of the new interface have proved highly successful, showing a dramatic 
improvement in a number of areas: 
° Considerable simplification of interfacing hardware, with a reduction from 36 
boards in the prototype (plus computer) to 29 in the development system (including 
a single-board computer). 
° Increased number of input plots per octant to the tracking computer 
° Increased software reliability, achieved through greater control of the interface 
and system timing. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Page 9 .2 
C o n c l u s i o n s and! Sugges t ions f o r F u r t h e r R e s e a r c h 
° Faster execution of software due to: 
- Faster instruction times 
- Improved program structure (suggested use of assembly language 'drivers' & 
high-level application software). 
- Less time involved in input/output-bound tasks due to efficiency of modern 
D M A controllers. 
It is concluded that the replacement of the tracking computer should be a high priority 
in a redesigned system and that the use of code-compatible microprocessors, such as the 
Motorola 680x0 family, is strongly recommended to assist future upgrade paths. I t is also 
suggested that a different bus structure be adopted to allow for standardisation to a 
recommended design. A possible candidate would be the V M E b u s for which a large number of 
68000...68020 (& 030) -based systems are available. 
Studies of alternative designs for the plot extractor hardware modules have not resulted 
in any successful practical implementations. The use of a standard " C F A R - > W B I - > Plot 
Forming" approach has been retained although there have been studies of alternative designs 
for the 3 modules. 
The original brief to investigate the use of custom logic in automatic radar track 
extraction systems has been rejected due to the high costs involved in a design which simply 
duplicates the existing system in a V L S I form. The poor reliability of the custom V L S I designs 
(none of the custom-designed devices worked correctly) combined with the difficulty in 
producing a perfect chip from early manufacturing runs has meant that this approach has not 
be found to be viable. 
It is suggested that the use of semi-custom logic, such as gate arrays (ULAs, ASICs ) is 
now a more cost effective approach because of the improvements in on-site design methods 
(typically using I B M P C s and compatibles). The gate complexity of these devices has 
increased considerably in recent years and it is now also possible to obtain U L A s which can be 
erased and re-programmed as required. Design tools allow the programmer to work directly 
from TTL-based prototypes and it would thereforebe possible to produce an initial design with 
a minimum of cost and effort. 
Software programmable devices have also been discussed with a view to their use in the 
plot extractor hardware. It has been concluded that current devices do not exhibit a fast enough 
performance for an implementation involving single processors connected serially, although 
there is potential for future fourth- and fifth-generation digital signal processors in this area. 
T h e App l i ca t ion of Dig i ta l T e c h n i q u e s to am 
Automat ic H a d a r T r a c k E x t r a c t i o n System. P a g e 9 . 3 
Comclusioims a n d Sugges t ions f o r Fuiirtlhier R e s e a r c h 
9.2 HemmmemdatioHsfe]p]B\srtheii°WoirTk 
The failure of the Nimrod project, which used similar technology to that of the R A T E S 
prototype, has led to a dramatic change in MOD policies. These now require the use of 
'off-the-shelf computer hardware, in place of custom designs and the software itself is being 
passed onto software houses for implementation, thereby decreasing both the design time and 
the risk involved in a project. Nimrod is not the only system to be let down by its computer 
technology - the Tornado's Foxhunter radar has suffered similar problems, and is unable to 
keep track of enemy aircraft whilst filtering out unwanted signals. 
A report issued by the House of Commons Defence Committee ("Implementing the 
Lessons of the Falklands Campaign") referred to a document issued by the U S Navy, which 
concluded that "the British were hampered by a lack of modern radars, target identification 
systems, data management systems and electronic warfare equipment in their fleet." 
These reports clearly promote the further development of radar systems, particularly 
in military situations. The general-purpose surveillance radar is likely to be an important 
component in future installations, particularly on grounds of cost, but only i f there are 
improvements in current signal processing techniques and new technology is used to the full. 
The Durham R A T E S system has shown the potential for a dramatic reduction in the 
size of tracking / filtering computers simply through use of modern microprocessors and it is 
likely that further improvements would be achieved if state-of-the-art components were used 
(e.g the Motorola 68020 or 030 and 68881 / 2). Further studies are also recommended in the area 
of V L S I semi-custom designs. With more manufacturers offering production facilities for 
these components, and increasing availability of workstation-based design tools there is now 
little reason for avoiding their use. 
The use of systolic architectures is predicted to be a major development area in the 
future, particularly as awareness of neural computing methods increases. The emergence of 
a number of "systolic processor array I.C.s", together with the increasing popularity of the 
Inmos Transputer family confirms these observations and it is therefore considered that 
systolic architectures should not be overlooked. The potential of systolic arrays for easy V L S I 
implementation suggests that this approach may represent the ultimate solution to a 
single-chip plot extractor. 
T h e A p p l i c a t i o n of Dig i ta l T e c h n i q u e s to a n 
Automat i c R a d a r T r a c k E x t r a c t i o n Bystem. P a g e 9 . 4 
C o n c l u s i o n s a n d Sugges t ions f o r F u r t h e r R e s e a r c h 
As a result of research at Durham, a major U . K . electronics company has taken an 
interest in the re-designed R A T E S system, and presentations have already been given to 
potential customers who represented the Navy of a NATO country. 
Further enhancements have been suggested, particularly applicable to the military 
environment, including development of the E C M module or the introduction of some form of 
"Identification Friend or Foe" ( I F F ) system. This latter feature has also been recommended 
as an essential feature of modern radar systems in the House of Commons Defence Committee 
report on the Falklands Campaign. 
To summarise, it is considered essential that the R A T E S design is developed further, 
as it represents an ideal low-cost solution to a general purpose surveillance radar. The 
functions it achieves are not restricted to military applications, and with further modification 
it could easily be used for commercial designs such as collision-avoidance systems, or 
enhanced navigational radars. 
T h e A p p l i c a t i o n of D ig i ta l T e c h n i q u e s to a n 
Automat i c H a d a r T r a c k E x t r a c t i o n System. P a g e 9 . 5 
APPENDIX A 
References 
and 
T h e Appl icat ion of Digi ta l Techniques to a n 
Automatic H a d a r T r a c k Extrac t ion System. Appendix A . 1 
R e f e r e n c e s a n d B ib l i ography 
[I] HERTZ, H. 
"Electric Waves", New York : Dover 1962. 
[2] HULSMEYER, C. 
"Hertzian-wave projecting and receiving 
apparatus adapted to indicate or give warning of 
the presence of a metallic body, such as a ship or 
train, in the line of projection of such waves", 
British Patent no 13170, 2nd Sept. 1904. 
[3] MARCONI, G. 
"Radio Telegraphy", Proc. I.R.E. 1922, vol 10, 
p216. 
[4] APPLETON, E . 
"The Scientific Principles of Radio-location", 
J.I.E.E., vol. 92, pt. 1,1945, pp 340-353. 
[5] WATSON-WATT, R. 
"The Evolution of Radiolocation", J.I.E.E., 
vol.93,ptl, 1946, pp374-382. 
[6] STEWART WATSON, D. 
"A Survey of C.R.T. Problems in Service 
Applications with special reference to radar", 
ibid., pt 3A, pp 
[7] BURGESS, J .S. 
"Recent Advances in Radar Technology", 
Proc I.E.E. Radar-77, p 8. 
[8] SMITH, R.A. 
"A Survey of the Development of Radar", 
J.I.E.E., vol.94,ptl, 1947, pp 172-178. 
[9] GARRATT, G.R.M. 
"The Birth of Radar", Electronic 
Engineering, , March 1958, pp 140-142. 
[10] DAVIES, D.H., FIELDING, C.C., 
GIRLING, FXJ. 
"Radar", Proc I.E.E., vol. 118, no 9R, Sept. 
1971,ppl071-1089. 
[II] RANDALL, J.T., BOOT, H A H . 
"Early Work on the Cavity Magnetron", 
J.I.E.E., vol93,pt3A,1946,pl82. 
[12] PAGE, R.M. 
"1977 Pioneer Award, Monoatatic Radar", 
ibid, p 557. 
[13] S K O L N K , M.I. 
"Fifty Years of Radar", Proc I.E.E.E., vol 73, 
no 2, Feb. 1985, ppl82-197. 
[14] WILLIAMS, F . C . 
"Introduction to Circuit Techniques for 
Radiolocation", J.I.E.E.,, vol 93, pt3, 1946, p289. 
[15] E A R L E BAILEY, A. 
"MTI Research at ADRDE", I.E.E.E. Radar 
'85 Conference Record Supplement, ppS-16-S-18. 
[16] BRYSON, S i r L . 
"All at Sea", Proc I.E.E.-A, vol 133, pt A, N o l , 
Jan 1986, pi . 
[17] C L A R K E , J . , DAVIES, D.E.N., 
RADFORD, M.F. 
"Review of United Kingdom Radar", I.E.E.E. 
Trans.AES, vol20, no5, Sept 1984, pp506-519. 
[18] EASTWOOD, Sir E . 
"Radar: New Techniques and Applications", 
Proc Royal Society London, Ser A, vol 354, no 1677, 
1977, pl37. 
[19] CAPENTIER, M H . 
"Radar: Yesterday, Today & Tomorrow", 
Proc International Conference on Radar '78, pi. 
[20] HALL, J.S. (ed) 
"Radar Aids to Navigation", MIT Radiation 
Laboratory Series, vol 2, McGraw Hill Book 
Company, 1947. 
[21] EMERSON, R.C. 
"Some Pulsed Doppler, M T I and AMTI 
Techniques", Rand Corporation Technical 
Report, No R-274, Mar. 1954. 
[22] EMERY, M. 
"Extracteur Radar Primaire et Radar 
Secondaire E V . 660 pour l'Aviation Civile", 
L'Onde Electrique, vol 48, no 491, Feb 1968, p 118. 
[23] POINSARD, H. , & GENDREU, R. 
"Systems de Detection d'Echoes a Fausses 
Alarmes Constantes", Revue Technique 
Thomson-CSF, vol 1, no 3, Sept. 1969. 
[24] REBOULOT, M. 
"Extracteur Microprogramme d'Infor-mation 
Radar", L'Onde Electrique, vol 48, no 491, Feb. 
1968, pl38. 
[25] CAHEN, R. & BERARD, H. 
"La Presentation d'Images Radar en 
Television", L'Onde Electrique, vol 48, no 491 
Feb. 1968, p i 25. 
[26] BATH, W.G. et al 
"False Alarm Control in Automated Radar 
Systems", (source uncertain). 
[27] WEISS, M. 
"Analysis of some Modern Cell-Averaging 
CFAR Processors in Multiple Target Situations", 
I.E.E.E. Transactions AES, AES-18, Jan. '82, pp 
102-114. 
[28] E B E R T , H. & SIEGENTHALER, K. 
"Digitale Radarzielextraktoren zur 
Automatischen Erkennung Fliegender 
Objekte", Regelungstechnishe Praxis und 
ProzefS-Rechentechnik, vol 14, pt 5, Oct 1972, p 149. 
[29] SCHONFELD, W.H. & GILLMANN, H. 
"Grundlagen fur Speicherung von 
Radarbildern auf Magnetband", Elektronische 
Rundschau, vol 11, pt 6, June 1957, pp 165 -167. 
[30] MILNE, K. 
"Principles and Concepts of Multistatic 
Surveillance Radar", Proc. I.E.E.E. Radar '77, 
[31] E B E R T , H . 
"Radar Data Processing Using 
Microcomputers", ibid, p 90 et seq. 
[32] KIME, F.W. 
"Evolution of the Man-Machine Interface in 
Surveillance Radar Systems", (source 
uncertain). 
T h e Applicat ion of Dig i ta l Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix A . 2 
Refe rences a n d B i b l i o g r a p h y 
[33] TUNNICLIFFE, R .J . 
"A Simple Automatic Radar Track Extraction 
System", Proc. I.E.E.E. Radar '77, pp 76 - 80. 
[34] MASCOT SUPPLIERS ASSOCIATION. 
"The Official Handbook of MASCOT", 
MASCOT Suppliers Association, Computing 
Standards Section, RSRE, Malvern, Dec. 1980. 
[35] MILES, J.A.H. & SHEPHERD, A. 
"Radar Automatic Track Extraction System 
(RATES), Software Description and Source Code 
Listings", ARE Internal Memorandum XCC 
82011, Oct. 1982. 
[36] SKOLNIK, M.I. 
"Radar Handbook", MacGraw Hill, 1970. 
[37] DILLARD, G.M. 
"A Moving Window Detector for Binary 
Integration", I.E.E.E. Transactions IT, IT-13, 
Jan. 1967, pp2-10. 
[38] HANSEN, V.G. & SAWYERS, JJH. 
"Detectability LOBS due to Greatest-Of 
Selection in a Cell Averaging CFAR", I.E.E.E. 
TransactionsAES, AES-16, Jan. 1980, pp 115 -118. 
[39] MOORE, J.D. & LAWRENCE, N.B. 
"Comparison of two CFAR Methods used with 
Square-Law Detection of Swerling 1 Targets", 
Proc. I.E.E.E. Radar '80,1980. 
[40] ROHLEMG, H. 
"Radar CFAR Thresholding in Clutter and 
Multiple Target Situations", I.E.E.E. 
Transactions AES, AES-19, July 1983, p 608. 
[41] ROHLING, H . 
"New CFAR Processor Based on an Ordered 
Statistic", Proc. I.E.E.E. Radar '85 , May 1985, pp 
271-275. 
[42] MAO, Y.H. , ZHOU, Z.C., MENG, X.Y. 
XONG, F.Q., ZHANG, S.Y. 
"A Non-Parametric C F A R Detector 
Implemented with CCD Tapped Delay Line" 
Proc. I.E.E.E. Radar '85 , May 1985, pp 430 - 434. 
[43] VOGEL, L . E . , REID, W.S. & STEICHEN, P.E. 
"An Examination of Radar Signal 
Processing via Non-Parametric Techniques" 
Proc. I.E.E.E. Radar '75 , April 1975, pp 533 - 537. 
[44] DILLARD, GM. & ANTONIAK, CJ3. 
"A Practical Distribution-free Detection 
Procedure for Multiple Range-bin Radars", 
I.E.E.E. Transactions AES, vol. AES-6, No 5, 
Sept.l970,pp629-635. 
[45] WALKER, JJ?. 
'Performance Data for a Double Threshold 
Radar Detector", I.E.E.E. Transactions AES, 
AES-7, Jan. 1971, pp 142 -146. 
[46] SWERLING, P. 
"The 'Double Threshold' Method of 
Detection", RAND Corp. Report RM1008, Dec. 
1952. 
[47] MARCOZ, F . & GALATI, G. 
"A Suboptimal Detection Technique: the 
Accumulator Detector", Alta Frequenza, vol. 
X L L Feb. 1972. 
[48] SPEARMAN, R., SPRACKLEN, C.T. & 
MILES, J H . 
"The Application of Systolic Arrays to Radar 
Signal Processing", Proc. I.E.E.E. Radar '86, 
May 1986, pp65-70. 
[49] QUIGLEY, A.L.C. & HOLMES, J . E . 
"The Development of Algorithms for the Forma-
tion and Updating of Tracks", ARE Internal Memo-
randum WP-XBC-7512, Nov. 1975. 
[50] RABINOWITZ, S.J., GAGER, C.H., 
BROOKNER, E . et al 
"Applications of Digital Technology to Radar", 
Proc. I.E.E.E., Vol. 73, No 2,Feb. 1985, pp 325 - 339. 
[51] FERRANTI COMPUTER SYSTEMS 
"Final Report of a Stu dy on the Application of LSI/ 
VLSI Techniques to Radar Plot Extraction Systems, 
Part A", Ferranti Report 4920, Issue 2, Nov. '83. 
[52] POLISE, A.T. & MOSKOVTTZ, G. 
"A Real-Time Application of Microprocessors to a 
Radar System", Proc. I.E.E.E. Southeastern Con-
ference, April 1981, pp 26-31. 
[53] LOPPNOW, D E . 
"Microcomputer Hardware for Radar Signal 
Processing with Distributed Architecture", Proc. 
I.E.E.E. Radar '85, May 1985, pp 184 -189. 
[54] HOLMES, JJ3. 
"Automatic Track Initiation", ARE Internal 
Memorandum WP-XBC-7505, June 1975. 
[55] COWAN, D. 
"Boost (iP-board Memory Capacity with Simple 
Hardware Changes", Electronic Design, Oct. 1981, 
pp 197 -198. 
[56] RUNG, H.T. 
"Why Systolic Architectures?", I.E.E.E. Com-
puter, Jan. 1982, pp 37 - 46. 
[57] KUNG, H.T. & LEISERSON, C.E. 
"Algorithms for VLSI Processor Arrays", in "In-
troduction to VLSI Systems", ed Mead & Conway, 
Addi son-Wesley. 
[58] KUNG, S.Y. 
"VLSI Array Processors", I.E.E.E. ASSP Maga-
zine, July 1985, pp4 - 22. 
[59] UMEO, H. 
"A Class of SEMD Machines Simulated by Systolic 
VLSI Arrays", in "VLSI: Algorithms and Architec-
tures", ed Bertolazzi & Luccio, North-Holland. 
T h e Appl icat ion of Dig i ta l Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix A . 3 
APPENDIX B 
Backplane Connections 
Motorola KDM Development Board 
T h e Appl icat ion of Digi ta l Techniques to a n 
Automatic R a d a r T r c a k Extrac t ion System. Appendix B . 1 
K D M B o a r d Connec to r Wir ing 
Pin Pin 
A +5V 1 +5V 
B +5V 2 +5V 
C +5V 3 +5V 
D -IRQ 2 4 -HALT 
E -IRQ 7 5 -RESET 
F VMA 6 -WRITE 
H GND 7 -VPA 
J ENABLE 8 GND 
K GND 9 GND 
L MEM CLK 10 VMALDS 
Ivl -12 V 11 -12V 
N ~BR 12 -REFREQ 
P -BG 13 REFGNT 
R -BGACK 14 HACK 
S -LDS 15 -UDS 
T +12V 16 +12 V 
U STANDBY 17 STANDBY 
V PWRFAIL 18 CLOCK 
W -BERR 19 VMAUDS 
X GND 20 GND 
Y GND 21 GND 
Z GND 22 GND 
A' -AS 23 -DTACK 
B' GND 24 GND 
C -D11 25 -D9 
D' -D15 26 -D13 
E* ~D10 27 -D8 
P -D14 28 -D12 
H" -D3 29 -D1 
J' -D7 30 -D5 
K' -D2 31 -DO 
L' -D6 32 -D4 
M' A15 33 A16 
N" A14 34 A13 
P' A11 35 A12 
R' A10 36 A9 
S' A7 37 A8 
T A6 38 A5 
U' A3 39 A4 
V A2 40 A1 
W GND 41 GND 
X' GND 42 GND 
Y GND 43 GND 
-D0 . . . -D15 - ( B i - d i r e c t i o n a l ) . I n v e r t e d 
data bus. 
A1...A16 - ( B i - d i r e c t i o n a l ) . Address bus. 
There i s no AO as upper and lower bytes 
are s e l e c t e d by separate s trobe s i g n a l s . 
- W R I T E - ( B i - d i r e c t i o n a l ) . Def ines the 
d i r e c t i o n f o r a data t r a n s f e r . Sense i s 
not reversed f o r e x t e r n a l bus master 
c o n t r o l . 
-UDS, - L D S - ( B i - d i r e c t i o n a l ) . Upper 
and lower data s trobes , c o n t r o l the 
t r a n s f e r of data from upper and lower 
bytes i n a word. 
- A S - ( B i - d i r e c t i o n a l ) . Address s trobe, 
i n d i c a t e s a v a l i d address on the bus. 
- D T A C K - (Bi- d i r e c t i o n a l ) . Due to the 
asynchronous bus a r c h i t e c t u r e of the 
68000, t h i s i s needed to s i g n i f y t h a t a 
data t r a n s f e r operat ion i s complete. In 
a processor read, an a c t i v e DTACK 
l a t c h e s the data , w h i l s t an a c t i v e 
s i g n a l during a w r i t e w i l l terminate the 
c y c l e . 
~ B R - ( i n p u t ) . A request from another 
device to gain c o n t r o l of the bus. 
~ B G - ( o u t p u t ) . P r o c e s s o r 
conf irmat ion t h a t the bus w i l l be 
r e l e a s e d a t the end of the c u r r e n t c y c l e . 
~ B G A C K - (input) . Conf irmation t h a t an 
e x t e r n a l device holds c o n t r o l of the 
bus. The s i g n a l cannot be a c t i v a t e d 
u n t i l f our condi t ions are met: 
1: Bus grant has been r e c e i v e d . 
2: Address s t robe i s i n a c t i v e , 
(processor not us ing the bus) . 
3: DTACK i s i n a c t i v e (per iphera l s not 
us ing bus) . 
4: BGACK i s i n a c t i v e (no other device has 
c la imed contro l ) . 
~ B E R R - ( i n p u t ) . A l e r t s the processor 
to an e r r o r i n the current bus c y c l e . 
~ R E S E T - ( B i - d i r e c t i o n a l ) . I n d i c a t e s a 
software r e s e t i n s t r u c t i o n or hardware 
e x t e r n a l r e s e t . 
~ H A L T - ( B i - d i r e c t i o n a l ) . As an 
input causes the processor to stop 
execution a t the end of the current 
c y c l e . An output i n d i c a t e s a f a i l u r e due 
to double bus f a u l t or s i m i l a r . 
MEM CLK, CLOCK, 
E N A B L E - ( B i - d i r e c t i o n a l ) . The s t a n -
dard 6800 compatible enable s i g n a l , 
l a s t i n g f o r 10 68000 c lock p e r i o d s . 
- V P A - ( i n p u t ) . S i g n a l t o t h e 
processor that i t i s address ing a 6800 
p e r i p h e r a l . 
~VMA - ( B i - d i r e c t i o n a l ) . Processor 
conf irmat ion that a 6800 address i s on 
the bus, and i t i s responding to ENABLE. 
~ I R Q 2 , I R Q 7 - ( i n p u t ) . I n t e r r u p t 
requests to the proces sor . 
T h e Applicat ion of Digi ta l Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix B . 2 
APPENDIX C 
Source Code Listing 
of 
RATES Development Software 
T h e Appl icat ion of Digi ta l Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix C . 1 
M A T E S D e v e l o p m e n t SolBtware • Source L i s t i n g 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
oooo 
"RADAR AUTOMATIC TRACK EXTRACTION SYSTEM" 
DURHAM VERSION 
SOURCE CODE 
(RATES) 
PROCESSOR : 
F I L E : 
DATE : 
PROGRAMMER : 
RELEASE VERSION 
MOTOROLA 68000 
RATES34.ASM 
9th Mar. '85 
Richar d Spearman 
3.4 
T h i s v e r s i o n implements b a s i c p l o t f i l t e r i n g , s t a t u s VDU c o n t r o l 
and command input. 
68000 p r e d e f i n e d address space 
0068 IRQ2 EQU $00068 I n t e r r u p t v e c t o r 2 
006C IRQ3 EQU $0006c I n t e r r u p t v e c t o r 3 
0070 IRQ4 EQU $00070 I n t e r r u p t v e c t o r 4 
0074 IRQ5 EQU $00074 I n t e r r u p t v e c t o r 5 
0078 IRQ6 EQU $00078 I n t e r r u p t v e c t o r 6 
0080 TRAPO EQU $00080 Trap 0, used t o emulate north IRQ, 
0000 
0000 ; KDM board hardware addresses 
0000 
0003FF01 Terminal EQU $3 f f 0 1 Address o f console port 
0003FF21 Port EQU $3ff21 Address o f second s e r i a l port 
000200F6 Macsbug EQU $200f6 Warm boot t o monitor ROM 
0000 
0000 ; RATES memory-mapped p e r i p h e r a l a d d r e s s e s 
0000 
00030000 C f a r EQU $30000 CFAR t h r e s h o l d v a l u e s (W) 
00032000 Synth EQU $32000 S y n t h e t i c s c h a r a c t e r s (W) 
00032000 Ecm EQU $32000 ECM data (R) 
00033001 VduL EQU $33001 S t a t u s VDU, l e f t hand s i d e (R/W) 
00033000 VduR EQU $33000 S t a t u s VDU, r i g h t hand s i d e (R/W) 
00034000 Rol l X EQU $34000 R o l l b a l l X c o - o r d i n a t e (R) 
00034002 R o l l Y EQU $34002 R o l l b a l l Y c o - o r d i n a t e (R) 
00035000 Constants EQU $35000 P l o t e x t r a c t o r c o n s t a n t s (R/W) 
00035002 PlotCount EQU $35002 Count of p l o t input words (R) 
00036000 TTCoords EQU $36000 T e s t T a r g e t s output address (W) 
00036000 ShipMotn EQU $36000 Ships motion data (R) 
0000 
00038000 DmaChanO EQU $38000 DMA Channel 0, base address 
00038040 DmaChanl EQU $38040 DMA Channel 1, base address 
00038080 DmaChan2 EQU $38080 DMA Channel 2, base address 
000380CO DmaChan3 EQU $380c0 DMA Channel 3, base address 
0000 
0000 ; M i s c e l l a n e o u s other equate v a l u e s 
oooo 
0020 B l o k S i z e EQU 32 Most e f f i c i e n t t r a n s f e r block s i z e 
oooo 
oooo 
oooo 
oooo ; Program base address 
oooo 
0000 4EC0 xxxx (PX) Begin BRA S t a r t u p 
0004 
0004 ; I n i t i a l program constant d e c l a r a t i o n s 
0004 
0000 N u l l EQU $00 
000D CR EQU $0d 
000A LF EQU $0a 
0008 BS EQU $08 
0007 BEL EQU $07 
0018 C t r l X EQU $18 
0004 
0004 
0010 
001A 
0027 
0039 
0039 
003D 
44 75 72 68 61 6D 20 52 41 54 45 53 
SysName 
53 6F 66 74 77 61 72 65 0D OA 
56 65 72 73 69 6F 6E 20 33 2E 34 0D OA 
DC.B 
52 61 64 61 72 20 53 65 6C 65 63 74 65 64 20 3A 20 00 
RadMess DC.B 'Radar S e l e c t e d : ', N u l l 
DC.B 'Durham RATES' 
DC.B 'Software', CR, LF 
'Version 3.4', CR, LF 
08 20 08 00 
00 
BackSp DC.B 
.ALIGN 
$08, $20, $08, N u l l 
2 
The Appl icat ion of Dig i ta l Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix C . 2 
M A T E S Development!; S o f t w a r e » S o u r c e L i s t i n g 
003E 
003E 
003E 
0040 xxxx 
0042 xxxx 
0044 xxxx 
0046 xxxx 
0048 xxxx 
004A xxxx 
004C xxxx 
004E xxxx 
0050 xxxx 
0052 xxxx 
0054 xxxx 
0056 xxxx 
0058 xxxx 
005A xxxx 
005C xxxx 
005E xxxx 
0060 xxxx 
0062 xxxx 
0064 xxxx 
0066 xxxx 
0068 xxxx 
0068 
0068 44 43 
006B 52 55 
006F 48 41 
0074 44 52 
0078 44 49 
007C 44 53 
0080 44 54 
0084 44 43 
0088 50 49 
008C 50 4F 
0090 50 52 
0094 52 41 
00 9A 44 50 
00A1 49 50 
00A8 53 45 
00AF 4C 45 
00B5 49 4E 
00BC 54 54 
ooco 54 54 
00C4 54 54 
00C8 4D 41 
00D0 
00D0 
00D0 
00D0 
00D0 
OODO 
00D0 
OODO 
OODO 41 20 
00F0 42 20 
0110 43 20 
0130 44 20 
0150 45 20 
0170 46 20 
0190 47 20 
01 BO 48 20 
01D0 
01D0 
01D0 
01D0 49 20 
01F0 4A 20 
0210 4B 20 
0230 4C 20 
0250 4D 20 
**** Table of permitted u s e r commands 
Commands 
(R) 
(R> 
(R) 
(R) 
(R) 
(R) 
(R) 
(R) 
(R) 
(R) 
<R> 
(R) 
(R) 
(R) 
(R) 
(R) 
(R) 
(R> 
(R) 
(R) 
(R) 
00 
4E 00 
4C 54 00 
50 00 
50 00 
50 00 
54 00 
54 00 
50 00 
50 00 
54 00 
44 41 52 00 
4C 49 53 54 00 
4C 49 53 54 00 
54 56 41 4C 00 
56 45 4C 00 
4A 45 43 54 00 
31 00 
32 00 
33 00 
43 53 42 55 47 00 
20 52 
20 52 
20 52 
20 42 
20 52 
20 53 
20 53 
20 52 
65 76 20 50 
61 64 61 72 
61 6E 67 65 
65 61 72 69 
61 6E 67 65 
50 46 20 52 
50 46 20 42 
61 6E 67 65 
DC W Coml - Commands 
DC.W Com2 - Commands 
DC.W Com3 - Commands 
DC W Com4 - Commands 
DC.W Com5 - Commands 
DC W Com6 - Commands 
DC W Com7 - Commands 
DC w Com8 - Commands 
DC w Com9 - Commands 
DC.W ComlO - Commands 
DC w Comll - Commands 
DC.W Coml2 - Commands 
DC.W Coml3 - Commands 
DC.W Coml 4 - Commands 
DC.W Coml5 - Commands 
DC w Coml6 - Commands 
DC.W Coml7 - Commands 
DC.W Coml8 - Commands 
DC.W Coml9 - Commands 
DC w Com20 - Commands 
DC w Com21 - Commands 
Coml: DC B 'DC, N u l l 
Com2: DC B 'RUN', N u l l 
Com3: DC B 'HALT', N u l l 
Com4: DC B 'DRP', N u l l 
Com5: DC B 'DIP', N u l l 
Com6: DC .B 'DSP' , N u l l 
Com7: DC B 'DTT' , N u l l 
Com8: DC B 'DCT' , N u l l 
Com9: DC B 'PIP', N u l l 
ComlO: DC B 'POP', N u l l 
Comll: DC B 'PRT' , N u l l 
Coml2: DC B •RADAR' , N u l l 
Coml3: DC B 'DPLIST ', N u l l 
Coml4: DC.B 'IPLIST ', N u l l 
Coml 5: DC B 'SETVAL ', N u l l 
Coml 6: DC.B 'LEVEL' , N u l l 
Coml7: DC B 'INJECT ', Null 
Coml8: DC.B 'TT1', N u l l 
Coml 9: DC.B 'TT2', N u l l 
Com20: DC B 'TT3' , N u l l 
Com21: DC B 'MACSBUG', N u l l 
.ALIGN 2 
Prompt s t r i n g s f o r s e t t i n g system parameters o r f o r 
d i s p l a y o f parameters on the system c o n s o l e . 
; Radar Dependent Parameter S t r i n g s 
65 72 69 6F 64 20 69 6E 20 4D 69 6C 6C 69 73 65 63 73 20 20 
Rdps DC.B 'A Rev Per i o d i n M i l l i s e c s 
20 52 61 6E 67 65 20 69 6E 20 44 61 74 61 6D 69 6C 65 73 20 
DC.B 'B Radar Range i n Datamiles 
20 53 44 20 69 6E 20 46 65 65 74 20 20 20 20 20 20 20 20 20 
DC.B 'C Range SD i n Feet 
6E 67 20 53 44 20 69 6E 20 43 20 44 65 67 72 65 65 73 20 20 
DC.B 'D Bear i n g SD i n C Degrees 
20 43 65 6C 6C 20 53 69 7A 65 20 69 6E 20 46 65 65 74 20 20 
DC.B 'E Range C e l l S i z e i n Feet 
61 6E 67 65 20 43 61 70 74 2E 20 53 69 7A 65 20 69 6E 20 46 
DC.B 'F SPF Range Capt. S i z e i n Feet 
65 61 72 69 6E 67 20 43 61 70 74 2E 20 69 6E 20 43 20 44 65 
DC.B 'G SPF Bear i n g Capt. i n C Degs 
20 4D 53 20 42 69 74 20 20 20 20 20 20 20 20 20 20 20 20 20 
DC.B 'H Range MS B i t 
; Radar Independent Parameter S t r i n g s 
20 49 6E 69 74 69 61 6C 20 53 50 46 20 43 6F 6E 66 69 64 65 6E 63 65 20 20 20 
Rips DC.B ' I I n i t i a l SPF Confidence 
20 53 50 46 20 43 6F 6E 66 69 64 65 6E 63 65 20 49 6E 63 72 65 6D 65 6E 74 20 
DC.B ' J SPF Confidence Increment 
20 4D 61 78 69 6D 75 6D 20 53 50 46 20 43 6F 6E 66 69 64 65 6E 63 65 20 20 20 
DC.B 'K Maximum SPF Confidence 
20 43 65 6E 74 69 20 53 50 46 20 53 6D 6F 6F 74 68 69 6E 67 20 46 61 63 74 6F 
DC.B 'L C e n t i SPF Smoothing F a c t o r 
20 57 61 72 6D 2D 75 70 20 52 65 76 73 20 20 20 20 20 20 20 20 20 20 20 20 20 
DC.B 'M Warm-up Revs 
20 20 20 00 
', N u l l 
20 20 20 00 
', N u l l 
20 20 20 00 
', N u l l 
20 20 20 00 
', N u l l 
20 20 20 00 
', N u l l 
65 65 74 00 
', N u l l 
67 73 20 00 
, N u l l 
20 20 20 00 
, N u l l 
20 20 20 00 
', N u l l 
20 20 20 00 
', N u l l 
20 20 20 00 
', N u l l 
72 20 20 00 
', N u l l 
20 20 20 00 
', N u l l 
T h e Applicat ion of Digital Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix C . 3 
B A T E S D e v e l o p m e n t S o f t w a r e • Source L i s t i n g 
0270 4E 20 20 43 65 6E 74 69 20 4E 6F 69 73 65 20 54 68 72 65 73 68 6F 6C 64 20 20 20 20 20 20 20 00 
DC.B 'N Ce n t i Noise T h r e s h o l d , N u l l 
0290 4F 20 20 43 65 6E 74 69 20 4D 61 6E 6F 65 75 76 72 65 20 54 68 72 65 73 68 6F 6C 64 20 20 20 00 
DC.B '0 C e n t i Manoeuvre T h r e s h o l d , N u l l 
02B0 50 20 20 43 65 6E 74 69 20 4D 61 6E 6F 65 75 76 72 65 20 44 65 63 61 79 20 46 61 63 74 6F 72 00 
DC.B 'P C e n t i Manoeuvre Decay F a c t o r ' , N u l l 
02D0 51 20 20 4D 61 78 20 4B 6E 6F 74 73 20 41 6C 6C 6F 77 65 64 20 20 20 20 20 20 20 20 20 20 20 00 
DC.B 'Q Max Knots Allowed , N u l l 
02F0 52 20 20 4D 61 78 20 42 65 61 72 69 6E 67 20 44 69 66 66 2E 20 69 6E 20 43 20 44 65 67 73 20 00 
DC.B "R Max Bear i n g D i f f . i n C Degs , N u l l 
0310 53 20 20 47 53 20 70 65 72 20 31 30 30 30 20 4B 6E 6F 74 73 20 20 20 20 20 20 20 20 20 20 20 00 
DC.B >S GS per 1000 Knots , N u l l 
0330 54 20 20 49 6E 69 74 69 61 6C 20 54 72 61 63 6B 20 43 6F 6E 66 69 64 65 6E 63 65 20 20 20 20 00 
DC.B , T I n i t i a l Track Confidence , N u l l 
0350 55 20 20 43 6F 6E 66 69 72 6D 65 64 20 54 72 61 63 6B 20 43 6F 6E 66 69 64 65 6E 63 65 20 20 00 
DC.B 'U Confirmed Track Confidence , N u l l 
0370 56 20 20 4D 61 78 20 4E 75 6D 62 65 72 20 6F 66 20 4D 69 73 73 65 64 20 4C 6F 6F 6B 73 20 20 00 
DC.B 'V Max Number o f Missed Looks , N u l l 
0390 57 20 20 53 68 69 70 73 20 4D 6F 74 69 6F 6E 20 43 6F 72 72 65 63 74 69 6F 6E 20 20 20 20 20 00 
DC.B >W Ships Motion C o r r e c t i o n , N u l l 
03B0 58 20 20 4C 6F 77 65 72 20 54 68 72 65 73 68 2E 20 43 6C 75 74 74 65 72 20 43 6F 75 6E 74 20 00 
DC.B 'X Lower Thresh. C l u t t e r Count , N u l l 
03D0 59 20 20 55 70 70 65 72 20 54 68 72 65 73 68 2E 20 43 6C 75 74 74 65 72 20 43 6F 75 6E 74 20 00 
DC.B 'Y Upper Thresh. C l u t t e r Count , N u l l 
03F0 5A 20 20 53 70 61 72 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 00 
DC.B 'Z Spare , N u l l 
0410 •ALIGN 2 
0410 
0410 
0410 ; I n i t i a l i s a t i o n and D e f a u l t Parameters 
0410 
0410 ; Radar Dependent V a r i a b l e s 
0410 
0410 0FA0 005A 00C9 0012 03D8 0514 00B4 0003 
RdpDef DC.W 4000, 90, 201, 18, 984, 1300, 180 . 3 ; 992 
0420 09C4 002A 0032 001E 00F6 04B0 00C8 0003 
DC.W 2500, 42, 50, 30, 246, 1200, 200, 3 
0430 09C4 002A 00C9 001E 03D8 0514 00C8 0004 
DC.W 2500, 42, 201, 30, 984, 1300, 200 , 4 
0440 09C4 001E 001E 000F 007B 0258 0096 0002 
DC.W 2500, 30, 30, 15, 123, 600, 150, 2 
0450 09C4 001E 005A 000F 0171 0514 0096 0004 
DC.W 2500, 30, 90, 15, 369, 1300, 150, 4 
0460 1F40 OOFC 005A 0022 0171 0514 00C8 0001 
DC.W 8000, 252, 90, 34, 369, 1300, 200 , 1 1006 
0470 
0470 0031 0063 0032 0045 DO 61 0015 
MaxRaNum DC.W $31 , $63, $32, $45, $61, $15; Max range nos. 
047C 
047C 0004 0001 0002 0001 3001 0008 
RangeFac DC.W 54, $1, $2, $1, $1, $8 ; Range f a c t o r s 
0488 
0488 ; Radar Independent V a r i a b l e s 
0488 
0488 0005 0005 000F 001E RipDef DC.W 5, 5, 15, 30 
0490 0005 012C 012C 001E DC.W 5, 300, 300, 30 
0498 09C4 01F4 0007 0004 DC.W 2500, 500, 7, 4 
04 AO 0008 0006 0008 0000 DC.W 8, 6, 8, 0 
04A8 0001 0000 0000 DC.W 1, 0, 0 
04AE 
04AE ; S t a t u s VDU I n i t i a l i s a t i o n Values 
04AE 
04AE 0000 0000 0034 0024 VDUITab DC.W S00, $00, $34, $24 
04B6 0001 0001 0075 0075 DC.W $01 , $01, $75, $75 
04 BE 0002 0002 0003 0003 DC.W $02, $02, $03, $03 
04C6 003F 003F 0004 0004 DC.W $3f $3f, $04, $04 
04CE 0007 0007 0005 0005 DC.W $07 $07, $05, $05 
04D6 0006 0006 0000 0000 DC.W $06 $06, $00, $00 
04DE 
04DE ; S t a t u s VDU template 
04DE 
04DE xxxx xxxx xxxx (R> VDUTemp DCB.W 640 0 
09DE 
09DE 
09DE 
09DE 
T h e Application of Dig i ta l Techniques to a n 
Automatic R a d a r T r a c k E x t r a c t i o n System. Appendix C . 4 
R A T E S D e v e l o p m e n t S o f t w a r e - Source L i s t i n g 
09DE - ******* ******* ************************************************ 
09DE . * * 
09DE ; * MAIN PROGRAM DATA AREA - SHOULD RESIDE IN RAM * 
09DE . ft * 
09DE > ************** ************************************************ 
09DE 
09DE 0000 oooo B u f f P t r DC.L 0 ; Address of c u r r e n t prompt 
09E2 XX XX XX XX XX XX (R) I npBuff DCB.B 82, 0 ; Console input b u f f e r 
0A34 XX XX XX XX XX XX (R) TropBuff DCB.B 82, 0 ; Temporary b u f f e r a r e a 
0A86 
OAS 6 . **** Main Incoming / outgoing data a r e a s **** 
0A86 ; 
OAS 6 XX XX XX XX XX XX (R) C e l l B l o c k DCB.B 4096, 0 • C l u t t e r c e l l s 
1A8 6 xxxx xxxx XXXX (R) ThreshVal DCB.W 4096, 0 • Threshold v a l u e s 
3A86 xxxx xxxx xxxx (R) SynthVal DCB.W 512, 0 • S y n t h e t i c s c h a r a c t e r codes 
3E86 XX XX XX XX XX XX (R) VDUMap DCB.B 640, 0 • RAM-based VDU template 
4106 oooo oooo Base DC.L 0 • Current input p l o t base adr. 
410A XXXX xxxx (R) F i r s t I P A DCB.L 2048, 0 • Incoming p l o t word storage 
61 OA 
61 OA . **** system Commands Table - #$80 i f on, #$00 i f o f f **** 
61 OA ; 
61 OA SysCommand 
610A 00 StopRun: DC.B 0 • Stop o r run command 
610B 00 DispUnsp: DC.B 0 D i s p l a y u n a s s o c i a t e d p l o t s 
610C 00 D i s p l p c : DC.B 0 • D i s p l a y input p l o t s 
610D 00 D i s p S t a t : DC.B 0 • D i s p l a y s t a t i o n a r y p l o t s 
610E 00 DispTent: DC.B 0 • D i s p l a y t e n t a t i v e t r a c k s 
610F 00 DispConf: DC.B 0 D i s p l a y confirmed t r a c k s 
6110 00 P l o t I P : DC.B 0 • P l o t input p l o t s 
6111 00 PlotOP: DC.B 0 Pl o t output p l o t s 
6112 00 P r i n t T r k s : DC.B 0 P r i n t t r a c k s command 
6113 00 Thresh DC.B 0 • Threshold command 
6114 0000 ThreshHol DC.W 0 • Threshold hole s i z e 
6116 0000 ThreshLev DC.W 0 • Threshold l e v e l 
6118 00 Manlnit DC.B 0 • Manual i n i t i a t i o n command 
6119 
6119 T e s t T a r g e t 
6119 00 TestNum: DC.B 0 • T e s t t a r g e t number 
611A oooo TestRange: DC.W 0 • T e s t t a r g e t range 
611C oooo T e s t B e a r : DC.W 0 • T e s t t a r g e t b e a r i n g 
611E oooo TestSpeed: DC.W 0 • Test t a r g e t speed 
6120 oooo TestHead: DC.W 0 • T e s t t a r g e t heading 
6122 
6122 oooo RadarType DC.W 0 • Radar type code 
6124 oooo ConstWord DC.W 0 • 'Old' c o n s t a n t s word 
6126 
6126 
6126 . **** i n t e g e r system parameters * ** * 
6126 ; 
6126 
6126 oooo RevPermi DC.W 0 • Rev p e r i o d i n m i l l i s e c o n d s 
6128 oooo RadRanDM: DC.W 0 • Radar range i n da t a m i l e s 
612A oooo RangeSDFt: DC.W 0 • Radar range SD i n f e e t 
612C oooo BearSDCd: DC.W 0 Beari n g SD i n C degrees 
612E oooo RangeCSFt: DC.W 0 Range c e l l s i z e i n f e e t 
6130 oooo SPFRCSFt: DC.W 0 SPF range capture s i z e i n f e e t 
6132 oooo SPFBCSCd: DC.W 0 SPF b e a r i n g capture s i z e i n C degrees 
6134 oooo RangeMSBT: DC.W 0 Range ms b i t 
6136 oooo I n i t S P F C : DC.W 0 I n i t i a l SPF confidence 
6138 oooo SPFConlnc: DC.W 0 SPF confidence increment 
613A oooo MaxSPFCon: DC.W 0 Maximum SPF confidence 
613C oooo CenSPFSmo: DC.W 0 C e n t i SPF smoothing f a c t o r 
613E oooo WarmRevs: DC.W 0 Warm up r e v s 
6140 oooo CenNoise: DC.W 0 C e n t i n o i s e t h r e s h o l d 
6142 oooo CenManThr: DC.W 0 C e n t l manoeuvre t h r e s h o l d 
6144 oooo CenMandy: DC.W 0 C e n t i manoeuvre decay f a c t o r 
6146 oooo MaxKnots: DC.W 0 Max knots allowed 
6148 oooo MaxBDC: DC.W o Max b e a r i n g d i f f e r e n c e 
614 A oooo GSPerKK: DC.W 0 GS per 1000 knots 
614C oooo I n i t T R L : DC.W o , I n i t i a l t r a c k l i k e l i h o o d 
614E oooo ConfTRL: DC.W 0 Confirmed t r a c k l i k e l i h o o d 
6150 oooo MaxMissed: DC.W o Max number o f missed looks 
6152 oooo ShipMotn: DC.W o Ships motion compensation 
6154 oooo LowerThr: DC.W o Lower t h r e s h o l d c l u t t e r count 
6156 oooo UpperThr: DC.W o Upper t h r e s h o l d c l u t t e r count 
6158 
6158 ; **** Derived system parameters »*•* 
6158 
6158 
6158 oooo RevPerSec DC.W o Rev pe r i o d i n seconds ( f l O ) 
615A oooo s h i f t s R : DC.W o S h i f t f o r segment range ( i n t ) 
615C oooo oooo RUPMile: DC.L o Range u n i t s per m i l e ( f l 6 ) 
T h e Appl icat ion of Digital Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix C . 5 
K A T E S D e v e l o p m e n t S o f t w a r e • Source L i s t i n g 
6160 0000 RadRange: DC.W 0 • Radar range ( i n t ) 
6162 0000 SynRanF: DC.W 0 • S y n t h e t i c s range f a c t o r ( f l 6 ) 
6164 0000 SPFRCS: DC.W 0 • SPF range capture s i z e ( i n t ) 
6166 0000 SPFBCS: p e w 0 • SPF be a r i n g capture s i z e ( i n t ) 
6168 0000 SPFSmooth: DC.W 0 • SPF smoothing f a c t o r ( f l 6 ) 
616 A 0000 RadRanSD: DC.W 0 • Radar range SD (flO) 
616C 0000 RadBearSD: DC.W 0 • Radar b e a r i n g SD ( f l 6 ) 
616E 0000 RadRadSD: DC.W 0 • Radar r a d i a n s SD ( f l 6 ) 
6170 0000 NoiseThr: DC.W 0 • Noise t h r e s h o l d (flO) 
6172 0000 ManvThr: DC.W 0 • Manoeuvre t h r e s h o l d ( flO) 
6174 oooo ManDFact: DC.W 0 • Manoeuvre decay f a c t o r (flO) 
6176 0000 RanNolse: DC.W 0 • Range noise t h r e s h o l d ( i n t ) 
6178 0000 MaxNRE: DC.W 0 • Max noise range e r r o r ( i n t ) 
617A 0000 BearNoise: DC.W 0 ; Bearing Noise T h r e s h o l d ( f l 6 ) 
617C 0000 MaxNBE: DC.W 0 ; Max n o i s e b e a r i n g e r r o r ( f l 6 ) 
617E 0000 MaxRanD: DC.W 0 • Max range d i f f e r e n c e ( i n t ) 
6180 0000 SpeedFact: DC.W 0 • Speed f a c t o r ( f l O ) 
6182 0000 MaxBearD: DC.W 0 • Max be a r i n g d i f f e r e n c e ( f l 6 ) 
6134 0000 MaxRadD: DC.W 0 • Max r a d i a n s d i f f e r e n c e ( f l 6 ) 
6186 0000 S h i f t C l u t : DC.W 0 • S h i f t f o r c l u t t e r range ( i n t ) 
6188 0000 CRange: DC.W 0 • C Range 
618A 0000 C S c a l e : DC.W 0 • C S c a l e 
618C 
618C 0000 MaxRSect DC.W 0 • Max range s e c t o r 
618E oooo MaxOn4: DC.W 0 • Max range s e c t o r / 4 
6190 0000 MaxOn7: DC.W 0 ; Max range s e c t o r / 7 
6192 oooo MaxOnl5: DC.W 0 • Max range s e c t o r / 15 
6194 oooo MaxBlack: DC.W 0 • Max bl a c k range s e c t o r 
6196 
6196 xxxx xxxx xxxx (R) ManPKnot DCB.W 5, 0 • Manoeuvre per knot t a b l e 
61A0 xxxx xxxx xxxx (R) ManPG DCB.W 5, 0 • Manoeuvre per G t a b l e 
61AA 
61AA ; **** system s t a t e v a r i a b l e s **** 
61AA ; 
61AA oooo Octant DC.W 0 C u r r e n t l y scanned octant 
61AC oooo PrevOct DC.W 0 Previous octant 
61AE oooo SecProct DC.W 0 Second p r e v i o u s o c t a n t 
61B0 oooo NextOct DC.W 0 Next o c t a n t 
61B2 oooo SectOctOn DC.W 0 Second octant on 
61B4 oooo FrthOctOn DC.W 0 Fourth octant on 
61B6 
61B6 ; **»* Spat s t a t e t a b l e * ** * 
61B6 i 
61B6 oooo RevNum DC.W 0 Current r e v . number 
61B8 oooo ShlpHead: DC.W 0 Ships heading i n degrees 
61BA oooo Shipspeed: DC.W o , Ships speed i n knots 
61BC oooo RollRange: DC.W 0 R o l l b a l l range i n m i l e s 
61BE oooo R o l l B e a r : DC.W 0 R o l l b a l l b e a r i n g i n degrees 
61C0 oooo TotFInput: DC.W o T o t a l f i l t e r input p l o t s 
61C2 oooo NumStat: DC.W o Number o f s t a t i o n a r y p l o t s 
61C4 oooo TotFOut: DC.W o T o t a l f i l t e r output p l o t s 
61C6 oooo TotUnass: DC.W o , T o t a l unassigned p l o t s 
61C8 oooo NumTent: DC.W 0 Number o f t e n t a t i v e t r a c k s 
61CA oooo NumConf: DC.W 0 Number of confirmed t r a c k s 
61CC oooo NumFIW: DC.W o ; Number o f f i l t e r input words 
61CE oooo NumFOP: DC.W o Number o f f i l t e r output p l o t s 
61D0 oooo NumUnass: DC.W o Number o f u n a s s o c i a t e d p l o t s 
61D2 oooo NumSynth: DC.W o Number o f s y n t h e t i c s c h a r s i n b u f f e r 
61D4 oooo TrackCount DC.W o Track count 
61D6 oooo Loading DC.W o System l o a d i n g parameter 
61D8 
61D8 
61D8 • **************** * ***************************************** 
61D8 • * * 
61D8 ; * S t a r t of main program code - * 
61D8 ; * I n i t i a l i s a t i o n r o u t i n e s * 
61D8 • ***************** ***************************************** 
61D8 ; 
61D8 
61D8 oooo oooo Zero DC.L soooooooo 
61DC 
61 DC 487A A804 (P) I n i t D a t a PEA I n p B u f f 
61E0 421F CLR.B (SP) + ; Nothing i n input b u f f e r 
61E2 487A A850 (P) PEA TmpBuff 
61E6 421F CLR.B <SP) + 
61E8 487A FF20 (P) PEA StopRun 
61 EC 421F CLR.B (SP) + ; RATES stopped. 
61EE 
61EE 41FA FFC6 (P) LEA RevNum, AO 
61F2 303C 000E MOVE.W #14, DO 
61F6 4258 C l e a r S t a t CLR.W (A0) + 
61F8 51C8 FFFC (P) DBRA DO, C l e a r S t a t ; C l e a r VDU s t a t i s t i c s 
T h e Applicat ion of Digital Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix C . 6 
R A T E S Deve lopmen t S o & w a r © • Source L i s t i n g 
61FC 207C 0003 8000 MOVE.L dDmaChanO, AO ; Program DMA c o n t r o l l e r 
6202 1168 0000 0000 MOVE.B 0(A0), 0(A0) ; f o r REQ d r i v e n c y c l e - s t e a l 
6208 217C AA92 0400 0004 MOVE.L #$AA920400, 4 (AO) ; t r a n s f e r from 1 6 - b i t d e v i c e 
6210 ; w i t h ACK. 
6210 
6210 43F9 0003 8040 LEA DmaChanl, A l 
6216 45FA A86E (P) LEA C e l l B l o c k , A2 
621A 1291 MOVE.B ( A l ) , (Al) ; C l e a r Dma s t a t u s . 
621C 237C 0AA1 0400 0004 MOVE.L #$0aal0400, 4(A1) ; Set Dma f o r b u r s t mode 
6224 234A 000C MOVE.L A2, $c ( A l ) ; a d d r e s s i n g c l u t t e r c e l l s . 
6226 337C 1000 000A MOVE.W #4096, $ a ( A l ) 
622E 487A FFA8 (P) PEA Zero 
6232 237A FFA4 0014 (P) MOVE.L Zero, $14(Al) 
6238 137C 0080 0007 MOVE.B #$80, 7(A1) ,- C l e a r 4096 c e l l s t o zero 
623E 
623E 45FA D846 (P> LEA SynthVal, A2 
6242 234A 000C MOVE.L A2, $ c ( A l ) 
6246 337C 00FF 000A MOVE.W #255, $a(Al) 
624C 1291 MOVE.B ( A l ) , (Al) 
624E 137C 0080 0007 MOVE.B 0$80, 7(A1) ; C l e a r 255 s y n t h e t i c s v a l s . 
6254 
6254 4840 xxxx (PX) PEA NorthProc ; Set i n t e r r u p t v e c t o r s 
6258 4840 xxxx (PX) PEA ReadChar 
625C 4840 xxxx (PX) PEA F i r s t O c t 
6260 21DF 0068 MOVE.L (SP)+, IRQ2 ; Octant demand IRQ 
6264 21D7 006C MOVE.L (SP), IRQ3 
6268 21DF 0070 MOVE.L (SP)+, IRQ4 ; ACIA input IRQ 
626C 21D7 0074 MOVE.L (SP) , IRQ5 
6270 21DF 0080 MOVE. L (SP)+, TRAP0 ; North marker IRQ 
6274 
6274 4E75 RTS 
6276 
6276 
6276 ; **** i n i t i a l i s e the L i q u i d C r y s t a l s t a t u s d i s p l a y and **** 
6276 . **** s e t U p a d i s p l a y template i n RAM. C l e a r a l l v a l s . **** 
6276 . **** zero & d i s p l a y v a l u e s to spaces . ** ** 
6276 ; 
6276 
6276 0026 VduOffset DC.W 38 ; Table of VDU template 
6278 006E DC.W 110 parameter d i s p l a y l o c n s . 
627A 00C4 DC.W 196 o f f s e t from s t a r t of RAM-based 
627C 00D6 DC.W 214 VDU map. 
627E 0114 DC.W 276 
6280 0126 DC.W 294 
6282 01B8 DC.W 440 
6284 0208 DC.W 520 
6286 0258 DC.W 600 
6288 02A8 DC.W 680 
628A 02F8 DC.W 760 
628C 0348 DC.W 840 
628E 
628E 41FA A21E (P) InitVDU LEA VDUITab, AO ; T r a n s f e r i n i t i a l i s a t i o n 
6292 43F9 0003 3000 LEA VduR, A l ; codes to VDU c o n t r o l l e r . 
6298 323C 0008 MOVE.W #8, Dl 
62 9C 4A29 0003 I W a i t TST.B 3(A1) ; Wait f o r VDU c o n t r o l l e r 
62A0 6B FA (P) BMI IVWait ; ready t o accept d a t a . 
62A2 3358 0002 MOVE.W (A0) + , 2(A1) 
62A6 3298 MOVE.W (A0)+, (Al) 
62A8 51C9 FFF2 (P> DBRA Dl, IVWait ; Loop u n t i l VDU i n i t i a l i s e d 
62AC 
62AC 41FA A230 (P> LEA VDUTemp, AO 
62B0 43FA DBD4 (P) LEA VDUMap, A l 
62B4 323C 027F MOVE.W #639, Dl 
62B8 32D8 IVLoop MOVE.W (A0)+, (Al) + ; Copy PROM template to RAM 
62BA 51C9 FFFC (P) DBRA D l , IVLoop 
62BE 4E75 RTS 
62C0 
62C0 . ******* **************************************************** 
62C0 • * * 
62C0 . * Mis c e l l a n e o u s c h a r a c t e r I/O sub r o u t i n e s * 
62C0 . * * 
62C0 . ******* **************************************************** 
62C0 
62C0 
62C0 . **** output a c h a r a c t e r to the port whose base address **** 
62C0 . **** ±s lOPort, from r e g i s t e r DO. B **** 
62C0 ; 
62C0 
62C0 0815 0001 Outch BTST. B #1, (A5) ; Wait f o r b u f f e r ready 
62C4 67 FA (P) BEQ.S Outch 
62C6 1B40 0002 MOVE.B DO, 2(A5) ; T r a n s f e r to port b u f f e r 
62CA 4E75 RTS 
T h e Appl icat ion of Dig i ta l Techniques to an 
Automatic R a d a r T r a c k Extrac t ion System. Appendix C . 7 
M A T E S Deve lopmen t S o f t w a r e » Source L i s t i n g 
62CC 
62CC . *»«* p r i n t a n u l l terminated s t r i n g on the system «*** 
62CC . **** console, by c a l l i n g s u b routine OutchO. A6 p o i n t s **** 
62CC . **** t o s t r i n g . Uses DO £ A5. 
62CC ; 
62CC 
62CC 4BF9 0003 FFOl P r i n t s t r LEA Terminal, A5 
62D2 101E GetChar MOVE.B (A6) + , DO 
62D6 XX (R) BNE.S L a s t C h a r 
62D6 61 E8 (P) BSR.S Outch 
62D8 60 F8 (P) BRA. S GetChar 
62DA 4E75 LastChar RTS 
62DC 
62DC 
62DC 
62DC . **** p r i n t the c u r r e n t prompt s t r i n g on the t e r m i n a l **** 
62DC ; 
62DC 
62DC 52 41 54 45 53 20 3E 20 
P r l DC.B 'RATES > ' 
62E4 OD OA 00 DC.B CR, LF, N u l l 
62E7 00 .ALIGN 2 
62E8 3E 2C OD OA 00 Pr2 DC.B '> ', CR, LF, N u l l 
62ED 00 .ALIGN 2 
62EE 
62EE 487A FE1A (P) PrPrompt PEA StopRun 
62F2 4DFA FFE8 (P) LEA P r l , A6 
62F6 081F 0007 BTST.B #7, (SP) + 
62FA 67 DO (P> BEQ P r i n t s t r 
62FC 4DFA FFEA (P) LEA Pr2, A6 
6300 60 CA (P) BRA. S P r i n t s t r 
6302 
6302 
6302 . **** D i s p l a y a c a r r i a g e r e t u r n , l i n e feed on t e r m i n a l **** 
6302 ; 
6302 
6302 4BF9 0003 FF01 NewLine LEA Terminal, A5 
6308 103C OOOD MOVE.B SCR, DO 
630C 61 B2 (P) BSR Outch 
630E 103C 000A MOVE.B #LF, DO 
6312 61 AC <P> BSR Outch 
6314 4E75 RTS 
6316 
6316 
6316 . **** Copy the s t a t u s VDU template t o t h e VDU c o n t r o l **** 
6316 . **** board. Uses AO, A l and Dl •*** 
6316 ; 
6316 
6316 48E7 40C0 VDUOut MOVEM.L D1/A0-A1, -(SP) 
631A 41FA DB6A (P) LEA VDUMap.AO 
631E 43F9 0003 3000 LEA VduR,Al 
6324 
6324 337C OAOA 0002 MOVE.W #S0A0A,2(A1) ; Set VDU s t a t u s t o r e c e i v e 
63 2A 32BC 0000 MOVE.W #$0000, (Al) ,- data i n template form. 
632E 337C OBOB 0002 MOVE.W S$0BOB, 2(A1) 
6334 32BC 0000 MOVE.W #$0000, (Al) 
6338 337C OCOC 0002 MOVE.W #$0C0C,2(A1) 
633E 323C 027F MOVE.W #639,Dl 
6342 
6342 4A29 0003 OutLoop TST.B 3 (Al) ; Wait f o r c o n t r o l l e r ready 
6346 6B FA (P) BMI.S OutLoop 
6348 3298 MOVE.W (A0)+, (Al) 
63 4A 51C9 FFF6 <P> DBRA Dl,OutLoop 
634E 4CDF 0302 MOVEM.L (SP)+, D1/A0-A1 
6352 4E75 RTS 
6354 
6354 . **** Convert a 16 b i t i n t e g e r t o a s c i i format. The **** 
6354 . **** parameters are pushed onto the st a c k p r i o r t o the **** 
6354 . **** c a l l : i n t e g e r f i r s t , b u f f e r address second. **** 
6354 
6354 
6354 48E7 6080 IntToAsc MOVEM.L D1/D2/A0,-(A7) 
6358 206F 0010 MOVE.L 12 + 4(A7), AO 
63 5C 322F 0012 MOVE.W 12 + 6(A7), Dl 
6360 4A41 TST.W Dl ; I s i n t e g e r n e g a t i v e 
6364 XX (R) BPL.S PosValue 
6364 10FC 002D MOVE.B #'-', (A0)+ ; I n s e r t •-' 
6368 4441 NEG.W Dl 
636A 
63 6A 343C 2710 PosValue MOVE.W #10000,D2 ; S t a r t i n g q u o t i e n t 
636E 
63 6E 48C1 DecDiv EXT.L Dl 
T h e Applicat ion of Digi ta l Techniques to a n 
Automatic R a d a r T r a c k Extrac t ion System. Appendix C . 8 
KATES Bevelopinaemt Software - Source Listing 
6370 84C1 DIVU Dl, D2 ; D i v i d e to g i v e r e s u l t S 
6374 X X (R> BNE.S MakeAscii ; remainder. 
6374 0C02 0001 CMP.B (50001, D2 
637A X X (R) BNE.S I n t Z e r o 
637A 
637A 0601 0030 MakeAscii ADD.B OS30, Dl ; Convert rmdr to A s c i i 
637E 10C1 MOVE.B Dl, (A0) + 
6380 
6380 4841 I n t Z e r o SWAP Dl ; Switch rmdr & r e s u l t 
6382 84FC 000A DIVU #10, D2 ; D i v i d e quotient by 10 
6386 66 E6 <P) BNE.S DecDiv 
6388 
6388 4210 CLR.B (AO) ; N u l l t e r m i n a t e 
638A 
638A 4CDF 0106 MOVEM.L (A7)+,D1/D2/A0 ; r e s t o r e r e g i s t e r s 
638E 2F57 0006 MOVE.L (A7), 6(A7) 
6392 DFFC 0000 0006 ADDA.L *6, A7 
6398 4E75 RTS 
63 9A 
63 9A 
63 9A . **** copy an A s c l l s t r i n g from a b u f f e r t o the s t a t u s **** 
63 9A ; * * * * V D U RAM template u s i n g f i e l d s 6 c h a r a c t e r s wide. **** 
63 9A ; ««** Needs at l e a s t 10 byte s o f l o c a l v a r i a b l e space. **** 
63 9A ; 
63 9A 
63 9A 4E54 FFF6 VduMapUp LINK A4, «-10 
63 9E 48E7 70F0 MOVEM.L D1-D3/A0-A3, -(SP) ; Push r e g i s t e r s 
63A2 
63A2 41FA FE12 (P) LEA RevNum, AO ; Address of f i r s t i n t e g e r 
63A6 43FA DADE (P) LEA VDUMap, Al 
63AA 45FA FECA (P) LEA VduOffset, A2 
63AE 323C O0OB MOVE.W #11, Dl 
63B2 
63B2 47EC FFF6 IntConv LEA -10 (A4), A3 ; Output b u f f e r address 
63B6 3F18 MOVE.W (A0)+, -(A7> 
63B8 2F0B MOVE.L A3, -(A7) 
63 BA 61 98 (P) BSR In t T o A s c 
63BC 
63 BC 343C 0005 MOVE.W #5, D2 ; Set c h a r a c t e r count 
63C0 361A CopyChar MOVE.W (A2)+, D3 ; Get output o f f s e t 
63C2 4A13 TST.B (A3) ; I s s t r i n g n u l l or short ? 
63C6 X X (R) BEQ.S SpaceOut 
63C6 
63C6 139B 30 00 MOVE.B (A3)+, (Al, D3) ; No: Copy A s c i i d i g i t 
63CA 4EC0 xxxx (PX) BRA Copylnc 
63CE 13BC 0020 30 00 SpaceOut MOVE.B «' \ (Al, D3) 
63D4 
63D4 5489 Copylnc ADDQ.L #2, Al 
63D6 51C9 FFDA (P) DBRA Dl,IntConv 
63DA 
63DA 4CDF 0F0E MOVEM.L (SP)+, D1-D3/A0-A3 ; Re s t o r e r e g i s t e r s 
63DE 4E5C UNLK A4 
63E0 4E75 RTS 
63E2 
63E2 
63E2 ; **** End of gener a l purpose output r o u t i n e s . Next one **** 
63E2 ; **** i s f o r handling Input from the cons o l e . I t i s only **** 
63E2 ; *+++ c a l l e d when an i n t e r r u p t i s generated from t h e **«* 
63E2 ; **** a c i a port connected t o the t e r m i n a l . **** 
63E2 ; **** mi a f f e c t e d r e g i s t e r s a r e saved . I f t he input **** 
63E2 . *»** c h a r a c t e r i s a CR, the command i i s passed t o the **** 
63E2 ; **** p a r s e r and i n t e r p r e t e r . **** 
63E2 ; 
63E2 
63E2 40E7 ReadChar MOVE.W SR, -(SP) ; Save s t a t u s r e g i s t e r 
63E4 48E7 E0E6 MOVEM. L D0-D2/A0-A2/A5-A6, - (SP) 
63E8 46FC 2400 MOVE. W #$2400, SR ; Mask a l l i n t e r r u p t s 
63EC 
63 EC 41FA A5F0 (P) LEA B u f f P t r , AO ; Current b u f f e r p o i n t e r 
63F0 4BF9 0003 FF01 LEA Terminal, A5 
63F6 1ABC 00D5 MOVE.B #Sd5, (A5) ; Set RTS high 
63 FA 
63 FA 102D 0002 InChar MOVE.B 2(A5), DO ; Read c h a r a c t e r from a c i a 
63FE 0200 007F AND. B #S7F,D0 
6402 
6402 0C0O 0008 CMP.B #BS, DO ; I s i t a backspace 
6408 X X (R) BNE.S NotBS 
6408 
6408 B1FA A5D8 (P) CMPA.L InpBuff, AO ; Can't backspace a t s t a r t 
64 0E X X (R) BNE.S EchoBS ; o f l i n e ! 
640E 103C 0007 MOVE.B #BEL, DO 
6412 61 00 FEAC (P) BSR Outch 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 9 
RATES Development Softwar® - Source Listing 
6416 4EC0 xxxx (PX) BRA E x l t R e a d 
641A 
641A 4DFA 9C1D (P> EchoBS LEA BackSp, A6 
641E 61 00 FEAC (P) BSR P r i n t s t r 
6422 5388 SUBQ.L dSOl, AO ; Input p o i n t e r t o prev. char 
6424 4EC0 X X X X (PX) BRA E x i t R e a d 
6428 
6428 0C00 0018 NotBS CMP.B «CtrlX, DO ; D e l e t e l i n e char ? 
642E X X (R> BEQ.S C l r l p B u f f 
642E 
642E 0C00 000D CMP.B SCR, DO ; C a r r i a g e r e t u r n ? 
6434 X X <R) BNE.S NotCR 
6434 
6434 4E80 xxxx (PX) BSR I n t e r p r e t ; I n t e r p r e t command 
6438 61 00 FEB4 (P) C l r l p B u f f BSR PrPrompt ; P r i n t new prompt s t r i n g 
643C 41FA A5A4 (P) LEA InpBuff, AO ; s c l e a r input b u f f e r . 
6440 4EC0 xxxx (PX) BRA E x i t R e a d 
6444 
6444 61 00 FE7A <P> NotCR BSR Dutch 
6448 10C0 MOVE.B DO, (A0) + ; Copy c h a r a c t e r t o b u f f e r 
644A 
644A 4210 Ex l t R e a d CLR.B (AO) ; N u l l t e r m i n a t e b u f f e r 
644C 487A A590 (P) PEA B u f f P t r 
6450 2EC8 MOVE.L AO, (SP) + ; Save p o i n t e r 
6452 
6452 1ABC 0095 MOVE.B 0$95, (A5) ; Enable RTS again 
6456 4CDF 6707 MOV EM. L (SP)+, D0-D2/A0-A2/A5-A6 
64 5A 46DF MOVE.W (SP)+, SR 
645C 4E73 RTE 
645E 
645E 
645E . **** Subroutine t o p a r s e t he input b u f f e r and p i c k out ***» 
645E - **** command s t r i n g s f o r e x e c u t i o n . The a p p r o p r i a t e **** 
645E • * *** subroutine i s then executed or an e r r o r p r i n t e d . **** 
645E . **** D7 i s used t o communicate the command sense. **** 
64 5E ; 
645E 
645E 48E7 C1E0 I n t e r p r e t MOVEM.L D0-D1/D7/A0-A2, - (SP) 
64 62 41FA A57E (P) LEA InpBuff, AO ; Set p o i n t e r t o b u f f e r s t a r t 
6466 1E3C 0080 MOVE.B #580, D7 ; Command i s ' a c t i v e ' 
64 6A 
64 6A 4E80 xxxx (PX) InterNext BSR R e a d S t r i n g ; Read command i n t o TmpBuff 
6470 X X (R) BEQ.S NoCommand 
6470 
6470 41FA 9BCC (P) LEA Commands, AO ; Address of commands t a b l e 
6474 4240 CLR.W DO ; DO i s index t o keyword 
6476 4281 CLR.L Dl 
6478 
6478 5240 NextKey ADDQ.W #$0001,DO 
647A 
64 7A 3230 00 00 MOVE.W (AO, D0.W), Dl ; Read o f f s e t byte 
6480 X X (R) BEQ.S L a s t E n t r y 
6480 
6480 43F0 10 00 LEA (AO, Dl.W), A l ; Generate keyword address 
6484 45FA A5AE (P) LEA TmpBuff, A2 
6488 B509 StrCmp CMPM.B (Al)+ , (A2) + ; Compare key wit h input s t r i n g 
64 8A 67 FC (P) BEQ.S StrCmp 
648C 
648C 4A22 TST.B -<A2> ; End o f command s t r i n g ? 
6490 X X (R) BEQ.S StrMatch 
6490 60 E6 (P) BRA NextKey ; Try another keyword 
6492 
6492 4240 L a s t E n t r y CLR.W DO ; No keyword match 
6494 
64 94 D040 StrMatch ADD .W DO, DO ; Generate subroutine o f f s e t 
6496 303B 00 X X (R) MOVE.W JTab (DO), DO 
64 9A 4EBB 00 X X (R) JSR JTab(DO) ; C a l l s u b routine - AO poi n t s 
64 9E ; t o r e s t of input b u f f e r . 
64 9E 487A A542 (P) PEA I n p B u f f 
64A2 421F CLR.B (SP) + 
64A4 4CDF 0783 NoCommand MOVEM.L (SP)+, D0-D1/D7/A0-A2 
64 A8 4E75 RTS 
64AA 
64AA ; ***« Jump t a b l e w i t h p o i n t e r s t o command subr o u t i n e s *«*« 
64AA ; 
64AA 
64AA JTab 
64AC xxxx (R) DC.W E r r o r - JTab ; F i r s t p r i n t s e r r o r message 
64AE xxxx (R) DC.W DelCmd - JTab ; Negate command a c t i o n 
64 BO xxxx (R) DC.W Run - JTab ; S t a r t the t r a c k i n g software 
64 B2 xxxx (R) DC.W Halt - JTab ,- Halt the t r a c k e r 
64B4 xxxx (R) DC.W DrpCom - JTab ; D i s p l a y r e s i d u a l p l o t s 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 10 
KATES Development Software - Source Listing 
64B6 xxxx (R) DC.W DipCom - JTab • D i s p l a y input p l o t s 
64B8 xxxx (R) DC.W DspCom - JTab • D i s p l a y s t a t i o n a r y p l o t s 
64BA xxxx (R) DC.W DttCom - JTab D i s p l a y t e n t a t i v e t r a c k s 
64BC xxxx (R) DC.W DctCom - JTab • D i s p l a y confirmed t r a c k s 
64BE xxxx (R) DC.W PipCom - JTab P l o t input p l o t s 
64C0 xxxx (R) DC.W PopCom - JTab P l o t output p l o t s 
64C2 xxxx (R) DC.W PrtCom - JTab P r i n t t r a c k s command 
64C4 xxxx (R) DC.W Radar - JTab D i s p l a y / s e t r a d a r type 
64C6 xxxx (R) DC.W ListRDP - JTab L i s t radar-dep parameters 
64C8 xxxx (R) DC.W L i s t R I P - JTab L i s t r a d a r - i n d parameters 
64CA xxxx (R) DC.W Set Value - JTab Set t r a c k i n g parameters 
64CC xxxx (R) DC.W ThreshCom - JTab Set t h r e s h o l d l e v e l 
64CE xxxx (R) DC.W ManCom - JTab Manual t r a c k i n i t i a t i o n 
64D0 xxxx (R) DC.W TT1 - JTab Set f i r s t t e s t t a r g e t 
64D2 xxxx (R) DC.W TT2 - JTab Set second t e s t t a r g e t 
64D4 xxxx (R) DC.W TT3 - JTab Set t h i r d t e s t t a r g e t 
64D6 xxxx (R) DC.W Monitor - JTab Jump t o KDM monitor 
64D6 
64D6 • ** * * Read a s t r i n g composed of al p h a s and numerics only **** 
64D6 . ***# from the b u f f e r pointed t o by AO, and s t o r e t h e **** 
64D6 . **** n u l l terminated r e s u l t i n t h e b u f f e r TmpBuff. **** 
64D6 ; 
64D6 48E7 C040 ReadStrlng MOVEM.L D0-D1/A1, -(SP) 
64DA 43FA A558 (P) LEA TmpBuff, A l Address of output b u f f e r 
64DE 4241 CLR.W Dl 
64E0 
64E0 1018 ReRead MOVE.B (A0)+, DO Read next c h a r a c t e r 
64E2 OCOO 0030 CMP.B #'0', DO 
64E8 X X (R) BLT.S NotAlNum Char < *zero' 
64EB OCOO 005A CMP.B #'Z',D0 
64EE X X (R) BGT.S NotAlNum Char > 'Z' 
64EE OCOO 0039 CMP.B 9'9', DO 
64F4 X X (R) BLT.S V a l i d C h a r 
64F4 OCOO 0041 CMP.B #'A' ,D0 
64FA X X (R) BLT.S NotAlNum '9' < char < 'A' 
64FA 
64FA 12C0 V a l l d C h a r MOVE.B DO, (Al) + Copy t o output b u f f e r 
64FC 5241 ADDQ.W 11, Dl Increment output count 
64FE 
64FE 4A41 NotAlNum TST.W Dl Has output been w r i t t e n ? 
6502 X X (R> BNE.S OutputDone 
6502 OCOO 0020 CMP.B #' \ DO Ignore l e a d i n g spaces. 
6506 67 D8 (P) BEQ.S ReRead 
6508 
6508 4211 OutputDone CLR.B (Al) N u l l t e r m i n a t e 
650A 4CDF 0203 MOVEM.L (SP)+, D0-D1/A1 
650E 4E75 RTS 
6510 
6510 . **** Read an i n t e g e r from the input b u f f e r pointed to by *«** 
6510 . **** AO and r e t u r n t h e i n t e g e r i n r e g i s t e r DO. **** 
6510 • **** I f D2 i s $FFFF, no I n t e g e r was found i n the b u f f e r . **** 
6510 ; 
6510 48E7 6000 Readlnt MOVEM.L D1-D2, -(SP) 
6514 343C FFFF MOVE.W # $ f f f f , D2 Set s t a t u s 
6518 1018 MOVE.B (AO) +, DO Read f i r s t c h a r a c t e r 
651C X X (R) BEQ.S GotTermCh 
651C OCOO 0020 CMP.B «' \ DO Ignore l e a d i n g spaces 
6520 67 EE (P) BEC.S Readlnt 
6522 
6522 4242 CLR.W D2 
6524 4281 CLR.L Dl R e s u l t r e g i s t e r 
6526 
6526 OCOO 002D CMP.B DO I s number negative? 
652C X X (R) BNE.S P o s l n t 
652C 343C 8000 MOVE.W #$8000,D2 
6530 1018 MOVE.B (A0)+, DO Read f i r s t d i g i t 
6532 
6532 0400 0030 Poslnt SUB.B »'0', DO Remove A s c i i o f f s e t 
6538 X X (R) BLT.S L a s t D i g i t 
6538 OCOO 000A CMP.B «S0a, DO ; Check: 0 <= Char <= 9 
653E X X (R) BGT.S L a s t D i g i t 
653E C2FC O00A MULU *S0a, Dl Sum - Sum * 10 + D i g i t 
6542 D240 ADD.W DO, Dl 
6544 1018 MOVE.B (AO) +, DO ; Next d i g i t 
6546 60 EA (P) BRA P o s l n t 
6548 
6548 4A42 L a s t D l g l t TST.W D2 
654C X X (R) BEQ.S GotTermCh 
654C 4441 NEG.W Dl Negate r e s u l t 
654E 
654E 2F01 GotTermCh MOVE.L Dl, -(SP) ; R e s u l t t o DO 
6550 4CDF 0007 MOVEM.L (SP)+, D0-D2 
6554 4E75 RTS 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 11 
RATES Development Software = Source Listing 
6556 . »*** p r i n t an e r r o r message on the console 6 
6556 . **«* input b u f f e r . 
6556 ; 
6556 
6556 ,- RATES E r r o r Messages 
6556 
6558 xxxx (R) E r r l n d e x DC.W I T L - E r r l n d e x 
65 5A xxxx (R) DC.W ICha r - E r r l n d e x 
655C xxxx (R) DC.W I P a r - E r r l n d e x 
655E xxxx (R) DC.W I F i l e - E r r l n d e x 
6560 xxxx (R) DC.W IName - E r r l n d e x 
6562 xxxx (R) DC.W INum - E r r l n d e x 
6564 xxxx (R) DC.W ICom - E r r l n d e x 
6564 0000 DC.W soooo 
6566 
6566 49 6E 76 61 6C 69 64 20 54 68 72 65 73 68 6F 6C 64 20 4C 65 76 65 6C 20 20 00 
IT L : DC.B ' I n v a l i d Threshold L e v e l ', N u l l 
6580 41 20 2D 20 5A 20 3F 00 
ICh a r : DC.B 'A - Z ?', N u l l 
6588 52 44 50 20 2F 20 52 49 50 20 3F 00 
I P a r : DC.B 'RDP / RIP ?', N u l l 
6594 4F 70 65 6E 20 46 69 6C 65 20 45 72 72 6F 72 20 20 00 
I F i l e : DC.B 'Open F i l e E r r o r ', N u l l 
65A6 4E 61 6D 65 20 4 5 72 72 6F 72 20 20 00 
IName: DC.B 'Name E r r o r ', N u l l 
65B3 4E 75 6D 62 65 72 20 3F 00 
INum: DC.B 'Number ?', N u l l 
65BC 43 6F 6D 6D 61 6E 64 20 3F 00 
ICom: DC.B 'Command ?', N u l l 
65C6 .ALIGN 2 
65C6 
65C6 303C 0006 E r r o r MOVE.W JS0006, DO ; I s s u e i l l e g a l command e r r o r 
65CA 
65CA D040 GenError ADD.W DO, DO ; Generate c o r r e c t o f f s e t 
65CC 4DFA FF88 (P) LEA E r r l n d e x , A6 
65D0 3036 00 00 MOVE.W (A6, D0.W), DO ; Form o f f s e t f o r s t r i n g 
65D4 4DF6 00 00 LEA (A6, DO.W), A6 
65D8 61 00 FCF2 (P) BSR P r i n t S t r ; P r i n t e r r o r message 
65DC 61 00 FD10 (P) BSR PrPrompt ; and prompt. 
65E0 487A A400 (P) PEA I n p B u f f 
65E4 421F CLR.B (SP)+ ; Reset input p o i n t e r 
65E6 4E75 RTS 
65E8 
65E8 . **** Negate the sense of the command which f o l l o w s i t **** 
65E8 
65E8 4207 DelCmd CLR.B D7 ; Negate command sense 
65EA 60 00 FE7E (P) BRA I n t e r N e x t 
65EE 
65EE . **** S t a r t (or stop) t he op e r a t i o n of the t r a c k e r *** 
65EE ; 
65EE 487A FB1A (P) Run PEA StopRun 
65F2 1EFC 0080 MOVE.B #$80, (SP) + 
65F6 4E75 RTS 
65F8 
65F8 . * * ** Suspend output from the t r a c k e r to the hardware 
65F8 ; 
65F8 487A FB10 (P) Halt PEA StopRun 
65FC 421F CLR.B (SP) + 
65FE 4E75 RTS 
6600 
6600 • ** * * Turn on d i s p l a y of u n a s s o c i a t e d p l o t s **»« 
6600 ; 
6600 487A FB09 (P) DrpCom PEA DispUnsp 
6604 1EC7 MOVE. B D7, (SP) + 
6606 4E75 RTS 
6608 
6608 . **** Turn on d i s p l a y of input p l o t s **** 
6608 ; 
6608 487A FB02 (P) DipCom PEA D i s p l p c 
660C 1EC7 MOVE. B D7, (SP) + 
660E 4E75 RTS 
6610 
6610 . **** i Turn on d i s p l a y of s t a t i o n a r y p l o t s **** 
6610 ; 
6610 487A FAFB (P) DspCom PEA D i s p S t a t 
6614 1EC7 MOVE.B D7, (SP) + 
6616 4E75 RTS 
6618 
6618 . **** Turn on d i s p l a y of t e n t a t i v e t r a c k s **** 
6618 
6618 487A FAF4 (P) DttCom PEA DispTent 
661C 1EC7 MOVE.B D7, (SP) + 
661E 4E75 RTS 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 12 
RATES Development Software* - Source Listing 
6620 • A A * * Turn on d i s p l a y of confirmed t r a c k s **** 
6620 
6620 487A FAED (P) DctCora PEA DispConf 
6624 1EC7 MOVE.B D7, (SP) + 
6626 4E75 RTS 
6628 
6628 > A A A A P l o t input p l o t data ** * * 
6628 
6628 487A FAE6 <P> PipCora PEA P l o t l p 
662C 1EC7 MOVE.B D7, (SP) + 
662E 4E75 RTS 
6630 
6630 . A A * * P l o t output p l o t data A A A A 
6630 
6630 487A FADE (P) PopCom PEA P l o t l p 
6634 1EC7 MOVE.B D7, (SP)+ 
6636 4E75 RTS 
6638 
6638 • * ** * P r i n t t r a c k data A A ft A 
6638 ; 
6638 487A FAD8 (P) PrtCom PEA P r i n t T r k s 
663C 1EC7 MOVE.B D7, (SP) + 
663E 4E75 RTS 
6640 
6640 
6640 • A A A A P r i n t t h e c u r r e n t r a d a r type on the s c r e e n A A * A 
6640 . A A A A followed by the prompt s t r i n g . 
6640 ; 
6640 
6640 4DFA 99E5 (P) Radar LEA RadMess, A6 ; Radar type - prompt s t r i n g 
6644 61 00 FC86 (P) BSR P r i n t s t r 
6648 303A FAD8 (P) MOVE.W RadarType, DO ; Get c u r r e n t r a d a r type 
664C 0640 0041 ADD.W #'A', DO 
6650 61 00 FC6E (P) BSR Outch ; P r i n t type l e t t e r 
6654 61 00 FCAC (P) BSR NewLine 
6658 4E75 RTS 
665ft 
665A 
665A • ** ** P r i n t t h e Radar Dependent o r Independent parameters ' * " 
665A • A * * * on t he console p o r t . A A A A 
665A ; 
665A 
665A 61 E4 (P) LlstRDP BSR Radar ; F i r s t l i n e of output 
665C 323C 0007 MOVE.W #$0007, Dl ; 8 oth e r parameters 
6660 4282 CLR.L D2 
6662 41FA FAC2 (P) LEA RevPermi, AO 
6666 43FA 9A68 (P) LEA Rdps, A l 
666A 
666A 4DF1 20 00 NextRDP LEA (Al, D2.W), A6 
666E 0682 0000 0020 ADD. L #$00000020, D2 ; Increment t o next s t r i n g 
6674 61 00 FC56 (P) BSR P r i n t s t r 
6678 
6678 3F18 MOVE.W (A0)+, -(SP) ; Push parameter v a l u e 
667A 487A A3B8 (P) PEA TmpBuff ; and s t r i n g address 
667E 61 00 FCD4 (P) BSR IntToAsc 
6682 4DFA A3B0 (P) LEA TmpBuff, A6 
6686 61 00 FC44 (P) BSR P r i n t s t r ; Convert t o A s c i i & p r i n t 
668A 61 00 FC76 (P) BSR NewLine 
668E 51C9 FFDA (P) DBRA Dl, Next RDP ; Next Parameter 
6692 4E75 RTS 
6694 
6694 
6694 • A A A A P r i n t r a d a r independent parameter s t r i n g s & v a l u e s . **** 
6694 ; 
6694 
6694 41 FA FAAO (P) L l s t R I P LEA I n i t S p f c , AO ; Address of parameter 1 
6698 43FA 9B36 (P) LEA Rips, A l 
669C 323C 0010 MOVE.W #$0010, Dl ; out o f a t o t a l of 17. 
66A0 4282 CLR.L D2 
66A2 61 00 FC5E (P) BSR NewLine 
66A6 
66A6 4DF1 20 00 Next RIP LEA (Al, D2.W), A6 
66AA 0682 0000 0020 ADD.L #$00000020, D2 ; Next parameter s t r i n g 
66B0 61 00 FC1A (P) BSR P r i n t s t r 
66B4 
66B4 3F18 MOVE.W (A0)+, -(SP) ; Push parameter v a l u e 
66B6 487A A37C (P) PEA TmpBuff ; and output ad d r e s s . 
66BA 61 00 FC98 (P) BSR IntToAsc 
66BE 4DFA A374 (P) LEA TmpBuff, A6 ; Set p o i n t e r t o r e s u l t 
66C2 61 00 FC08 (P) BSR P r i n t s t r 
66C6 61 00 FC3A (P) BSR NewLine 
66CA 51C9 FFDA (P) DBRA Dl, Next RIP ; Next parameter 
66CE 4E75 RTS 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 13 
RATES Development Software - Source Listing 
66D0 ; **** s e t a value f o r any one of the t r a c k i n g parameters **** 
66D0 ; 
66D0 
66D0 43FA FA54 (P) SetValue LEA RevPermi, A l 
66D4 4240 CLR.W DO 
66D6 1018 MOVE. B (A0)+, DO ; Read next char i n b u f f e r 
66DA X X (R) BEQ.S V a l u e E r r o r ; Next c h a r i s n u l l 
66DA 0C00 0020 CMP.B »' DO 
66DE 67 F0 (P) BEQ.S Set V a l u e ; Ignore l e a d i n g spaces 
66E0 
GGEO 0400 0041 SUB. a #'A', DO 
66E6 X X (R) BMI.S V a l u e E r r o r 
66E6 0C00 001A CMP.B #26,DO ; > 'Z' ? 
66EC X X (R) BGT.S V a l u e E r r o r 
66EC 
66EC D040 ADD.W DO, DO ; Convert l e t t e r t o index 
66EE 43F1 00 00 LEA (Al, D0.W), A l 
66F2 61 00 FE1C (P) BSR Readlnt 
66F8 X X (R) BNE.S St o r e V a l u e 
66F8 
66F8 303C 0005 MOVE.W #5, DO ; No parameter v a l u e given 
66FC 60 00 FECC (P) BRA GenError 
6700 
6700 303C 0001 V a l u e E r r o r MOVE.W »1, DO ; E r r o r i n parameter code 
6704 60 00 FEC4 (P) BRA GenError 
6708 
6708 3280 StoreValue MOVE.W DO, (Al) ; Write new va l u e 
67 OA 4E80 xxxx (PX) BSR D e r i v e P a r s ; R e c a l c u l a t e o t h e r v a l u e s 
670E 4E75 RTS 
6710 
6710 . ***. s e t a t h r e s h o l d l e v e l i n the CFAR c l u t t e r map **** 
6710 ; **** Des t r o y s contents of DO, D l & Al AO p o i n t s t o t h e **** 
6710 . **** input b u f f e r , D7 i s s e t t o command sense. **** 
6710 ; 
6710 
6710 43FA FA01 (P) ThreshCom LEA Thresh, A l 
6714 4A07 TST.B D7 ; T e s t command sense 
6718 xx (R) BEQ.S NoLevel 
6718 
6718 61 00 FDF6 (P) BSR Readlnt ; Read hole s i z e 
671E X X (R) BEQ.S T h r e s h E r r 
671E 3200 MOVE.W DO, Dl ; S t o r e hole s i z e 
6720 61 00 FDEE (P) BSR Readlnt 
6726 X X (R) BEQ.S L e v e l E r r 
6726 4A40 TST.W DO 
672A X X (R) BMI.S L e v e l E r r ; Can't be neg a t i v e 
672A 
67 2A 0C40 007F CMP.W #127, DO ,- Or > 127 
6730 X X (R) BGT.S L e v e l E r r 
6730 
6730 12FC 0080 MOVE.B #$80, (Al) + 
6734 32C1 MOVE.W Dl, (Al) + ; R e s t o r e hole s i z e 
6736 3280 MOVE.W DO, (Al) ,- Save new l e v e l 
6738 4EC0 xxxx (PX) BRA ThreshDer ; Go d e r i v e new parameters 
673C 
67 3C 4211 L e v e l E r r CLR.B (Al) 
673E 303C 0000 MOVE.W #0, DO ; Set e r r o r code 
6742 60 00 FE86 (P) BRA GenError 
6746 
6746 303C 0005 T h r e s h E r r MOVE.W • 5, DO ; Command e r r o r code 
674A 60 00 FE7E (P) BRA GenError 
674E 
674E 4211 NoLevel CLR.B (Al) 
6750 
6750 4E80 xxxx (PX) ThreshDer BSR D e r i v e P a r s ; C a l c u l a t e d e r i v e d parameters 
6754 4E75 RTS 
6756 
6756 ; **** Manually i n i t i a t e a t r a c k * * * * 
6756 ; 
6756 487A F9C0 (P) ManCom PEA Manlnit 
67 5A 1EC7 MOVE.B D7, (SP) + 
675C 4E75 RTS 
675E 
675E 
675E ; **** Set the parameters f o r one of the t e s t t a r g e t s **** 
675E ; **** AO p o i n t s to input b u f f e r , D7 i s command sense. **** 
675E . **** d e s t r o y s t he contents of DO A l . * * * * 
675E 
675E 303C 0001 TT1 MOVE.W #$01, DO 
6762 4EC0 xxxx (PX) BRA TTProc 
6766 
6766 303C 0002 TT2 MOVE.W #$02, DO 
67 6A 4EC0 xxxx (PX) BRA TTProc 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 14 
HATES Development Software - Source Listing 
676E 303C 0003 TT3 MOVE.W #$03, DO 
6772 
6772 43FA F9A5 (P) TTProc LEA TestNum, Al 
6776 4 AO 7 TST.B D7 ; Test command sense 
67 7A X X (R) BNE.S TTSet 
677A 
67 7A 4400 NEG.B DO ; Target g e n e r a t i o n o f f 
677C 1280 MOVE.B DO, (Al) 
677E 4EC0 X X X X (PX) BRA TTEnd 
6782 
6782 12C0 TTSet MOVE.B DO, (Al) + 
6784 61 00 FD8A (P) BSR Readlnt ; Read t a r g e t range 
67 8A X X (R) BEQ.S TTEnd 
67 8A 32C0 MOVE.W DO, (Al) + 
678C 
678C 61 00 FD82 (P) BSR Readlnt ; Read t a r g e t b e a r i n g 
6792 X X (R) BEQ.S TTEnd 
6792 32C0 MOVE.W DO, (Al)+ 
6794 
6794 61 00 FD7A (P) BSR Readlnt ; Read t a r g e t speed 
67 9A X X (R) BEQ.S TTEnd 
67 9A 32C0 MOVE.W DO, (Al) + 
679C 
67 9C 61 00 FD72 (P) BSR Readlnt ; Read t a r g e t heading 
67A2 X X (R) BEQ.S TTEnd 
67A2 3280 MOVE.W DO, (Al) 
67A4 
67A4 4E75 TTEnd RTS 
67A6 
67A6 
67A6 • *** * Jump back to RDM board monitor **** 
67A6 ; 
67A6 4BF9 0003 FF01 Monitor LEA Terminal, A5 
67AC 61 00 FB54 (P) BSR NewLine 
67B0 1ABC 0015 MOVE.B #$15, (A5) ; C l e a r i n t e r r u p t s t a t u s 
67B4 21FC 0002 1706 0068 MOVE.L #$21706, IRQ2 
67 BC 21FC 0002 1706 006C MOVE.L #$21706, IRQ3 ; Reset v e c t o r s 
67C4 21FC 0002 1706 0070 MOVE.L #$21706, IRQ4 
67 CC 4EF9 0002 00F6 JMP MacsBug 
67D2 
67D2 
67D2 • ** * * ********************************************************* 
67D2 . * * 
67D2 ; * Routines f o r performing c a l c u l a t i o n s on f i x e d p o i n t data * 
67D2 ; * s f o r d e r i v i n g parameters from t he b a s i c r a d a r dependent * 
67D2 ; * and independent v a l u e s . * 
67D2 * 
67D2 . ************************************************************** 
67D2 ; 
67D2 48E7 40C0 CopyParam MOVEM.L D1/A0-A1, -(A7) ; Push r e g i s t e r s 
67D6 41FA 9C38 (P) LEA RdpDef, AO 
67DA 487A F946 (P) PEA RadarType 
67DE 321F MOVE.W (SP)+, D l 
67E0 E949 LSL.W #4, Dl ; Generate index t o p a r s . 
67E2 41F0 10 00 LEA (AO, Dl.W), AO 
67E6 43FA F93E (P) LEA RevPermi, A l 
67EA 323C 0007 MOVE.W #7, Dl ; 8 parameters t o copy 
67EE 
67 EE 32D8 CopyNext MOVE.W (A0)+, (Al) + ; Copy i n t o RAM 
67F0 51C9 FFFC (P) DBRA Dl, CopyNext 
67F4 41FA 9C92 (P) LEA RipDef, AO 
67F8 323C 0010 MOVE.W #16, Dl ; 16 independent parameters 
67FC 
67FC 32D8 CopyMore MOVE.W (A0)+, (Al) + ; Copy t o v a r i a b l e s 
67FE 51C9 FFFC (P) DBRA Dl, CopyMore 
6802 
6802 4CDF 0302 MOVEM.L (A7)+, D1/A0-A1 ; Restore r e g i s t e r s 
6806 4E75 RTS 
6808 
6808 
6808 . **** Perform a f i x e d p o i n t d i v i d e o p e r a t i o n such t h a t ***»' 
6808 • ** ** I n t e g e r DO / I n t e g e r Dl g i v e s r e s u l t i n t h e form : 
6808 • **** (16 b i t i n t e g e r £ 16 b i t f r a c t i o n a l p a r t ) **** 
6808 
6808 
6808 80C1 D i v i d e l 6 DIVU Dl, DO ; Generate i n t e g e r £ rmdr 
680A 3F00 MOVE.W DO, -(SP) ; Push i n t e g e r p a r t 
680C 4240 CLR.W DO 
680E 80C1 DIVU Dl, DO ; D i v i d e rmdr by quotient 
6810 4840 SWAP DO 
6812 301F MOVE.W (SP)+, DO ; Replace rmdr w i t h i n t e g e r 
6814 4840 SWAP DO ; Swap bytes 
6816 4E75 RTS 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 15 
RATES Development Software - Source Listing 
6818 . **** M u l t i p l y two decimal number s together, where the **** 
6818 . **** numbers each have a 16 b i t i n t e g e r p a r t and 16 b i t **** 
6818 • **** f r a c t i o n a l p a r t . The numbers s t a r t i n Dl and D2. **** 
6818 • ** * ft The r e s u l t i s l e f t i n r e g i s t e r DO ft ft 4 * 
6818 . ** * 4 Uses: a.b * x.y = (ax + O.bx + O.ay + (O.b)(O.y)) **** 
6818 ; 
6818 48E7 3800 Multl6 MOVEM.L D2-D4, - (SP) 
681C 4284 CLR.L D4 ; C l e a r r e s u l t r e g i s t e r 
681E 2401 MOVE.L Dl, D2 
6820 3601 MOVE.W Dl, D3 ; F r a c t i o n to D3 
6822 
6822 4842 SWAP D2 
6824 C6C0 MULU DO, D3 ; (O.b)(O.y) 
6826 4843 SWAP D3 
6828 D843 ADD .W D3, D4 ; S t o r e p a r t i a l r e s u l t 
68 2A 
68 2A 3602 MOVE.W D2, D3 
682C C6C0 MULU DO, D3 ; (O.b)x 
682E D883 ADD.L D3, D4 ; Accumulate r e s u l t 
6830 
6830 4840 SWAP DO 
6832 3601 MOVE.W Dl , D3 
6834 C6C0 MULU DO, D3 ; (O.y)a 
6836 D883 ADD.L D3, D4 ; Accumulate r e s u l t 
6838 
6838 C0C2 MULU D2, DO ; ab 
68 3A 4840 SWAP DO ; Rearrange words 
683C 4240 CLR.W DO 
683E D084 ADD.L D4, DO Accumulate r e s u l t 
6840 
6840 4CDF 001C MOVEM.L (SP)+, D2-D4 6844 4E75 RTS 
6846 
6846 . **** De r i v e parameters based on the r a d a r dependent **** 
6846 • * * * * parameters. These a r e only c a l c u l a t e d o c c a s i o n a l l y **** 
6846 ; 
6846 48E7 F8F0 D e r l v e F i x MOVEM.L D0-D4/A0-A3, - (SP) 
684A 41FA F90C (P) LEA RevPerSec, AO 
684E 
684E 303C 000A MOVE.W #10, DO 
6852 323A F8D2 (P) MOVE.W RevPermi, Dl ; Get rev p e r i o d i n m i l l i s e c s 
6856 48C1 EXT.L Dl 
6858 E1A9 LSL.L DO, Dl 
68 5A 82FC 03E8 DIVU #1000, Dl 
685E 30C1 MOVE.W Dl, (A0) + ; Rev p e r i o d i n sees (flO) 
6860 
6860 907A F8D2 (P) SUB.W RangeMsBt, DO ; S h i f t S R = 10 - RangeMsBit 
6864 30CO MOVE .W DO, (A0) + ; S h i f t f o r segment range 
6866 
6866 203C 0000 BB80 MOVE.L #48000, DO 
68 6C 323A F8C0 (P) MOVE.W RangeCSFt, Dl ; RUPM = RCSFt / 48000 
6870 61 96 (P) BSR D i v i d e l 6 
6872 20C0 MOVE.L DO, (A0) + ; Range u n i t s / m i l e ( f l 6 ) 
6874 
6874 4281 CLR.L Dl 
6876 323A F8B0 (P) MOVE.W RadRanDM, Dl 
68 7A 4841 SWAP Dl 
687C 61 9A (P) BSR M u l t l 6 ; RadarRan " RRDH * RUPM 
687E 4840 SWAP DO 
6880 30C0 MOVE.W DO, (A0) + , Radar range ( i n t e g e r ) 
6882 
6882 4281 CLR.L Dl 
6884 323C 03FF MOVE.W #1023, Dl 
688B 4841 SWAP Dl ; SynRF = 1023 / RadarRan 
68 8A 82C0 DIVU DO, Dl 
688C 30C1 MOVE.W Dl, (A0) + ; S y n t h e t i c s range f a c t ( f l 6 ) 
688E 
688E 303A F8A0 (P) MOVE.W SPFRCSFt, DO 
6892 C0FC 0008 MULU #8, DO ; SPFRCS = SPFRCSFt * 8 / RCSFT 
6896 48C0 EXT.L DO 
6898 SOFA F894 (P) DIVU RangeCSFt, DO 
68 9C 30C0 MOVE.W DO, (A0) + ; Spf range capt. s i z e ( i n t ) 
68 9E 
68 9E 303A F892 (P) MOVE.W SPFBCSCd, DO 
68A2 C0FC E902 MULU #$E902, DO 
68A6 4840 SWAP DO 
68A8 30C0 MOVE.W DO, (A0) + ; Spf b e a r i n g capt. s i z e ( i n t ) 
68AA 
68AA 4280 CLR.L DO 
68AC 303A F88E (P) MOVE.W CenSPFSmo, DO j SPFS = CSPFS / 100 
68B0 323C 0064 MOVE.W #100, Dl 
68B4 61 00 FF52 (P) BSR D i v i d e l 6 
68B8 30C0 MOVE.W DO, (A0) + ; Spf smoothing f a c t o r ( f l 6 ) 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 16 
BATES Development Soft-war® - Source Listing 
68BA 4280 CLR.L DO 
68BC 303A F86C (P) MOVE.W RangeSDFt, DO 
68C0 223C 0000 1770 MOVE.L #6000,Dl 
68C6 61 00 FF40 (P) BSR D i v l d e l 6 
68CA 223A F890 (P) MOVE.L RUPMile, Dl 
68CE 61 00 FF48 (P) BSR M u l t l 6 ,- RRSD = RSDF * 6000 / RUPM 
68D2 2600 MOVE.L DO, D3 ; Sto r e RRSD i n £16 format 
68D4 EC88 LSR.L 56, DO 
6BD6 30C0 MOVE.W DO, (A0) + ; Radar range sd (flO) 
68D8 0 
68D8 303A F852 (P) MOVE.W BearSDCd, DO 
68DC COFC 003A MULU #$003A, DO 
68E0 E848 LSR.W #4, DO 
68E2 30C0 MOVE.W DO, (A0) + ; Radar b e a r i n g sd ( f l 6 ) 
68E4 
68E4 48C0 EXT. L DO 
68E6 223C 0003 243F MOVE. L #$0003243F, Dl 
6BEC 61 00 FF2A (P) BSR M u l t l 6 
6BF0 30C0 MOVE.W DO, (A0) + ; Radar r a d i a n s sd ( f l 6 } 
68F2 
68F2 4280 CLR.L DO 
68F4 303A F84A (P) MOVE.W CenNoise, DO 
68F8 323C 0064 MOVE.W #100, Dl 
68FC 61 00 FFOA (P) BSR D i v l d e l 6 
6900 2800 MOVE.L DO, D4 ; S t o r e NoiseThr i n ( f l 6 ) 
6902 EC88 LSR.L #6, DO 
6904 30C0 MOVE.W DO, (A0) + ,- Noise t h r e s h o l d (flO) 
6906 
6906 4280 CLR.L DO 
6908 303A F838 (P) MOVE.W CenManThr, DO 
690C 323C 0064 MOVE.W #100, Dl 
6910 61 00 FEF6 (P) BSR D l v i d e l 6 
6914 EC88 LSR.L #6, DO 
6916 30CO MOVE.W DO, (A0) + ; Manoeuvre t h r e s h o l d (flO) 
6918 
6918 4280 CLR.L DO 
691A 303A F828 (P) MOVE.W CenMandy, DO 
691E 323C 0064 MOVE.W #100, Dl 
6922 61 00 FEE4 (P) BSR D i v i d e l 6 
6926 30C0 MOVE.W DO, (A0) + ; Manoeuvre decay f a c t o r (flO) 
6928 
6928 2003 MOVE.L D3, DO ; Restore RadRanSD 
692A 2204 MOVE.L D4, Dl ; Restore NoiseThr 
692C 61 00 FEEA (P) BSR Mult16 
6930 4840 SWAP DO 
6932 30C0 MOVE.W DO, (A0) + ; Range noise t h r e s h o l d ( i n t ) 
6934 4840 SWAP DO 
6936 223C 0002 72F1 MOVE.L #$000272F1, Dl 
693C 61 00 FEDA (P) BSR Mult16 
6940 4840 SWAP DO 
6942 30C0 MOVE.W DO, (A0) + ; Max noise range e r r o r ( i n t ) 
6944 
6944 4280 CLR.L DO 
694 6 303A F824 (P) MOVE.W RadBearSD, DO 
694A 2204 MOVE.L D4, Dl 
694C 61 00 FECA (P) BSR M u l t l 6 
6950 30CO MOVE.W DO, (A0) + ; Bearing n o i s e t h r e s h o l d ( f l 6 
6952 223C 0002 72F1 MOVE.L #$000272F1, Dl 
6958 61 00 FEBE (P) BSR Mult 16 
695C 30C0 MOVE.W DO, (A0) + ; Max n o i s e b e a r i n g e r r o r ( f l 6 ) 
695E 
695E 4280 CLR.L DO 
6960 303A F7E4 (P) MOVE.W MaxKnots, DO 
6964 323C 0E1O MOVE.W #3600, Dl 
6968 61 00 FE9E (P) BSR D i v l d e l 6 
696C 223A F7EE (P) MOVE.L RUPMile, Dl 
6970 61 00 FEA6 (P) BSR Mult16 ; MaxRanDiff - MaxKnots / 3600 
6974 4281 CLR.L Dl ; * RUPMile * RevPerSec 
6976 323A F7E0 (P) MOVE.W RevPerSec, Dl 
697A ED89 LSL. L #6, Dl 
697C 61 00 FE9A (P) BSR M u l t l 6 
6980 4840 SWAP DO 
6982 30C0 MOVE.W DO, (A0) + ; Max range d i f f e r e n c e ( i n t ) 
6984 
6984 3200 MOVE.W DO, Dl 
6986 4280 CLR.L DO 
6988 303A F7BC (P) MOVE.W MaxKnots, DO 
698C 61 00 FE7A <P> BSR D i v i d e l 6 
6990 EC88 LSR.L #6, DO 
6992 30C0 MOVE.W DO, (A0)+ ; Speed f a c t o r ( flO) 
6994 
6994 303A F7B2 (P) MOVE.W MaxBDC, DO 
6998 COFC 003A MULU #$003A, DO ; MaxBearDiff » MaxBDC * 5.5e-5 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 17 
RATEE 5 Development Softws ire - Source Listing 7 
699C E848 LSR.W #4, DO 
699E 30C0 MOVE.W DO, (A0)+ ; Max b e a r i n g d i f f e r e n c e ( f l 6 ) 
6 9 AO 
69A0 223C 0003 243F MOVE.L #$0003243F, Dl 
69A6 61 00 FE70 <P) BSR Mult 16 
69AA 30C0 MOVE.W DO, (A0) + ; Max r a d i a n s d i f f e r e n c e ( f l 6 ) 
69AC 
69AC 4280 CLR.L D0 
69AE 303C OOAF MOVE.W #S00AF, DO 
69B2 223A F7A8 (P) MOVE.L RUPMile, Dl 
69B6 61 UO FE60 (P) BSR Mult16 
69BA 2A00 MOVE.L DO, D5 ; D5 = h a l f G 
69BC 41FA F7E2 (P) LEA ManPKnot + 10, AO 
69C0 43FA F7E8 (P) LEA ManPG + 10, A l 
69C4 3C3C 0004 MOVE.W #4, D6 ; D6 = missed look count 
69C8 
69C8 3206 C a l c F e a s MOVE.W D6, Dl 
69CA 5241 ADDQ.W #1, Dl 
69CC C2FA F78A (Pi MULU RevPerSec, Dl ; Delay - (MLC+i) * RPS 
69D0 ED89 LSL.L #6, Dl 
69D2 2001 MOVE.L Dl, DO 
69D4 61 00 FE42 (P) BSR Mult16 ; DS = delay * delay 
69D8 2800 MOVE.L D0,D4 ; D4 = d e l a y squared 
69DA 
69DA 4281 CLR.L Dl 
69DC 323A F76C (P) MOVE.W GSPerKK, Dl 
69E0 4841 SWAP Dl 
69E2 61 00 FE34 (P) BSR Mult16 
69E6 4240 CLR.W DO 
69E8 4840 SWAP DO 
69EA 223C 0000 03E8 MOVE.L #1000, Dl 
69F0 61 00 FE16 (P) BSR D i v i d e l 6 ; FTS = DS * GSPerKK / 1000 
69F4 2205 MOVE.L D5,D1 
69F6 61 00 FE20 (P) BSR M u l t l 6 
69FA 3100 MOVE.W DO, -(AO) ; Manoeuvre per knot [ ] 
69FC 
69FC 2205 MOVE. L D5, Dl 
69FE 2004 MOVE.L D4, DO 
6A00 61 00 FE16 (P) BSR Mult16 
6A04 4840 SWAP DO 
6A06 3300 MOVE.W DO, - ( A l ) ; Manoeuvre per G[J 
6 AO 8 
6A08 51CE FFBE (P) DBRA D6, C a l c F e a s 
6A0C 
6A0C 
6A0C . 4 4 4 4 Routines t o d e r i v e t he v a r i a b l e parameters - needed 4 4 4 4 
6A0C . 4 4 4 4 more f r e q u e n t l y than the above . subroutine. 4 4 4 4 
6A0C 
6A0C 48E7 F080 D e r i v e P a r s MOVEM.L D0-D3/A0, -(A7) ; Get r e g i s t e r space 
6A10 3639 0003 5000 MOVE.W Constants, D3 
6A16 
6A16 3203 MOVE.W D3, Dl 
6A18 0241 0078 AND.W #$0078, Dl 
6A1C 487A F706 (P) PEA ConstWord 
6A20 3EC1 MOVE.W Dl, (SP) + 
6A22 0243 0018 AND.W #$0018, D3 
6A26 E64B LSR.W #3, D3 ; I s o l a t e C Range S h i f t 
6A28 343C 0001 MOVE.W #1, D2 
6A2C E76A LSL.W D3, D2 
6A2E 487A F758 (P) PEA CRange 
6A32 3EC2 MOVE.W D2, (SP) + ; Save C Range 
6A34 
6A34 0241 0060 AND.W #$0060, Dl 
6A38 EA49 LSR.W #5, Dl ; I s o l a t e C S c a l e & save 
6A3A 487A F74E (P) PEA C S c a l e 
6A3E 3EC1 MOVE.W Dl, (SP) + 
6A40 
6A40 323A F6E0 (P) MOVE.W RadarType, Dl 
6A44 41FA 9A36 (P) LEA RangeFac, AO ; S t a r t of range f a c t o r s t a b l e 
6A48 3030 10 00 MOVE.W 0(A0,D1.W), DO ; Load range f a c t o r 
6A4C 41FA 9A22 (P) LEA MaxRaNum, AO 
6A50 COFO 10 00 MULU 0(A0, Dl.W), DO 
6A54 E248 LSR.W #1, DO ; Ad j u s t f o r b i n a r y point 
6A56 E668 LSR.W D3, DO ; S h i f t r i g h t by C Range S h i f t 
6A58 
6A58 41FA F732 (P) LEA MaxRSect, AO 
6A5C 30C0 MOVE.W DO, (AO)+ ; Max range s e c t o r 
6A5E 
6A5E 48C0 EXT.L DO 
6A60 2200 MOVE.L DO, Dl ; Sto r e max range s e c t o r 
6A62 E488 LSR.L #2, DO 
6A64 30C0 MOVE.W DO, (A0)+ ; Max range s e c t o r / 4 
6A66 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 18 
HATES Development Software - Source l is t ing 
6A66 2001 MOVE.L Dl, DO 
6A68 80FC 0007 DIVU #7, DO 
6A6C 30C0 MOVE.W DO, (A0) + ; Max s e c t o r / 7 
6A6E 
6A6E 2001 MOVE.L Dl, DO 
6A70 80FC 000F DIVU #15, DO 
6A74 30C0 MOVE.W DO, (A0) + ; Max s e c t o r / 15 
6A76 
6A76 303A F69C (P) MOVE .W ThreshHol, DO 
6A7A C0C1 MULU Dl, DO 
6A7C 323A F6AA (P) KOVE.W RadRanDM, Dl 
6A80 80C1 DIVU Dl, DO 
6A82 30C0 MOVE.W DO, (A0) + ; Max b l a c k range s e c t o r 
6A84 
6A84 323A F6D4 (P) MOVE.W Shlf t S R , Dl 
6A88 D243 ADD.W D3, Dl 
6A8A 5341 SUBQ.W #1, Dl 
6A8C 487A F6F8 (P) PEA S h i f t C l u t 
6A90 3EC1 MOVE.W Dl, (SP) + ; S h i f t f o r c l u t t e r range 
6A92 4E75 RTS ; End of d e r i v e parameters 
6A94 
6A94 . **** T e s t to see i f c o n s t a n t s word has changed. I f no **** 
6A94 . **** change then no need t o r e c a l c u l a t e parameters. **** 
6A94 ; 
6A94 
6A94 3039 0003 5000 CheckConst MOVE.W Constants, DO 
6A9A 0240 0078 AND.W #$0078, DO 
6A9E B0 7 A F684 (P) CMP.W ConstWord, DO 
6AA2 66 00 FF68 (P) BNE D e r l v e P a r s 
6AA6 4E75 RTS 
6AA8 
6AA8 . ************************************************************** 
6AA8 • * * 
6AA8 ; * End of mi s c e l l a n e o u s c a l c u l a t i o n r o u t i n e s . * 
6AA8 ; * The r o u t i n e s which f o l l o w form the main p a r t of the * 
6AA8 ; * i n t e r f a c e t o the p l o t forming hardware. * 
6AA8 • * * 
6AA8 ; * The f i r s t r o u t i n e i s the main d r i v e r program, c a l l e d when * 
6AA8 ; * s t a r t i n g t he RATES software. The software loops i n t h i s * 
6AA8 ; * r o u t i n e u n t i l t h e t r a c k e r i s s t a r t e d . * 
6AA8 ; * * 
6AA8 ************************************************************** 
6AA8 ; 
6AA8 
6AA8 46FC 2700 S t a r t u p MOVE.W #$2700, SR ; Mask o f f a l l i n t e r r u p t s 
6AAC 
6AAC 61 00 F72E (P) BSR I n i t D a t a ; I n i t i a l i s e data a r e a s 
6AB0 61 00 F7DC (P) BSR InitVDU ; I n i t i a l i s e s t a t u s VDU 
6AB4 
6AB4 4DFA 954E (P) LEA SysName, A6 • P r i n t RATES I n t r o 
6AB8 61 0C F812 (P) BSR P r i n t s t r 
6ABC 3039 0003 5000 MOVE.W Constants, DO ; and c u r r e n t r a d a r type. 
6AC2 0240 0007 AND.W #$0007, DO 
6 AC 6 487A F65A (P) PEA RadarType 
6ACA 3EC0 MOVE.W DO, (SP) + 
6ACC 61 00 FB72 (P) BSR Radar 
6 ADO 61 00 FDOO (P) BSR CopyParam ; Copy dependent parameters 
6AD4 61 00 FD70 (P) BSR D e r i v e F i x 
6AD8 
6AD8 1ABC 0095 MOVE.B #$95, (A5) ; A c t i v a t e i n t e r u p t s on ACIA 
6ADC 46FC 2200 MOVE.W #$2200, SR ; and wait f o r the t r a c k e r t o 
6AE0 ; be s t a r t e d . 
6AE0 41FA F628 (P) LEA StopRun, AO 
6AE4 4A10 Walt4Go TST.B (AO) 
6AE6 67 FC (P) BEQ Wait4Go 
6AE8 
6AE8 61 00 F804 (P) BSR PrPrompt 
6AEC 46FC 2700 MOVE.W #$2700, SR ; Mask o f f i n t e r u p t s again 
6AF0 
6AF0 3039 0003 5000 S y s l n i t MOVE.W Constants, DO 
6AF6 0240 0380 AND.W #$0380, DO ; Mask out a l l but octant 
6AFA 0C40 0280 CMP.W #$0280, DO 
6AFE 66 F0 (P) BNE.S S y s l n i t • Wait u n t i l o ctant 5 
6B00 
6B00 46FC 2500 MOVE.W #$2500,SR ; Enable n o r t h i n t e r r u p t 
6B04 41FA F638 (P) LEA WarmRevs, AO 
6B08 4E80 xxxx (PX) WarmWait BSR MipDa ; I n i t i a l i s e v a r i a b l e s 
6B0C 4A50 TST.W (AO) 
6B0E 66 F8 (P) BNE.S WarmWait ; Warm up de l a y p e r i o d . 
6B10 
6B10 3039 0003 5002 MOVE.W PlotCount, DO • Enable the DMA I n t e r f a c e 
6B16 4E72 2000 TryAgain STOP #$2000 ; Enable a l l i n t e r u p t s 
6B1A 60 FA (P) BRA. S TryAgain ; and wait f o r north. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 19 
KATES Development Software • Source Listing 
6B1C . ************************************************************** 
6B1C - ft ft 
6B1C ; * T h i s r o u t i n e i s c a l l e d whenever an OCTANT DEMAND i r q i s * 
6B1C ,- * r e c e i v e d . F l r s t O c t i s only c a l l e d once - on subsequent * 
6B1C ; * o c c a s i o n s the v e c t o r p o i n t s t o OctDemand. Both r o u t i n e s * 
6B1C ; * c l e a r the st a c k to a known s t a t e (a s t a c k r e s e t ) , then * 
6B1C ; * push the i n t e r r u p t r e t u r n address and s t a t u s r e g i s t e r . At * 
6B1C ; * the end o f the subroutine, e x e c u t i o n jumps t o the chosen * 
6B1C ; * i n t e r r u p t r e t u r n a d d r e s s . * 
6B1C . * * 
6B1C . * * * * * *********** ********************************************** 
6B1C ; 
6B1C 
6B1C 46FC 2700 F i r s t o c t MOVE.W #$2700, SR ; Mask o f f a l l i n t e r u p t s 
6B20 2E7C 0000 0800 MOVEA.L #$0800, A7 ; Reset s t a c k p o i n t e r 
6B26 4ICO xxxx (PX) LEA F i r s t T r a c k , AO 
6B2A 2F08 MOVE.L AO, -(A7) ; Push s t a r t address of t r a c k e r 
6B2C 4EC0 xxxx (PX) BRA Oc t P r o c e s s 
6B30 
6B30 46FC 2700 OctDemand MOVE.W #$2700, SR ; Mask I n t e r r u p t s 
6B34 2E7C 0000 0800 MOVEA.L #$0800, A7 ; Reset s t a c k p o i n t e r 
6B3A 4 ICO xxxx (PX) LEA T r a c k e r , AO 
6B3E 2F08 MOVE.L AO, -(A7) ; Normal t r a c k e r address 
6B40 
6B40 3F3C 2000 OctProces s MOVE.W #$2000, -(A7) ; Push c o r r e c t v a l u e of SR 
6B44 4E80 xxxx (PX) BSR DataOut ; Output c a l c u l a t e d data 
6B48 4E80 xxxx (PX) BSR ResetOctant ; Reset octant parameters 
6B4C 4A43 TST.W D3 
6B50 X X (R> BNE.S NotNorth 
6B50 
6B50 41FA F66E (P) LEA TotFInput, AO 
6B54 4258 CLR.W (A0)+ ; On north only, c l e a r data 
6B56 4258 CLR.W (A0) + 
6B58 4258 CLR.W (A0) + 
6B5A 4258 CLR.W (A0) + 
6B5C 4258 CLR.W (A0) + 
6B5E 
6B5E 4E80 xxxx (PX) NotNorth BSR MipDa 
6B62 4E73 RTE 
6B64 
6B64 
6B64 . **** Routine c a l l e d a f t e r an octant demand i n t e r r u p t . **** 
6B64 . **** F i r s t T r a c k i s o nly c a l l e d once t o p r i n t prompt and **** 
6B64 . **** r e s e t t h e i n t e r r u p t v e c t o r . Routines a r e c a l l e d t o **** 
6B64 • **** output t he c l u t t e r c e l l and t h r e s h o l d v a l u e s . **** 
6B64 ; 
6B64 
6B64 2E 2E 2E 54 72 61 63 6B 65 72 20 69 6E 69 74 69 61 74 65 64 20 00 
I n i t S t r DC.B '...Tracker i n i t i a t e d \ N u l l 
6B7A .ALIGN 2 
6B7A 
6B7A 4DFA FFE8 (P) F i r s t T r a c k LEA I n i t S t r , A6 ; P r i n t i n i t i a l i s e d message 
6B7E 61 00 F74C (P) BSR P r i n t s t r 
6B82 61 00 F76A (P) BSR PrPrompt 
6B86 487A FFA8 (P) PEA OctDemand 
6B8A 21DF 0068 MOVE.L (SP)+, IRQ2 ; Replace octant i r q v e c t o r 
6B8E 
6B8E 4E80 X X X X (PX) T r a c k e r BSR C l u t t e r O u t 
6B92 4E80 xxxx (PX) BSR ThreshOut 
6B96 46FC 2000 MOVE.W #$2000, SR 
6B9A 
6B9A 487A F63A (P) WaitLoop PEA Loading 
6B9E 525F ADD.W #1, (SP)+ ; When i d l e , increment v a l u e 
6BA0 ; t o a s s e s s l o a d i n g f a c t o r . 
6BA0 323C 03E8 MOVE.W #1000, D l 
6BA4 51C9 FFFE (P) DelayLoop DBRA Dl, DelayLoop 
6BA8 
6BA8 60 F0 (P) BRA WaitLoop 
6BAA 
6BAA 
6BAA . ************************************************************** 
6BAA . * * 
6BAA ; * T h i s r o u t i n e i s c a l l e d whenever an NORTH l r q i s r e c e i v e d . * 
6BAA ; * I t updates t he c l u t t e r map and checks to see i f any o f * 
6BAA ; * the co n t r o l - p a n e l s e t t i n g s have changed, c a l c u l a t i n g new * 
6BAA ; * d e r i v e d parameters i f n e c e s s a r y . * 
6BAA . * * 
6BAA . ***************** ********************************************* 
6BAA ; 
6BAA 
6BAA 46FC 2600 NorthProc MOVE.W #$2600, SR ; Mask most i n t e r r u p t s 
6BAE 48E7 FFFE MOVEM.L D0-D7/AO-A6, -(A7) ; Push a l l r e g i s t e r s t o s t a c k 
6BB2 487A F556 (P) PEA StopRun 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 20 
MATES Development Software»Source Listing 
6BB6 4A1F TST.B (SP) + 
6BBA X X (R) BEQ.S Tr a c k S t o p 
6BBA 
6BBA 61 00 F7DE (P) BSR VDUMapUp ; Update the s t a t u s VDU 
6BBE 487A F5F6 (PI PEA RevNum 
6BC2 525F ADD.W #1, (SP) + 
6BC4 41FA F578 (P) LEA WarmRevs, AO 
6BC8 4A50 TST.W (AO) ; I s t r a c k e r running? 
6BCC X X (R) BEQ.S Running 
6BCC 
6BCC 5350 SUB.W (1, (AO) ; Decrement warm-up count 
6BCE 
6BCE 61 00 FEC4 (P) Running BSR CheckConst 
6BD2 
6BD2 61 00 F742 (P) TrackStop BSR VDUOut 
6BD6 4CDF 7FFF MOVEM.L (A7)+, D0-D7/A0-A6 ; Restore r e g i s t e r s 
6BDA 4E73 RTE 
6BDC 
6BDC 
6BDC . ************************************************************** 
6BDC . * * 
6BDC ; * T r a n s f e r data, block by block, t o t h e a p p r o p r i a t e b u f f e r s * 
6BDC ; * i n the p l o t e x t r a c t o r hardware. T h i s v e r s i o n i s designed * 
6BDC ; * around an 8MHz CPU r a t e with normal DTACK d e l a y s , and * 
6BDC ; * completes the o p e r a t i o n u s i n g 32 loops. * 
6BDC . * * 
6BDC . ******** ****************************************************** 
6BDC ; 
6BDC 
6BDC 48E7 F0E0 DataOut MOVEM.L D0-D3/A0-A2, - (A7) 
6BE0 43 FA CEA4 (P) LEA SynthVal, A l ; Load address p o i n t e r s 
6BE4 45FA AEA0 (P) LEA T hreshVal, A2 
6BE8 41FA 9E9C (P) LEA C e l l B l o c k , AO 
6BEC 
6BEC 303A F5BC (P) MOVE.W Octant, DO ; Set c o r r e c t output octant 
6BF0 323C 000A MOVE.W #10, Dl 
6BF4 E36B LSL.W Dl, DO ; Generate octant v a l u e 
6BF6 D0C0 ADDA.W DO, AO ; and add t o form CFAR outpu 
6BF8 D4C0 ADDA DO, A2 ; and t h r e s h o l d a d d r e s s e s . 
6BFA 
6BFA 363C 001F MOVE.W #31, D3 ; Set t r a n s f e r block count 
6BFE 4A79 0003 5000 ScanWait TST.W Co n s t a n t s 
6C04 6A F8 (P) BPL.S ScanWait ; Wait f o r scan p e r i o d 
6C06 
6C06 323C 000F MOVE.W #15,Dl ; Set t r a n s f e r block s i z e 
6C0A 33D9 0003 2000 TxScan MOVE.W (Al) + , Synth 
6C10 51C9 FFF8 (P) DBRA Dl, TxScan ; T r a n s f e r s y n t h e t i c s data 
6C14 
6C14 323C OOOF MOVE.W #15,Dl ,- Set t r a n s f e r block s i z e 
6C18 4A79 0003 5000 In t e r W a i t TST.W Cons t a n t s 
6C1E 6B F8 (P) BMI.S I n t e r W a i t ; Wait f o r I n t e r S c a n 
6C20 
6C20 30DA T x l n t e r MOVE.W (A2)+, (A0)+ ; Copy t h r e s h o l d words t o B3 
6C22 51C9 FFFC (P) DBRA Dl, T x l n t e r 
6C26 
6C26 51CB FFD6 (P> DBRA D3, ScanWait ,- Decrement block count 
6C2A 4CDF 070F MOVEM.L (A7)+, D0-D3/A0-A2 
6C2E 4E75 RTS 
6C30 
6C30 
6C30 . ******** ****************************************************** 
6C30 . * * 
6C30 ; * T h i s r o u t i n e i s c a l l e d a f t e r every octant demand t o r e s e t * 
6C30 ; * t h e octant-dependent parameters. * 
6C30 . * * 
6C30 . ************************************************************** 
6C30 • 
6C30 
6C30 48E7 E080 ResetOctant MOVEM.L D0-D2/A0, - (SP) 
6C34 487A F598 (P) PEA NumFOP 
6C38 425F CLR.W (SP)+ ; C l e a r f i l t e r output word 
count 
6C3A 3039 0003 5000 MOVE.W Constants, DO 
6C40 3400 MOVE.W DO, D2 
6C42 E54A LSL.W #2, D2 
6C44 0642 0200 ADD.W #$0200, D2 
6C48 0242 0E00 AND .W #$0E00, D2 ; C a l c u l a t e c e l l address o f f s e 
6C4C 41FA 9E38 (P) LEA C e l l B l o c k , AO 
6C50 D0C2 ADDA.W D2, AO 
6C52 
6C52 343C OOFF MOVE.W #255,D2 
6C56 
6C56 4298 C l e a r C e l l CLR.L (A0)+ ; C l e a r c l u t t e r c e l l s 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 21 
RATES Development Software - Source Listing 
6C58 51CA FFFC <P> DBRA 02, C l e a r C e l l 
6C5C 41FA F54C (P> LEA Octant, AO 
6C60 
6C60 323C 0007 MOVE.W 07, Dl 
6C64 E268 LSR.W Dl, DO 
6C66 0240 0007 AND.W #7, DO Generate t h e octant number 
6C6A 3600 MOVE.W DO, D3 
6C6C 30C0 MOVE.W DO, (A0) + and save. 
6C6E 
6C6E 5340 SUBQ.W #1, DO 
6C70 0240 0007 AND.W #7, DO 
6C74 30C0 MOVE.W DO, (AO)+ Previo u s octant 
6C76 
6C76 5340 SUBQ.W »1, DO 
6C78 0240 0007 AND.W «7, DO 
6C7C 30C0 MOVE.W DO, (A0) + Second p r e v i o u s octant 
6C7E 
6C7E 5640 ADDQ.W »3, DO 
6C80 0240 0007 AND.W #7, DO 
6C84 30C0 MOVE.W DO, (A0) + Next octant 
6C86 
6C86 5240 ADDQ.W #1, DO 
6C88 0240 0007 AND.W #7, DO 
6C8C 30C0 MOVE.W DO, (AO)+ Second octant on 
6C8E 
6C8E 5440 ADDQ.W #2, DO 
6C90 0240 0007 AND.W »7, DO 
6C94 30C0 MOVE.W DO, (A0> + F o u r t h octant on 
6C96 
6C96 4 CDF 0107 MOVEM. L (SP)+, D0-D2/A0 
6C9A 4E75 RTS 
6C9C 
6C9C 
6C9C . ***************** ********************************************* 
6C9C ; * * 
6C9C ; * T h i s r o u t i n e i s c a l l e d t o terminat e previous DMA operatn * 
6C9C ; * and r e s t a r t i t with a new word count and t r a n s f e r address * 
6C9C ; * I t i s c a l l e d every o c t a n t a f t e r data output and parameter * 
6C9C ; * r e s e t . * 
6C9C ; * * 
6C9C . ************************************************************** 
6C9C ; 
6C9C 
6C9C 48E7 C0E0 MipDa MOVEM. L D0-D1/AO-A2, -(A7) 
6CA0 41F9 0003 8000 LEA DmaChanO, AO ; Load DMA base address 
6CA6 43FA D45E (P) LEA Base, A l 
6CAA 0828 0003 0000 BTST.B «3, 0 (AO) ; I s i t s t i l l running? 
6CB2 X X (R) BEQ.S NoDmaAct 
6CB2 
6CB2 117C 0010 0007 MOVE.B #510, 7 (AO) ; Software abort DMA ch 0 
6CB8 1168 0000 0000 NoDraaAct MOVE.B 0(A0), 0(A0) ; Reset DMA s t a t u s r e g i s t e r 
6CBE 2028 oooc MOVE.L $C(A0), DO / Read next t r a n s f e r address 
6CC2 9089 SUB.L A l , DO ; S u b t r a c t base address 
6CC4 E448 LSR.W «2, DO 
6CC6 487A F504 (P) PEA NumFIW 
6CCA 3EC0 MOVE.W DO, (SP) + ; D i v i d e by 2 t o gi v e no of 
6CCC 487A F4F2 (P) PEA TotFInput ; p l o t s r e a d i n . 
6CD0 D15F ADD.W DO, (SP) + 
6CD2 
6CD2 45FA D436 (P) LEA F i r s t l P A , A2 
6CD6 303A F4D2 (P) MOVE.W Octant, DO 
6CDA 0800 0000 BTST.B (0, DO 
6CE0 X X (R) BNE.S EvenOct ; I s t h i s an even o c t a n t ? 
6CE0 D5FC 0000 2000 ADDA.L «$2000, A2 
6CE6 
6CE6 228A EvenOct MOVE.L A2, (Al) ; New base address 
6CE8 214A OOOC MOVE.L A2, SC(AO) ; S t o r e i n dma c o n t r o l l e r 
6CEC 317C 1000 000A MOVE.W S51000, $A(A0) t Set count value 
6CF2 i n c 0080 0007 MOVE.B 4580, 7 (AO) ; and s t a r t o p e r a t i o n 
6CF8 3039 0003 5002 MOVE.W PlotCount, DO 
6CFE 
6CFE 4CDF 0703 MOVEM.L (A7)+, D0-D1/A0-A2 ; Resto r e r e g i s t e r s 
6D02 4E75 RTS 
6D04 
6D04 . ************************************************************** 
6D04 ; * * 
6D04 * Update the v a l u e s i n the c l u t t e r c e l l t a b l e , based on the * 
6D04 * presence of t a r g e t s i n a c e l l c a u s i n g an increment i n the * 
6D04 * c l u t t e r count f o r t h a t l o c a t i o n . A maximum of 512 syn t h . * 
6D04 * c h a r a c t e r s a r e a l s o sent t o the output b u f f e r i s DispIPC * 
6D04 ; * i s turned on. * 
6D04 ; * * 
6D04 . ************************************************************** 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 22 
RATES Development Software = Source Listing 
6D04 48E7 FCFO C l u t t e r O u t MOVEM.L D0-D5/A0-A3, - (SP) 
6D08 207A D3FC (P) MOVEA.L Base, AO ; Load s t a r t o f p l o t s addres 
6D0C 43FA CD78 (P) LEA SynthVal, Al ; and s y n t h e t i c s address 
6D10 45FA 9D74 (P) LEA C e l l B l o c k , A2 ; and c l u t t e r byte address 
6D14 303A F470 (P) MOVE.W S h l f t C l u t , DO ; Load s h i f t f o r c l u t t e r range 
6D18 
6D18 323A F4B8 (P) MOVE.W NumSynth, Dl ; Dl i s no. s y n t h e t i c s * 2 
6D1C D241 ADD.W Dl, Dl 
6D1E D2C1 ADDA.W Dl, Al ; Form s y n t h e t i c s address 
6D20 
6D20 34 3A F4AA (P! MOVE.W NumFIW, D2 
6D24 5342 SUBQ.W #1, D2 ; Dl i s no. FIW - 1 
6D28 X X (R) BMI.S No C l u t t e r 
6D28 
6D28 3610 MoreClutr MOVE.W (AO), D3 ; Load p l o t b e a r i n g 
6D2A 3828 0002 MOVE.W 2(AO), D4 ; and range 
6D2E E06C LSR.W DO, D4 ; S h i f t p l o t range 
6D30 0C44 003F CMP.W #63, D4 
6D36 X X (R) BLE.S C h e c k C e l l 
6D36 
6D36 383C 003F MOVE.W #63, D4 
6D3A 47FA F458 (P) C h e c k C e l l LEA MaxOnlS + 2, A3 
6D3E 3A3C 0002 MOVE.W #2, D5 
6D42 B863 NoMRSMatch CMP.W -(A 3 ) , D4 ,- Compare a g a i n s t max range 
6D44 5ECD FFFC (P) DBGT D5, NoMRSMatch ; s e c t o r v a l u e s . 
6D48 
6D48 5845 ADDQ.W #4, D5 ; O f f s e t comparison r e s u l t . 
6D4A E86B LSR.W D4, D3 ; R e - s c a l e p l o t bearing 
6D4C 0243 01C0 AND.W #$01C0, D3 
6D50 D843 ADD.W D3, D4 ; Add range s b e a r i n g to form 
6D52 1A32 40 00 MOVE.B 0(A2, D4.W), D5 ; index i n t o c l u t t e r c e l l t a b l e 
6D56 0C05 000F CMP.B #15, D5 
6D5C X X (R) BGE.S AtMaxVal 
6D5C 
6D5C 5232 00 00 ADDQ.B #1,0(A2,D0.W) ; Increment c l u t t e r c e l l value 
6D60 487A F3AA (P) AtMaxVal PEA D i s p I P C 
6D64 081F 0007 BTST.B #7, (SP) + 
6D6A X X (R) BEQ.S EndCUpdate 
6D6A 
6D6A 0C41 0400 CMP.W #1024, Dl ; C l u t t e r c e l l count a t 1024? 
6D6E 6C 00 xxxx (R) BGE EndCUpdate 
6D72 
6D72 5841 ADDQ.W #4, Dl 
6D74 3618 MOVE.W (A0)+, D3 ; Load b e a r i n g 
6D76 3818 MOVE.W (A0)+, D4 ; Load range 
6D78 E64B LSR.W #3, D3 ; S c a l e b e a r i n g down 
6D7A C8FA F3E6 (P) MULU SynRanF, D4 ; M u l t i p l y by s y n t h e t i c s r . f 
6D7E . 4844 SWAP D4 
6D80 0244 03FF AND.W #S03FF, D4 
6D84 0044 0800 OR.W #$0800, D4 
6D88 32C3 MOVE.W D3, (Al) + ,- Save b e a r i n g & range v a l u e s 
6D8A 32C4 MOVE.W D4, (Al) + ; as s y n t h e t i c s a d d r e s s . 
6D8C 
6D8C 51CA FF9A (P) EndCUpdate DBRA D2, MoreClutr ; Next s e t of input words 
6D90 E249 LSR.W 11, Dl 
6D92 0241 01FE AND.W #510, Dl 
6D96 487A F43A (P) PEA NumSynth 
6D9A 3EC1 MOVE.W Dl, (SP) + ; Store number o f s y n t h e t i c s 
6D9C 
6D9C 4CDF 0F3F NoClutter MOVEM.L (SP)+, D0-D5/A0-A3 
6DA0 4E75 RTS 
6DA2 
6DA2 
6DA2 
6DA2 . ************************************* ************************* 
6DA2 • * * 
6DA2 ; * T h i s r o u t i n e c a l c u l a t e s and s t o r e s the t h r e s h o l d v a l u e s * 
6DA2 ; * based on t he c l u t t e r l e v e l w i t h i n a given a r e a : I f * 
6DA2 ; * i s high, the l e v e l i s doubled s i f low i s halved. Upper * 
6DA2 ,- * and lower t h r e s h o l d s a r e imposed. * 
6DA2 . * * 
6DA2 . ************************************************************** 
6DA2 • 
6DA2 
6DA2 48E7 F880 ThreshOut MOVEM.L D0-D4/A0, - (SP) 
6DA6 303A F402 IP) MOVE.W Octant, DO 
6DAA 323C 00 OA MOVE.W #10, Dl 
6DAE E368 LSL.W Dl, DO ; C a l c u l a t e octant p a r t 
6DB0 
6DB0 323A F3E2 (P) MOVE.W MaxBlack, Dl ; Dl i s max bl a c k range s e c t o r 
6DB4 
6DB6 
4242 CLR.W D2 ; D2 i s b e a r i n g p a r t 
6DB6 41FA RCCE (P) NextBear LEA ThreshVal, AO 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 23 
MATES Development Software - Source Listing 
6DBA DOCO ADDA.W DO, AO 
6DBC D0C2 ADDA.W D2, AO ; Form c e l l address 
6DBE 
6DBE 4243 CLR.W D3 ; D3 i s range s e c t o r 
6DC0 30FC 007F C l r B l a c k MOVE.W #127, (A0) + ; Set bl a c k range c e l l v a l u e s 
6DC4 5243 ADD .W #1, D3 
6DC6 B243 CMP.W D3, Dl 
6DC8 6F F6 <P) BLE.S C l r B l a c k 
6DCA 
6DCA 3F03 NextRange MOVE.W D3, -(SP) ; Push range p a r t 
6DCC 3800 MOVE.W DO, D4 
6DCE D842 ADD.W D2, D4 
6DD0 E24C LSR.W #1, D4 
6DD2 3F04 MOVE.W D4, -(SP) ; Push b e a r i n g p a r t 
6DD4 4E80 xxxx (PX) BSR C a l T h r V a l 
6DD8 30DF MOVE.W (SP)+, (A0) + ; Pop new t h r e s h o l d value 
6DDA 5243 ADD.W #1, D3 
6DDC B67A F3AE (P) CMP.W MaxRSect, D3 
6DE0 66 E8 (P! BNE.S NextRange 
6DE2 
6DE2 0642 0080 ADD.W 0128, D2 
6DE6 0C42 0400 CMP.W #1024, D2 
6DEA 66 CA (P) BNE.S NextBear 
6DEC 
6DEC 4CDF 011F MOVEM.L (SP)+, D0-D4/A0 
6DF0 4E75 RTS 
6DF2 
6DF2 
6DF2 
6DF2 • ************************************************************** 
6DF2 • * * 
6DF2 ; * C a l c u l a t e new t h r e s h o l d v a l u e s f o r a g i v e n c e l l . The * 
6DF2 ; * r o u t i n e i s passed the range p a r t & be a r i n g p a r t a s * 
6DF2 ; * parameters. I t r e t u r n s the t h r e s h o l d . T h i s may be equal * 
6DF2 ; * to a f i x e d v a l u e i f c a l c u l a t i o n i s turned o f f . * 
6DF2 • * * 
6DF2 > ************************************************************** 
6DF2 ; 
6DF2 
6DF2 48E7 F0C0 C a l T h r V a l MOVEM.L D0-D3/A0-A1, -(SP) 
6DF6 487A F31B (P) PEA T h r e s h 
6DFA 081F 0007 BTST.B #7, (SP) + 
6E00 X X (R) BNE.S C a l c L e v 
6E00 
6E00 343A F314 (P) MOVE.W ThreshLev, D2 ; Return f i x e d v a l u e 
6E04 4EC0 xxxx (PX) BRA EndCalcs 
6E08 
6E08 322F 001C Ca l c L e v MOVE.W 24 + 4(A7), Dl ; Pop b e a r i n g p a r t 
6E0C 302F 001E MOVE.W 24 + 6(A7), DO ; Pop range p a r t 
6E10 
6E10 43FA F382 (P) LEA MaxOnl5 + 2, A l 
6E14 343C 0002 MOVE.W *2,D2 
6E18 B061 Te s t L e v CMP.W - ( A l ) , DO ; F i n d t h e range s h i f t v a l u e 
6E1A 5EC8 FFFC (P) DBGT DO, Tes t L e v 
6E1E 5242 ADDQ.W #1, D2 
6E20 
6E20 3601 MOVE.W Dl, D3 ; Dl i s f u l l b e a r i n g p a r t 
6E22 E46B LSR.W D2, D3 ; S h i f t b e a r i n g p a r t 
6E24 0243 OFCO AND.W #$0FC0, D3 
6E28 D640 ADD.W DO, D3 ; add t h r e s h o l d p a r t . 
6E2A 
6E2A 43FA 9C5A (P) LEA C e l l B l o c k , A l 
6E2E 1631 30 00 MOVE.B 0(A1, D3.W), D3 ; Load c l u t t e r d e n s i t y 
6E32 4883 EXT.W D3 
6E34 
6E34 43FA AC50 (P) LEA ThreshVal, A l 
6E38 D041 ADD.W Dl, DO 
6E3A E348 LSL.W #1, DO 
6E3C 3431 00 00 MOVE.W 0(A1, DO.W), D2 ; Read p r e s e n t t h r e s h o l d l e v e l 
6E40 
6E40 B67A F314 (P) CMP.W UpperThr, D3 ; Compare upper t h r e s h o l d with 
6E44 6F 00 xxxx (R) BLE LTUpper 
6E48 
6E48 4A42 TST.W D2 ; I s present l e v e l zero? 
6E4C X X (R) BNE.S NonZero 
6E4C 343C 0001 MOVE.W #1, D2 ; R e s u l t i s '1' 
6E50 4ECO xxxx (PX) BRA EndCalcs 
6E54 
6E54 0C42 0040 NonZero CMP.W #64, D2 
6E5A X X (R) BLT.S• LT64 
6E5A 343C 007F MOVE.W #127, D2 ; Set t o max t h r e s h o l d 
6E5E 4EC0 xxxx (PX) BRA EndCalcs 
6E62 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 24 
RATES Development Softwair© - Source Listing 
6E62 D442 
6E64 4EC0 xxxx (PX) 
6E68 
6E68 B67A F2EA <P> 
6E6E X X (R) 
6E6E E24A 
6E70 
6E70 3F42 0028 
6E74 4CDF 013F 
6E78 2F57 0002 
6E7C DFFC 0000 0002 
6E82 4E75 
6E84 
LT64 
EndCalcs 
ADD .W 
BRA 
CMP.W 
BGE.S 
LSR.W 
MOVE.W 
MOVEM.L 
MOVE.L 
ADDA, I, 
RTS 
D2, D2 
EndCalcs 
LowerThr, D3 
EndCalcs 
»1, D2 
D2, 32 + 8(SP) 
(SP)+, D0-D5/A0 
(A7), 2(A7) 
#2, A7 
Double present t h r e s h o l d 
Halve p r e s e n t t h r e s h o l d 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix C . 25 
A P P E N D I X B 
tBomuree Lasting 
for 
M o v i n g I k r g e t Generator 
(Written in ADA, runs under CP/M on Cifer 2684) 
The Application of Digital Techniques to an 
Automatic Hadar Track Extraction System. Appendix D . 1 
Test Target Generatoii' • ADA Source Listing 
B>TYPE TARGET.ADA 
PROCEDURE t e s t _ t a r g e t I S 
— FIRSTLY SET CONSTANTS FOR TYPE 992 RADAR 
radar_range : CONSTANT FLOAT := 4390.0; 
rupm : CONSTANT FLOAT 48.78; 
i n v _ s p e e d _ f a c t o r : CONSTANT FLOAT :- 5.42E-2; 
TYPE ccnmand I S ( h i g h l i g h t , d o u b l e _ w i d t h , g r a p h , b l i n k , o l d _ c l e a r ) ; 
e s c : CONSTANT CHARACTER := CHARACTER'VAL(27); 
a t a n , i d e n t : INTEGER; 
t t _ r a n g e : ARRAY(1..3) OF INTEGER; 
t t _ b e a r i n g : ARRAY(1..3) OF INTEGER; 
t t _ a l o n g : ARRAY(1..3) OF FLOAT; 
t t _ c r o s s : ARRAY(1..3) OF FLOAT; 
t t _ a v a i l a b l e : ARRAY (1. .3) OF BOOLEAN; 
distance,bearing,heading,speed : INTEGER; 
t r i g : ARRAY (0..80) OF FLOAT; 
sin,cos,hypot : FLOAT; 
Subroutine t o manipulate the g r a p h i c s c a p a b i l i t i e s of 
the s c r e e n . 'OP' i s one of ' h i g h l i g h t ' 'double_width' 
' b l i n k ' , 'graph' or ' o l d c l e a r ' . ' D I R ' i s '1' t o 
t u r n the e f f e c t on or '0' t o t u r n i t o f f . 
PROCEDURE s c r e e n (op : command; d i r : INTEGER) I S 
BEGIN 
PUT (esc) ; 
CASE op I S 
WHEN h i g h l i g h t => 
I F d i r - 1 THEN PUT('N'); 
ELSE PUT('O'); PUT ( e s c ) ; PUT (' + ' ) ; END I F ; 
WHEN double_width => 
I F d i r = 1 THEN PUT('E'); ELSE P U T ( ' I ' ) ; END I F ; 
WHEN graph => 
PUT { ' * • ) ; PUT (CHARACTER'VALfdir + 6 4 ) ) ; 
WHEN b l i n k => 
I F d i r - 1 THEN PUT('F'); ELSE PUT('G'); END I F ; 
WHEN o l d _ c l e a r => 
PUT('M'); sc r e e n ( d o u b l e _ w i d t h , 0 ) ; 
END CASE; 
END s c r e e n ; 
Draw box and then annotate the u s e r d i s p l a y 
PROCEDURE s c r e e n _ i n i t i a l i s e I S 
PROCEDURE h o r i z o n t a l I S 
— Draw h o r i z o n t a l l i n e s 
BEGIN 
s c r e e n ( h i g h l i g h t , 1 ) ; 
s c r e e n ( g r a p h , 9 ) ; PUT (' ' ) ; 
FOR i IN 1..5 LOOP 
s c r e e n ( g r a p h , 1 1 ) ; 
FOR j IN 1..12 LOOP 
PUT(' ' ) ; 
END LOOP; 
scr e e n ( g r a p h , 1 2 ) ; PUT(' ' ) ; 
END LOOP; 
new_line; 
END h o r i z o n t a l ; 
PROCEDURE v e r t i c a l ( l i n e , c o d e : INTEGER ) I S 
— Draw v e r t i c a l l i n e s 
BEGIN 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix D . 2 
Test Target Generator • ADA Source Listing 
s c r e e n ( g r a p h , 9 ) ; PUT(• • ) ; 
FOR i IN 1..5 LOOP 
s c r e e n ( g r a p h , 0 ) ; 
FOR j IN 1..12 LOOP 
PUT(• " ) ; 
END LOOP; 
sc r e e n ( g r a p h , 9 ) ; PUT(• • ) ; 
END LOOP; 
new_line; 
END v e r t i c a l ; 
BEGIN 
put ( e s c ) ; p u t ( ' J ' ) ; 
put ( e s c ) ; p u t ( ' V ' ) ; 
new_line; 
s c r e e n ( o l d _ c l e a r , 0 ) ; 
s c r e e n ( h i g h l i g h t , 1 ) ; 
s c r e e n ( d o u b l e _ w i d t h , 1) 
put("RATES 992 
s c r e e n ( h i g h l i g h t , 0 ) ; 
s c r e e n ( d o u b l e _ w i d t h , 0 ) ; 
new_line; new_line; new_line; 
h o r i z o n t a l ; 
s c r e e n ( g r a p h , 9 ) ; put (' 
s c r e e n (graph, 9 ) ; POTC 
s c r e e n (graph, 9 ) ; PUT(' 
s c r e e n ( g r a p h , 9 ) ; PUT ( 1 
s c r e e n ( g r a p h , 9 ) ; PUT (' 
sc r e e n ( g r a p h , 9 ) ; PUT (• 
n e w l i n e ; 
FOR i IN 1..3 LOOP 
h o r i z o n t a l ; 
FOR j IN 1..3 LOOP 
v e r t i c a l ( j , i ) ; 
END LOOP; 
END LOOP; 
sc r e e n ( g r a p h , 9 ) ; PUT(• •) ; 
FOR i IN 1.. 5 LOOP 
s c r e e n ( g r a p h , 1 4 ) ; 
FOR j IN 1..12 LOOP PUTC ' ) ; 
s c r e e n (graph, 13) ,* PUT(' ' ) ; 
END LOOP; 
s c r e e n ( g r a p h , 0 ) ; 
s c r e e n ( h i g h l i g h t , 0 ) ; 
END s c r e e n i n i t i a l i s e ; 
TEST TARGET GENERATOR"); 
screen(graph, 0) ; 
sc r e e n ( g r a p h , 0 ) ; 
s c r e e n ( g r a p h , 0 ) ; 
s c r e e n ( g r a p h , 0 ) ; 
s c r e e n ( g r a p h , 0 ) ; 
put("NUMBER"); 
PUT("RANGE"); 
PUT("BEARING"); 
PUT("SPEED"); 
PUT("HEADING"); 
D i r e c t c u r s o r t o a p p r o p r i a t e input p o s i t i o n 
PROCEDURE p o s i t i o n ( t a r g e t _ n u m b e r , i t e m : INTEGER) I S 
BEGIN 
PUT(esc); PUT(•P •) ; 
PUT(CHARACTER 1VAL(item*13+36)); 
PUT(CHARACTER 1VAL(target_number*4+36)); 
END p o s i t i o n ; 
Turn b l i n k i n g t a r g e t i . d . on (or o f f ) i f s e l e c t e d 
PROCEDURE number ( f l a s h , target_number : INTEGER) I S 
BEGIN 
s c r e e n ( h i g h l i g h t , 1 ) ; 
p o s i t i o n ( t a r g e t _ n u m b e r , 0 ) ; 
I F f l a s h = 1 THEN s c r e e n ( b l i n k , 1 ) ; END I F ; 
s c r e e n ( d o u b l e _ w i d t h , 1 ) ; 
PUT ("TT">; PUT (target_number) ; 
sc r e e n ( d o u b l e _ w i d t h , 0 ) ; 
s c r e e n ( b l i n k , 0 ) ; 
END number; 
C l e a r d i s p l a y o f chosen t a r g e t parameters 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix D . 3 
Test Target Generator - ADA Source Listing 
PROCEDURE c l e a r _ l i n e ( t a r g e t _ n u m b e r : INTEGER) I S 
BEGIN 
FOR i IN 1..4 LOOP 
p o s i t i o n (target_number, i ) ; 
PUT(" " ) ; 
END LOOP; 
END c l e a r _ l i n e ; 
Use d i r e c t keyboard input to read chosen t a r g e t number 
PROCEDURE get_target_number (code : OUT INTEGER) I S 
code := bdos(6, 255) - 48; 
I F code > 0 AND code < 4 THEN 
c l e a r _ l i n e ( c o d e ) ; 
number(1,code); 
ELSE 
I F code = -21 THEN 
PUT ( e s c ) ; PUT('W'); 
BDOS(O); 
ELSE code : = 0; 
END I F ; 
END I F ; 
END get_target_number; 
Read range, bearing, speed s heading f o r chosen t a r g e t 
PROCEDURE r e a d d a t a ( c o d e : INTEGER) I S 
BEGIN 
I F code > 0 AND code < 4 THEN 
FOR j IN 1..4 LOOP 
p o s i t i o n ( c o d e , j ) ; 
CASE j I S 
WHEN 1 -> G E T ( d i s t a n c e ) ; 
I F d i s t a n c e = 0 THEN e x i t ; END I F ; 
WHEN 2 => GET (bearing) ; 
WHEN 3 => GET (speed); 
WHEN 4 -> GET (heading) ; 
END CASE; 
END LOOP; 
I F d i s t a n c e /= 0 THEN t t _ a v a i l a b l e ( c o d e ) := t r u e ; 
ELSE t t _ a v a i l a b l e ( c o d e ) f a l s e ; END I F ; 
number(0,code); 
END I F ; 
END read data; 
START OF MAIN CALCULATING ROUTINES — 
PROCEDURE s e t _ c o n s t a n t s I S 
BEGIN 
t r i g ( 0 ) : = 0 . 0 ; t r i g ( 1 ) : = 1 6 0 6 . 0 ; t r i g ( 2 ) : = 3 1 9 6 . 0 ; 
t r i g ( 3 ) : = 4 7 5 6 . 0 ; t r i g ( 4 ) : = 6 2 7 0 . 0 ; t r i g ( 5 ) : = 7 7 2 3 . 0 ; 
t r i g ( 6 ) : = 9 1 0 2 . 0 ; t r i g ( 7 ) : = 1 0 3 9 4 . 0 ; t r i g ( 8 ) : = 1 1 5 8 5 . 0 ; t r i g ( 9 ) : = 1 2 6 6 5 . 0 ; 
t r l g ( 1 0 ) : = 1 3 6 2 3 . 0 ; trig(11):=14449.0; trig(12):=15137.0; t r i g (13):=15679.0; 
trig(14):=16069.0; trig(15):=16305.0; trig(16):=16384.0; 
FOR i IN 0..16 LOOP t r i g ( i ) : = t r i g ( i ) * 0 . 6 1 0 4 E - 4 ; END LOOP; 
FOR i IN 0..15 LOOP t r i g ( 3 2 - i ) := t r i g ( i ) ; END LOOP; 
FOR 1 IN 0..31 LOOP t r i g ( 6 4 - i ) := - t r i g ( i ) ; END LOOP; 
FOR I IN 1..3 LOOP 
t t a v a i l a b l e ( i ) := f a l s e ; number(0,i); 
END LOOP; 
END s e t _ c o n s t a n t s ; 
C a l c u l a t e a square root by Newton's approximation 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix D . 4 
Test Target Generator - ADA Source Listing 
FUNCTION s q r t ( d i s t : FLOAT) RETURN FLOAT I S 
g u e s s , d e l t : FLOAT; 
BEGIN 
I F d i s t = 0.0 THEN RETURN 0.0; 
E L S I F d i s t - 1.0 THEN RETURN 1.0; 
ELSE 
guess := d l s t / 2.0; 
LOOP 
delt:=guess - (guess * guess - d i s t ) / ( 2 . 0 * g u e s s ) ; 
EXIT WHEN ABS(guess - d e l t ) < 0.5; 
guess d e l t ; 
END LOOP; 
RETURN d e l t ; 
END I F ; 
END s q r t ; 
C a l c u l a t e s i n and c o s i n e u s i n g a look-up t a b l e 
PROCEDURE sin_and_cos (angle : INTEGER) I S 
rads_per_degree : CONSTANT FLOAT := 1.74533E-2; 
pi_by_32 : CONSTANT FLOAT := 9.81748E-2; 
element : INTEGER; 
x, s , c , s i n r a d s , c o s r a d s : FLOAT; 
BEGIN 
x := FLOAT(angle) * rads_per_degree; 
element := INTEGER (x / p i _ b y _ 3 2 ) ; 
s := t r i g ( e l e m e n t ) ; 
c := t r i g ( 1 6 + e l e m e n t ) ; 
s i n rads := x - FLOAT (element) * pi_by_32; 
cos_rads := 1.0 - s i n _ r a d s * sin__rads * 0.5; 
s i n s * cos_rads + c* s i n _ r a d s ; 
cos := c * cos_rads - s * s i n _ r a d s ; 
END sin_ a n d _ c o s ; 
Use Pythagoras to f i n d hypotenuse of & 'R* then use 
an approximation t o e s t a b l i s h t he arctangent 
PROCEDURE atan_and_hypot (q, r : FLOAT) I S 
x,x2, angle : FLOAT; 
BEGIN 
hypot := s q r t (q*q + r«r); 
x q/r; 
I F X < -0.4142136 THEN 
X : = ( X + 0.4142136) / (x » (-0.4142136) + 1.0); 
angle := -0.125; 
E L S I F X < 0.4142136 THEN 
x := (x - 0.4142136)/(x*0.4142136+1.0); 
angle := 0.125; 
ELSE angle 0.0; 
END I F ; 
x2 := x*x; 
a t a n := INTEGER(((((0.016733)»x2+0.169562)*x2+0.4462159)/(0.1401829el+x2)*x+angle)*0.32768e5); 
END atan_and_hypot; 
I n i t i a l i s e a new t a r g e t with a p p r o p r i a t e along i c r o s s v e c t o r s 
PROCEDURE s e t _ t a r g e t ( c o d e : INTEGER) I S 
beta : INTEGER; 
d i s t _ p e r _ r e v : FLOAT; 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix D . 5 
Test Target Generator - ADA Source Listing 
BEGIN 
I F code > 0 AND code < 4 THEN 
tt _ r a n g e ( c o d e ) := INTEGER(FLOAT(distance) * rupm); 
tt_bearing(code):=INTEGER(FLOAT(bearing) * 0.182044E3); 
beta := heading - bea r i n g ; 
I F b eta < 0 THEN 
beta := beta + 360; 
END I F ; 
s i n _ a n d _ c o s (beta) ; 
d i s t _ p e r _ r e v := FLOAT (speed) * i n v _ s p e e d _ f a c t o r ; 
t t _ a l o n g ( c o d e ) := d i s t _ p e r _ r e v * cos; 
t t _ c r o s s (code) := d i s t _ p e r _ r e v * s i n ; 
END I F ; 
END s e t _ t a r g e t ; 
T r a n s f e r each of the t a r g e t s i n t u r n to the t e s t t a r g e t 
generator, c a l c u l a t i n g new p o s i t i o n & updating s t o r e d 
parameters before output. 
PROCEDURE o u t p u t _ t a r g e t s I S 
a l o n g _ r a n g e , r a t i o : FLOAT; 
BEGIN 
FOR n IN 1.. 3 LOOP 
I F t t _ a v a i l a b l e ( n ) THEN 
along_range FLOAT (tt _ r a n g e (n)) + t t _ a l o n g ( n ) ; 
a t a n _ a n d _ h y p o t ( t t _ c r o s s (n), a l o n g r a n g e ) ; 
I F hypot > radar_range THEN 
t t _ a l o n g ( n ) - t t along ( n ) ; 
t t _ c r o s s ( n ) := - t t _ c r o s s (n) ; 
ELSE 
t t b e a r l n g ( n ) := t t _ b e a r i n g ( n ) + a t a n ; 
r a t i o := (FLOAT (t t _ r a n g e (n)) - 1.0) / hypot; 
t t _ a l o n g ( n ) := hypot - along_range * r a t i o ; 
t t _ c r o s s ( n ) := t t c r o s s (n) * r a t i o ; 
t t _ r a n g e ( n ) := INTEGER(hypot + 0.5); 
PUT ( t t _ r a n g e (n)) ; PUT(" ") ; 
P U T ( t t _ b e a r i n g ( n ) ) ; n e w _ l i n e ; 
END I F ; 
END I F ; 
END LOOP; 
END o u t p u t _ t a r g e t s ; 
The main program 
BEGIN 
s c r e e n _ i n i t i a l i s e ; 
s e t _ c o n s t a n t s ; 
LOOP 
g e t _ t a r g e t _ n u m b e r ( i d e n t ) ; 
r e a d _ d a t a ( i d e n t ) ; 
s e t t a r g e t ( i d e n t ) ; 
o u t p u t _ t a r g e t s; 
END LOOP; 
END; 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix D . 6 
A P P E N D I X E 
Som°ce L i s t i n g 
for 
Systolic CFAR Simialation 
(Written in PASCAL, runs on Apple Macintosh) 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix E .1 
Systolic CFAR Simulation - PASCAL Source Listing 
program s i m u l a t e ; 
const 
width = 9; 
depth - 5; 
N = 6; 
type 
c e l l _ t y p e = r e c o r d 
case code : i n t e g e r of 
0 : ( 
Xin, Xout : r e a l ; 
Zin, Yout : r e a l ; 
Xptr, Zptr : ' r e a l 
) ; 
1 : ( 
Ain, Bin, Sout : r e a l ; 
Aptr, Bptr : ' r e a l 
) ; 
end; 
var 
c e l l : a r r a y [ 1 . . w i d t h , 1..depth] o f c e l l _ t y p e ; 
x v a l , cago : r e a l ; 
inv__n, one, manual, comp, inv_k, zero : r e a l ; 
source, r e s : t e x t ; 
p u l s e , i d : i n t e g e r ; 
( Connect t h e elements of the a r r a y t o g e t h e r } 
procedure connect; 
var 
x, y : i n t e g e r ; 
begin 
f o r x := 1 t o 9 do 
f o r y :« 2 t o 4 do 
begin 
c e l l [x, y].code : 
c e l l [ x , y ] . A p t r : 
c e l l [ x , y ) . B p t r : 
end; 
1; 
n i l ; 
n i l ; 
f o r x := 1 t o 9 do 
begin 
c e l l [ x , l j . c o d e 
c e l l f x , 5],code 
c e l l [ x , 5 ) . Z p t r 
i f x < 7 then 
c e l l [ x , 
e l s e 
c e l l [ x , 
i f x > 1 
begin 
c e l l [ x , l j . X p t r := @ c e l l [ x - 1, 1].Xout; 
c e l l f x , 5 ) . X p t r := @ c e l l [ x - 1, 5).Xout; 
end 
e l s e 
begin 
c e l l [ x , l j . X p t r := S x v a l ; 
c e l l f x , 5J.Xptr := @ c e l l [ l , 4).Sout; 
end; 
end; 
:= 0; 
:= 0; 
@one; 
1] . Z p t r := 8inv_n 
1 ] . Z p t r := @one; 
then 
f o r x :» 1 t o 3 do 
begin 
c e l l [ (2 * x -
c e l l f ( 2 * x -
end; 
c e l l [ l , 3 ] . A p t r 
c e l l [ l , 3 ] . B p t r 
c e l l [ 3 , 3 ] . A p t r 
c e l l [ 3 , 3 ] . B p t r 
c e l l [ l , 4 ] . A p t r 
c e l l [ l , 4 ) . B p t r 
1 ) , 2].Aptr := @ c e l l [ ( 2 * x - 1 ) , l ] . Y o u t ; 
1 ) , 2 ) . B p t r := @ c e l l [ ( 2 * x ) , l l . Y o u t ; 
2).Sout; = @ c e l l [ l 
= @zero; 
= @ c e l l [ 3 , 2].Sout; 
- @ c e l l [ 5 , 2].Sout; 
= S c e l l t l , 3].Sout; 
= @ c e l l [ 3 , 3].Sout; 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix E . 2 
Systolic CFAE Simulation - PASCAL Source Listing 
c e l l [ 9 , 2 ] . A p t r := @ c e l l [ 9 , 1).Yout; 
c e l l [ 9 , 2 ) . B p t r :- @zero; 
c e l l [ 9 , 3 ] . A p t r @ c e l l [ 9 , 2].Sout; 
c e l l [ 9 , 3 ] . B p t r :- @zero; 
end; 
I C a l c u l a t e the new v a l u e o f the s u p p l i e d element } 
procedure c a l c u l a t e (var element : c e l l _ t y p e ) ; 
begin 
c a s e element.code of 
0 : 
begin 
element.Xout element.Xin; 
element.Yout := element.Xin * element.Zin; 
end; 
1 : 
element.Sout := element.Ain + element.Bin; 
end; 
end; 
{ Read the new inputs t o the chosen element ) 
procedure s h i f t (var element : c e l l _ t y p e ) ; 
begin 
w i t h element do 
begin 
case code of 
0 : 
begin 
i f Xptr <> n i l then 
X i n := Xptr* 
e l s e 
Xin := 0; 
i f Zptr <> n i l then 
Zl n := Z p t r A 
e l s e 
Zin :- 0; 
end; 
1 : 
begin 
i f A p t r <> n i l then 
Ain := A p t r A 
e l s e 
Ain := 0; 
i f Bptr <> n i l then 
Bin := Bptr* 
e l s e 
Bin := 0; 
end; 
end; 
end; 
end; 
( Simulate r i s i n g edge of g l o b a l c l o c k ) 
procedure move_data; 
v a r 
x, y : i n t e g e r ; 
begin 
f o r x := 1 t o 9 do 
f o r y := 1 t o 5 do 
begin 
s h i f t ( c e l l [ x , y ] ) ; 
end; 
end; 
( Simulate f a l l i n g edge o f g l o b a l c l o c k ) 
procedure d o _ c a l c s ; 
v a r 
x, y : i n t e g e r ; 
begin 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix E . 3 
Systolic CFAE Simulation - PASCAL Source Listing 
f o r x := 1 t o 9 do 
f o r y z= 1 t o 5 do 
begin 
c a l c u l a t e ( c e l l [x, y ] ) ; 
end; 
end; 
f u n c t i o n max (a, b : r e a l ) : r e a l ; 
begin 
i f (a > b) then 
max : = a 
e l s e 
max := b; 
end; 
( D i s p l a y / p r i n t the r e s u l t s ) 
procedure show; 
v a r 
x, y : i n t e g e r ; 
cago_sum : r e a l ; 
begin 
cago_sum :>= 0; 
f o r x := 4 t o 9 do 
begin 
cago_sum :- cago_sum + c e l l t x , 1].Xout; 
end; 
cago_sum := cago_sum / 6; 
w r i t e ( r e s , t r u n c (max ( c e l l [1, 4] .Sout, c e l l f 9 , 5 ] . X o u t ) ) , c h r ( 9 ) ) ; 
w r i t e l n ( r e s , t r u n c ( c e l l [ 9 , 3 ) . S o u t ) ) ; 
w r i t e l n ( ' S y s t o l i c CAGO g i v e s : \ m a x ( c e l l ( 1 , 4).Sout, c e l l [ 9 , 5 ] . X o u t ) ) ; 
w r i t e l n ( ' T e s t c e l l : ', c e l l ( 9 , 3 ) . S o u t ) ; 
w r i t e l n ; 
end; 
( The c l o c k i s s p l i t i n t o two phases : the r i s i n g edge and the ) 
( f a l l i n g edge. On t h e r i s i n g edge, data i s copied to t h e ) 
( element i n p u t s . On the f a l l i n g edge c a l c u l a t i o n s a r e done ) 
procedure c l o c k ; 
begin 
p u l s e :- p u l s e + 1; 
movedata; 
show; 
d o _ c a l c s ; 
end; 
procedure i n i t i a l i s e ; 
begin 
open(source, 'Simulation D a t a ' ) ; 
open(res, ' R e s u l t s ' ) ; 
r e w r i t e (r e s ) ; 
r e s e t ( s o u r c e ) ; 
p u l s e := 0; 
in v _ n := 1 / N; 
one := 1.0; 
zero := 0.0; 
end; 
begin 
i n i t i a l i s e ; 
connect; 
w h i l e not eof (source) do 
begin 
r e a d l n ( s o u r c e , i d ) ; 
r e a d l n ( s o u r c e , x v a l ) ; 
r e a d l n ( s o u r c e , cago); 
c l o c k ; 
end; 
c l o s e ( s o u r c e ) ; 
c l o s e (res) 
end. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix E . 4 
A P P E N D I X F 
The Application o f 
S y s t o l i c A r r a y s 
to 
S i g n a l Processing 
(Published in I .E.E.E. Conference Proceedings, Radar '86) 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix F .1 
'The Application of Systolic Arrays to Radar Signal Processing" 
The Applications of Systolic Arrays 
To Radar Signal Processing 
RSpearmant CXSpracklent J.H.Miles0 
Abstract 
Durham University, Depanment of Applied 
Physics and Electronics, have for many years been 
involved in the development of digital signal processing 
techniques for radar signals. More recently they have 
carried out major research projects for various 
semiconductor manufacturers on the design and 
simulation of very large scale integrated circuits and 
have become involved in the area of knowledge 
representation using massively parallel processors. This 
has naturally led to a realisation of the dramatic 
advantages to be gained from the incorporation of 
systolic arrays into digital systems and, in this paper, 
into digital radar signal processors. 
Introduction 
In this paper we present the design of a 
systolic array processor radar system and compare it to a 
conventional radar processor. It is shown that the use of 
very large scale integrated circuit techniques, in the form 
of systolic arrays, leads to the dramatic performance 
improvements normally associated with emitter coupled 
logic, while retaining the space and power saving 
advantages associated with very large scale integration 
and CMOS technology. 
We show how systolic arrays can be used to 
replace the boards of high speed logic normally 
associated with a high performance radar implementing 
all of the normal processing functions associated with a 
general purpose digital processor, but at the speed 
associated with the fixed function logic arrays. 
Modern radar systems demand both high 
performance and portability, and many improvements 
have been made in recent years, including the use of 
digital techniques. The gradual change from small scale 
integration to very large scale integrated (VLSI) 
techniques, and the use of microprocessor and special 
purpose digital signal processing elements have led to 
dramatic improvements in speed, size, cost and power 
consumption. Since, in most cases, production volumes 
are very low the use of general purpose processors is 
important. Although in recent years, sophisticated 
computer aided design tools have made it relatively 
straightforward to design semi-custom VLSI devices, it 
is only in the area of arrays of replicated structures that 
the necessary circuit density improvements have been 
made that will allow components of the complexity 
necessary 10 implement a radar processor. 
In this paper an alternative approach to the 
general purpose programmable processor is proposed, 
based on the systolic array approach developed 
originally at Carnegie Mellon University. 
Multi-Processor Architectures 
The design of digital signal processing systems 
has increased in complexity over the past few years, 
beyond the point where a single processing element is 
used to perform a variety of sequential operations on an 
incoming data stream. To achieve a greater throughput, 
the same element can be replicated to spread the load 
more evenly. The significant point about the 
enhancements is that the single element performs many 
operations on the data before an output is given. 
Typically, the processor would be a standard 
microprocessor or possibly a bit-slice device - however 
these both suffer from the disadvantage of a sizeable 
instruction set and a correspondingly low throughput 
and I/O rates. 
An ideal compromise would be some form of 
dedicated hardware following a constant instruction 
sequence, such as the multiplier-accumulator devices. It 
is at this point that we introduce the concept of a 
systolic array. Such an array consists of a set of 
interconnected cells, each of which performs some 
elemental operation. Data flows between cells in a 
rythmic (i.e. systolic) fashion. The array does not 
necessarily produce a final result from each element, as 
partial results usually flow between the elements. 
There is no instruction/operand FETCH and we 
are able to use each data item several times - i.e. we are 
not I/O bound. The use of extensive pipelining and 
concurrency means that many of the simple cells will 
be performing computations at the same time. 
Radar Signal Processing 
In attempting to design a systolic array radar 
signal processor it is necessary to consider the design of 
a basic radar signal processing system. The architecture 
is based around a monostotic surveillance tracking radar 
with log video input and appropriate synchronisation 
data. 
An analogue to digital converter (A/D) is 
coupled to a constant false alarm rate processor that 
evaluates the first threshold crossings to produce binary 
target data. This is fed to a second threshold process 
which integrates the signal over azimuth. The resulting 
declaration is then averaged in terms of both range and 
azimuth to produce a centre of plot prediction. 
t Durham University, Dept. of Applied Physics & Electronics. " Admiralty Research Establishment, Portsmouth. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix F . 2 
'The Application of Systolic Arrays to Radar Signal Processing" 
The most commonly used form of 
CFAR detector uses a sliding window over the full 
range of the radar with a target being declared if the 
video level in a central cell exceeds the averages of the 
cells on either side of i t (Fig. 1). 
In this example a target would be 
identified i f : 
where N is number of cells in sum, KJW are 
constants. This type of calculation may be simplified if 
the summation of the cells is considered as : 
Ixt-xt-4 = I^t-l-^t-S) * x t - *t-5 
thus reducing the computation from 4 additions to 1 
addition and 1 subtraction. 
For a standard first threshold processor, 
the above calculations would be performed by either 
dedicated logic or using a programmable device. Neither 
method would normally involve pipelining at any stage 
hence the maximum throughput of the processor would 
be proportional to the sum of the times for each 
individual calculation. 
rcngocsio—s» 
M A X I N 
( 'K-.H+C } fc{ V a c a t e ? ) — C > 
Using general MSI components, it is 
estimated that the time taken to evaluate a target 
detection is: 
'mult 
For modem radar signal processing 
applications a more flexible solution, combined with 
higher throughput is clearly required and one way to 
achieve this could be through the use of a pipelined 
architecture for the first and second threshold processors, 
since it is these sections which immediately affect the 
maximurn digitisation rate. 
The proposed systolic architecture makes 
use of high levels of pipelining between processing 
cells, with data flow occuring only at regular intervals 
as defined by the global clock. The block diagram of 
such a system is shown in Fig. 2. The complete first 
threshold section makes use of only 2 basic processor 
cells with a minimum of interconnection to external 
circuits. The ease of implementation of this circuit in 
VLSI form has been paramount in its design, 
accounting for the use of large numbers of replicated 
structures. 
All processor cells latch input data on the 
first half of each clock cycle, whilst the second half of 
the cycle results in the following actions: 
Type 0 : 
Type 1 : 
Type 2 : 
Type 3 : 
Sin = Sin + Xin - Yin, 
Sout = Sin. 
Yout = Yin, 
Xout = Xin 
Sin = Sin * w +• z, 
Sout = Sin, 
Yout = Yin. 
Xout = Xin 
Sin = Sin, 
Sout = Sin, 
Xout = Xin, 
Yout = Yin 
Sin = Xin + Yin, 
Sout = Sin, 
Zout = Zin 
It may be observed from these 
descriptions that types 1 & 2 are essentially equivalent 
as are types 0 & 3, hence the basic structure consists of 
only 2 distinct units. 
which gives a mean time of 120nS and 
hence a maximum digitisation rate of 3 MHz. 
delay 
lino , 
4 ^ . Xin 
Sin 
• & Xin 
© Sin 
Typo I 
INPUT 
DATA 
Soul Soul 
Yin O -
Xout 
TypoO 
© S i n 
Yout Yin O 
_ ( > } X i n Xout 
Typo I 
1 ' N 0 
Typo 1 
£ Yin 
Sin Sout 
Yout Yin 
'Xin Xout 
Z n 
- o 
CFAR 
OUTPUT 
<S Xin J 
Fig. 2 : Sycaitic CFAH Pfocaocw 
The Application of Digital Techniques to am 
Automatic Radar Track Extraction System. Appendix F . 3 
'The Application of Systolic Arrays to Radar Signal Processing" 
The time taken for a result to appear at the 
bo an dry of the type 3 ceil is now equal to the time 
taken by the partial result propagating from cell 0 
through the 3 intervening cells and is equivalent to a 
total of 5 clock cycles. In this case, however, the clock 
rate can be significantly higher than in a non-pipelined 
solution and is restricted only by the maximum 
processing time of any individual ceiL 
Typically the type 1 cell ( a multiplier-
accumulator) would have the longest processing time of 
appro*. 50nS, resulting in a maximum data rate of 
20MHz. The output data would be delayed for 5 range 
cells as against 1 range cell for the non-pipelined case, 
however total data throughput is higher. In addition, a 
dramatic improvement may be achieved by expanding 
the systolic block into an array, and adding other 
processing functions, whilst retaining the same global 
clock rate. 
target will be declared within the width of the processor 
window. A better solution can be achieved with each 
block being subject to separate second threshold 
processing, producing an array of Tuts' which may be 
fed in parallel to a systolic plot extractor (Fig. 6 ). 
IMC/DEC 
THRESHOLDS 
ocfeiy: 
1 rcngoaccn 
Rg. 3 : Second ThrcohcJri 
Evoiuaicn Cod 
EralnatiflB s£ 2 n d Threshold, 
Initial research into the systolic concept 
resulted in techniques for evaluating the first threshold, 
however further work has suggested that an solution to 
complete plot extraction may be achieved using a larger 
number of basic cells and an array of the original 
processor blocks. 
The second threshold is an azimuth-
orientated process, involving integration of the first-
threshold detections over sequential pulse repetitions, 
until a certain level (the second threshold) is reached 
whereupon a target is deemed to exist in terms of both 
range and bearing. The calculations make use of a 
principle described by Marcoz and Galati and involve 
simple integration using predefined increments, with a 
maximum returned value such that targets can die away 
if not detected on successive pulse repetitions. 
Assuming a binary output x t from the first 
threshold detector, arrays of count values and target 
declarations accumulated on range scan i : Yj , Zj , 
thresholds M, L and increment / decrement values 15, d 
( Q > 3 ) then : 
if x t = 1 then Y| = Y N 1 + INC 
else Y, = Y n - DEC 
if Y| a M then Z, = 1, Y| = MTN( Y l f M ) 
if ( Z, . x a 0 ) & ( Z, = 1 ) then Ds'C = B, DEC = 3 
else 
if ( Y, < L ) then Z, = 0, INC = 3, DEC = R 
Y, = MAX( Y|, 0 ) 
This is a formal statement of 
the Marcoz and Galati algorithm, which may be 
implemented in several systolic forms, although as 
shown in Fig. 3 provides the simplest solution. 
Whilst adaption to an array of block processors with 
each adding to the integral from the previous azimuth 
sweep, seems obvious, this does not lead to the 
optimum solution since there is no guarantee that a 
The output from the second threshold circuit takes 
the form of a binary target declaration which may be fed 
directly to a plot extraction process, the purpose of 
which is to establish a central coordinate for the target 
in question, by integration over a predefined area and 
suitable weighting of the accumulated "hits'. The most 
readily adaptable form of this algorithm involves taking 
moments of the plot about range and azimuth, 
averaging these and hence computing the absolute 
coordinate of the target. (Fig. 4 ). 
Given a area size of M azimuth pulses and N range 
cells, for each M the corresponding range moment is 
equal to: 
I R M = Z { M M Lxy 
Similarly the azimuth moment for each range depth is : 
Z 0 „ » Z ( M M } J-XIJ 
The absolute centre of gravity of the plot may now be 
taken as: 
0 = ( Z H - l f f ) 0i ) / ZN + 0 O 
R = ( Z U*W) Ri) / ZN + R 0 
where 0Q and RQ arc base coordinates of the plot and 
ZN is the sum of active plot cells given by : 
ZN = Z {1=1>N; J=UM) xi,s 
azimuth - M DUt3G3 
in tno oc3 
X(N/M) 
RQ. 4 : Calculation o4 
Plot Coordinator 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix F . 4 
'The Application of Systolic Arrays to Radar Signal Processing" 
This extractor may be successfully 
implemented in systolic form, using a single processing 
element far each cell in the plot window. The 
configuration, as shown in Fig. 6 may be expanded to 
cover any area and only requires the appropriate range 
and azimuth weightings to be input to the boundry 
cells. 
This systolic array has been 
subject to simulation and has produced results 
comparable with those achieved using a conventional 
plot extractor. The increase in speed in the final stage of 
the unit gives rise to a considerable increase in the 
number of plots which may be handled per sweep, and 
confirms the advantages of the systolic concept. 
A o u t 
Rou t 
N o u t 
P a o u t 
8 (1 -3 -1 ) 
AOUt 
R o u t 
N o u t 
p x o u l 
\ 
E AOUt 
R o u i 
N O M 
T 
N o u l 
A m Rrrt NOT 
P i g . 5 : S y o t o l l e 
P l o t E a t r o o t O f 
T y p o S c o I to 
V V V 
T y p o 8 eof lo 
The output from the plot 
extractor takes the form of accumulated range and 
bearing moments( ZR. £ 0 ) and an active cell count ( 
XN ). It is only necessary to divide the moments by the 
cell count and add the results to base coordinates to 
determine the plot centre. It is suggested that this 
function be evaluated outside the systolic array, in order 
to preserve the regular structure. In addition, gating is 
required to prevent plots being declared in very close 
proximity to each other. Since the whole plot extractor 
is clocked globally, there is no need for any reference 
range and bearing to be included until the final stage of 
calculation, as these may be determined from the fixed 
delays which occur within the structure. 
For the plot extractor section, 
data is again latched on the first half of a clock cycle, 
whilst the following takes place on the second half of 
the cycle: 
Type 5 : Aout = Ain + q ° Xin 
Rout = Rin + p ° Xin 
Nout = Nin + Xin 
Xout = X 
X = Xin 
Type 6 : Aout = Ain + x 
Rout = Rin + y 
Noui = Nin + z 
The extra delay in the Type 5 cells is required to 
synchronise the calculations in the final cells. 
It is hoped that a hardware 
implementation of the plot extractor will be produced 
shortly, and further work is to be done to produce a 
VLSI implementation of the complete system. 
Conclusion 
We have shown how systolic arrays can 
be used to replace the boards of high speed logic 
normally associated with a high performance radar and 
can be used to implement all of the normal processing 
functions associated with such a system. In particular, 
we have presented multi-function systolic arrays that 
have the flexibility associated with a general purpose 
digital processor, but the speed associated with fixed 
function logic arrays. 
It is concluded that systolic arrays offer 
the radar engineer a means of making dramatic savings 
in power consumption and space requirements, while 
maintaining the speed associated with conventional high 
speed logic techniques and the flexibility associated with 
general purpose digital processors. 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix F . 5 
'The Application of Systolic Arrays to Radar Signal Processing" 
range daiays 
Input Data 
=4 L J 
Threshold 
Constants n 1 • L J L J 
• • M & G M & G M & G 
L _ L _ • 
1 £ 3 4 
2L2 4S 
t 
V 
Fig. 6 : Complete Systolic Plot Extractor 
For Further Reference: 
The Application of Digital Techniques to an 
Automatic Radar Track Extraction System. Appendix F . 6 
