Novel scanning techniques for CCD image capture and display by Emberson, M.D. (Matthew David)
 
 
NOVEL SCANNING TECHNIQUES FOR CCD IMAGE 
CAPTURE AND DISPLAY 
 
 
 
M.D. (Matthew David) Emberson 
 
 
A Thesis Submitted for the Degree of PhD 
at the 
University of St Andrews 
 
 
  
1995 
Full metadata for this item is available in                                                                           
St Andrews Research Repository 
at: 
http://research-repository.st-andrews.ac.uk/ 
 
 
 
Please use this identifier to cite or link to this item: 
http://hdl.handle.net/10023/15039             
     
           
 
This item is protected by original copyright 
 
N ovel Scanning Techniques 
for C C D  Im age C apture  
and D isplay
A thesis presented by 
M. D. Ember son B.Sc. Hons S t  Andrews 
to the University of St. Andrews 
in application for the degree of 
Doctor of Philosophy.
August 24, 1994
ProQuest Number: 10166558
all rights reserved
INFORMaTION TO aLL USERS 
The quality of this reproduction is dependent upon the quality of the copy submitted.
In the unlikely event that the author did not send a com p le te  manuscript 
and there are missing pages, these will be noted. also, if material had to be removed,
a note will indicate the deletion.
uest
ProQuest 10166558
Published by ProQuest LLO (2017). Copyright of the Dissertation is held by the author.
all rights reserved.
This work is protected against unauthorized copying under Title 17, United States C ode
Microform Edition © ProQuest LLO.
ProQuest LLO.
789 East Eisenhower Parkway 
P.Q. Box 1346 
ann arbor, Ml 48106- 1346

To Eleanor , . .
“Searching for tha t ultimate adrenaline rush, we prepare 
to hurl ourselves over the brink! W hat fate awaits us?”
-  B ill W a t t e r so n  1991.
My thanks to Dr. R.C.G. Killean, Dr. U. Arndt 
and Prof. A. Mathieson.
Copyright © M.D. Emberson 1994-
Set in MIgjX using 12pt. Computer Modem.
Graphics in Adobe Illustrator® and Adobe Photoshop®. 
Plots in Unigraph 2000.
Schematics in Viewlogic Workview.
Printed at 600dpi.
I Matthew David Emberson hereby certify tha t this thesis has been composed by 
myself, tha t it is a record of my own work, and that is has not been accepted in partial 
or complete fulfilment of any other degree or professional qualification.
Signed  ...................    Date .?.^.^../4fy.....
I was admitted to the Faculty of Science of the University of St. Andrews under 
Ordinance General No 12 on 1st October 1988 and as a candidate for the degree of 
Ph.D. on 1st October 1989.
Signed  ...................     Date
I hereby certify tha t the candidate has fulfilled the conditions of the Resolution and 
Regulations appropriate to the degree of Ph.D.
Signed  .................................................. D a te .........................
In submitting this thesis to the University of St. Andrews I understand th a t I am 
giving permission for it to be made available for use in accordance with the regulations 
of the University Library for the time being in force, subject to any copyright vested 
in the work not being affected thereby. I also understand tha t the title and abstract 
will be published, and tha t a copy of the work may be made and supplied to any bona 
fide library or research worker.
Ill
A bstract
This work details two investigations into image capture, taken from the fields of X- 
ray and laser research, and also details two scanning systems: a wire surface generator 
and a video security device.
Firstly a camera system is described tha t can display images, digitize them and 
provide real time false shading. This camera is shown to have a linear intensity response 
and to have a maximum saturation level below the digitizing range. Some example 
outputs are then illustrated.
The ability to irradiate c c D s  with direct x-ray radiation is also investigated. A 
camera is developed tha t vertically integrates such images and is shown to give an 
increase in the processing speed of existing equipment and to reduce experiment times 
by a factor of 388.
Taking this idea further, a fast one dimensional camera is developed. This camera 
couples laser pulses onto a CCD via a fibre optic faceplate and a 25/zm slit. Unusual 
scanning techniques are used to achieve image storage within the sensor itself and a 
method for correcting dark current and other errors is proposed.
Next a mechanism for displaying wire surface representations of {x^y,intensity) 
images is investigated. Results obtained from real time, hidden line removing hardware 
are illustrated, along with improved algorithms for shaded surface generation.
This is then developed into a security device protecting VDUs from radio based 
surveillance. This is achieved by randomizing the display order of raster lines along 
with a hardware solution for random sequence generation.
Finally the generation of Uniformly distributed random numbers is achieved by 
processing readings from a digitized. Normally distributed voltage source. The effects 
of this processing are investigated and an analysis of the underlying theory is used to 
determine an optimal setting for the gain stage.
IV
C ontents
1 Introduction  and D evelopm ent Hardware 1
1.1 In tro d u ctio n ........................................................................................................ 1
1.2 Development H ardw are ....................................................................................  4
1.2.1 The design of a general purpose development s y s t e m ..................  4
1.2.2 Adapting the SCN2674 to high resolution applications ................  5
1.2.3 Frame grabber and display b o a r d ....................................................  8
1.2.4 Memory and pixel m app ings................................................................ 9
1.2.5 Logic control of the memory circuits ...............................................  10
1.2.6 Video driving s t a g e s ............................................................................  11
1.2.7 Power supplies ....................................................................................  12
1.3 A Digital Output Video C am era .................................................................... 15
1.3.1 The requirements of the camera sy stem ..........................................  15
1.3.2 Digital driving circuitry .....................................................................  15
1.3.3 Analog driving c i r c u i t r y .....................................................................  15
1.3.4 Initial amplification h a rd w a re ...........................................................  16
1.3.5 A higher frequency amplifier s tag e .....................................................  17
1.3.6 Discrete sample & h o ld ........................................................................  18
1.3.7 Constant voltage s o u r c e .....................................................................  18
1.3.8 Buffered high frequency amplifier stage  .................................. 19
1.3.9 DC removal by balancing with a negative s u p p ly ...........................  20
1.4 Analysis and Use of the C am era ..................................    23
1.4.1 The use of the shade mapping h a r d w a r e ........................................  23
1.4.2 Calculation of offset and noise for the c a m e r a ..............................  25
1.4.3 Driver and analysis so ftw are ............................................................... 26
2 V ertical Integration o f X-Ray P hotons U sing a Charge C oupled A rea  
Sensor 27
2.1 In tro d u ctio n ......................................................................................................   . 27
2.1.1 Generic crystallographic structural analysis.....................................  27
2.1.2 The analysis of a single Bragg reflection ........................................  28
2.2 x-ray Detection Using Charge Coupled Devices .......................................  31
2.2.1 A phosphor based, continuous, x-ray photon d e te c to r .................. 31
2.2.2 The suitability of CCDs to x-ray applications..................................  34
2.3 Vertical Integration H a rd w a re ........................................................................ 39
2.3.1 Basic design p rin c ip a ls .........................................................................  39
2.3.2 Summing via programmable lo g ic ...................................................... 40
2.3.3 Generating read and write line tim ing ...............................................  42
2.3.4 The choice of memory device ............................................................ 44
2.3.5 The final c irc u it ...................................................................................... 45
2.3.6 Accessing the R A M ...............................................................................  46
2.3.7 Achieving high speed data t r a n s f e r ..................................................  46
2.4 R esu lts .................................................................................................................. 48
2.4.1 The read and write signal t i m i n g .....................................................  48
2.4.2 Vertical summing in software ............................................................ 49
2.4.3 Hardware r e s u l t s ..................................................................................  49
2.4.4 Future work and radiation te s t in g .....................................................  50
A  Solid S tate  Streak Cam era 52
3.1 In tro d u ctio n ........................................................................................................ 52
3.1.1 The generation & use of short duration laser p u ls e s ....................  52
3.1.2 Existing measuring techn iques............................................................ 53
3.1.3 A proposed solid state c a m e ra ............................................................ 54
3.2 Laser Coupling To The C a m e ra ..................................................................... 56
3.2.1 Imaging a slit onto the CCD su rfa ce ..................................................  56
3.2.2 Mounting a slit in front of the C C D ..................................................  57
3.2.3 Coupling via optical f ib r e s ..................................................................  58
3.3 Digital Controller Electronics ........................................................................  59
3.3.1 General purpose ‘windowing’ h a rd w a re ...........................................  59
3.3.2 Microprocessor generated controller s ig n a ls .....................................  62
3.3.3 CCD drivers and reset pulse g e n e ra tio n ...........................................  62
3.3.4 Trigger input pulse conditioning........................................................  63
3.3.5 IR laser analysis ...................................................................................... 65
3.4 The Digitizing Camera H e a d ........................................................................... 65
3.4.1 The CCD bias voltage su p p ly ...............................................................  65
3.4.2 Analog signal conditioning ..................................................................  66
3.4.3 The digitizer and data storage c ircu itry ...........................................  69
3.4.4 Finding the noise levels on this detector ........................................  70
3.4.5 Bandwidth co n sid e ra tio n s ..................................................................  71
3.4.6 Correcting for gain d is to r t io n ............................................................ 71
3.4.7 Initial c a lib ra tio n ................................................................................... 73
3.5 Dark C u r r e n t ....................................................................................................  75
3.5.1 Theory of dark current build u p ......................................................... 75
3.5.2 Dark current build up during a sequence of fram es........................  76
3.5.3 The repeatability of dark current r e a d in g s .....................................  77
3.5.4 Subtracting ‘dark’ frames from a frame sequence...........................  80
3.5.5 Finding pixel widths from dark current readings  ........................  81
3.6 R esu lts .................................................................................................................. 82
3.6.1 Fully corrected frames from a pulsed l a s e r .....................................  82
3.6.2 Displaying image sequences as su rfa c e s ............................................  84
3.6.3 The power vs. time re la tionsh ip .........................................................  85
VI
A  h a rd w are  S o lu tio n  to  Surface  G e n e ra tio n  88
4.1 In tro d u c tio n .......................................................................................................  88
4.1.1 O bjectives ...........................................................................................   . 88
4.1.2 Full wire frame g e n e ra tio n .................................................................  89
4.1.3 Ray-tracing and s h a d in g ....................................................................  92
4.1.4 Hidden line and hidden area re m o v a l.............................................  93
4.2 Fast Software Solu tions.................................................................................... 95
4.2.1 Simplification of viewing a n g le ..........................................................  95
4.2.2 Shading a lg o rith m s..............................................................................  98
4.2.3 Hidden line rem oval..................................................................................101
4.3 Basic Hardware Solutions ................................................................................. 103
4.3.1 Adaptation of algorithms to hardw are................................................. 103
4.3.2 M ultiplexors...............................................................................................106
4.3.3 O utput f i l te r s ............................................................................................106
4.3.4 The firmware in te r fa c e ........................................................................... 107
4.3.5 Hidden line calculations in so ftw are .....................................................108
4.3.6 Results from a Z80 im plem enta tion .....................................................108
4.4 Hidden Line H a rd w a re .........................................................................................109
4.4.1 Adaptation of hidden line a lg o rith m s ................................................. 109
4.4.2 R esu lts .........................................................................................................115
4.4.3 A DMA so lu tio n ........................................................................................ 115
4.4.4 Investigated m od ifica tions.....................................................................117
4.4.5 Future w o rk ...............................................................................................118
D isp lay ing  Im ages B y  R an d o m  Sequence O rd e r S cann ing  119
5.1 In tro d u ctio n ........................................................................................................... 119
5.2 An Electrostatic Implementation ...........................................; .......................122
5.2.1 Simplifications to the invention specifica tion .................................... 122
5.2.2 The generation of ^-axis w aveform s.....................................................123
5.2.3 The generation of trigger and cr-axis w a v e fo rm s ..............................125
5.2.4 Improvements to the original specifications........................................128
5.2.5 R esu lts .........................................................................................................129
5.3 Investigation of Electromagnetic D eflection.................................................... 131
5.3.1 Existing electromagnetic d is p la y s ........................................................131
5.3.2 Trials with an existing m o n i to r ........................................................... 133
5.3.3 Software correcting the display ........................................................... 134
5.3.4 Fourier analysis of y-axis waveforms.....................................................138
5.3.5 Hardware im plem entations.....................................................................143
5.3.6 Colour s y s te m s .........................................................................................148
5.4 Generating Random Sequences ........................................................................149
5.4.1 Random and pseudo-random sequence g e n e ra to r s ...........................149
5.4.2 Software solutions......................................................................................150
5.4.3 A proposed hardware so lu tio n ...............................................................152
VII
6 G enerating U niform ly D istributed  D ig ita l N um bers 154
6.1 In tro d u ctio n ............................................................................................................154
6.1.1 O bjectives .................................................................................................... 154
6.1.2 Box-Müller and Normal distribution theory .  ................................155
6.2 Calculation Of The Theoretical P aram eters.................................................... 156
6.2.1 Cut-off effects and s c a l in g .......................................................................156
6.2.2 S im u la tio n s .................................................................................................158
6.2.3 Evaluation of u n ifo rm ity .......................................................................... 159
6.2.4 Calculating a distribution analytically ................................................ 159
6.2.5 Finding the cumulative density function, # ..........................................160
6.2.6 Analysing the effect of changing the cut-off p o i n t ............................ 162
6.2.7 Finding Cq from maximum d ev ia tio n s ................................................... 163
6.3 Hardware Im plem entations..................................................................................166
6.3.1 Noise generation ....................................................................................... 166
6.3.2 8 Bit h a r d w a r e .......................................................................................... 168
6.3.3 Setting the c amplification p a ra m e te r................................................... 169
6.3.4 Generating a mapping R O M ................................................................... 172
6.3.5 Results from the 8 bit h a rd w are ............................................................. 173
6.3.6 9 Bit h a r d w a r e .......................................................................................... 174
6.4 Finding An Exact Value For Cq ........................................................................175
6.4.1 A more detailed examination of the d is tr ib u tio n ................................175
6.4.2 Analysis of the distribution using integers ......................................... 178
6.4.3 Deducing Cq from the minimum com bination ...................................... 180
6.4.4 Further analysis of the d is tr ib u tio n ...................................................... 181
6.4.5 One final im provem ent............................................................................. 181
7 C onclusions 183
7.1 Possible Future W o rk ........................................................................................... 183
7.2 C onclu sio n s ............................................................................................................185
A  Charge C oupled D evices 186
A .l In tro d u c tio n ............................................................................................................186
A.2 CCD S tru c tu re ........................................................................................................ 187
A.3 Driving CCD I n p u ts .............................................................................................. 189
A.4 Output Processing M e th o d s .............................................................................. 190
Vlll
List o f F igures
1.1 Block diagram of the graphics and display system.......................................  6
1.2 Circuit diagram of the timing and video controller......................................  7
1.3 The timing of the video driver stages..............................................................  8
1.4 The mapping from pixel address to physical location..................................  9
1.5 Logic control of the stored and live images....................................................  11
1.6 Circuit of the video driver stage.......................................................................  13
1.7 Power supply design for the development hardware..................................... 14
1.8 A higher frequency amplification stage...........................................................  17
1.9 A discrete sample and hold circuit...................................................................  18
1.10 The digitizing part of the camera circuit........................................................  19
1.11 Removing the DC offset from the ccD o u tp u t s ........................................... 20
1.12 Buffer and amplifier stages for the CCD camera............................................  22
1.13 A simple frame grabbed image from the camera illustrating both satu­
rated black and saturated white regions.........................................................  24
1.14 Enhancing the edges using the colour m a p ...................................................  24
1.15 Using the colour map to show the full extent of the image........................  25
2.1 Apparatus used for single Bragg reflection analysis.....................................  29
2.2 Point spread function in a phosphor................................................................ 30
2.3 The integration from an area to a line............................................................  31
2.4 The components of the reciprocal space spot profile.................................... 32
2.5 A real time continuous photon detector.......................................................... 33
2.6 Containment of emitted optical photons......................................................... 34
2.7 Quantum Efficiency of CCDs.............................................................................. 36
2.8 Block diagram of the vertical summer hardware........................................... 40
2.9 Timing of the read and write pulses................................................................  42
2.10 Circuit element showing the read, write and control timing......................  43
2.11 Internal layout of p a l  2 logic chip...................................................................  45
2.12 Measured output of the read and write enable circuit................................. 48
2.13 Hardware summer acting on the test image................................................... 49
2.14 Summing a frame grabbed real life image......................................................  50
2.15 Summing a live image.........................................................................................  51
3.1 Imaging a slit onto the CCD surface................................................................. 56
3.2 The diffraction generated by mounting a slit onto the ccD .......................  57
3.3 The final version of the laser to CCD coupling hardware............................. 59
3.4 Block diagram of the one dimensional camera............................................... 60
3.5 Reset timing for the c c D  camera head............................................................ 63
IX
3.6 Oscilloscope trace of the laser pulse trigger output......................................  64
3.7 Circuit diagram of the input pulse shaper......................................................  64
3.8 The power supply for the camera electronics.................................................  67
3.9 Experimental dual slope integrator..................................................................  68
3.10 Block diagram of the camera head circuitry................................................... 68
3.11 A triangular waveform used for distortion calibration.................................  73
3.12 The distortion correction mapping...................................................................  74
3.13 Average dark current per line vs. line number..............................................  77
3.14 The distribution of the deviations for 5 dark frames.................................... 79
3.15 A single line output from a dark frame. .   .................................................  81
3.16 A selection of lines though a laser pulse.........................................................  83
3.17 An example data set plotted as a {distance, time, intensity) graph. . . .  85
3.18 Power against time for a NdYAC laser p u l s e ..............................................  86
3.19 Power against time generated by frame integration.....................................  87
4.1 Building up a surface representation...............................................................  90
4.2 Changing the viewing position of a plane....................................................... 91
4.3 Viewing an object through a s c r e e n ..............................................................  91
4.4 The vectors representing a small surface area...............................................  92
4.5 The screen and world co o rd in a te s .................................................................  96
4.6 Part of a surface representation with constant z values..............................  97
4.7 Results of using area to define shade...............................................................  99
4.8 Surface generation using shade proportional to area.................................... 99
4.9 Area calculation by using single pixel widths.................................................... 100
4.10 Results of single pixel width area calculation.................................................... 101
4.11 Brass cutout image shaded using vertical differences.......................................102
4.12 Using light vectors to generate a full surface representation.......................... 102
4.13 Example wire frame using only the x  axis pixels..............................................103
4.14 Block diagram of the initial hardware.................................................................105
4.15 The Chebyshev f i l t e r ............................................................................................ 107
4.16 Block diagram of the full surface generator....................................................... 109
4.17 Surface rendering without hidden line removal................................................. 112
4.18 Example output without using any beam gating..............................................113
4.19 The effect of gating the beam............................................................................... 114
4.20 The equivalent logic of the 16v8 g a l .................................................................. 114
5.1 Block diagram of the vdu security patent......................................................... 120
5.2 DAC610C implementation..................................................................................... 124
5.3 The final circuit for y-axis generation.  ..................................................126
5.4 T-axis deflection circuit...........................................................................................127
5.5 Horizontal control timings......................................................................................128
5.6 The scrambled text as seen by Marconi..............................................................130
5.7 The readable version of the tex t...........................................................................130
5.8 A black and white scrambled graphics image.................................................... 131
5.9 The unscrambled black and white graphics image........................................... 132
5.10 A grey-scale scrambled image................................................................................132
5.11 Existing inputs to the vertical coil drivers......................................................... 134
5.12 Text scrambled over 16 lines................................................................................. 135
X
5.13 Example unscrambled tex t................................................................................... 136
5.14 The effects of scrambling a diagonal line...........................................................136
5.15 The general form of the y-axis waveform...........................................................138
5.16 The amplitude spectrum envelope and an example waveform......................142
5.17 A proposed schematic for a supply rail driver..................................................143
5.18 A traditional current amplifier.............................................................................144
5.19 The Howland current source................................................................................ 145
5.20 Measurement of the rise time of the amplifier..................................................146
5.21 Graph of input frequency against beam deflection..........................................147
5.22 A 50 bit fixed sequence generator....................................................................... 150
5.23 Program to produce random sequences............................................................. 151
5.24 Proposed random sequence generator................................................................ 153
6.1 Digitizing a real world voltage source..................................................  156
6.2 Graph of the pseudo-Normal distribution results............................................ 158
6.3 The Cumulative Distribution Function, $ ........................................................ 162
6.4 A selection of distributions for varying cut-off values.....................................164
6.5 Distribution for 9 bits, c =  3................................................................................165
6.6 Distribution for 16 bits, c =  3..............................................................................165
6.7 Graph of maximum deviation against c.............................................................166
6.8 Circuit diagram of the wideband noise generator............................................ 167
6.9 Block diagram of the sampling hardware. .  .................................................168
6.10 Full circuit diagram for the 8 bit mapping........................................................170
6.11 Example distribution from the converter data lines........................................171
6.12 O utput from the Normal to Uniform mapping hardware.............................. 173
6.13 Full circuit diagram of the 9 bit mapping hardware....................................... 176
6.14 Results of the 9 bit Normal to Uniform conversion.........................................177
6.15 Part of the real axis showing the distribution of the delta functions . . 177
A .l The electrode patterns on a CCD surface...........................................................189
A.2 Typical c c D  driving waveforms and output signals........................................ 191
XI
C hapter 1 
In troduction  and D evelopm ent 
H ardware
1.1 Introduction
There are many existing designs of CCD cameras ranging from those available in the 
high street shops up to those used for complex scientific laboratory equipment. Their 
applications now range from colour auto-focus household cameras up to large format 
dental x-ray systems.
One noticeable path in the development of CCD equipment has been tha t the format 
of the devices has been dictated, not so much by the application, but by the existing 
technology to which the CCDs have been applied. Hence the normal format of an 
inexpensive CCD is still a 288 by 388 pixel framing device suitable for t v  applications. 
It has only been in the last few years tha t cC D s have been made for specific applications, 
and hence most applications of such devices concentrate on generating normal area 
pictures, usually for viewing via a display system.
This research aims to look at two CCD based instruments th a t do not follow the 
normal area image gathering format. In particular, scientific use of these devices will 
be looked at and the hidden problems associated with turning photon densities into 
digital signals.
Most CCD cameras used in laboratory instruments have been developed from a 
normal format camera by adding frame grabbing facilities and digitization units. These 
systems, rather than addressing the problems at their source, have usually been ‘add 
on’ parts, a CCD camera providing an analog signal which is converted into a PAL 
(or similar) format video signal. This is then passed into the frame grabber where
it is converted back into the analog signal and then digitized to generate a computer 
accessible image.
This has meant that, though many 16 bit digitizers are available, the signal to noise 
ratios of the cameras have in fact been far poorer than would be required to make use 
of this resolution and hence unrealistic claims have sometimes been made.
Thermally induced charge build up (dark current) within a CCD is another major 
cause of error tha t is rarely considered. Many applications take accurate measurements 
of signal strength but do not correct for the dark current distortions tha t have been 
included in such measurements.
Display hardware designs have also remained very static, usually following the nor­
mal interlaced raster scanning methods used for conventional t v  and video monitor 
technologies. There has been little research into non-standard displays but, as will be 
seen, there are many possible ways of driving displays and these can illustrate signifi­
cant advantages to the experimental analysis of image data.
Some work has been done into scanning systems tha t use vector rather than pixel 
baaed imaging but these devices have tended to be used in popular arcade games and 
some military applications rather than be put to use for general research purposes. 
There are many advantages to be gained from novel scanning of display hardware, 
including surveillance protection and reducing observed flicker. Most research in this 
fleld has concentrated on software solutions to the image rendering problems and only 
the BBC seem to have done signiflcant work into the possibility of hardware modification 
or designs [1, 2].
Chapter 2 will look at a method of scanning a CCD tha t allows it to be used as 
a one dimensional sensor but tha t makes use of the area sensing pixels to increase 
the device’s saturation level for x-ray photons. This looks primarily a t novel frame 
grabbing hardware tha t utilizes a normal CCD signal in a non standard way. Particular 
attention is paid to an application of such a device to x-ray sensing, an area in which 
the CCD is finding increased popularity within the scientific community.
Chapter 3 will look at a further example of using a CCD as a one dimensional 
camera, in this case acting as a fast framing camera. This extends the ideas used in 
chapter 2 to use the actual CCD silicon as both the one dimensional sensor and the 
image store. This chapter also goes into detailed analysis of the effects of dark current
and digitization on camera images. Algorithms are developed to correct for the build 
up of dark current distortions both within the amplification stages and the digitization 
stages, and also to analyse the actual surface dimensions of the c c D .
Chapter 4 will look at a method of representing {x,y,intensity) signals, such as 
those coming from a normal cC D  camera, in the form of a 3d surface. The need 
for such displays is becoming increasingly obvious and, with the advent of framing 
cameras which look at the time progression of (x,y,intensity) images, their use will 
become more common particularly as some interesting details can be seen from surface 
representations. The development of hardware and software to generate such images, 
quickly, from a CCD camera will also be described.
Chapter 5 goes on to look at a non raster scanning technique tha t allows video 
protection by scrambling the scan order of the output lines. A development circuit 
implementing a patent specification developed in the University of St. Andrews by 
Dr. P. Hirst and Prof. A. Maitland [84] will be looked at along with enhancements 
to the original proposal and an analysis of the waveforms required to generate an 
electromagnetically scanned output.
This will be taken a stage further in chapter 6 where a theoretical approach to 
the generation of Uniform random numbers from Normally distributed voltages will 
be undertaken. In particular the effects of digitizing continuous quantities will be 
investigated and the subsequent effect this has on the use of standard, statistical, 
conversion equations. An optimum choice of resolution for such conversions will also 
be examined.
Finally appendix A provides a brief analysis of existing CCD technology and cov­
ers some of the conventional driving electronics. The problems associated with both 
CCD input driving and output processing will be considered and some of the existing 
solutions to these problems will be described.
Firstly however, an analysis of the hardware developed to test out ideas and act as 
a prototype platform for experimental circuitry will be given before moving on to the 
developmental research work.
1.2 D evelopm ent Hardware
1.2 .1  T h e d esign  o f  a gen eral purpose d evelop m en t sy stem
Before looking at the specific investigations carried out in this field it is necessary to 
look at the development hardware. Most of the original circuitry was developed around 
existing technology but a few points of interest emerged and these proved to be worth 
investigating in their own right.
In order to carry out any analysis of scanning techniques it was felt th a t a full 
and versatile development environment was needed. This was required to provide very 
flexible timing and pixel generation for both the driving of the CCD inputs and control 
of the display systems. This in turn requires a system that could provide variable 
frequency outputs for the CCD driving signals and any number of row or column clocks 
to drive both CCD and display inputs. The resulting hardware was based on the 
SCN2674 AVDC [3] (Advanced Video Display Controller). This component was designed 
to run PAL and NTSC displays but is very flexible and provides suitable outputs to drive 
camera and display controllers. Unfortunately it does not have a high enough clock 
frequency to provide full frame CCD control so a modified circuit had to be developed 
th a t enabled a faster clock to be sent to the c c D  drivers.
In order to analyse the signals being input to the development hardware it was felt 
th a t an ‘off the shelf’ graphics and camera system would not be suitable. Manufacturers 
do not like to supply circuit diagrams and most of the internal functions of cameras 
and display systems are packaged within A S ic  designs and hence are not adaptable to 
this type of development and in most cases the required signals are not even available.
Because of these limitations a simple graphics system was developed based on a 
graphics board previously designed in conjunction with Mr. I. Sheldon in 1988. The 
driving signals for this system w ere  provided by a PC interface board tha t was developed 
by Dr. D.S.S. Robb for this purpose.
This board provided a Zilog Z80 microcomputer with an interface to a PC and a 
method of passing bytes between the processor and the PC. The Z80 provided direct 
access to the development hardware allowing the PC processor to carry out functions 
such as clock interfacing, without interrupting essential monitoring of signals such as 
the frame grabbing functions which will be described later.
This development system contained a block of memory th a t was driven by the 
SCN2674 and provided video images as a sequence of digital pixel intensities, each of 
which was an 8 bit parallel signal. The memory could either be filled from the PC, 
under control of a Pascal program, or from another digital source such as an 8 bit 
digitized CCD camera output. It could also be read by the PC at any time.
The 8 bit video output from this system was fed into the address inputs of another 
memory th a t allowed any mapping from the input 8 bit value to any 8 bit data  output. 
The data inputs to this memory could be either from the RAM or from another 8 bit 
data  source such as the digital camera signal to be described later.
The output of this mapping was then fed into a digital to analog converter and then 
on to a normal video monitor or, via a PAL converter, to a colour TV.
This flexibility results in the hardware being multi-purpose and allows it to act as a 
simple graphics board for the PC, a s  a frame grabber for a CCD camera or as a real time 
shade mapping for a live video signal. The main difference between this system and 
available frame grabbers is that the camera signal is never available as an analog video 
output but is digitized, in synchronization with the memory board, at its source. This 
allows the shade mapping of the camera signals to be achieved via the mapping RAM 
and also allows the digitizer to function precisely in synchronization with the display 
and timing control.
A camera system was also built that was driven by this hardware and provided a 
second source of the digital video signals. This was intended for use with the x-ray 
sensors described later but operated using standard format c c D s ,  in particular the 
EEV CCD02 series of sensors [4].
A full block diagram of this system is shown in figure 1.1. Most of this electronics 
follows simple design principles and details of the whole circuitry will not be gone 
into here. However, an overview of the different sections of this design is necessary to 
explain the origin of the driving and analysis signals described in later chapters. The 
following provides details and full circuit diagrams for each section of the development 
hardware.
1.2 .2  A d ap tin g  th e  SC N 2674  to  h igh reso lu tion  ap p lication s
Figure 1.2 shows the circuit diagram of the timing and controller circuits. A three
CCD
Row, 
store 
i & Image I Shift
10 10 Analog
Out
A ÿ
Video ' ' 
Drivers '
Address
Clocks
Control
Signal
Generator
Figure 1.1: Block diagram of the graphics and display system.
phase clock is generated by a divide by three circuit and is then fed into a divide by 
four circuit. The outputs of this are fed direct to the lowest 2 bits of the addressing 
stages for the memory hardware (signals Aq and Ai). For every 4 clocks into this stage 
a single clock is sent to the a v d c . This allows the a v d c  to be driven from a clock 
frequency of around 2MHz (the maximum it can be driven at) provided a source crystal 
of 25MHz is used. The outputs o f the a v d c  then drive the address lines from A 2 to 
Aiq and also the synchronization signals such as horizontal and vertical blanks.
As the effect of this is to output 4 pixels for every clock seen by the AVDC, all the 
settings within the a v d c  will then b e  in multiples of 4 pixels rather than the single 
pixels it was designed for.
This circuit also provides stages to delay signals such as the horizontal blank and 
synchronization signals, so that they are correctly timed to drive the display hardware 
after the mapping and latching stages have delayed the digital video signal.
It should also be noted that the exact synchronization of these signals is achieved 
by latching them all simultaneously on a half clock from the original divider stages.
6
1- " !' H Iu ^ ; f' JK —' ■'!—vw-
A
-■j—i ,  I
T j LA:
l A .
7T
A :
I A<
K
:
i
k ft
Û
□
uniiiniiii”
-At'
A
; j B K Pyy-
A i'
11
Figure 1.2; Circuit diagram of the timing and video controller.
Clock 
Byte Clock 
HBlank 
R03 
R02 
ROl 
Reset 
Convert
20ns
n. n n n_ n.
_F
J7r "1
i _  __r
Figure 1.3: The timing of the video driver stages.
T T
Figure 1.3 shows the timing of the output signals and illustrates how the output 
timings relate to each other. The slopes on the ccD drive signals are also shown.
An enable line from the PC was provided in order to access the a v d c  and program 
in the required parameters for the number of characters per row, number of lines per 
screen, and constants such as equalization, blank period, synchronization times and 
front and back porches.
1.2 .3  Fram e grabber and d isp lay board
All the RAM addresses are multiplexed with the PC controller signals and are then fed 
to the four 32k r a m  chips. The enable line from the PC is used to feed the multiplexers, 
ensuring tha t the PC has priority over the video signal. The output stages are latched 
so that, when the PC accesses the r a m , the video output stays constant at its last value 
rather than reverting to a random value or to zero. This is not the normal method of 
prioritizing a display output, as the user of a graphics systems does not want to have 
the image interrupted. However the purpose of this hardware is to provide an analysis 
tool and this was felt to be a suitable compromise.
The data outputs from this memory are then fed into the address input of the 
mapping RAM chip. Another enable line allows some of the PC controller address lines 
to access the address bits of this RAM and hence, along with the multiplexed data  lines, 
allows the PC to put the mapping data into the RAM. A two stage setup was used tha t
Physical Pixel Locations
Memory Addresses
385 386 387
32 76 93 2 768 3 3 1 5 4 33 15 5
6 5 536 65537 6 5 922 65923
9 8 304 98 6 9 1
775
Figure 1.4: The mapping from pixel address to physical location.
allowed a different mapping to be enabled when either the memory, or the live video 
signal are being fed through this mapping. This is a hardwired line supplying the upper 
address bit of the memory. These signals were also multiplexed with the PC addresses.
1 .2 .4  M em ory  and p ixel m appings
The memory addresses were arranged in such a way as to minimize possible interference 
from the decoders. The order of the address outputs from the a v d c  is sequential, taking 
no account of the number of rows in the image, since the AVDC outputs addresses for 
characters not for pixels. Because of this it also provides 4 row selection signals to 
select which row of the character is being accessed. Two of these row lines are used to 
select which RAM chip is being accessed. These are fed into the highest address bits and 
hence into the chip selection circuitry. In this way the memory chips are interleaved, 
one for the first row, the next for row 2 and so on.
Internally the a v d c  registers were then set to output 4 rows per character, 97 
characters per row (one quarter of the number of pixels) and 72 rows.
Figure 1.4 shows how the addressing corresponds to the pixels seen on the display 
output.
Chapter 4 makes use of this feature to access only one quarter of the image by using
only one memory chip as a source of data and hence accessing only every fourth line 
of the image.
Initially the hardware was set up to use 388 pixels per row and 288 rows. This 
corresponds to a normal CCD camera system. Alterations to this were made when 
needed by the investigations covered in later chapters. The initial settings were for a 
non-interlaced display system. This reduced the resolution of the display but enabled 
the camera to be driven in such a way tha t the images were displayed with a one to 
one correspondence between camera pixels and memory locations. This is not normally 
the case with video digitizers tha t take composite signals. This system provides easy 
analysis of image coordinates and also reduces the flicker of the image.
Inserted figure I (see back cover) shows the circuit of the memory and colour map­
ping stages.
1.2 .5  Logic control o f  th e  m em ory circu its
Another circuit added to the controller was one which produced a logical mapping 
controlled by lines from the PC and the development hardware. Four inputs were 
taken from the PC card, combined with the ODD frame output from the AVDC and then 
decoded to provide read, write and enable signals for the CCD data. The o d d  frame 
signal is usually used for interlace purposes but in this case it serves as a line tha t 
changes state with alternating frames.
The three outputs of this circuit allowed a number of functions to be performed 
including writing of the CCD image into the frame storage memory (frame grabbing), 
output of just the CCD live signal, output of the stored frame and a mode tha t alternates 
between the frame image and the live image.
This latter allowed a picture to be overlaid with the live image. This meant that 
pixels could be set in the frame memory and overlaid very precisely onto the live image 
and hence allow very accurate measurement of features within this image.
The circuit of this section is shown in figure 1.5.
The frame grabbing function is achieved by the Z80 processor accessing the a v d c  
registers and waiting for a vertical blank. When this is detected these control lines are 
set to pass data from the camera into the frame storage. The AVDC is then monitored 
until the frame has completed and the vertical blank is active again. The lines are then
10
- <  P A G E  C O N T R O L ,
Figure 1.5: Logic control of the stored and live images.
Device Speed Resolution Price
SP9770
SP9768
PNA7518P
5ns
12ns
33ns
10 Bits 
8 Bits 
8 Bits
i?80-00
/54-GO
/10-46
Table 1.1: Video rate digital to analog converters.
reset to complete the storage operation.
1.2 .6  V id eo  driv ing stages
In order to view the results a simple video output stage was added tha t provided 
conversion from the digital video signal to a normal composite synchronization signal 
for a standard monitor.
The output of the final latches of the memory circuit is fed into a high speed 
(30MHz) d /a  converter. Table 1.1 shows the devices considered for this conversion 
stage. The PNA 7518 [5] was chosen as it is very stable and flexible as to the output 
voltages it can operate over. In particular it takes two input voltage levels corre­
sponding to the upper and lower limits of the conversion range and these were set to 
correspond to the saturation levels for black and white. The output is then combined 
with the synchronization signal from the AVDC via a summing video op-amp which in
11
this case is an LM733 [6]. Again, this part was chosen from a selection of available 
products including the MPOP02, NE5534, NE5517, LM318, NE592 and the NE5205.
Finally the composite signal is sent through a 500 resistor required for impedance 
matching to the monitor. A resistor was added between the synchronization signal and 
ground in order to provide synchronization level adjusting. This allowed the signal 
contrast to be extended to match the type of monitor used.
Because of the sensitivity of the supply inputs to the d /a  converter, a low noise, 
dual amplifier package was required. It was decided to use a RC5532A amplifier for this 
stage and the constant voltage feed was provided by an MP5010HN 1-22V bandgap 
device tha t provides a very stable output over a wide temperature range.
Figure 1.6 shows the full circuit of this stage.
Development with Mr. Sheldon added a p a l  encoder and UHF unit to this in order 
to provide 2 or 3 bits per colour plane. This allowed false colours rather than false 
shades to be generated in the mapping r a m .
1 .2 .7  Pow er supplies
All the power supplies built both for this development hardware and the circuits de­
veloped in later chapters are based on a simple linear power supply design. The supply 
for this development electronics is shown in figure 1.7.
The analog and digital grounds were kept separate and only connected at the CCD 
development boards in order to ensure that a good star earth point existed.
The CCD bias levels are very critical and the operation is very dependent on the 
relative voltage levels. Because of this the driver voltages are set via an LM317L (low 
power) adjustable voltage regulator. The larger current requirements of the driver 
stages are provided from a higher power version of the same device (LM317T) and the 
normal 5V and -5V levels are generated from high power fixed voltage units tha t could 
easily supply the large digital section of the development hardware.
In order to minimize mains hum pick up from the power supplies, these voltages 
were generated remotely from the camera head and passed through to the sensitive 
electronics via shielded multi-core cables.
12
AW
a  A a
Û QÛ > >
Figure 1,6: Circuit of the video driver stage. 
13
H F-
I
t -
Figure 1.7: Power supply design for the development hardware,
14
1.3 A  D ig ita l O utput V ideo Cam era
1.3 .1  T h e requ irem en ts o f  th e  cam era sy stem
In order to  assess the image collection techniques described later a simple camera 
system was developed. This had to be able to interface to the synchronous digital 
signals and also provide digital output tha t the display circuitry could access.
The camera was mounted remotely to the display and its associated power supply 
circuits and hence needed to be driven from the minimum of signals. Because of the 
need to pass digital data  back to the display hardware it was decided tha t ribbon cable 
would be used but every alternate strand was grounded thus forming a simple screen 
in a similar manner to the twisted pair screening method.
1.3 .2  D ig ita l d riv in g circu itry
As described in the previous section, the a v d c  enabled a completely variable set of 
timings to be used for the display hardware. The circuitry controlling the timing 
allowed any individual pixel to be accompanied by a full three phase clock to the CCD 
row shift inputs. The camera driving was achieved by a set of digital logic gates tha t 
took only the vertical blank, horizontal blank and the CCD phase clock (the 25MHz 
signal). These were combined into the horizontal clocldng signals and also into the 
vertical shifts required to clock the CCD image down into the row readout register.
The vertical blank, in particular, is used to trigger the image shifting from the exposed 
area into the image s to ra g e  section of the CCD.
Inserted figure II shows the circuit diagram of the digital stages. It is based around 
three 74LS194 shift registers, one for each output line, and two 74HC4040 counters [7] 
for the frame shifting section. The use of a n d  g a te s  on the inputs improved the signal 
rise and fall times after they had been transmitted down the connecting cables.
1.3 .3  A nalog  d riv in g circu itry
The conversion from digital (5V) to CCD driving signal is done using the DS0026 clock 
driver chips [8]. This choice will be detailed further in chapter 3. There are a number of 
possible driver chips, including the Sony BX1432A which is a video processing module, 
the ICL7667 from Intersil and the EEV ESB3650 series. The EEV components were of
I
Device Speed Resolution Price
MP7683XKN
MP7684KN
CA3318C
ADC300
ADC301
ADC304
ADC208
5MHz
lOMHz
20MHz
20MHz
3MHz
20MHz
15MHz
8 Bits 
8 Bits 
8 Bits 
8 Bits 
8 Bits 
8 Bits 
8 Bits
£45-00
£57-28
£72-00
£33-26
NA
£10-00
NA
Table 1.2: Video rate analog to digital converters.
particular interest as they form an entire camera controller which includes timing pulse 
shaping [9] and video processing [10]. Unfortunately too few of the required outputs 
are available to outside electronics and hence they could not be used for this project.
A stabilized power supply to the DS0026 drivers enabled good edges to be imposed 
on the output waveforms with the slopes for rising and falling edges being created by 
RC networks tha t act as filters to round off the edges and produce the required critical 
slopes.
The input capacitors allow for an increase in the rise times for the faster clocks and 
the use of smaller output resistors improves the filters for the higher frequency pulse 
shaping.
1 .3 .4  In itia l am plification  hardware
For this design a high frequency amplification and digitization stage was required. The 
output of the CCD had to be sampled and then held for input into an analog to digital 
conversion stage.
It was decided to use an e c l  sample and hold unit and then feed the output from this 
into a digitizer. Three possible components were considered the SHM360 or SHM361 
from Datel and the HUMC (25ns) or UH3 (30ns) parts both available from a number 
of alternative sources. The component chosen was the SHM361 from Datel [11] and 
the clocks were driven through an MC10124 t t l  to ECL converter [12] and then back 
to TTL via an MC10125. This unit had a clock output and this was converted back 
to TTL levels and input to an ADC304 c o n v e r te r  [13]. Table 1.2 shows the selection of 
alternative converters available at the time.
16
Figure 1.8: A higher frequency amplification stage.
The differential amplification stage was provided by an LM733 amplifier, a common 
component for use with video amplification stages. The circuit diagram for this version 
of the digitizer is shown in inserted figure III.
1.3 .5  A  h igher frequ ency am plifier stage
Analysis of the output of this circuit showed that the capacitive effects reduced the 
bandwidth of the output signals and hence led to poor quality output from the camera. 
In order to improve this a higher frequency stage was built using an AD5532 video 
amplifier [14]. This is a very high bandwidth (4GHz for small signals) device tha t 
allowed the fine detail of the c o d  output to be analysed. This was further improved 
by incorporating it into a dedicated PC S. This improved the noise characteristics of 
the circuit and its schematic is shown in figure 1.8.
17
Figure 1.9: A discrete sample and hold circuit.
1.3 .6  D iscrete  sam ple hold
Problems with the sensitivity of the e c l  devices led to the design of a discrete sample 
and hold circuit.
This circuit was based around an existing system designed by Mr. J. Wade at The 
University. The effect of this was not satisfactory however, as the noise added to the 
signal degraded the results more than the sampler improved the circuit and in addition 
the input impedance caused leakage of the signal. The appropriate element of this 
circuit is shown for reference in figure 1.9.
One important point that was observed here was tha t the CCD output signal was 
stable for longer than the conversion time of the digitizer. This meant that, provided 
a very stable output signal could be obtained, then the converter could be connected 
directly to the amplifier outputs and produce good results.
In order to achieve this two improvements were needed. Firstly a voltage reference 
was needed for the a / d  converter as the now redundant SHM361 had provided this 
stable voltage source. Secondly the use of a multiple buffer stage was required to 
improve the signal amplification and allow direct connection of the converter.
1 .3 .7  C onstan t vo ltage  source
A simple voltage reference, similar to that used to drive the video output, was suitable 
for the ADC304. To reduce noise, an OP27 low noise instrumentation amplifier was 
used and the MP5010 122V bandgap source provided the stable input. The gain was
18
■WNA-
Figure 1.10; The digitizing part of the camera circuit.
adjustable via a potentiometer and provided fine adjustment of the conversion levels. 
The entire circuit was then designed onto a p c b  to minimize noise.
Figure 1.10 shows the final circuit of the conversion stages. As can be seen from 
this diagram a latch was added to provide stable output signals and to provide drive 
for the cable lengths back to the display hardware (about 0*5m).
1.3 .8  B uffered  h igh  frequency am plifier stage
A number of buffer stages were considered. The buffers had to be suitable for the 
high frequencies involved (50MHz or so) without causing noticeable distortion. They
19
Bandwidth Input Supply Manufacturer
Device Full Power Unity Gain Impedance
Unity Gain Products
EL2001 70MHz - 8 u n ±5V Elantec
EL2002 180MHz — 2 u n ±18V Eiantec
HOS 50 [15] lOOMHz - NA ±10V National
Amplifiers
OPA633 260MHz 40MHz NA ±12V Burr Brown
OPA620 lOOMHz NA NA ±5V Burr Brown
Table 1.3: High Frequency buffers and amplifiers.
L7V rxT ♦ V«i\j
   —^  T o  B U f C 'â r  AmK>
IN» B u ffijr  Ainp
V
t inil. K
Figure 1.11: Removing th e  DC offset from the CCD outputs
also had to be able to take the signal levels of about 200mV. Table 1.3 shows the 
components considered.
The final choice was to use the EL2001 unity gain device as this easily met the 
required bandwidth and has good input impedance. The OPA620 amplifier [16] was 
then chosen to provide the gain stages.
1.3 .9  DC rem oval by balancing w ith  a n eg a tiv e  su pp ly
The problem of removing the DC offset from the c c D  outputs was solved by using 
a negative supply of -15V and feeding the CCD output signals through two matched 
resistors in series, to this negative voltage level. This is shown in figure 1.11
The output DC signal is now reduced via the voltage divider, to a signal th a t can
2 0
be fed into the sensitive inputs of the buffers. This technique does not appear to be 
used in camera design, presumably because the presence of negative supplies requires 
considerable circuitry overheads.
The major advantage achieved by this is tha t there is no signal dependent distortion 
tha t is normally present when capacitive DC blocking is used. There is however a fixed 
distortion in the signal but this is a systematic, rather than random, error and is 
corrected for by the amplifier stages before passing into the digitizer.
The disadvantage o f  this system is tha t the required AC signal is halved by the 
voltage divider and hence the signal to noise ratio is halved. Provided very stable and 
smooth negative supplies are used, and they are very well decoupled at the source, 
then this is not a significant problem.
A DC offset was also added to the circuit to correct for imbalances in the amplifiers 
and offsets in the gain stages. Again this was also adjusted by a potentiometer for 
increased accuracy.
The final CCD decoupling and amplifier stages are shown in figure 1.12. Here the use 
of the buffers is illustrated, both on the CCD outputs before the differential amplifier, 
and on the output of the second stage amplification to drive the A /D  converter.
The decoupling of the power supplies to both the CCD and the analog circuitry was 
found to be essential and tantalum bead capacitors were used to improve the smoothing 
effects for fast transients. A large (100/xF) capacitor was used to smooth the negative 
voltage source obtained from a bench supply.
In order to protect the CCD outputs the circuit was powered up with the divider 
shorted to ground by a two pole switch. This was then switched out of the circuit when 
all the supplies were stable and the negative voltages could not provide damaging over­
load on the CCD PET output stages.
Two amplifier stages (a difference amplifier followed by a gain stage) were used to 
keep the bandwidth of the circuit high enough for the converter to have time to digitize 
the signal. As the converter was being used in its negative supply mode (converting 
from 0 to -2V), this second stage also acted as an inverter amplifier.
The whole buffer and amplifier stage was made as a double sided PCB using the 
component side as a large ground plane. This made a very significant improvement to 
the noise characteristics of the camera.
2 1
-"Ÿ— -AAA---
H>
Ht h '
Figure 1.12: Buffer and amplifier stages for the CCD camera.
22
1.4 A nalysis and U se of th e  Cam era
1.4 .1  T h e use o f th e  shade m apping hardw are
The advantage of false colour or false shade hardware is th a t it allows more detail to 
become visible to the unaided eye.
The controlling software written for the camera was fairly complex and allowed a 
large number of operations to be performed on the images. These included:
•  d o w n lo a d in g  im a g e s  to  t h e  PC fo r s to ra g e ,
•  lo a d in g  o f s to re d  o r  c r e a te d  im a g e s  fro m  th e  PC to  th e  d isp lay ,
• switching the hardware between the different modes of display 
(live camera image, display memory image, frame grabbing etc),
• loading of a variety of colour maps.
All the pixels of the images are grabbed as bytes, 0 representing black and 255 
representing white. The shade mapping allowed this to be changed to say, inverse 
(mapping 0 to 255, 1 to 254 and so on). Figure 1.13 shows an image frame grabbed 
from the camera and then displayed on the display hardware. This image was created 
by drilling a few holes into a brass p la te  which was then mounted in front of the 
CCD and illuminated with a diffuse light source. The source was adjusted so th a t the 
resultant image just reached saturation at its brightest point while still keeping the 
background at saturation black.
The edges c a n  be enhanced by using a shade map that maps 0 to 0 ,1  to 32, 2 to 
64, 3 to 96 and so on up to 7 which maps to 224. The pattern then starts again with 
8 mapping to 0 and so o n . This produces the image shown in figure 1.14.
By mapping 0 to 0 ,1  to 255, 2 to 0 ,3  to 255 and so on, the image in figure 1.15 
is obtained. This shows the full extent of the image but loses detail of the underlying 
structure tha t makes up the brighter areas.
A routine was also written tha t mapped all the shades to 0 except for 0 itself which 
was mapped to 255. This was displayed for a short time and then 0 was mapped to 0 
and 1 was mapped to 255. This continued all the way through the shades and allowed 
the observer to see how the intensity areas changed throughout the image.
A similar technique allowed only every 10 shades to be turned on, having the effect 
of contouring the image.
23
Figure 1.13: A simple frame grabbed image from the camera illustrating both saturated 
black and saturated white regions.
#
#
Figure 1.14: Enhancing the edges using the colour map
24
Figure 1.15: Using the colour map to show the full extent of the image.
As c a n  b e  seen  fro m  th e s e  im a g e s  th e  c a m e ra  is q u i te  s ta b le  a n d  g o o d  re s u l ts  w ere  
o b ta in e d  fro m  th e  u se  o f n o rm a l  CCDs.
One other form of image enhancement is to display the image as a surface. Routines 
were written to do this via the camera and display hardware but a much more detailed 
investigation into this form of enhancement will be carried out in chapter 4.
1.4 .2  C alcu lation  o f  offset and noise for th e  cam era
In order to evaluate the camera performance the image was first adjusted so tha t in 
total darkness a slight background ‘haze’ could be seen. This meant tha t the camera 
generated a clearly visible intensity floor, allowing more accurate analysis of the image 
noise.
The amplifiers were then set so as to not quite saturate the image for full brightness 
on the CCD. This meant tha t the full range could be properly analysed.
Once correctly set up a reference dark frame was taken tha t allowed software pro­
cessing to find the offset level on the image by simply finding the mean pixel intensity. 
The mean was found to be 18*003 ADUs (analog to digital converter units).
25
It was also possible to find the noise levels in the camera by looking a t the deviation 
from this mean value. From this program the variance was found to be 3-337 a d u s  
and hence the standard deviation was 1-827 a d u s .
1.4 .3  D river and analysis softw are
The controller software also provided the ability to compress the data  downloaded from 
the image.
The algorithm used here was developed for smooth images such as those obtained 
from the x-ray experiments analysed in chapter 2. These images have the useful prop­
erty tha t they are smoothly shaded in both the x  and y axes.
The algorithm operated by finding the first row of data, run length encoding it and 
sending it to the output. For the subsequent rows, the differences between this row 
and the previous row is found, these differences are then run length encoded and finally 
Huffman coded. The resulting codes are then sent to the output.
The result of this method is to make use of both the horizontal and vertical regular­
ity of the data to improve the encoding reduction. In some simulated images, results 
of up to 95% reduction were achieved.
Experiments with irregular images showed the weakness of this algorithm and re­
sults of only 5% or 6% reduction can be expected for discontinuous images.
Other routines to work out minimum and maximum values, number of occurrences 
of each value and so on were also written to aid in the development work and the 
analysis of resulting images.
Some test images were also created using shaded areas and lines. This enabled the 
vertical summer hardware in chapter 2 to be tested and also provided test images for 
the surface generators in chapter 4 and the scrambler detailed in chapter 5.
26
C hapter 2 
V ertical Integration  o f X-Ray  
P h oton s U sing a Charge C oupled  
A rea Sensor
2.1 Introduction
2.1 .1  G eneric crysta llograp h ic stru ctural an alysis
One of the most interesting applications of ccDs is in the field of x-ray detection. As 
will be shown later the silicon provides a large gain to the x-ray signal and also has 
good quantum efficiency in the soft X-ray region.
W ithin the field of x-ray crystallography there are a number of applications for 
x-ray detection. Area detectors are most useful in applications where a large section 
of the reflected x-ray beam is to be analysed, but so far they have not found their way 
into applications where the experiment requires a very restricted analysis of the beam 
in only one dimension.
Intensity readings for large area experiments are usually done using two angles. 
Once an intensity reading has been taken the detector is rotated through a small angle 
(A0) and a new reading is taken. Once a full range of intensity against detector angles 
has been measured, the crystal itself is moved through a small angle (Aw) and the 
angular movements of the detector are repeated. Computer settings and the use of 
stepper motors allows both of these angles to be accurately set up on a universal 
mount such as the c a d 4  x-ray diffractometer universal mount.
For many applications, particularly with biological crystals, the angles scanned are 
quite large. These experiments look at the spatial distribution of Bragg reflections
27
caused by the crystal’s atomic structure. The position in space of these spots, and 
their intensities, can be analysed to produce the atomic positions. The analysis requires 
vast amounts of computation and is usually done by computer. One example of this 
type of detector is the f a s t !  system used by Dr. Uli Arndt a t MRC laboratories 
Cambridge [17]. Here a large area sensor is used enabling the detector to be fixed 
in one place and making use of the size of the detector to cover all positions in one 
setting. These experiments are slow, sometimes taking 8 hours. The software suite 
used at Cambridge is the m u d d  system, written in F o r t r a n  and processing in this 
environment can take up to 24 hours to complete after the data collection has finished.
Some initial work into using cC D  detectors for this application has also been done 
by the MRC research groups looking a t both the distortion correction of normal, SIT 
tube, detection [18] and also the use of CCDs as x-ray TV detectors [19, 20].
This illustrates the first major problem of this type of detector. The time taken to 
collect the data means tha t biological crystals tend to denature producing radicals and 
gradually losing their structure. W ith the availability of very high intensity sources 
such as the CERN accelerator, it is now necessary to develop faster systems th a t can 
replace the SIT tubes used by these detectors.
2.1 .2  T h e an alysis o f  a sin gle B ragg reflection
Apart from the large area experiments described above, there are some experiments 
th a t look at individual reflection spots, rather than the spot distribution. These a t­
tem pt to map the intensity profile around a single spot and hence look at the electron 
distribution within a molecule. One such experiment is being pioneered by Prof. A. 
Mathieson of La Tiobe University [21, 22].
Figure 2.1 shows the schematic of the experimental apparatus tha t is used for 
most crystallography detectors where such measurements of the Bragg reflections are 
required. The normal beam used is a 0-5mm^ collimated x-ray source generated from 
0-7A Molybdenum or 1-5A Copper emissions from a IkW  x-ray tube. This beam strikes 
a test crystal and the diffracted beam then goes on to strike a detector.
Traditionally, for small area analysis this detector is a Nal crystal (coated with alu­
minium to reduce reflections) tha t forms part of a scintillation counter. This produces
tDeveloped by Enraf-Nonius, Holland.
28
Al Coating 
on Nal Photo
Collimator Crystal Window surface Oil Multiplier
C J >  ®0. 1mm
Stepper
IBM
PC
X-Ray
Source
Motors
Figure 2.1: Apparatus used for single Bragg reflection analysis.
a p p ro x im a te ly  300 q u a n ta  o f l ig h t  p e r  in c id e n t  X -ray  p h o to n .
This light is then passed through oil to enhance the optical coupling into a photo­
multiplier. This in turn feeds a discriminator and is then sampled. The x-ray energy 
is detected by the number of photons the scintillation counter produces. The counter 
has an upper limit of 10000 counts per second before saturation and if this is exceeded 
then the further counts are lost. This is one of the limiting parts of such apparatus 
and defines the minimum time in which experiments can be done.
Initial work into using the f a s t  system for this type of experiment [23] showed that 
the device, though just able to gain the required resolution, took a very long time to 
collect sufficient data.
Another problem is that, though the incident X-ray photons cause a large gain to 
occur in the phosphor coating of the s i t  tube, at the same time the directionality of the 
photons is lost. This means tha t the emitted optical photons come out of the phosphor 
at almost any angle and give rise to what is known as the point spread function ( p s r ) 
of the detector. Figure 2.2 shows this effect. There are many problems associated with 
this and it is the main cause of low resolution in many detectors. The ‘tails’ of the 
emitted Gaussian light cone can extend over a very wide area and in some cases, such 
as the FAST unit, these tails can be detected over the entire viewing frame.
29
Distribution of 
emitted Light
Emitted Photons
Phosphor
Incident X-ray 
photon
Figure 2.2: Point spread function in a phosphor.
The apparatus for single reflection analysis differs from other systems in tha t only 
a very small angular movement is used and hence only one spot is covered. The wide 
input area of the f a s t  detector, very useful for the large area systems, becomes a 
problem for this type of experiment as much more detail is needed. To overcome this 
a slit is used to mask off all but the required area of the Nal detector. The height of 
the slit allows for up to 3mm of vertical beam spreading to occur in the atmosphere 
and still be incident on the detector and hence be included in a single reading.
Typically a 0-01° step is used, covering 0-5° to 1° in both 29 and w. In order to 
prevent saturation, the experiment uses 10 seconds per position and this leads to an 
average of about 10 hours per set of readings.
If the scintillation detector were to be replaced with an area detector the resultant 
image would be as represented in figure 2.3a. The x-axis of this image is generated by 
the angular rotation in 29. The y-axis is not a feature of the crystal structure bu t is 
generated by atmospheric effects and crystal irregularities. This is effectively integrated 
by the scintillation detector into a single one dimensional image representing intensity 
in the 29 axis, as shown in figure 2.3b.
After a single Aw rotation is done, another such intensity profile is generated. 
Eventually an intensity picture of w against 29 is produced and a corresponding contour 
map can be calculated. This represents the x-ray densities within the reciprocal space
30
y i
yo
xl 20X
y i
xl
yo
z
xl
X  =20
(a) The detected image. (b) The resultant line.
Figure 2.3: The integration from an area to a line.
of the reflections.
Many problems are faced when doing this type of experiment as the required in­
formation is often swamped by spread in the wavelength, A, of the radiation and non- 
uniformaties in the crystal structure. Figure 2.4 shows how various effects contribute 
to the contour map. The mosaic spread, denoted by /i, is the effect of crystal irreg­
ularities and causes a spread in the w axis of the w, 2$ space. The source variations, 
a, are always parallel to the 9 axis and are caused by the changes in the radiation 
beam coming into the crystal. The ou tput beam wavelength, which is the only feature 
dependent on 9, causes changes in the A component.
2.2 X -r a y  D etection  U sing Charge C oupled D e­
vices
2.2 .1  A  p hosphor based , continuous, X-ray p h oton  d etecto r
There have been a few attem pts to use phosphor screens to convert the x-rays into 
optical photons. Examples of these include x-ray microscopes [24], image analysis [25] 
and some work in the crystallography fields of protein [26, 27] and synchrotron [28] 
studies.
31
CO Mosaic Spread, jJ,
Source,<T
Wavelength, 7l
45
20
Figure 2.4: The components of the reciprocal space spot profile.
One of the main problems to be overcome in the single Bragg reflection analysis is 
the need to detect as many of the x-ray photons as possible to reduce the experimental 
time. The conventional drive electronics for a c c D  has a frame shift period tha t would 
cause problems as the correct position of incident photons would not be recorded during 
such a frame shift. Before looking at direct illumination of CCDs by x-rays, an idea 
developed in conjunction with Dr. D.S.S. Robb at St. Andrews university in 1988 will be 
discussed. This system uses a phosphor detector feeding into the c c D  image collectors.
Figure 2.5 shows the schematic of this proposed detector. Its operation is very 
simple: the X-ray photons are converted to optical photons a t the phosphor, the photon 
beam is passed through a gain stage and then focussed onto a beam splitter. The two 
beams now go to two CCDs via shutters tha t will alternate the beam onto first one CCD 
and then the other. While the beam is active on one CCD the other is being read out 
and vice versa. This ensures continuous analysis of the incident x-rays.
There are clearly many problems of aligning such a system and the two ou tput 
signals would also have to be combined to get the correct real time signals.
Normal phosphors can give close to 100% quantum efiiciency ( q e ), with a 1-5A x-ray 
photon producing 3000 4500A optical photons. These are emitted into Att steradians. 
In normal conditions however, this would normally lead to only 300 photons coming 
out in the correct direction (a O-Stt cone). This coupled w ith the losses in the system 
and in a CCD, where a QE of only 80% can be e x p e c te d , means a large gain stage is 
required to operate this experiment.
32
CDD Array
7 K
18mm
V
Phosphor
Shutters
A
x-ray
Photons V 10 X 10 mm
Proximity 
Focussed Diode 22.5 urn" pixelsBeam Splitter
1 X-ray 
photon
x300 x50 1.5% 45% each way 70 photons 
per event
Figure 2.5: A real time continuous photon detector.
One way to improve this is to use some form of containment for the phosphor. 
Small fibre optic bundles can be hollowed out for the first few millimeters and can then 
be filled with phosphor [29]. This means that all the light emitted in the phosphor 
is channeled down the fibre it is emitted from. This reduces the resolution of the 
detector bu t does form a good solution to the containment problem. The layout of 
such a system is shown in figure 2.6. It is also possible to use small micro tubes filled 
with a scintillating material core [30] instead of fibre optic lines.
In order to get the intensity signals up to a suitable level for the optical response 
of the CCD, a proximity focussed diode is required. This is simply an optical diode 
amplifier th a t has the emission stage very close to the gain stage ensuring tha t the 
possible spread of photons is very small across the unit and hence good resolution is 
maintained.
There is also the problem of having very low incident X-ray counts. This would mean 
that the image could not simply be treated as an intensity map and some interpretation 
of the centre of each light cone (created when the light spreads out as it passes through 
the apparatus) would have to be done so as to identify the position of the individual 
incident x-rays.
33
Fibre Optic Bundle
Outer Sleeve Core Phosphor
Figure 2.6: Containment of emitted optical photons.
2.2 .2  T h e su itab ility  o f CCDs to  x-ray  ap p lication s
Unfortunately this device would not achieve the vertical integration, done by the slit 
in the original apparatus, that is needed to handle the vertical spread of the Bragg 
reflections, though it would provide a very good alternative to the existing s i t  tubes. 
Because of this limitation a new system had to be developed tha t would allow vertical 
integration and also reduce the complexity of the instrument as a whole.
One development in CCD technology is the ability to directly irradiate them with 
soft x-rays and allow the silicon to provide the required gain [31, 32, 33]. The data 
given in table 2.1 provides some useful insights into the response of EEV cC D s to 
X-ray photons [34, 35]. This is clearly to be preferred as the CCD has an extremely 
good point spread function and also provides very good rigidity, immunity to magnetic 
fields, and very well defined structure that eliminates the need for complex distortion 
calculations and thermal compensation circuitry. The CCD is also a much smaller unit 
than the existing SIT tubes, and other opto-electronic devices such as the photicon [36] 
and vidicon [37] cameras and would thus lead to a smaller, more versatile instrument.
From the data in table 2.1 it is possible to show the following:
Saturation 300nA X =  339 x lO^e". InA
heEnergy of Cu a  line =  — — 8-05 x lO^eU;
34
CCD peak output voltage 180mV
Peak output current 300nA
InA ou tput per cell 1130e"
•^Cu 1-54A (a  line)
No. (e~,e+) per detected x-ray ^  E(eV) 3-6QE at 1-54A 32%
Table 2.1: D ata o n  the P86320 CCD.
Gain =
Saturation
lA D U  -
8 05 X 1Q3 
3 6
339 x 103 
2240
151
=  2240 © QE of 32%;
=  151 x-rays;
=  0-59 x-rays,255
339 x 10* 
255 1330e
Clearly it is possible to irradiate an area ccD with the X-ray beam directly. The CCD 
cells will collect the incident photons and, as the frame is read out it can be digitized 
and the digital rows summed to achieve the required vertical integration. The CCD 
provides good QE at soft x-ray wavelengths [38] and studies have shown they are very 
suitable to general X-ray detection [39, 40, 41] and even to single photon counting [42]. 
Figure 2.7 shows the quantum efficiency of CCDs at non standard wavelengths.
One other problem th a t must be considered is the build up of dark current relative 
to the required detection levels. At its worst the dark current a t 21°C reaches 3nA. 
From the data this corresponds to
3nA =  3 X 1130 =  3390e“ ,
which in terms of suitable ADC units corresponds to 2-55 counts. When compared 
with the actual signal this presents a problem as it will swamp any wanted, x-ray 
generated, electrons. Chapter 3 will cover the methods developed for measuring and 
then subtracting this dark current signal. The error tha t must be considered here is 
due to the random nature of the dark current. This is dependent on the square root
35
710
•H
100
i
"  80
60
■Ho 1.0
V i s i b l e
L i g h t
204J
Jü 10 3
3 10^10 1 . 0
b-
g•HO“HM-lIH0)
g■MO0)-P
(0
■b
P h o t o n  E n e r g y  ( K e V )
Figure 2.7: Quantum Efficiency of CCDs.
of the number of thermally generated electrons. Hence the maximum error is given by
Error — ^/n — \/3390 =  58 electrons.
Where n is the number of electrons involved.
From this the fractional error in ADUs can be seen as
58Error 1330 0 04
i.e. the total dark current at maximum will be 2-55 ±  0-04 a d u s . As 0 04 is much less 
than the count generated by the incident , x-ray, photons, the subtraction will easily 
produce an accurate detection method.
There are of course limitations to the use of directly illum inated ccDs. Radiation 
damage of the electrodes and the silicon itself has been detected in many devices. 
Technical publications by EEV [43, 44] suggest that, if back illum inated devices are 
used, then the high resistivity devices can withstand soft X-ray radiation indefinitely 
for intensities of less than lO'^  rads.
36
Consultation with EEV suggested a number of ways of improving the applica­
tion of CCDS in this a re a . The use of higher resistivity silicon [45] and depletion 
layers greater than 30/zm [46] should produce much better QE, Though expensive (a 
100Qcm“ \  100/im device currently being around «£6000), such devices are now becom­
ing more readily available and are provided in the same format as the cheaper optical 
units. Because of this the following experiments were carried out on normal optical 
CCDS and when future work requires it, the more suitable X-ray sensitive devices could 
be substituted. Once again it is in the field of astronomy detectors tha t much of the 
pioneering work in high sensitivity CCDs has been carried out and has led to  a number 
of relevant device evaluations [47, 48].
Research work at EEV is being performed in many of these fields. In particular 
they are developing a low dark current, back illuminated device for i^l300, and work 
using 31kücm~^ silicon is producing good results. They are also developing 11/im  
devices for high definition TV systems. Unfortunately at the time this research was 
being carried out none of these devices were available but, as they were being designed 
to be electrically identical to the normal TV sensor, the development work described 
here should be applicable for later devices.
In order to apply the area technology of the CCD to Prof. Mathieson’s experiment, 
it is necessary to find some way of vertically integrating the pixels to simulate the use 
of a slit and a scintillation counter. One possible solution would be the use of a large 
pixel linear array of sensitive elements. Such arrays can have pixels with the same 
width as the area c c D  pixels (22/j,m) bu t with a height of up to 5mm. These linear 
detectors are often known as reticonsl and are based on either CCD or diode array 
technology [49].
These were initially developed as position detectors using phosphor [50] or phos­
phor and fibre-optic [51] couplings. Development continued into the directly radiated 
sensors for crystallographic applications [52, 53, 54], spectroscopy [39, 40, 55] and then 
into synchrotron detection [56]. The main problem tha t these units suffer from is that 
the noise levels, particularly the dark current, are dependent on the area of the cells 
and hence when large cells are used the noise levels go up. As diode arrays are in­
herently more noisy tha t CCDs anyway, they become unsuitable for the lower intensity
^The company EG&G Reticon pioneered work into these detectors.
37
I
applications. They also have the same dynamic range as units with smaller cells. This 
means tha t the beam intensity (per m^) must be lower as the larger area pixels will 
reach saturation faster than would devices with smaller pixels.
This leads on to the application of area CCDs to one dimensional detection. As the 
dynamic range of the CCD cells is the same as that of similar linear CCD detectors it 
is possible to use the cells of the area detector to trap the charge, and then ‘add up’ 
the charge after reading out the individual values. In this way a dynamic range of 288 
times the linear celled devices can be obtained for a normal t v  sensor of 388x288 cells.
If an area CCD was to be used this vertical summing could be done in two ways. If 
the CCD were to be mounted on its side, then as a ‘row’ was read out, all the pixels 
could be summed one after the other and then at the end of the ‘row’ a resultant 
value could be collected. This would be an ideal solution except for the fact th a t it is 
necessary to have continuous da ta collection. When a frame is shifted out of the active 
area of the c c D  and into the storage area it will pass horizontally through the beam 
if the CCD is on its side. This means that the more complex problem of having to 
vertically sum pixels when the c c D  is mounted normally has to be solved. When the 
CCDS active area is shifted down, the incident photons will still appear in the correct 
horizontal position and, as the hardware is vertically integrating, the photons vertical 
position is not important.
Because of the low intensity of incident X-rays on the CCD it is very improbable 
tha t there will be more than one X-ray photon per pixel per frame (assuming a normal 
50Hz frame rate). Because of this it is only necessary to use a logical comparison on 
the ou tput to detect events. Such a circuit will look a t the charge on the ou tput of the 
CCD and compare it to the charge that would be expected if a single x-ray photon was 
incident on tha t cell.
W ithin Prof. Mathieson’s experiment a 0-lmm slit is used giving a peak count of 
about 10000 events per second, spread over the full 5mm height of the detector. As 
the pixels are 22-5//m high, this ensures tha t over the area of the original slit a c c D  
detector would see
No. Counts 10000
0 1 x 1 0 - 3  5 x 1 0 - 3 62 5 X -rays p e r  p ix e l.No. pixels 22-5x10-3 22-5x10-3 
In normal operation a t v  sensor is running at 50 frames per second and hence an
38
expected ^ = 1 - 2 5  x-rays per pixel per frame should be seen. This means that, if the 
apparatus were to be run a t 80% maximum power, the worst case would be to expect 
one x-ray photon per pixel.
Clearly such a setup will lose some of the events. E ither a pixel will contain more 
than one incident photon, in which case the extra charge will have to  be recognized and 
suitably processed, or the photon will appear at the edge of a cell and the charge will 
be shared between two cells. It has been shown that, in the worst case, 50% of incident 
photons cause some energy to be spread between adjacent pixels [40]. This can be 
removed by computer processing of adjacent pixel intensities but it certainly identifies 
the need for some type of post processing of the results. There have been a number of 
attem pts to do this type of processing and algorithms are generally available. For this 
application a standard method using a 3x3 grid [48] to process the energy readings 
would be ideal but, in order to analyse simple data a direct voltage comparison will be 
used here.
The hardware will have to store a complete row of data a t any one time. Each 
pixel voltage read out of the CCD will have to feed into a comparator and be converted 
to either a ‘1’ or a ‘0’ depending on whether it is above or below the required charge 
level for a single detected event. This will then be added to a stored value for tha t 
horizontal position and the resultant sum held until the next pixel is available for this 
horizontal position. At the end of the frame, and within the vertical flyback time, 
all the 388 values representing the vertical sum must be read out into the analysing 
computer system.
2.3 V ertical In tegration  Hardware
2.3 .1  B asic  d esign  principals
If the x-ray camera were to be run a t the normal TV rate of 50 frames per second the 
pixel information would be available a t a rate of 8MHz. This means there are only 
125ns available to do the read out, increment and write back, of the vertical summed 
data. The timing of this is very critical. The currently available memory chips have 
35ns access times. This, added to a counter update time of 25ns, the incremental time 
of a PAL summing device, 20ns, and latch delays of 10ns or so means tha t there is no
39
Clock y
Byte
Clock
HBlank
Signal
LOGIC
enrd wr RAM
Figure 2.8: Block diagram of the vertical summer hardware, 
spare time available
The most obvious consequence of this is that the memory device has to be a dual 
port unit. The added delays of multiplexing the da ta and memory busses with the 
processor would prevent the timing constraints from being achieved.
As can be seen from figure 2.8 the remainder of the hardware is relatively simple. 
A counter is updated from the pixel clock and provides the addresses for the dual 
port memory device. This in tu rn  reads out a value into a summing section where 
the comparator ou tput is added to it. The logic then latches the resultant output and 
writes it back into the memory. This process continues for the whole line, after which 
the counter is reset and the process begins again. When the vertical blank signal is 
detected by the processor a DMA cycle is initiated that reads out the da ta and then 
replaces it with zeroes ready for the summing of a new frame.
2 .3 .2  Sum m ing v ia  program m able logic
Because of the very short time available to the summing process, traditional syn­
chronous adders are not fast enough. Alternatives were considered. Firstly a loadable 
counter could be used, feeding in the pixel value and then adding one to it if necessary, 
or secondly, a logic array could be used to add in the value asynchronously. The timing 
complexity of the loadable latches lead to unnecessary complications as did the need 
to use multiple devices (loadable counters such as the 74LS191 are only available in 4
40
bit or decade counting packages and then not always in the faster logic types such as 
the 74F family).
The 16v8 g a l  gives the flexibility needed and is also available in a 15ns access
version. This, though expensive, gave better timing than the TTL versions could, and
also provided the flexibility to do other logic functions within the circuit.
The basic equation of carry forward adder is found by extending the half adder 
logic,
D'q =  Dq 0  J5, (2.1)
Cl = Do A B, (2.2)
where Dq is the least significant bit, B  is the input bit and Ci is the carry produced 
by this sum.
This can be extended so that
D q =  D o  0  jB,
D'l = (Do A Di) 0  Di,
This set of equations can be substituted with equations 2.1 and 2.2 to get
D q  — D q  A B
V D q  a B,
D[ = Do A B A Di
V Do A B  ADi ,
In order to get this into a form suitable for a logic array, these equations must now
be expanded to get______________________
D q =  B A Do
V B A D^,
D[ = ^ A  Do A D7
V Dq a  D i
V B A D i ,
41
I 20ns I
H— H
Clock
Clock
Clock
L
Byte Clock
Byte Clock
RD
r
Figure 2.9: Timing of the read and write pulses.
Because of th e  need for 9 bit output, and also due to the limited number of minterme 
available to the array, it was necessary to use a further array to generate the most 
significant bit. Thus both D j and Dg were defined in a second p a l . The data was fed 
into these s y n c h ro n o u s ly  by providing a c a r ry  ou tput from the first PAL, defined as
C  =  B  A Dq a  D i  a  D2 A D3 A D4 A D 5 A Dq,
i.e. the carry ou tput of bit six. The definitions of D? and Dq were then just the same as 
for Do and D i, bu t with this carry bit being fed in instead of the comparator output.
2.3 .3  G en eratin g  read and w rite  line tim in g
The timing generation for the memory had to be derived from the CCD clock and the 
byte clock (as defined in chapter 1 ). The CCD clock provides a higher frequency clock 
th a t can be reduced to provide the correct read, write and control pulses to drive the 
circuit.
Figure 2.9 shows the required timing for this circuit and includes the slight discrep­
ancies in the pulse generations tha t the gate delays produce. F irst the data is read 
out, with RD active, (low). Then there is a delay to allow the addition to be done and 
finally the data is latched and fed into the memory with the W R signal low. Normal 
d e s ig n  techniques would lead to either a state machine design, or to a cascaded flip- 
flop system. Unfortunately these would incur too many time overheads and would not
42
1 / 6  7 4 P 0 4
B y c . «  c l o c k  > — ------
1/6 7 4F*04 1/6 7 4F04
~TT
- <  R d
Enab1o
Figure 2.10: Circuit element showing the read, write and control timing.
provide the exact timings needed for this application. One solution is to make use of 
the finite rise times of a flip-flop output.
Figure 2.10 shows the circuit element used to implement this timing. It works by 
letting the pixel clock reset the outputs to their initial positions of r d  low and W R 
high. The next falling edge of the c c D  clock comes just before the end of the byte 
clock since the byte clock is derived from the CCD clock. This means tha t this edge 
is ignored by the flip-flops. The second falling edge causes the RD signal to be set to 
high as a 0 is clocked into the flip-flop from the data input.
This high value is now clocked into the lower flip-flop by the next rising edge of the 
CCD clock and hence the W R signal is activated. Finally the whole circuit is reset by 
the pixel signal when it goes active again at the start of the next pixel ou tput cycle.
In order to make use of the propagation delay time in the middle of this timing 
period, the Q ou tput of the lower flip-flop was used to latch the da ta signals driving 
the inputs of the p a l s .
Though this circuit operated well, it was, not surprisingly, very unstable as a strip- 
board circuit and any loading of the flip-flops caused tim ing changes. This meant that
43
Device Price^ Access Time Size
IDT 7130 ./:13.58 35ns Ik x  8
IDT 7025 N.A. 35ns 8k X 16
PDSP16520* N.A. 50ns Ik x  16
VT16DP8 N.A. 70ns 2kx 8
HM6302D N.A. 28ns 2kx 8
VT16DP8 N.A. 70ns 2kx 8
MT42C8127^ N.A. 100ns 128kx 8
IDT 70104 ^18-62 25ns Ik x  9
^1490 35ns Ik x  9
IDT 7010 £17-87 25ns Ik x  9
£17-87 35ns Ik x  9
MK41H78I! N.A. 20-25ns 4k X 4
Table 2.2: Dual port memory devices.
a low impedance oscilloscope could not be used as a test device. Once a printed circuit 
board had been manufactured the stability was greatly improved and the timing be­
came very reliable. Experimentation showed that a 74LS74 was not suitable, creating 
poor edges on the drive lines, the 74F74 worked well though and provided reliable 
results, as shown in section 2.4.1.
2 .3 .4  T h e choice o f  m em ory  d evice
When considering the choice of memory device certain parameters could be defined. 
Firstly it had to be a 9 bit device because, in the worst case, there may be a photon 
in every vertical position, leading to a count of 288 photons, requiring 9 bits to store.
Secondly, the device had to have at most 45ns access time as the timing diagram of 
the read and write lines illustrates. Table 2.2 show a list of the parts considered and 
their characteristics.
Some of these devices were arranged so as to be stackable, for example the IDT70104 
is the slave version of the IDT7010. These devices can be used in parallel, providing the
^As of June 1991.
^This device is a quad port memory.
§A line memory device.
^A serial and parallel accessed device.
II This device also has a built in auto clearing function enabling all the meinory locations to be 
zeroed via a single control line.
44
> f _ .
Figure 2.11: Internal layout of p a l  2 logic chip.
larger bit sizes, and allowing the master unit to arbitrate as to which part is accessing 
the storage. In the hardware developed here, the IDT7010, 35ns part was used [57]. 
This was a faster device than was necessary thus guaranteeing the timing would be 
met, and also proved to be the most cost effective of the devices available. Being a 9 
bit device (designed for parity checking of 8 bit words) it provided everything tha t was 
needed. In the event tha t a faster version might have been needed it could also have 
been upgraded to the 25ns version.
2 .3 .5  T h e final circuit
Inserted figure IV shows the circuit diagram of the final hardware implementation. The 
logic arrays p a l  1 and PAL 2 provide the summing described earlier, and the remaining 
part of PAL 2 was used to provide most of the less time critical logic functions (figure 
2.11). Two positive edge triggered latches, a 74F374 and a 74F74 were used to latch 
the 9 bit output of the summer, a 74LS125 buffer was also needed to add the ÜË feature 
to the flip-flop.
45
There was also a need to modify the original timing requirements because the 
update rate of the 74HCT4040 was still not good enough to meet the timing. Two 
latches (74LS374s) were put in to hold the counter output one cycle behind the update 
clock. This removed the dependence on the update time of the counter but no longer 
allowed the correct memory accessing timing, having the effect of delaying the entire 
image by one pixel and dropping one pixel value from the end of the line. The 388 pixels 
per line are effectively reduced to 387. As this instrument was developed to provide 
an experimental confirmation of the principles, this was thought to be a reasonable 
compromise.
2 .3 .6  A ccessin g  th e  RAM
The other problem with the dual port RAM was in getting the 9 bit data into the 
processor storage RAM. The read cycle of the dual port r a m  produced all 9 bits of 
stored data on the 9 data lines. By latching the most significant bit into a flip-flop 
and enabling it onto the 8  bit processor data bus via a tristate buffer, it was possible 
to ensure that after reading the RAM a subsequent read could be from this latched bit 
and thus all 9 bits of data could be collected.
Unfortunately the use of a DMA chip presented problems as the DMA is not capable 
of this kind of complex switching. The solution was to use the lowest address line, Aq, 
instead of a selection line and then address the r a m  chip with address lines Ai  to Ag. 
Now, even bytes contained the main 8  bits of the word and the odd bytes contained 
the one bit data tha t corresponded to the ninth bit of the previously read word.
It was now possible to use the DMA to zero the r a m  contents provided this ninth 
bit was suitably dealt with. When a zero byte was written to the RAM the ninth bit 
was pulled to ground ensuring tha t all nine bits were written as zeroes. This doubled 
the time the DMA took to erase the bytes because the addressing was now such tha t 
every odd byte acted the same as every even byte (for write cycles). As will be seen 
from the readout timing, this increase was just acceptable.
2 .3 .7  A ch iev in g  h igh  sp eed  d ata  transfer
In order tha t the DMA transfer can be done as fast as possible, two areas of memory 
within the Z80 address space were set up. One contained zeroes for 776 bytes. This
46
was used to allow the DMA to erase the dual port memory by simply transferring this 
blank data into the dual port address space. The other section was used to store the 
data obtained from the DMA transfer when the dual port memory was read out.
Given a clock frequency for the DMA of 4MHz, a transfer rate of one byte per 6 
clock cycles, the need to transfer 776 bytes into the Z80 RAM and then the need to 
erase 776 bytes to zero, the timings of the readout system are found to be
, 6 x 2 x 776transfer cycle time =  —   r— - =  2-33ms.4 x 1 0 6
If the register setup times for the DMA are included with this, an expected cycle time 
of 2-4ms would be reasonable. This can be compared with the same timings using the 
LDDR Z80 command which requires
21 X 2 X 776  ^ _
— V i ÿ  =
which, as the flyback time was measured to be 3-07 ±  0*02ms, could not be used. 
Clearly the DMA solution is just capable of achieving real time data movement.
Having ascertained tha t the proposed method would work, the software was then 
implemented via the following algorithm.
1. Fill Z80 RAM area with zeroes.
2. Setup DMA transfer parameters.
3. Wait till Vblank signal goes active.
4. Do DMA Transfer of dual port data memory into Z80 storage memory.
5. Setup new DMA transfer parameters.
6. Transfer zeroed memory area from Z80 into dual port RAM.
7. Transfer stored data from Z80 to PC.
(Most of this happens during the frame period).
8. Repeat from 2 until required number of frames have been summed.
Once this had been implemented, software on the PC was generated to take in each 
set of values and store them. Options to display, graphically and numerically, the data 
from any particular frame were also provided. With a 4M byte RAM PC, about ten 
thousand frames can be stored, easily enough to ensure tha t no hard disk transfers 
would be required. This is necessary as these would slow the data collection process
down were they to be needed during the experiment. Data can still be written to the
hard disk after the experiment has concluded.
47
: : ,  : : I ; : : ! I : ; : : I : : : : i  : t i ! r : ! : ! I : : : ! ; : : ! : ; :  i : : I ! : i i .
u ! i
/ " \  / ^ \  1  / /  .. J<D I" ■• ,•■■P !" /  .  ^ "!
" I
■•-‘x
r  " V ' 1
• !i- • . . . !
; ; : : . : : I t : : : . : ; • : • : : : : : : : ; ] s : j : I i : : ; :
r  \ ; •
- 2 3 . 2 0 0  n s  7 6 . 8 0 0  n s  1 7 6 . 8 0 0  n s
Figure 2.12: Measured output of the read and write enable circuit.
2.4 R esu lts
2 .4 .1  T h e read and w rite  signal tim in g
In order to verify the output of the memory control hardware, it was necessary to use 
a fast, high input impedance oscilloscope. This was mainly due to the fact tha t the 
circuit relied on the fast edges of the flip-flop outputs and, when a capacitive load was 
applied to these outputs, the edges became less sharp and the timing shifted enough 
to become unstable.
Figure 2.12 shows the clock inputs along with the RD and WR outputs from this 
circuit as measured by a Hewlett Packard IGHz digital sampling scope.
Comparison of these timings with those given in figure 2.9 illustrates tha t this 
circuit produces the required pulse durations very accurately.
48
2 5 0 -
200-
100 -
5 0 -
0 50 100 150 200 250 300 350
Horizontal Pixel No.
Figure 2.13: Hardware summer acting on the test image.
2 .4 .2  V ertical su m m in g in softw are
In order to test the hardware, it was necessary to have a comparison. By accessing 
the graphics ability of the hardware developed in chapter 1 , and not attem pting this in 
real time, it was possible to use either a test image or to read a frame grabbed image 
into the PC and write a program to compute the correct output of the vertical summer. 
This program took 123 ±  Is to execute when run on a simple test image.
2 .4 .3  H ardw are resu lts
Figure 2.13 shows the output of the summing hardware when operating on a test image 
consisting of a filled circle (right hand side), a filled triangle (middle) and a shaded 
vertical bar (left hand side) all superimposed on a grid using 40 pixel spacing. This 
compared very well with the output of the software summer.
Once positive results had been obtained, the hardware was run on a frame grabbed 
image (figure 1.13), using the most significant bit of the output as the summing circuits 
input data bit. This result is shown in figure 2.14. Finally the system was run in real 
time using the live video signal. The results, shown in figure 2.15, agree very closely to 
the expected values and even show some extra noise immunity over the frame grabbed
49
2 5 0 -
200 -
w 150- 
O
o^ 1004
50-
I 1----------- 1----------n— "— I---------- 1--------- “y—
0 50 100 150 200 250 300 350
Horizontal Pixel No.
Figure 2.14: Summing a frame grabbed real life image.
version as the camera system was not loading the video signal.
2 .4 .4  F uture w ork and rad iation  testin g
Before work can be continued in this field, it will be necessary to build the entire system 
onto a printed circuit board, and preferably go to surface mount devices to reduce the 
noise levels. Redesigned power supply noise suppression and very good decoupling 
would also be beneficial. This should allow the noise floor to be lowered below the 
requirements on the x-ray detection circuitry. It would also be necessary to provide 
active feedback to the comparator to allow the dark current to be subtracted.
Testing of the camera on x-ray sources proved very difficult because of the camera 
noise levels. The experiment uses radiation from either 1-5Â copper (Cu) or 0-7A 
molybdenum (Mb) sources. These have an energy given by
hi/ heenergy (eV) = e eA’
3 X 10  ^ X 6-626 X 1-241 x 10"^
A X 1-6022 X 10-19 A
8-271keV C u © l-5 A  
17-72keV M b @ 0 -7 l.
50
250-
2 0 0 - 
I  ^w 1504
100 -
50-
n  1---------- 1— — I-------- 1--------- 1--------- 1—
50 100 150 200 250 300 350
Horizontal Pixel No.
Figure 2.15; Summing a live image.
Isotope Energy
Cobalt (Coqo) 
Caesium (CS1 3 7)
Manganese (Mns4 )
1-173, 1-333 MeV 
2 2  - 26 keV 
8 8  keV 
5-4 - 6-0 keV 
835 keV
Table 2.3: Available radiation sources.
Table 2.3 shows some possible 7  emitting test sources [58]. The Mu54 should be 
of particular use as it has radiation levels well into the normal CCD sensitive regions, 
giving a 10-15% quantum efficiency (rising to 60% for a 60/im silicon C C D ). The source 
tha t most closely matches the x-ray source is an Fcss isotope. This was not available 
for use however so tests could not be done at this time.
51
C hapter 3 
A  Solid S ta te  Streak C am era
3.1 Introduction
3 .1 .1  T h e gen eration  & use o f  short d uration  laser pu lses
For some years now it has been evident tha t short duration laser pulses have many 
applications. W ith mode locked dye lasers [59] now capable of producing reliable 
pulses with durations in the low femto-second ranges [60], it is now possible to create 
‘packets’ of light only a fraction of a millimeter long. W ithin such time scales molecular 
interactions can be filmed as sequences of images [61], tectonic plate movements can 
be detected to an accuracy of a single millimeter via satellite ranging [62] and optical 
properties of solids can be very accurately determined using the broadening effects on 
the monochromaticity of such pulses.
Along with an increase in the numbers of diode lasers and mode locked systems, 
there has also been a build up in the number of medium length pulse sources. These 
have medical applications as they are able to deliver large amounts of energy in a very 
localized way but cause minimal heating as the pulses are short compared to their ‘off’ 
periods. There are also telecommunications uses for medium length pulses as they can 
be used to modulate digital data  onto a fibre link.
One problem tha t all short pulse research suffers from is tha t detailed analysis of 
the pulses is hard to do. Power meters such as the Newport 835 or 840, can look 
a t changes with laser output power with time but cannot look at mode changes or 
frequency broadening within the pulses.
If more advanced research into these pulses is to be achieved, one instrument that 
is needed is a fast detector tha t can look at the beam profile in time, and not the
52
integrated power. For medium pulse duration lasers this would need to look at a 
period of, say, 200^s in 10/xs frames. W ith an emitted beam profile of about 5mm such 
a camera would need to be able to resolve 50/^m detail and be able to cover the entire 
beam width in one frame.
3 .1 .2  E x istin g  m easu rin g  techn iques
There are a number of techniques currently in use to analyse laser pulses. Sensors 
such as light dependent resistors are too slow for these applications but some of the 
faster optically sensitive silicon detectors can be used, allowing longer duration pulses 
to be looked at with light sensitive diodes similar to those used in conventional power 
meters.
There are two ways of looking at the faster pulses. Either the beam is passed 
through a streak camera [63] and looked at in a multiple or one shot recording mode, 
or an auto correlated sampling technique [64] is used.
W ithin a streak camera the laser pulse is converted into an electron beam tha t is 
then deflected, at radio frequencies, across a phosphor screen. A very high deflection 
rate can then be used to trace the beam across the screen and build up an image tha t 
can be read out via a photodiode array. For repetitive sampling very good results 
are obtained down into the pico-second pulse durations. The main problem with such 
instruments is tha t they are hard to tune and give poor results when used in a single 
shot mode. The power gains required to move the beam are achieved by using sharply 
resonant circuits and these are only tunable over a very short range of frequencies. As 
the gain is also hard to adjust, very fast pulses cannot be analysed as the low intensity 
output is not detected by standard readout systems.
The alternative for very fast pulses, in the femto-second region, is to use autocor­
related sampling technique where a composite image is obtained by instantaneously 
sampling the magnitude of successive pulses each at a slightly later time than the last. 
In this way all the parts of the pulse are examined and, assuming tha t all pulses are 
identical, the shape of the pulses can be determined.
One problem with all these detectors is that they examine the whole beam profile 
rather than only one single part of it. This means tha t they integrate the power of 
the beam over its whole cross sectional area (see section 3.6.3). There are very few
53
techniques for looking at beam shapes, or profiles, while the pulse is occurring.
One possible method of doing this would be to use a framing camera [65]. These 
use very fast beam deflection systems to move an image across the surface of a CRT and 
hence onto a photographic plate. After each frame period, the entire image is moved 
to a new location on the plate and a small exposure time is allowed before moving 
on to the next frame position. This means tha t after the end of the imaging period 
a set of frames has been taken. By developing the images and then scanning with a 
densitometer, the beam profiles can be built up.
This system, while easily fast enough to do lO/US per frame (and even down to 
Ins per frame) is not capable of looking at very many separate frames. The simple 
system usually accommodates only a two by eight grid and hence only 16 pictures can 
be taken. It is also very difficult to use as the deflection tubes are large and require 
detailed setting up for any one imaging session. The delay in developing the images is 
also a problem as it can take many attem pts to get the precise setup tha t will produce 
useful images. Even so framing cameras are readily available from such suppliers as 
Hadland, T.R.W  and Hamamatsu.
Clearly such a system is not suited to the sort of measurements tha t are required in 
order to fully analyse medium and short duration laser pulses. A portable, low inter­
ference (the radio frequency scanning of streak cameras can cause significant problems) 
and fast turn around device is required.
3 .1 .3  A  proposed  solid  s ta te  cam era
In conjunction with Dr. D.S.S. Robb an idea was developed to make use of a c c D  
sensor to achieve fast, one dimensional analysis of laser pulses. This was based around 
a normal TV CCD sensor and made use of the silicon charge storage as both the optical 
sensor and as a means of storing data while beam analysis was in progress.
The original research into charge coupled devices at Bell Systems laboratories [6 6 ] 
was as a possible means of making digital serial memories and shift registers [67]. A 
charge insertion device was used to put charge onto one end of a row of charge coupled 
cells. The charge in all cells could then be transferred one cell along and a charge 
sensor at the other end could read out the binary, or even analog, signal from the end 
cell. Unfortunately the problems of dark current, coupled with the rapid growth of
54
s ta t ic  an d  d y n a m ic  RAM ch ip s, lead  to  b e tte r  so lu tio n s  to  th e  m em ory  p rob lem  b u t  
ch arge sen sitiv e  d e te c tio n  w en t on  to  b e  ap p lied  to  lin ear array an d  th en  area  array, 
lig h t sen sit iv e  d etec to rs .
The method of one dimensional analysis used here is based on allowing only one 
horizontal row of an area CCD to be illuminated by the beam at any one time.
Before the pulse starts, the CCD is continually clocked out to ensure th a t there is 
no build up of dark current or background light. A trigger pulse from the laser source 
stops this clocking thus allowing charge from the pulse to build up on the one exposed 
row. After a fixed integration time, the charge in the whole c c D  is shifted down one 
line and the next integration period started. In this way a succession of lines are stored 
in the sensor below the illuminated line.
Once the pulse has died away, the c c D  is read out. After a few lines of blank data, 
the first line of the experiment will have been shifted down into the output register 
and data collection can begin. Lines are read out sequentially until the entire pulse 
has been recorded.
Because of the very high sensitivity of the CCD, in some cases it is possible to 
get single photon detection [6 8 ], such an experiment is able to handle this single shot 
detection method with no problem.
The basic digital readout circuitry for such a camera is reasonably well known but 
there are two significant points of interest in the system used here. Firstly the coupling 
of the light to only one row of pixels (22-5/im high) had to be achieved with virtually no 
light leakage into surrounding pixels, and secondly a correction for a / d  distortion and 
dark current had to be developed. The latter was of particular interest as it was hoped 
to read out the CCD in a slow scan mode so as to reduce noise and improve the output 
amplification stages. This would mean tha t a significant amount of dark current would 
build up during the period of data storage and would have to be subtracted out.
The proposed system has a number of further applications. As the instrument can 
be mounted at any angle it is possible to look at many slices through the laser beam 
and hence three dimensional analysis {x, y,intensity) can be done. If pulses are found 
to be reproducible then the instrument could also be moved up and down so as to look 
at the full pulse characteristics in both axes.
55
The Imaged Line
Cylindrical Lens
25pm Slit
CCD Sensitive Area
CCD Frame Storage Area
Laser Light
Figure 3.1: Imaging a slit onto the CCD surface.
3.2 Laser C oupling To T he Cam era
3.2 .1  Im agin g  a slit onto  th e  CCD surface
The first problem to be overcome was the need to couple the laser beam onto a single 
row of CCD cells. The first attem pt was to pass the laser beam through an adjustable 
slit and then image the first maxima of the diffraction pattern onto the CCD via a 
cylindrical lens. It was hoped tha t the second maxima would now fall outside the CCD 
light gathering area. Figure 3.1 shows the arrangement for this experiment.
A row readout circuit was set up to enable the CCD to be read out onto an oscil­
loscope and hence allow the output waveform to be analysed. The image was placed 
vertically on the CCD surface so that the thickness of the imaged beam could be seen 
as a spread in the row output waveform. If there was any vertical misalignment of the 
imaged slit then this would be seen as a further spread in the output waveform. To 
correct for this the slit was adjusted in angle so as to minimize the observed image 
spread and thus ensure tha t it was vertical with respect to the CCD pixels.
It soon became evident tha t the smallest slit that could be clearly imaged did not 
allow the beam to cover just one row and the alignment was so sensitive tha t even 
thermal effects could cause misalignment. The smaller slits were not suitable because 
the errors in the lens and the non uniform thickness of the slit became too pronounced
56
CCD
Surface
Slit
Figure 3.2: The diffraction generated by mounting a slit onto the CCD.
to give useful results.
3 .2 .2  M ou n tin g  a slit in front o f  th e  CCD
In order to overcome the problems of the image spread, a razor blade was used, coming 
down from the top of the image, to form a slit between the blade and the top of the 
storage section of the CCD. This allowed the laser to directly radiate the pixels without 
the need for a lensing system.
Testing of this arrangement was carried out by using an existing video camera 
and simply viewing the t v  picture at very high contrast. This revealed tha t the beam 
spread, caused by the diffraction pattern being so close to the optically sensitive surface, 
meant tha t though it was possible to get the correct beam width at the razor blade, it 
had spread out by the time the image reached the silicon of the CCD.
The same system was then extended by mounting a Melles Griot 25/xmx5mm slit 
onto the glass front of the CCD. This produced better results as the spread was much 
smaller with the reduced distance. Figure 3.2 illustrates the effects of diffraction on 
this arrangement. The distance between the maxima can be found from
wsin(^) % lu- = nX(t + D)
and hence, a t n = l ,  the central peak has a half width given by
A(t T  D)y w
57
633 X 10-^(0-55 +  1-2) x 10'^
~  25 X 10-6
=  44-3/im.
Clearly the full width of the peak, which contains 90% of the power, spreads over 4  
pixels (each with a width of 22-5;um).
It was also found tha t internal reflections within the glass covering contributed to 
the spread of the beam. The net effect of these problems was to significantly reduce 
the time resolution of the camera and hence further improvement was needed if the 
time resolution was to be high enough to meet the requirements.
3 .2 .3  C oupling v ia  op tica l fibres
One of the alternative coupling systems available for EEV products is to use a fibre optic 
block. In this case the CCD-02-06-1-621 sensor was used. This is a scientific grade, 
TV  frame sensor costing about <£1170. It contains 6 ^m  diameter fibres coherently 
bundled to form a 8 mm x 5mm block tha t is mounted close to the CCD surface and 
very accurately aligns the image on the fibre bundles with the c c D  elements. When 
the 25/Lim slit was mounted directly onto the faceplate of this fibre block the distance 
between the slit and the fibre surface was so small as to be negligible and thus removed 
the diffraction problems. The final version of the optical coupling arrangement is shown 
in figure 3.3.
The availability of a 6 //.m slit gave the possibility of going to an even more accurate 
system were it to be required. This size would also match the 6 /im fibre optic thickness.
Alignment of the slit was done on the camera system developed in chapter 1 . The 
slit was placed by hand with a false contrast colour mapping set up to enhance the 
visibility of any light leakage around the slit. The slit could now be aligned to cover 
just one row of the CCD and, once a suitable position had been decided upon and the 
slit fixed using optical wax, the camera hardware could be used to carry out a frame 
grab of the slit image.
This image could have been analysed to find the vertical position of the slit in a 
number of ways. The simplest was to measure the height of the image on the screen 
and the distance from the bottom  of the image to the illuminated line. This was done 
and, given tha t there are 288 lines on the screen it could be deduced tha t the slit was,
58
O p t ic a l  Wax
2 Spin slit
Laser Input
Fibre Optic Faceplate OOOOCxQO
Frame Store CCD ooooooo■GQQCOOO
Figure 3.3: The final version o f the laser to CCD coupling hardware.
in this case, mounted at line 179. This was added to the number of lines in the frame 
storage area, 288, to get 467 possible line images before lines of data will be lost in the 
shifting down process. The hardware described in section 3.3.1 was thus set to a little 
less than this, 460 or so, to prevent corruption of the initial few lines before the data 
collection stage begins.
3.3 D ig ita l Controller E lectronics
3.3 .1  G eneral p urpose ‘w in d ow in g’ hardw are
The controller for this camera was based around a single digital circuit tha t was con­
trolled via an 8255 digital i /o  board [69] in a PC. The block diagram of this controller 
is shown in figure 3.4. The clocks were generated from a counter section and then fed 
out to the rest of the circuit via some enabling logic. Before an experiment starts the 
fast row clocks are enabled to the row readout drivers and the CCD. These row clocks 
are counted and, when a predetermined number have been sent to the CCD, the counter 
is reset and a single pulse is sent to the column shift circuitry. This performs a full 
three phase clocking cycle on both the frame and store sections of the c c D ,  shifting
59
E x p eriment _  
Trigger
Pulse I 
c ondit i o n e r  ,
i §
5 E n  ^  ^
1 i 2 1  ' êJ  i
Experiment
Enable
Past 
Gn clocks
En 0) ; 1 o■!i 3 G2 1
C C D  Image 
& Store 
Shifts
C C D  row 
shifts
Figure 3.4: Block diagram of the one dimensional camera.
the stored charge down by one row. This process repeats continuously and prevents 
the build up of dark current in the charge wells.
The number of row clocks sent at this stage, as well as the number used to read 
out the data described later in this section, is set to be the width of the CCD in pixels. 
In this case 388 pixels are being used per row but the hardware is able to handle c c D s  
with up 4096 horizontal pixels.
The clearing process will continue until the PC sends a signal tha t primes the circuit 
to allow a trigger input through.
When such an experiment start signal reaches the circuit, this clearing process is 
stopped and all the counters are reset to zero. The circuit waits for the falling edge of 
the experiment start and then begins issuing lO/xs pulses to the column shifting circuits. 
These pulses are passed on to the three phase generators and then through the high 
current drivers to the CCD. They are also passed from the three phase generator into a 
counter which counts the number of full three phase cycles th a t have been sent. When 
a predetermined number have passed through, this stage of the operation stops.
The number of column clocks, i.e. the number of frames tha t can be taken, is slightly 
less than the vertical position of the slit as determined in section 3.2.3. This ensures 
tha t a few lines can be read out before the actual data, allowing these lines to act as a 
buffer area for charge build up in the CCD when it is being clocked down. If these lines 
were not present then this extra charge would corrupt the first few frames of useful
60
data.
The 10/Lis pulses are generated by a counter that counts to the value of 2” +  1 . 
The most significant bit of the counter has a very long off time (counts from 0  to 
2 ") and then a single count of high output before the system resets. This resetting 
is achieved with just one 2  input n a n d  gate in the usual way. As can be seen this 
method minimizes the column shift time, and thus allows the frame time to be reduced 
by using a different value of n. In this way 5, 2*5 or even 1-25/zs frame times can be 
easily achieved. For the operation of this circuit, with an input clock of 1 2 MHz, the 
value of n  was chosen to be 7. This meant that the output pulses occurred every 129 
cycles or once every 10-75//S. The minimum that would be easily achieved would hence 
be a t n==l, corresponding to a frame shift of 4Mhz.
Theory dictates tha t the electron drift velocity within a CCD electrode field limits 
the maximum clocking speed of both the column and row electrodes. In the case of 
EEV devices analysis of this effect has shown that a normal t v  sensor cannot be column 
clocked at greater than 4MHz without blurring of the data occurring, and hence the 
recommended running frequency is quoted as 2MHz. Because of this the clocks fed 
into the three phase cycle generator were set well below this at 0-7MHz (1*4/Lis periods) 
giving a full three phase cycle of 4-29/^s.
When the photons hit the CCD surface they generate electrons tha t are pulled under 
the positive electrode. This will be the case for 6-46/^s of the 10-75/Lis pulse. For the 
remaining part these electrons will be formed under a moving field and it is not clearly 
defined as to which electrode they will be attracted to. If only one position on the c c D  
surface is considered then, in normal conditions, it can be assumed that the positive 
electrode is in the centre of the slit and electrons will always be closer to this than to 
the surrounding positive electrodes which are three positions above and below.
If the situation where this positive electrode has moved down one position is con­
sidered next, then the electrons will only be nearer this if they fall into the bottom  two 
thirds of the slit, otherwise they will be attracted to the upper electrode which is now 
just above the top of the slit.
For the next shift the electrons will now have to fall into the lower third to be 
attracted to the bottom electrode.
In this way it can be seen tha t it is well defined where the individual electrons will
61
be attracted but this position changes to the upper line a t some point. As the shift 
is occurring for 40% of the time this period of uncertainty will be for one third of the 
clocking time or about 13% of the full 10*75/is period. Optimization of the clocking 
period would have to be carried out to improve this resolution.
The final stage is the read out of the data. The arrival of the experiment s tart signal 
triggers a switch to the slow row readout clock. This has no effect on the apparatus 
until the lO^ ns pulses have shifted the data down to the predetermined point. However, 
when this stage has completed the slow row readout clock is used to read out the data 
in a slow scan mode. This readout is done in a similar way to the CCD clearing stage 
before the experiment start pulse arrived. Rows are clocked out and at the end of an 
entire row a single column shift is automatically done to allow readout of the next row 
of data.
A full circuit diagram of the digital controller is given in inserted figure V.
3 .3 .2  M icrop rocessor gen erated  controller signals
The original signals for this instrument came from an i /o  card containing an 8255 
driver. This allowed direct control from a PASCAL program on the PC and also had 
control of most of the signals including experiment start, fast or slow readout clocks 
and row readout enables. As the apparatus was developed further these were gradually 
automated with just a single line tha t acted as an enable switch when combined with 
the input signal available from the laser pulsing hardware. The i /o  board also provided 
an 8  bit data bus and the required clocking signals tha t were used to read out the stored 
data.
3 .3 .3  CCD drivers and reset pulse gen eration
The final stage to be designed was the reset circuitry for the CCD. This has to be part 
of the output cycle and obviously the time between the data becoming valid and the 
reset pulse defines the maximum time available for the A/D converter to complete its 
operation. This reset pulse can occur at almost any time over the three phase cycle, 
but in this case it has been fixed so as to optimize the valid period of the output. 
Figure 3.5 illustrates the timing of this pulse along with the control signals sent to the 
camera head.
62
..J
Rl
R2
R3
Figure 3.5: Reset timing for the CCD camera head.
The CCD requires 10-12V pulses to drive its row and column shift signals. These 
were generated from the DS0026 clock drivers. There are a number of different options 
to these, including the EEV hybrid parts and some Sony units. More details on such 
options are given in the appendix. Most of these are not designed to be used in non 
standard camera applications and were thus limited in their frequency ranges. Because 
of this the simpler DS0026 parts were used and were found to be very suitable to this 
type of drive application.
Because of possible crosstalk between the digital and analog lines the head was 
mounted remotely with the conversion to 12V being done on the digital controller 
board and then passed through ribbon cable to the analog head. It would probably 
have been advisable to also mount the voltage sources on this head to reduce the noise 
still further but, as will be seen later, crosstalk problems were so small as to  become 
part of the background noise signal.
3 .3 .4  Trigger inpu t pulse con d ition in g
The available laser driver, a Spectra Diode Laboratories SDL922, had a t t l  output 
representing the current pulse used to trigger the laser pulse. However, when analysed 
it was found to produce a signal as shown in figure 3.6.
This clearly needed a conditioner to allow it to be used to drive the experiment 
s tart signal. The design of this stage was based around a standard comparator setup. 
Table 3.1 shows a list of available parts and the final circuit is shown in figure 3.7.
The LM311 was chosen for this application as it has a bandwidth just able to handle
63
5V
ov
■5V- 2 6 . 5 0 0 0  u s 9 8 . 5 0 0 0  us  
Tim e
2 2 3 . 5 0 0 0  us
Figure 3.6: Oscilloscope trace of the laser pulse trigger output.
Figure 3.7: Circuit diagram of the input pulse shaper.
Device Supplier Comments
LM306
LM311P
LM311
Farnell
Farnell
R.S.
Only TTL and OC output 
Only 30V, TTL direct drive 
High current, high bandwidth
Table 3.1: A selection of comparator devices.
64
the required trigger speed.
A diode input limiter was needed to remove the negative going end pulse tha t 
would otherwise cause the comparator to saturate as the single supply rail output 
induces negative voltage mirroring of the input. The voltage setting was adjusted so 
as to make the unit trigger only on the primary start pulse, ignoring the secondary 
part. The input latches of the digital hardware required a minimum of 0-5 /iS  to latch 
the experiment start signal so the voltage setting had to be very precise so as to keep 
within the short pulse but also to provide a long enough pulse for the latches. This 
was achieved through a multi-turn pot.
3 .3 .5  IR laser analysis
Some of the more popular pulse sources are in the infra red spectrum , as generated 
by some solid state lasers. These have some advantages for this experiment as a fully 
opaque filter may be used to completely remove non IR wavelengths. This allows the 
camera to be run at normal room light levels without saturating the CCD.
The test laser used here, along with most medium length pulsed systems, has a 
minimum repetition rate of lOHz. This means that manual resetting of the system 
could occur during a pulse and hence affect the results.
In practice it was found that the use of the PC to prime the system worked well 
with this repetition rate. In the event of faster system being used, then a shutter could 
be incorporated tha t used one laser pulse to trigger its opening, then stayed open for 
the actual pulse to be analysed and then closed for the next one.
3.4 T he D ig itiz in g  Cam era H ead
3.4 .1  T h e CCD bias v o ltage  supply
The control inputs to the CCD consist mainly of the bias voltages and frame shifter 
signals. Because of the need for a self contained instrument it was decided tha t a 
dedicated power supply would be required to provide these bias voltages. The supply 
described in chapter 1  would have been suitable but it was felt tha t an alternative design 
for the low current supplies could be used to provide both a cheaper and simpler power 
source while still providing the functionality of the more complex designs shown in
65
figure 1.7.
A simple transistor stage was used to supply a constant voltage for the minor 
voltages (2 V and 6 V) and a 78L15 was used to generate a variable voltage for the 17V 
and 22V supplies. This was achieved by tying the ground inputs to a voltage divider 
and hence adding a fixed voltage level to the normal 15V output of this component.
The final circuit for this new power supply is shown in figure 3.8. This includes the 
5V, 24V and -12V supplies which are required for both the digital circuitry and the 
output amplification and processing stages.
3 .4 .2  A nalog  sign al con d ition in g
Processing of the CCD output stages is needed to first remove the DC offset 17V), 
then remove the reset noise and finally amplify the signal to the required output level. 
For slow scan operations of the type used for this camera the usual practice is to use 
capacitive coupling to remove the DC component, then use a dual slope integrator to 
reduce the readout noise of the CCD output and finally use a simple amplifier to obtain 
the required levels.
In order to test this type of circuitry a dual slope integrator was built as in figure 3.9. 
This worked as predicted but suffered very badly from noise pick up in the stripboard 
used for its construction. It was noted at this point that the readout noise of the CCD 
was in fact lower than a single unit of digitization for an 8 -bit A /D  converter (i.e. less 
than the saturation point -f- 256). This meant that the converter could be driven from 
the direct signal without the need for reset noise removal provided the dummy output 
was used to correct for the reset level errors (see appendix).
Figure 3.10 shows the block diagram of the output processing stages. The first part 
was a simple differential amplifier using an NE532 dual op-amp package. This part is 
nominally specified to work at a maximum input offset voltage of 15V. It was found, 
however, tha t the amplifier still worked well at the 17V offset voltage directly available 
from the CCD outputs. It was worthwhile using the amplifier in this way as the ability 
to DC couple the signals meant a significant increase in the accuracy and linearity of 
the amplifier stages.
The next stages are a gain and offset adjuster for the a / d  converter and then a 
limiter tha t provided active voltage clamping of the signal. This signal was then fed
66
H  f
— I \
Figure 3.8: The power supply for the camera electronics.
67
Figure 3.9: Experimental dual slope integrator.
CCD
Differ e n t i a l
Amp
G a i n  Stage Ac t i v e  C l a m pAna l o g
Out
Row, Store & 
Image Shifts
Input»10
A / D
C o n v e r t e rC l o c k
Inputs
15
IBM
In t e r f a c e
B o a r d
Figure 3.10: Block diagram of the camera head circuitry.
68
into the digitizing section.
3.4 .3  T h e d ig itizer  and d ata  storage circu itry
Originally the a / d  was the ZN439E. This is a successive approximation converter tha t 
has a clock period of down to 6 /is and hence provided adequate conversion time when 
the systems was completely driven by a PC and the data was read out into the PC 
as it was digitized. Analysis of the results taken at this speed showed tha t the dark 
current build up was too large for this approach to provide suitable accuracy and so the 
digitizing stage was replaced with a faster converter, the ADC304, as used in chapter 
1 .
The a / d  was set up so as to operate in the stable part of the output waveform. 
The reset pulses were optimized to allow this stable period to be as long as possible. 
The a / d  timing was also set so tha t the shifting stages of the ccD were causing the 
least interference. This was achieved by using the fast clocks and shifting the phase of 
the a / d  drive pulses so as not to coincide with the row clocks.
At the same time as the A /D  was upgraded, a storage stage had to be added 
so th a t the higher conversion rates could be met without being limited by the PC 
communications rate.
Because this circuit was mounted remotely to the other digital sections, the system 
had to be self contained, taking a minimum of extra signals. Two counters were used, 
clocked from either the row readout pulses or from a processor control line. When the 
experiment start signal comes into this stage, the counters are reset and then, when 
the readout stage starts, they are allowed to increment. These provide the address 
signals for a 32k byte memory chip. The digital hardware supplies the correct timing 
for the row readout pulses enabling the data to be stored sequentially in this memory, 
one pixel readout cycle always corresponding to one memory location.
The nominal parameters for the hardware were to look at a period of 200/iS in 
lOfis frames. This would require 388 x 2 0  =  7760 pixels. As the system can be 
run at much faster clock rates (up to lp,s per frame) this memory size would need 
to be correspondingly larger and the choice of 32k just about meets the maximum 
requirement.
When the full 32k memory has been filled, this part of the circuit latches up.
69
preventing further writes to the memory until the experiment s tart signal resets the 
circuit. This latching also passes onto the memory r d  and WR connections, switching 
them so tha t the memory now puts its addressed data onto the PC interface lines rather 
than reading data from the A /D  lines.
The processor on the PC downloads the data by toggling a direct control line into 
these address counters. This causes the counters to clock back to zero and hence 
present data to the 8  digital lines. Further pulses on the control line sequentially move 
through the address sp ace , the PC simply reading the data bus and then clocking on 
to  the next value.
A full circuit diagram of the readout and data storage circuit can be found in 
inserted figure VI.
3 .4 .4  F in d in g  th e  n oise levels on th is d etecto r
In order to find the noise of the amplification stages it was necessary to  remove the 
CCD and replace its outputs with a known, constant, voltage level. This meant tha t 
the loading on the row shift lines was not as it would have been were the CCD to be 
left in the circuit. As the digitization points were chosen so as to act when no shifts 
were occurring, this was not as large a problem as it could have been.
The substituted voltage level was set to about half the CCD saturation voltage level, 
about lOOmV, and an experiment run commenced. The mean output would now be the 
constant voltage source and the variance of this would be a measure of the noise levels. 
This assumes the noise level of the reference voltage source is low when compared to 
the circuit noise being tested. Given the source was a fully stabilized, regulated power 
supply, this was felt to be a reasonable assumption.
In order to analyse the results a program was written to examine the data  values 
and find their distribution. The noise was, predictably, Gaussian in nature and over a 
sample set of 388 x  80 data points had a standard deviation of 0*941 ADUs.
The a / d  used here has an inherent error of ±0*5 unit. This is an absolute error, 
always causing the result to be rounded by a random amount between 0.5 and -0.5. The 
cause of this error is in the way tha t most flash analog to digital converters operate. 
They choose an output value by comparing the input voltage to a set of known, fixed 
voltage levels. Internally there is a set of comparators, each of which is fed with one
70
of these fixed voltages and the input voltage. For any given input all comparators 
fed with a fixed voltage level tha t is less than the input voltage will turn  on. The 
comparator outputs are then encoded to a binary value and provided as output. The 
effect of this is to make the a / d  round down any given input to the lower signal. To 
improve this the voltages tha t are fed to the comparators are compensated to give a 
monotonie reading at 0 and 255, and hence the rounding is ±0-5 rather the between 0 
to + 1 .
Because of this behavior it is not easy to analyse the a / d  error in isolation. One 
possible way to do it would be to treat the a / d  error as a normal, Gaussian, random 
noise source, with o — 0 5. This would ensure error calculations were always within 
the correct parameters.
Fortunately a lot of data is available and this allows the effect of the a / d  and the 
amplifier noise to be considered as one noise source acting as a dithering value to help 
calculate the deviations. The value given above is thus representative of the compound 
error without the need to look at the causes separately.
This value is easily good enough for the purposes of the camera and, w ith the 
techniques for dark current subtraction described in subsequent sections, provides a 
very stable starting point for data analysis.
3 .4 .5  B a n d w id th  con sid erations
The bandwidth of the amplifiers was a major concern in this design as the high speed 
converter being used required a stable input to produce a reliable conversion. Tests 
of this were carried out by passing a square wave into the amplifier system and then 
analysing the output. The amplifiers were found to be slightly over-damped but had a 
full scale bandwidth of twice the pixel rate. This meant that it was possible to stabilize 
the output from a minimum to a maximum change on a pixel boundary and verified 
th a t the design bandwidth was within the required limits.
3 .4 .6  C orrectin g  for gain  d istortion
A major problem with all digitizers is the fact that they are usually not perfectly linear 
and are also not perfectly uniform in the voltage range tha t each unit converts over. 
Because these errors are systematic rather than random in nature they can be corrected
71
for.
Having built the amplifier and digitizing stages and verified the noise levels as being 
small, the next requirement was to correct for distortions both within the digitizer 
and within the amplifier stages driving the converter. To do this the amplifiers were 
calibrated to provide the correct gain and DC offset for normal operation. The CCD was 
then removed and the amplifier input pins were connected to a triangle wave generator.
The signal generator was adjusted so as to just saturate the input a t both the 
minimum and maximum voltages. When triggered the camera now acted as a simple 
digitizing oscilloscope, providing many frames showing the triangular waveform. The 
waveform could now be used as an indicator of the full scale gain of the amplifiers and 
allowed the DC oflFset to be analysed.
The amplifier gain was set to give a full scale reading of slightly larger than the 
maximum signal out of the CCD to ensure the complete range was covered. This was set 
up by trial and error using a helium-neon laser source. Once the signal generator was 
adjusted to give a full scale output the signal was found to be approximately 280mV. 
This compares well with the 200mV lower bound for the maximum c c d  output as 
specified in the literature.
The DC offset was set to 20mV, or so, so as to allow the minimum output levels to 
be clearly visible in the results.
The final stage in the analysis of the amplifiers is in the linearity of the a / d  itself. 
The ADC304 converter has an input pin linked to the centre tap on the converter 
resistor chain. This can be used to provide better linearity adjustment by tying this pin 
to a voltage reference set half way through the conversion range. This is set incorrectly 
in figure 3.11 and illustrates the distortion correction needed for the triangle wave 
input.
A program was written that took the data set and extracted the waveforms by 
looking for the first non zero value, reading till a saturation value was detected and then 
repeating the process. Because of the complexity of such an algorithm each line was 
output to the user to allow false readings to be discarded manually. These waveforms 
were then averaged in order to remove background noise in both the instrument and 
the signal source. The result of this should have been a straight line were there no 
distortion.
72
4—\250-
2 0 0 -
95  150-
100 -
50
0 50 100 150 200 250 300 350
Time
Figure 3.11: A triangular waveform used for distortion calibration.
By finding the equation of a line passing through both 0 and 255 this average data 
set enabled a correction mapping (in the form of a lookup table) to be deduced and 
from this the required correction factors for each pixel could be found. Each actual 
conversion reading is simply used as an index into the lookup array to find the correction 
factor. Figure 3.12 shows the results of this where the input (T-axis) is mapped to a 
corresponding output (?/-axis). As the resolution of the output mapping is higher than 
the input resolution the resultant output has to be non-monotonic. The values of 0  
to 1 0 0 0  for the output range gave a suitable resolution with only a small increase in 
required processing time. Thus the results can now be corrected for all gain distortions 
between the CCD output and the end of the digitizing process.
3 .4 .7  In itia l ca libration
Having got readings for the voltage input against a / d  reading, it is now possible to 
convert to charge and hence number of electrons detected. As only relative effects are 
needed for this application this is not too important but, if needed, can be deduced 
from the data  given in table 2 . 1  and the subsequent calculations.
From this data it is possible to show that an output range of 200mV corresponds 
to 339 X  10  ^ electrons. As the full scale output for this hardware is 280mV, then each
73
1000-1
800-Iï 600-
o
Io 400-<ut
Ü
200 -
0 50 100 150 200 250
A /D  output value
Figure 3.12: The distortion correction mapping.
division corresponds to
1  280—  X —  X 339 X 10  ^ =  1861e” per ADU.ZvO 2 UU
It was also possible to look at the saturation point for the sensor. This was done 
by increasing neutral density filtering of a HeNe laser until the sensor output was half 
way through the full range. This was a good working point, given the dark current 
build up tha t will be discussed later.
Once this half saturation point had been found, the laser power was measured 
and the beam profile was captured. The energy falling onto the CCD is now some 
fraction of the full beam energy, as measured by the power meter. Assuming the laser 
profile is Gaussian, it is possible to work out the peak intensity by considering the two 
dimensional Normal curve equation
p
27t<j 2
- i ( ^ ) (3.1)
Where P  is the total power of the beam (in Watts). For a HeNe laser of 0-806mW 
output power the measured beam power, after passing through a set of neutral density 
filters, was 0*343 it  0*001/iW with a background power measured at 0*024 ±  0*001/zW. 
This results in a power to the slit of 0*319 ±  0*002/xW when the room is completely 
dark.
74
By looking at a plot of the measured pulse as output by the experiment, it was seen 
th a t the peak intensity was 141 ADUs and hence the half peak height was 70-5 ADUs. 
The half peak height was measured at a point approximately 8  pixels from the peak,
i.e. 8  X 22-5/xm or 180/u.m.
For rigorous treatment, the required analysis is to look at the double integral
r + 6  r-\-6
However, as 6 (half the pixel width) is small compared to the size of the Normal, it is 
possible to approximate this to simply the area multiplied by the centre height of the 
function.
This means that, by taking the ratio of the maximum peak height to the half peak 
height the calculation to find a reduces to
and hence, with the x  separation being 180/^m, a is found to be 1 *5 3 x 1 0 “ .^
By substituting this into equation 3.1 it can be seen tha t the peak value of f {x ,  y) 
occurring at / ( 0 , 0 ) is
i  =  2-172 W atts
3.5 Dark Current
3.5 .1  T h eory  o f  dark current build  up
Dark current, otherwise known as the ‘fat zero’, is the build up of thermally excited 
electrons in the charge wells of the c c D  [70]. When the electrons in the semiconductor 
get excited into the conduction band, near to one of the c c D s  conductor electrodes, 
they are trapped by the potential under tha t electrode and appear as signal when read 
out.
Clearly this effect is dependent on both temperature and time. The build up with 
time is generally believed to be linear, but for large charge levels some saturation 
effects may be seen [71]. These are caused when impurities in the silicon absorb some 
of the free electrons. Once these have all been saturated the gain of the silicon should 
suddenly increase. As can be seen from results given later this effect is too small to
75
notice and the subtraction of dark current will take care of a large part of this problem 
anyway.
The dark current build up with temperature arises from the increased probability of 
an electron achieving the higher energy state when it has higher thermal stimulation. 
This follows the diode law
ÜSLO.
(3 2)
Under normal operating conditions Vbg is 1-1 volts. Using this, it can be seen th a t a 
IK  drop in temperature will correspond to as much as a 3.5% change in dark current. 
However, over the sort of periods being considered here (about 20 seconds for a single 
experiment), ambiant temperature was very stable and this amount of dependency did 
not cause any problems.
For the purposes of this experimental work, the sensor was not tem perature sta­
bilized, which would have required the use of a cold finger or Peltier system and the 
added complexity of having to prevent condensation via techniques such as using a 
vacuum envelope or passing nitrogen gas across the sensor surface. The added size and 
extreme mechanical complexity of these options meant tha t software correction would 
be the preferable solution. Because of the large temperature dependence of the dark 
current build up it would be necessary to correct the data at the time of its collection 
rather than using some fixed correction method for all data sets.
Some interesting work is being done into very low dark current devices [72], they 
are not yet commercially available however, and it may be some years before significant 
reductions in dark current levels are seen.
3 .5 .2  D ark  current build  up during a seq u en ce o f fram es
When run in complete darkness for 80 frames, the slow scan method of data  collection 
produced a set of blank frames that illustrated the build up of dark current. Figure 
3.13 shows the average reading per line, plotted against the line number. This is in 
effect a plot of dark current reading against time. This graph shows tha t the data can 
be successfully collected provided the illumination, when present, is kept to about half 
of the saturation level, thus allowing the dark current to build up without saturating 
the sensor. From the results of section 3.4.7 and a best fit line for figure 3.13 this can
76
30
25-
U 2 0 -
5  10 -
5 -
0 10 20 30 40 50 60 70 80
Frame Number (Time)
Figure 3.13: Average dark current per line vs. line number, 
be seen to correspond to a dark current build up, in one cell, of
The quoted value for this sensor [4] is 20000 electrons per element per second, so this 
compares favorably.
3 .5 .3  T h e rep ea tab ility  o f  dark current readings
Possibly the best solution to correcting for dark current is to be able to subtract a set 
of readings with no light (i.e. just dark current), from the one with both dark current 
and the required signal. The resultant should be the required signal but with added 
noise due to the error in the dark current readings when they are subtracted.
To verify tha t this technique can be used it must first be established that the error 
in the dark current readings is small enough to produce acceptable results.
To do this a set of five experiments were performed in close succession in total 
darkness. These were then compared via computer processing.
In order to fully analyse the data a best estimator for the error has to be found. 
Given tha t the dark current is discrete it should be possible to approximate its Poisson 
distribution with a Normal distribution, Àf{n,n).  The standard deviation for thermal 
build up is then dependent on the square root of the number of excited electrons. Given
77
the data  in chapter 2 , table 2 .1 , and using this Normal approximation, it is possible to 
show th a t the deviation of the dark current when it reaches half the saturation level, 
(an a / d  reading of 128) is y ® |M = 4 i i . 7  electrons, and hence the error is about |  of 
an ADU.
This is small, and visual analysis of the data confirms this slightly increases the 
deviations of readings a t large dark current values.
The other effect on the deviation is the dependence of dark current with tempera­
ture. This should be dependent on absolute temperature change as defined in equation 
3.2. The slight changes in temperature over the few seconds of data  collection, will 
have an approximate linear effect on the deviation build up. This should be minimal 
as the fractional change in absolute temperature is at most ^  =  3 4  x 10“ .^
As an approximation to the overall error for the experiment, rather than use a 
fractional error, the mean variance for the full data set was identified as a suitable best 
estimator.
This can be calculated by finding the mean of all the variances for each point in 
the five data sets. Any one variance, being based on only 5 samples, will be very 
inaccurate, but the mean over all 80 x 388 points will be much better defined.
The variance for this is defined by
Var =
N x M
E f  (%ij -- 27)2E
(3.3)M  X N
where N  is the number of lines in the experiment, M  is the number of data samples 
in one line and P  is the number of full data sets being averaged over.
In order to reduce this to a computable form, it is necessary to be able to build up 
intermediate results as analysis progresses through the data. The well known reduction 
of the standard deviation formula gives a new form of equation 3.3 defining
E  ^ ^ -^ e (e ^V
This can be calculated by keeping a set of values representing the values, one 
for each of the P  sets. As this is a small number (5 in this case) the result can be 
computed without too much difficulty.
78
4.0*10"'-
0 .0 * 10“
60 - 2 0 0 20 40 60
Deviation from the Mean
Figure 3.14: The distribution of the deviations for 5 dark frames.
The only other limiting feature of this method is tha t it requires, in this case, the 
storage of numbers as large as the sum of (388 x 80 x 5)^ =  155200% (of order 10^^). 
This is potentially larger than the maximum integer capability of most programming 
languages. In reality, this was not found to be too serious a problem as most of 
the numbers actually involved are smaller than the maximum 255 output and hence 
reduced the calculation to lie within the programming language constraints.
When processed in this way the data showed that the reproducibility of dark current 
was very good. Using the standard deviation derived from\/Var, and using equation 3.4 
to process the data, the deviation was found to be 1-352 corrected ADUs. Observation 
of the data in the worst case showed that the error can reach ± 1 0  corrected a d u s , as 
seen in figure 3.14 which shows a histogram built up from the deviations of every point 
from the mean of 5 corresponding points within the 5 data sets. It shows the noise to 
be very small compared to the peak output and also shows tha t the noise does have 
an approximately Gaussian spread.
This value includes the noise of the amplifier section as well. The result found in 
section 3.4.4 can be subtracted from the above noise value to obtain some measure of 
the reproducibility of the dark current tha t is independent of instrument noise.
If two independent Normal distributions A^ i and N 2 are subtracted then the resul-
79
tan t distribution has a standard deviation given by
From this the resultant error in the apparatus, cr, was shown to be 0-97 corrected a d u s  
for the mean noise value, and approximately 1 1  corrected a d u s  for the worst case value.
These noise levels are small compared with the range of the converter and hence 
the use of software error correction will give the required accuracy.
In order to deal with the errors rigorously, it is necessary to look at the form of these 
noise values. For the instrument noise the distribution is known to be approximately 
Gaussian and hence it can be expressed as a standard deviation, Oi.
For thse dark current reference frames, the noise figure, Cd, will be of the form
Cd =  +  (3.5)
where G{n) is a function of the number of electrons, n, and involves both the linear 
tem perature dependence (~  n) and the Poisson distributed dependence (~  y/n).
3 .5 .4  S u b tractin g  ‘dark’ fram es from  a fram e sequ en ce
Having verified tha t the dark current is reproducible within stable parameters it is 
now possible to subtract it from a data set provided that the time between taldng the 
dark frames and the actual results is small, thus guaranteeing similar temperatures. 
For even higher accuracy it would be possible to take a few dark frames before and 
after the experiment and then average over these. As the temperature in the available 
laboratory facilities only changes noticeably over a period of hours, this was felt to be 
an unnecessary complication but in extreme cases could be a useful technique.
Given the error, Q  hi a single data set, the mean of 5 such data sets will be known 
to Hence, when the mean dark frames are subtracted from the result frames, the 
new noise figure, Ç,  will be given as
Cr — \ / C j  ±  7Cd ,5
80
110-1
^ 1 0 0 -
90-
80-
liliUlAuuuLjnunru'70-
60
0 50 1 0 0 150 200 250 300 350
CCD Pixels (Time)
Figure 3.15: A single line output from a dark frame.
By substituting in equation 3.5 it can be seen that the rigorous treatm ent leads to
( r  =  ] j ~  [ \ / c r ï  +  Q ‘^ { n ) ^  ■
Using the mean figure and maximum values for the results are found to have an
error figure of 1-48 corrected a d u s  and 12 corrected a d u s  respectively.
3 .5 .5  F in d in g  p ixel w id th s from  dark current readings
Figure 3.15 shows a single output dark line. As can be seen there are a few pixels tha t 
appear to have a much greater signal than others. This is due to the fact th a t dark 
current is also dependent on the area of silicon involved [73]. Though CCDs are made 
to close tolerances, pixels are not always the same width, though it is true to say that 
all pixels in a single column have the same width. This fact can be used in conjunction 
with the above dark current readings to analyse the surface of the CCD and correct for 
pixel size variations.
The mean frame of dark current readings allows a very accurate record of the actual 
dark current build up parameters. As the data is only shifted between rows when it 
is read out, almost all the build up will occur when pixels are being stored somewhere 
within the CCD. Once the time dependency of the build up has been established for 
the entire experiment, by fitting a line to the entire data, it is possible to predict the
81
values for each single pixel with some accuracy. The difference between this predicted 
value and the actual reading for each pixel is an indication of the relative size of the 
pixel. Since the average pixel size is well defined at 22*5/zm, this difference is also a 
measure of the physical size of the pixels.
If this process is used for the entire frame, then many rows of data will produce 
values and these can then be averaged to produce even more accurate values for the 
pixel widths.
In theory, the same technique could be applied to looking at successive rows and 
hence a pixel size map can be built up for the entire cCD surface. In reality the pixels 
were found to be too small in variation for this last phase to be detected within the 
range of the available equipment.
3.6 R esu lts
3 .6 .1  F ully  corrected  fram es from  a pulsed  laser
The test laser for this apparatus was a diode pumped solid state laser producing 150mJ 
at 810nm and 1064nm. This is based around a NdYAG and AlGaAs crystal laser which 
produces a wide range of pulse shapes covering about 200/Lis maximum. These lasers 
can be set to trigger in different ways depending on the current applied and the pulse 
rate. In this case the laser was set to produce a fast peak followed by a couple of 
smaller peaks, as Gaussian profile pulses.
Having set the camera up to examine the output from this laser a few frames were 
taken and processed by removing the dark current noise as described earlier. Some of 
these frames are illustrated in figure 3.16. These illustrate the build up and decay of 
the primary laser pulse. The results were not as good as hoped for but still proved the 
principles of operation. The problem, as can be seen from the example frames is that 
the CCD is smearing the data out.
Two possible causes were identified, either the coupling was not good enough and 
the light was being spread out over a number of lines or the frame shifting was not 
very efiicient and the trapped charge was being smeared across the surface of the CCD 
as it was being read out.
Tests using a beam chopper showed that the latter was not likely to be the cause
82
200 220 240 260 280 300 320 340 200 220 240 280 280 300 320 340
(a) Frame 9. (b) Frame 12. (c) Frame 15.
200 220 240 260 280 300 320 340
(d) Frame 18. (e) Frame 24. (f) Frame 27.
200 220 240 260 280 3O0 320 340
(g) Frame 33. (h) Frame 36.
Figure 3.16: A selection of lines though a laser pulse.
83
as pulses generated by the beam chopper seemed to be slow on the rise as well as the 
decay side. If frame smear was to blame then only the decay side of the pulse should 
be affected.
This being the case the solution had to lie within the coupling mechanism. Un­
fortunately there was very little tha t could be done to improve this without getting 
some vendor redesign. Consultation with EEV showed that the mask layer, normally 
used to shield the store section, could be redesigned to allow a perfectly aligned slit 
to be made actually on the silicon surface. It was not believed possible to mount any 
external slit onto the CCD surface as the sensitive silicon requires chemical means to 
adhere things to it and glues would simply destroy the sensitive surface.
Another coupling problem would be if the beam is saturating the sensor. If the 
intensity was too great then the trapped charge would spread out over the surrounding 
pixels. This possibility was investigated by mounting the slit on a normal camera 
system. As the light could be contained within the one line, this was deemed to  be 
a valid test. Calculations could then be made to produce a similar power into the 
slit with the unusual shift times being taken into account. It was also verified that 
if a sharp edge was mounted cutting off part of the beam near to the slit, then this 
produced a similarly sharp cutoff for the light seen in any one line, thus ensuring tha t 
the horizontal spread was not a degrading factor in the image resolution.
It was eventually decided tha t a combination of the slit mounting and the frame 
shift was the cause of the problem. The effect was to reduce the frame time to only 
about 50^s. at which point the spreading out effect could be virtually eliminated.
Future analysis would take two routes. Either the column clock dependency could 
be analysed and maybe increased to the 3MHz possible from the existing hardware, 
or a very precisely aligned 6 /zm slit could be used. If the alignment could be made to 
within I  of a cell (i.e. over just one electrode), then the smearing of electrons would be 
almost completely eliminated. It should also be possible to use some form of adhesive 
to mount the slit very tightly to the fibre faceplate thus reducing light leakage.
3 .6 .2  D isp lay in g  im age sequ en ces as surfaces
One of the biggest problems with displaying frames from a sequence is seeing the detail 
in a usable from. The best method for analysis is a video type picture where the pulse
84
Intensity
350
Distance
Time
Figure 3.17: An example data set plotted as a (distance, time, intensity) graph.
is seen to run through its phases in a couple of seconds. The overall structure can be 
seen and if controls are added to allow individual frames to be seen as with a pause 
function on a v c R ,  then the detail can be further analysed.
One other useful form is to plot a 3d graph of time against distance across the pulse 
against intensity, i.e. a surface plot of the data. This form allows an overall view of the 
image to be presented and also provides the ability to see effects progressing through 
the pulse that are not so easily seen when individual frames are viewed without their 
relationship to each other.
In chapter 4 both software and hardware solutions to this type of display will be 
covered. Figure 3.17 shows the test data plotted as a surface representation. The pulse 
shapes can be seen and their relative timing is also made obvious.
3 .6 .3  T he pow er vs. tim e relationsh ip
Figure 3.18 shows an example plot of output power against time for one form of the 
pulse setup, found via a digitizing oscilloscope and a fast optical diode. It should
85
I• 17 . 5000 us 7 . 5 0 0 0 0  us  
Time
3 2 . 5 0 0 0  us
Figure 3.18; Power against time for a NdYAG laser pulse
be noted tha t the pulse positions are the same for those used in figure 3.19 but the 
intensities of the peaks varies greatly for pulse to pulse.
In order to test the camera with a comparison, a program was written to integrate 
the power in the pulse frames and hence produce a power against time relationship 
from the camera data. This program summed all the data values for a line and used 
tha t value as the power rating for this line, effectively integrating the beam power and 
hence representative of the pulse at tha t time.
The results of this are shown in figure 3.19. As can be seen the power spread across 
the surface has had the effect of smearing the pulses out along the time axis. Even so 
it is still possible to see the basic structure.
86
50
40-
. >  2 0 -
1 0 -
5 10 15 20 30 3525 40
Frame Number
Figure 3.19: Power against time generated by frame integration.
87
C hapter 4 
A  hardware Solution  to  Surface  
G eneration
4.1 Introduction
4 .1 .1  O b jectives
The intensity of light emanating from an area of a surface is affected by many factors, 
the most obvious being the intensity of the incident light and the reflectivity of the 
surface. The study of representing different objects has become a vast research area 
and a large amount of work has been done on generating faster and more accurate 
models for computer imaging. The most common form of hardware solution has been 
to carry out computer analysis of the image data as fast as possible. While this has 
led to some of the spectacular images seen in modern computer literature it has not 
yet addressed one vital area of object representation - namely the representation of 
intensity surfaces on two dimensional screens in real time. It is one of the purposes of 
this chapter to remedy this situation.
The simplest form of this type of data is tha t generated by area detectors where a 
sensitive area, in the (cr, y) plane, is used to detect an intensity signal at regular spacings 
of X and y within tha t area. Since CCD image detectors produce {x ^ y intensity) data 
values representing the intensity of incidental light on a surface they form an ideal 
source of such images.
As described in chapter 3 the need to display such 3d data on a 2 d  screen has not 
been adequately explored. In particular the requirement for fast, real time displays 
has become apparent as complex rendering algorithms take time and require expensive 
computer analysis hardware. One solution to the display of area detector images will be
88
presented here along with an investigation into the sort of hidden line hardware needed 
to provide intelligible representation of these intensity surfaces. A few improvements 
to the standard algorithms tha t have been used for simple image representation will 
also be discussed
4 .1 .2  Full w ire fram e gen eration
The use of wire frame representations allows graphical data to be viewed in such a 
way tha t the gradients on the curves are visible. Lines tha t are close together repre­
sent shallow gradients while those that are widely spaced indicate large gradients (the 
opposite of contours on a map).
Another major advantage of surface, rather than grey-scale, image representation 
is th a t details are shown as linear effect. Unfortunately both the human eye and 
most graphics displays have non linear intensity responses to grey-scale images tha t 
prevent them from being able to differentiate between small changes in very bright 
or very dark images. Chapter 1  shows these effects along with some possible image 
enhancements tha t improve the information content for the human eye. Examples of 
the visual benefits of surface representation will be given later on in this chapter.
Figure 4.1 shows how a wire frame surface is displayed on the screen. Two adjacent 
points in the real world grid are mapped onto the screen, and then the two screen 
points are joined by a straight line. Lines are drawn so as to connect all adjacent 
points along the æ-axis (figure 4.1a) of the image and then along some lines parallel 
to this (figure 4.1b). Next, lines are drawn connecting all the adjacent points in the 
2/-axis (figure 4.1c) and finally some lines parallel to this axis (figure 4.Id).
The representation of the surface also depends on the observation point relative to 
the surface. For example, if the intensity is constant for all points on the surface, and 
the surface is viewed from a long distance down the ^-axis {intensity) a simple grid 
would be displayed on the screen (figure 4.2a). If the viewing point is then rotated 
round the a:-axis, the displayed image would change so that the squares compress in 
one direction (figure 4.2b). This eventually becomes a single line when the image is 
viewed from along the t/-axis i.e. viewed edge on. If the viewing position were to be 
rotated about both the x  and z axes then the plane would be viewed as in figure 4.2c. 
This is the type of view th a t will be dealt with in this chapter. The correct mapping
89
(a) Draw x axis. (b) Draw parallel axes.
X
■I
(c) draw y axis. (d) draw parallel axes.
Figure 4.1: Building up a surface representation.
from world to screen coordinates depends only on the rotation angles to the x  and z 
axes and the {x, y) coordinates in the image surface.
Figure 4.3 shows how the surface is viewed (in only one dimension). It also illus­
trates how the perspective is kept correct by this method of displaying the data. The 
value of hx can be found via
«“ (^0  =
  hj;
T ’
and hence
h X d
Clearly, the height of the image is proportional to the inverse of the distance between 
the eye and the object. This theory can be extended to find h y  (3 d  to 2d ) and even 
h z  (4 d  to 3 d ) representations
90
Y
/|\
Y
A
(a) Viewing from above.
X
(b) Rotated about the x 
axis.
^ x
(c) Rotated about both x and y axes.
Figure 4.2: Changing the viewing position of a plane.
Object
Screen
Figure 4.3: Viewing an object through a screen
91
JL
Figure 4.4: The vectors representing a small surface area.
4 .1 .3  R ay-tracin g  and shading
Shading is one of the more complex parts of surface generation. The usual simplifi­
cation for ray tracing algorithms is to remove texture calculations when displaying a 
surface. This is justifiable since, as there is no physical reality to an intensity surface, 
an algorithm must create some form of artificial texture for the image. The second 
simplification is to ignore reflections between some parts of the surface and others. 
Once the coordinates of the light source have been specified, it is simply necessary to 
calculate the angle between a vector from the light source to the object and a vector 
normal to each surface element. The cosine of this angle represents the reflected light 
fraction tha t would be seen by an observer looking along the vector of the light source 
and can be used as an intensity value for the element when it is displayed in 2d . The 
scaling of this value, necessary to create integer values of pixel intensities, is a form of 
representation of the texture and hence reflectivity of the object.
W ith reference to figure 4.4 the points A, B  and C can be expressed by two vectors, 
a  and b  where
a  =  c 3 ,
and
b = CB.
92
Firstly, the normal vector to this plane is required. This is given by
a  X b  =  |a | |b |s in ^ .n ,
where n  is the unit vector normal to the surface and 9 is the angle between a  and b. 
This can then be reduced to get
a  X b  =  {ayhz — dzi>y)  ^+  {d^hx — dxby)j +  {dxby — dybx)l^> (4.1)
By considering the vector 1, which is the vector from the light source, L, to the 
surface element, it is possible to find the angle, <j6 , between this vector and the normal 
vector found in equation 4.1 using
1 • (a  X b ) =  |11 |a  X b | cos ^
and hence
cos 9 1 • (a  X b )|11 |a  X b | ’
d x d x  T  d y d y  ~f“ d ^ d z
+ al + a l ^ d l  + dl + d\
Where d  is the vector product a  x b .
Quite clearly this is very computationally intensive. Even for powerful computer 
facilities, full frame generation can take as long as 30 minutes.
4 .1 .4  H id d en  line and h idden  area rem oval
There are three ways traditionally used to remove hidden parts of 3 d  objects: The 
hidden sections can be calculated from the coordinates of the surrounding objects; 
some visual trick can be used tha t makes use of the two dimensionality of the screen 
or the resolution of the screen can be employed to achieve the required effect.
The first of these involves large amounts of computation even for line drawings. 
Every line must be intersected with every other line tha t could be in front of it and, 
if they are found to be overlapping in the particular projection being used, then only 
the visible parts are displayed. The extension of this to area intersections is used 
to  allow shaded hidden area removal. Some reduction in the computational require­
ments of this approach have been achieved but it is mostly the application of surface
93
draw ing techniques to  m ore com plex 3 d  rendering th at has drawn the a tten tion  of 
researchers [74, 75).
Both of these methods are very versatile, and can produce correct images from any 
viewing point and any orientation. However, even for very powerful computer facilities 
this sort of calculation takes a long time and only supercomputers can achieve speeds 
approaching real time rendering, and then only for simple images. Techniques such 
as sorting the image data into depth related order can help to limit the number of 
calculations needed but such algorithms are still too complex for effective hardware 
implementation.
Because of this complexity a number of simplification techniques have been devel­
oped. If it is possible to draw the areas that make up a shaded surface in such a way 
th a t once drawn an area can only be obscured, and can never itself obscure areas tha t 
are drawn later, then it is possible to draw the image starting with points furthest 
away and then moving to those closer in to the observer. Each area will now be drawn 
over any sections tha t are behind them , thus obscuring them. The area may in turn be 
obscured by something tha t is drawn later but cannot appear in front of such a later 
addition. Once all the shading has been achieved, the correct ‘solid’ im age is displayed.
This same technique cannot be applied to wire frame drawings because there are 
no shaded areas to blank out hidden parts. One solution is to blank out the areas 
between the lines by pretending that they are shaded in black. This works well, but 
still requires very much more calculation than the wire frame drawing on its own would 
have needed. However, if the surface is drawn from front to back as with the shaded 
versions the following algorithm will work just as well and has the added advantage of 
requiring very little computer overhead.
This algorithm will display wire frame surfaces provided the projection conforms 
to the above restrictions.
1. Draw the line that is furthest from the observer.
2. Draw any line that is in the same plane as this one.
3. Start to draw the next furthest line.
4. Each point that is to be drawn has a position on the 
screen given by X=x,Y=y, compare this point's y 
coordinate to the y coordinates of any other points 
plotted on the same vertical line (i.e. on the line X=x)
5. Plot this point only if there are no points above it or
94
there are no points below it.
6. Repeat this for all lines in the same plane as this one
7. Repeat this for all remaining planes in the image.
As can be seen the image is built up from back to front making use of the resolution 
of the display to simplify the calculation.
This method is the basis used for the hardware implementation tha t will be covered 
in the following sections. All the data used comes from a grid such as the cells on the 
surface of a CCD. If the image is displayed such that the x-axis of the CCD is parallel 
to the horizontal axis of the screen, and the intensity signal for each point is parallel to 
the vertical axis, then there is one more simplification available. If the image is built 
up by starting with the lines connecting (0 , 0 , zq) and (1 , 0 , z\) then the only lines that 
are in the same plane as this one are those with y coordinate of 0 . It is then possible 
to build up the image as a set of lines from
( 0 , 0 ,  zo)  - >  ( 1 , 0 ,  z i )  - >  ... ( n , 0 , 2 n )
and to know tha t all of these lines are in the same plane and hence do not overlap.
This technique is not true for lines drawn in the planes where # i s a  constant, such 
as the lines from (0 , 0 , zg) to (0 , 1 , zi), as these are not drawn in the depth first order. 
Because of this it is necessary to use only the lines parallel to the x-axis and ignore 
those parallel to the i/-axis. As will be seen in later examples this does not detract 
significantly from the appearance of the image.
4.2 Fast Software Solutions
4 .2 .1  S im p lification  o f v iew in g  angle
When the mapping from 3 d  to 2 d  is done, it is usually necessary to define both a 
viewing position of the eye and a position of the screen in the coordinate system of 
the surface to be displayed. The screen coordinates are deduced by finding the point 
a t which a line connecting the viewing coordinates to the surface element intersects 
with the screen, as described earlier. For drawing purposes however this mapping can 
be viewed as simply the incorporation of the real world y axis into the x  and z axes 
to form the x  and y axes of the screen. This is the way a normal technical drawing is 
done.
95
Xs= Xr+Yrsin(0) 
Ys= Zr+Yr-sin(0)
■r
Real world (3D) Coordinates
Ys/K
Screen Coordinates
Figure 4.5: The screen and world coordinates
Figure 4.5 shows the representation of the a;, y and z axes in this form. The standard 
projection is obtained when the angle 9 (as measured on the page) is 30°. However, in 
general the mapping follows the form
Xs ~  Ær +  2/r sin(^),
Vs =  Zr + 3/r C 0 S ( 9 ) .
Where (xs.Vs) and {xr,Vr^Zr) are coordinates in the screen and real world (3d) coordi­
nates respectively.
This poses the first obstacle to finding a hardware solution, namely the need for 
trigonometric functions, which are inherently difficult to implement in hardware. For 
practical purposes the projection can be fixed, and the sine and cosine values can 
be hard-coded as two real numbers. This still presents complex hardware problems. 
However, if the projection is changed so tha t 6 — 45° then the y axis of the real world 
coordinates will be displayed on the screen as a diagonal line defined by the equation 
ys =  Xs. The 45° projection defines sin 45° =  cos45° =  0-707. By approximating this 
value to 0-75 it is now possible to calculate the mapping by a simple multiplication by
Hence, with a 6 % error it is now possible to define the mapping as
3Xs — Xj- -f* ^2/rj
Vs +  ^ 2/r-
Since the minimum change tha t can be made in ys is one pixel, the approximation 
of sin 45° =  0-75 cannot be used for y values that are not multiples of 4. this means
96
6
5
4
3
2
1
0
Xs
Figure 4.6: Part of a surface representation with constant z values.
th a t some information must be lost if a VGA type display is to be used as the 640 by 480 
resolution prevents the required scaling in either axis tha t would allow all the available 
data to be used. Because of the simplification of mapping Xr pixels to Xg pixels on a 
one to one basis, it was decided to simply use every fourth row from the CCD image.
In this way (0,0, zq) maps to the screen coordinates (0, Zq) and the next pixel in the 
yr axis that can be drawn is (0,4, Z4 ) which maps to (3, Z4 4 - 3). For a plane defined by 
z =  0, this will appear as in figure 4.6.
Visually it was found tha t the multiple of three for the ys axis was not essential. As 
can be seen from one of the later examples (e.g. figure 4.13) the use of an offset of just 
one pixel gave very good results. The larger the gap the more ‘above’ the surface the 
observer appears to be. Because of this new simplification, the surface can be plotted 
by taking every fourth horizontal line from the CCD image and displaying it offset by 
one pixel in both the Xg and yg axes for each line plotted.
Because the final aim is to produce a camera system tha t outputs general surfaces 
this fixed projection would appear to be a serious limitation. However, in order to 
change the view it is simply necessary to rotate the camera about its longitudinal axis 
rather than change the image projection. This will have the effect of rotating the 
surface without changing the projection method.
The need to get images from a camera did however cause one problem. The lines
97
parallel to the y axis can only be drawn when the next line data is available. Examples 
were examined to determine alternative methods and these showed th a t given sufficient 
numbers of horizontal lines, the vertical lines could be ignored and the images could 
still be correctly interpreted. The real life example given later illustrates this quite 
well.
The initial complex surface generation has now been simplified to looking at every 
fourth yr value and hence the mappings
Xg ~  Xr ~\ { yr  ~  0 , 4 , 8 )
and
ys =
As can be seen a hardware counter can provide the values of yr and and as 
values are read out from the CCD the resultant Xg and y g can be found by using a simple 
adder circuit to combine the yr value with the Xr and z  ^ {intensity) values respectively.
4 .2 .2  Shading a lgorith m s
Simplification of the shading algorithms is more complex. Two techniques were tried, 
using visual properties of surfaces to allow simplifications in the calculations.
The first method used was to display the shade as a function of the area taken 
up on the screen. This is based around the fact tha t when these areas are large, the 
gradient of the surface is also large which in turn means tha t the angle to the observer 
is smaller. Unfortunately, this only applies when the areas being considered are angled 
in only one plane. W ith a surface there are two axes of rotation and hence it is possible 
to invalidate this algorithm.
It was found tha t when implemented on a 12MHz 80286 PC, a 50 by 50 grid took 
42 seconds to display using a grey-scale image of only 16 shades. An example of this 
type of shading is given in figure 4.7.
Figure 4.8 shows the typical situation. The shade of the quadrilateral is improved 
by splitting it into two triangles and dealing with each separately. The area of an 
arbitrary triangle is given by defining
+  { A y  -  B y f
98
A B
Figure 4.7; Results of using area to define shade.
Figure 4.8: Surface generation using shade proportional to area.
99
/ 1 pixel
— H 1^
Figure 4.9: Area calculation by using single pixel widths. 
& == -  C a:)' +  %  -  C y)" =
C =  y (Ca; —  4- { C y  —  A y Y  —
B C
AC
a 4 - 6  4 - c
and
area =  ^Js{s — a){s -  b){s — c).
Unfortunately this is still very hard to calculate in hardware. One solution is to 
make use of earlier simplifications in the wire frame drawing. Here each horizontal cell 
of the CCD is mapped to one pixel on the screen. This means tha t the width of the 
quadrilateral is only one pixel. Hence the area becomes the difference between the ys 
value of this pixel and the corresponding ys value of the pixel in the previous row tha t 
is positioned at the same Xs coordinate. This is shown in figure 4.9 where the area is 
proportional to ygl — ^g2. When implemented on the PC this algorithm reduced the 
rendering time to 30 seconds for a full cC D  image rendered on the display hardware 
using 256 grey shades. The results in figure 4.10 are from an image tha t was generated 
by reading the frame buffer into the PC and then sending the.surface image to the 
graphics display hardware after processing it for shading.
This example also illustrates one other change. It was found tha t if the shading 
was gradually reduced from front to back, then an improved result was obtained giving 
the impression of reduced intensity with distance from the screen.
100
Figure 4.10: Results of single pixel width area calculation.
Visually, these techniques gave very good results for most simple surfaces. The 
results can be compared to figures 4.11 and 4.12 which were generated by the vertical 
difference and the full cosine reflection methods respectively.
4 .2 .3  H id d en  line rem oval
The simplified projection described earlier makes it possible to modify the hidden 
line removal algorithm to make it simpler to implement in hardware. The projection 
requires tha t every new horizontal line taken from the CCD image has a start point one 
pixel to the right of the previous lines start point. If it is decided to map one CCD cell 
to one pixel on the screen then it is no longer necessary to connect these two pixels 
with a line. In most cases they will be very close together on the screen and only when 
high gradients are being displayed will they be far enough apart for the missing pixels 
to become evident. The results of this can be seen in figure 4.13 where only the peak 
areas in the centre show significant reduction of quality. It should be noted th a t this 
effect is very much less pronounced in the hardware versions as the oscilloscope beam 
is continuous and hence ‘fills in’ the missing lines.
101
Figure 4.11: Brass cutout image shaded using vertical differences.
Figure 4.12: Using light vectors to generate a full surface representation.
102
J
Figure 4.13: Example wire frame using only the x  axis pixels.
There are now only hidden pixels rather than hidden lines to be removed. The 
removal of these pixels is done by using Xs as an index into an array where the greatest 
value of Us used at this value of Xs is stored. If a pixel has a ys value greater than the 
stored value then it is displayed and the stored value updated. If the pixel has a ys 
value tha t is less than tha t stored then it is not displayed. This only takes care of the 
top half of the image. It is possible, as the previous algorithm illustrates, to see the 
under-side of the surface. This is achieved, in a similar way, by using another array 
th a t contains the minimum values of y s. Now, for any given Xg, ys pixels are displayed 
when they are less than the stored value.
When executed on a PC reading the CCD frame buffer, the rendering time was 
reduced to 2 * 8  seconds for this method.
4.3 B asic H ardware Solutions
4 .3 .1  A d a p ta tio n  o f a lgorith m s to  hardw are
In order to design a real time surface generator certain parameters had to be set. 
Firstly a refresh rate had to be established. Normal pa l  t v  uses 50Hz but tends to
103
generate eye strain and can produce visible flicker in some cases. Because of this it was 
decided tha t the screen refresh rate would have to be closer to lOOHz to give a good 
quality display.
Fortunately the image update frequency does not need to be this high. The human 
eye tends to be only able to spot changes over about 100ms or so, hence with a stable 
image provided by the lOOHz refresh rate, the image update rate can be as slow as 
lOHz.
The type of display also had to be defined. The normal, electromagnetic, displays 
are inflexible and very limited in their capability so it was decided to make use of the 
higher bandwidth and beam gating capability of an oscilloscope’s electrostatic display. 
Because of the variability of the vertical input gain, it was also possible to have a 
scaling of the image vertically. A larger input gain leads to a larger vertical offset 
between rows, thus the correction for the 4 line vertical spacing needed to meet the 
theory could be set quite accurately.
The display selected was an 80MHz Hameg oscilloscope. The flyback can be accu­
rately controlled on this device and the availability of trigger delay inputs meant tha t 
the unit could be better tailored to provide special display requirements.
In order to update the image being displayed, w ithout causing flicker or loss of 
picture, it was decided to build the generator with a double memory system. The data 
in one memory block being output to the screen while the other is being set up. A 
single write instruction from the Z80 processor will then flip the memory banks over 
and the new data will be displayed and the old will become available for updating.
Figure 4.14 shows the block diagram of the basic hardware. As can be seen the 
ability to turn off the display when no pixels are to appear was achieved by using 
the most significant bit of the data store as an output driving the beam gate input of 
the oscilloscope. This made it possible for the oscilloscope beam to be turned off at 
any point in the output waveform, a t the expense of only allowing 7 bit data  to be 
displayed.
The memory addresses were initially accessed by a counter tha t counted sequentially 
through the r a m  addresses 0 to 32k. This was set up as 512 pixels per row and 64 
rows so as to enable a one to one mapping from CCD cells to output pixels. There are 
388 pixels on a CCD row and this choice of RAM configuration gives a maximum y value
104
15
15
7 bit 
D/A
Output
Buffer
15
15Address
Bus msb ScopeEnable
Bank
Select
Data
Bus
Clock Voltage
Reference
MUX
sel
15 bit 
counter
RAM 
Bank 2
RAM 
Bank 1
Figure 4.14: Block diagram of the initial hardware.
of 64. This maps to a maximum Xg value of 388 +  64 =  452, hence a 9 bit address is 
required.
As there are 288 lines on a CCD, and every 4 lines are to be displayed, the ideal 
would be to have 72 lines displayed. Unfortunately the 32k limit only allowed 64 lines 
but, as can be seen from the end results in figure 4.19 this did not significantly degrade 
the image.
The circuit was developed to attach to the frame grabber, camera and display 
hardware developed in chapter 1. This allowed the board to be directly accessed by 
the Z80 processor and indirectly by the PC controller. The RAM was accessed directly 
via the Z80 address and data buses, and the two banks of RAM were switched via status 
line outputs from the processor board, thus allowing the switch from one bank to the 
other to be done in a single write operation as defined earlier. This board also provided 
all the timing signals, such as vertical blanks, tha t are needed for such a system. Were 
this hardware to be provided as an in line unit for a normal video signal it would be 
necessary to extract the vertical and horizontal synchronization signals and use these 
to detect every fourth row and put it into the surface generating RAM.
Another advantage in  using the frame grabber hardware was tha t the RAM layout
105
u sed  for th e  fram e sto ra g e  w as four w ay  in terleaved  and  h en ce  tran sfer o f  every  fou rth  
lin e  for su rface ren d erin g  cou ld  b e  d on e  from  on ly  on e p h y sica l RAM chip .
4 .3 .2  M u ltip lexors
The normal t t l  multiplexor, the 74LS257, only provides one 4-bit output set, the 
selection input routing either the A or the B inputs to the outputs. For the purposes 
of the bank selection a multiplexing system was devised tha t would allow a control 
input to either route A to 5i and B to S 2 or to route A to S 2 and B to 5 i. This was 
engineered by a 16v8 GAL, with logic outputs and S 2 defined by
Si — (ctrl A A) V (ctrl A ,
5*2 =  (ctrl A a ) V (ctrl A B ) .
W ith the 20 pin package it was possible to have four such sets all driven from a 
common control input, replacing the two 16 pin devices needed to do this in discrete 
TTL.
4 .3 .3  O utp u t filters
The output of this memory was now sent to an d /a  unit, the PNA7518 [5], and then 
through a buffer amplifier and on to the oscilloscope voltage defiection input. Very
quickly it became evident tha t the bandwidth of the scope was too good for our pur­
poses as the beam stepped up to each value too quickly and the expected filling in of 
the lines between each pixel (section 4.2.3) did not happen. This problem was over­
come by filtering the display output. An active, 2 pole, Chebyshev filter was used for 
this purpose.
W ith reference to figure 4.15, the time constant is given by
where /o has the dimensions of s“ \  fn is dimensionless,
for 0*5dB ripple,
for 2-OdB and higher speed tailoff
106
fn = 1-231
k =  1-842
fn =  0-907
k =  2-114
Vin >
5  . 3 S p
Figure 4.15: The Chebyshev filter
and k is the voltage gain of the amplifier stage.
As the circuit is using 1024 x 32 bytes per frame and 100 frames per second the 
clocking speed for the pixels is 3-28MHz. For the 2-OdB tail off, equation 4.2 gives 
rc ~  5-35xl0~®s and, choosing r to be comparable to the op-amp input impedance, 
say lOkn, c is now found to be 5 35pF and r{k — 1) =  ll-14kfi.
Along with a simple, low noise, voltage reference for the d /a  this completed the 
analog part of the circuit. Because of the video rate operation of this circuitry, the 
voltage source had to be very stable. An MP5010 1-22V fixed voltage reference was 
used. This fed an OP-27 low noise instrumentation amplifier, wired as a non-inverting 
gain stage. The complete circuit diagram for the first stage surface hardware is given 
in inserted figure VII.
4 .3 .4  T h e firm ware in terface
Before an image was generated the processor waited for a vertical blank period and 
then did a frame grab. Once available, this data was used to fill the surface RAM. It 
was then necessary for the processor to do all the mappings from real world to screen 
coordinates.
Each line seen on the display represented 512 pixels. For the first line of the image
107
the processor had to fill in the first 388 bytes with the corresponding first row of the 
CCD frame store. As the most significant bit was needed for the gate output, this data 
had to be shifted down by one bit (i.e. divided by 2). It also had to be shifted by one 
bit again so tha t the vertical component of yr could be added in to give the ys value. 
For the rest of the 512 bytes in this row the processor put in a value with the most 
significant bit set (in this case 128). The hardware monitored this bit and, when set, 
the beam was turned off. In this way the line being drawn would appear to end part 
way across the screen.
For the next 512 bytes, the processor set the most significant bit of the first byte, 
thus achieving the addition of the yr component in the horizontal axis. The processor 
then moved the fourth line of image data into bytes 2 to 389 of the display, performing 
the two shifts and adding in the \yr  value (i.e. for this line adding in the value 1) to 
each byte as it placed it in the memory. Finally the processor set the highest bit of all 
the bytes in the rest of the row to prevent them from being drawn.
This process was repeated for each line until the entire 64 lines of the frame buffer 
had been sent to the display. Once finished the processor changed over the memory 
banks and the new data became visible.
Finally the whole procedure was then repeated for the second memory bank and 
then back to the first, thus providing continuous update of the image,
4 .3 .5  H id d en  line calcu lations in softw are
The simplest method of achieving the hidden line removal was to read in the frame 
buffer data into the PC, carry out the hidden line routines and then output the data 
to the surface generator via the Z80. The routine to do this achieved good results but 
was slow as all the transfers between the PC and the Z80 are very time consuming. 
The best results achieved frame rendering in 40 seconds. This was done by using only 
integer calculations and optimizing the code that read in the CCD data so tha t it only 
accesses every fourth line.
4 .3 .6  R esu lts  from  a Z80 im p lem en tation
Once the code had been developed in PASCAL, it was now possible to rewrite it in Z80 
assembler thus considerably speeding up the process. Running on a 6MHz processor.
108
Figure 4.16: Block diagram of the full surface generator.
the rendering, timed over 100 frames, was now reduced to 1-066 db 0-005 seconds 
per frame when the Z80 was running in polling mode, and when dedicated to frame 
rendering this time was reduced to 0-954 db 0-005 seconds per frame.
4.4 H idden Line Hardware
4 .4 .1  A d a p ta tio n  o f h idd en  line a lgorith m s
Having developed the basic display hardware the next stage was to look at implement­
ing the hidden line algorithms in hardware. The software described earlier consists of 
three parts: the addition of the y,. component into both Xr and Zr (to generate Xg and 
ys) and the hidden line removal. These also convert into three functional blocks of 
hardware as illustrated in figure 4.16
In order to add in the yr component into Xs two counters and a comparator had 
to be added to the original circuit. One counter counts up from 0 to 511. This 
represents the pixel count for a single line. This counter then triggers the second 
counter to increment the number of lines displayed. This is similar to the original 
system , however, a comparator is used to compare the output of the pixel counter to 
the output of the line counter. By making the circuit inactive while the pixel counter
109
is less than the line counter, a time delay which is proportional to the line number, 
is produced. This provides the left hand offset of the image line, effectively doing the 
mapping of yr into Xs-
When the comparators a= b  output goes active, it is latched to prevent further 
changes (which would occur every 64 clocks as only 6 bits are used for the comparison) 
and then fed into an a n d  gate along with the clock signal. This permits the original 
pixel clock signal to get through to two more counters. One of these counters provides 
addressing for the data r a m  and will output successive values to the display. This is 
only reset at the end of a full display output. The other counter is reset before each line 
is output. It counts the input pulses until it reaches 388. When this value is reached, 
the counter is reset and a signal inhibits the clock pulses going into the address counter. 
The pixel counter will continue counting until it reaches 511, thus putting in the time 
delay needed to make each output line the same duration.
The ability to stop the pulses getting through to the address counter means that 
it can simply be left where it is and will start from this new point when the next 388 
pixels are to be read out. This allows the data from the frame buffer to be transferred 
all in one block as the break up of lines for this circuit is now the same as it is for 
the frame buffer (i.e. both are simply contiguous). Unfortunately this does not give 
more ys output capability as the next possible increment to the number of lines would 
be 128 and there are only 72 available from the c c D . The large delay tha t this would 
result in would add flicker to the display as it would also halve the refresh rate.
One problem that can now be solved is the presence of the saturation line that 
appears when the CCD image is shifted dow n. For the normal camera image this 
appeared as a bright line at the top of the screen, but, if this were to appear in the 
surface representation then a ‘wall’ would appear in front of the required image. As 
the frame buffer is laid out in an interleaved system the image does not have to be 
taken from the lines 0, 4, 8 etc. and can in fact be taken from the image at lines 3, 7, 
11 etc. by taking the image from the fourth interleaved memory block, thus ignoring 
the saturated lines in the image.
When the final, 64th line has been output a single blank line is sent to the display. 
This allows the hidden line circuitry to be reset by writing zeroes into the memory. 
After this everything is reset to begin the output cycle again.
110
The generation of ys is slightly harder as the correct fraction of yr has to be added 
to the intensity (zr) value for every pixel displayed. One possible way to do this would 
be via an analog summing amplifier driven from the output of the Zr D/A and also from 
the output of a D/A attached to the yr counter described earlier. This system , while 
effective, is very prone to noise and also makes it hard for the design of a hidden line 
circuit which is an inherently digital process.
Instead of the analog system a more complex digital summer was used based upon 
two 74LS283 4 bit adders. These adders were set up to add one six bit to one seven 
bit value. The six bit input being the yr counter (0 to 63) and the seven bits being 
supplied by the most significant seven bits of the intensity data for this pixel {Zr). In 
this way the adder output is guaranteed to be within the range of its eight bit output. 
Because the top seven bits of the image data have been used, the transfer of data 
from the frame buffer to the surface RAM is now a one-to-one transfer with no data 
processing being done, the hardware simply ignores the least significant bit of data.
The output of this summing circuit, when fed via the d /a  and op-amps, gave the 
full surface with no hidden line removal. This provided a good test point for the circuit 
and also made it possible to add a switch that would either enable or disable hidden 
line removal by feeding either this output or the hidden line output into the d /a  and 
buffer stages. Figure 4.17 shows an example output of this stage.
The last requirement was to remove the hidden lines. This was based very closely 
on the program version described earlier, and consists of a memory tha t acts as the test 
array in the code, a comparator tha t selects either the stored value or the new pixel 
value depending on which is the greater, and a set of latches to select which of these 
should be output to the oscilloscope. The output of the comparator also provided the 
gate enable signal for the oscilloscope. This output was latched along with the data so 
as to disable the beam if the ys value it is receiving is a hidden value.
This hidden line circuit operates by feeding the value of the 0-511 pixel counter 
into the address inputs of a RAM. Initially set to zero at the start of a frame, this 
RAM stores the highest ys value used for this counter output (i.e. for this value of a^ s). 
The data outputs of this RAM are then sent to the comparators with the output of the 
summing circuitry described earlier. If the stored value is greater than the summed 
output then this, along with the comparator signal, is latched into the output register
111
Figure 4.17; Surface rendering without hidden line removal.
on the negative edge of the Xg counter. If the stored output is less than this summed 
output then it is the summed output that is latched.
During the negative half cycle of the Xs clock the value of this latch is written back 
into the r a m . Either the new maximum ys is stored or the old value is written back 
in. During the memory erase period this latch is disabled and the data bus is forced 
to zero by the pull down resistors. Hence zeroes are written into the memory on every 
write cycle for the entire 512 pixels.
On the next rising edge of the clock the contents of the comparator latch are 
transferred into another latch to generate a stable input to the d /a  converter and the 
analog circuits.
Because of the use of a full 7 bits of data from the image, it was no longer possible to 
use the RAM as a means of turning the display off when no pixels were to be displayed. 
The comparator output provided an off signal for use when there were hidden parts of 
the display but did not solve the problem of what to do about the edges of the display 
where there was no surface to be shown.
Figure 4.18 shows the resultant surface when no means of turning the beam off was
112
Figure 4.18: Example output without using any beam gating.
used. This shows the brightening of the image where the beam repeated parts of the 
image where hidden line effects were detected. It also shows the ‘mess’ th a t is produced 
outside of the image due to there being no means of turning the beam off when no 
image should be displayed.
The presence of the address counter enable line, available from the pixel comparator 
stage, provided a suitable beam gate to remove this unwanted part of the image. Figure
4.19 shows the effect of putting this signal, along with the comparator output, into an 
OR gate and then into the beam gate input of the oscilloscope. The removal of the 
bright spots and the non-surface parts of the image gives a much more pleasing picture.
Most of the logic gates for this circuit were implemented within a  16v8 g a l . Figure
4.20 shows the logic equivalent of this device. Because of the lack of pull up resistors 
in GAL outputs, the g a l  could not be used to generate a reliable mono-stable, this was 
implemented in discrete logic. Inserted figure VIII shows the final circuit diagram of 
the surface generator.
113
Figure 4.19: The effect of gating the beam.
■ > J
FEK01111 >
F E B D I l ia  '
3
I I
>-T
"MOrCUOCK
■FEBDIOUT
< FBBD200T
Figure 4.20: The equivalent logic of the 16v8 GAL.
114
4 .4 .2  R esu lts
Figure 4.19 shows the output created from the test image used to evaluate the camera 
system developed in chapter 1. It illustrates a number of points. The low background 
noise level can be seen in the flat parts of the image, and the dynamic range of the 
output is clearly illustrated in the high gradient areas of the image. This picture was 
taken while the unit was running in real time. Slight movements of objects within the 
image could be clearly seen on the display and the resulting images were very stable. 
One point to note here is the enhanced detail that surface representation of this type 
provides. The rough edges of the cutout are noticeable and the extent of the light 
spread out can be clearly seen.
4 .4 .3  A  DMA so lu tion
Because of the need for high speed transfers, the Z80 system used in the previous 
circuits was found to be too slow. Using the block load, l d d r , command to move 
memory blocks, the transfer rate is given by
rate =   -------  —frame time
_  CPU Clock Frequency
No. Bytes x  T states per l d d r
6 x 1 0 6  
"  388 x 64 x 21
=  11-51 frames
Though good, in fact well above the original requirements, it is possible to do even 
better by using a DMA device to carry out fast memory to memory transfers without 
the overheads of the setups needed for the l d d r  instruction.
There were two problems to be overcome with this solution. The first was the 
lack of memory map available to the Z80 processor, the existing hardware providing 
continuous RAM in only 16k pages. The second problem was the lack of fast DMA chips 
in the Z80 family.
The first of these problems has already been solved in chapter 2. Here a reset 
controlled flip-flop was used to allow alternating RD and WR signals to be sent for
115
certain parts of the memory map. The surface hardware simply made use of the same 
memory map and replaced the vertical integration hardware.
The speed of the DMA turned out to be much faster than the l d d r  instruction. 
The predicted times of transfer can be found from analysis of the DMA cycle time. 
There are 388 pixels per line, 64 rows being displayed and hence 24832 bytes need to 
be moved to update the display once. The DMA chip, the Z8410 [76], is rated to do 
one transfer every 6 clock cycles and has a max clock frequency of 4MHz and hence 
the transfer time is given by
4 x l Q 6
24832 x 6 26-85 frames s
This corresponds to 0-0372 seconds per frame and gives an improvement of y  x |  =  
2-33 over the l d d r  command (equation 4.3). It also removes the need for software 
overheads in the setting up of the l d d r  command.
When set to free run (no frame grab) the measured time for 200 cycles, averaged 
over 5 readings, was 7-70 ±  0-04 seconds, which corresponds to a frame time of 0-0385 
±  0-0002 seconds per frame.
The discrepancy, though small, was found to be due to the added time of synchro­
nizing to the vertical blank signal and in communications delays between the PC and 
the Z80.
For every frame transferred it was also necessary to perform a frame grab to capture 
the video input signal. This takes one frame period to do, so an added time of 20ms 
is needed per frame. However, because the frame grab can only be initiated during 
the vertical blank time, the cycle would start with a frame grab, take one and a bit 
frame times to complete the transfer, and would then have to wait until the end of this 
third frame period until the next vertical blank, and hence the next frame grab, could 
occur. This should, theoretically result in an update time of 0-06s or 16-7 frames 5“ .^ 
In reality the transfer time for this hardware was found to be 16-37 ±  0-01 frames 
(averaged over 5 frames), which, taking into account the transfer times, was a very 
close match to the theoretical time.
One further possibility was examined at this stage. D ata on the Zilog DMA de­
vice suggested that the use of a 6MHz clock was possible, though not guaranteed by 
the manufacturers. This was tried and a corresponding increase in performance was
116
observed. As this is pushing the specifications of the device, continuous operation at 
these speeds v/as not made use of.
4 .4 .4  In v estig a ted  m odification s
Some flicker in the display could be noticed when it was being driven from the live 
video signal. Shielding improved the image, as did increasing the distance from the 
power supply where some magnetic pick up was affecting the digital rise times. Some 
of the flicker was also found to be reduced by shortening the cables carrying the video 
signals between circuit boards.
Though helping with the system, it was evident that these improvements were not 
sufficient to solve the picture quality problem. Two other possibilities were then looked 
at. One of these arises from the fact tha t the cycle time between bytes being read out 
of the display memory and the decision as to whether they are visible or are part of 
a hidden area, is very close to the limit of the memory access time and could cause 
loss of data when clock edges are not very well defined. The other possibility was tha t 
the changeover between the two banks of memory was actually becoming visible and 
causing a glitch on the output data lines.
The speed problem was solved by reducing the clock frequency to 1-843MHz. This 
now reduced the frame rate to only 50 frames a second, but did stabilize the picture and 
reduced the flicker to only one every few seconds. Crystals of intermediate frequency 
were not available, but it should be possible to go up to 70 frames per seconds without 
getting too close to the limit of the memory access times. It was decided th a t the 
remaining flicker was due to noise pick up in the oscilloscope trigger leads and hence 
the circuit was now operating as intended. Were full RF techniques to be used on a p c b  
version of this circuit then it should be possible to go back to the full lOOHz refresh 
rate.
In order to investigate the effect of the memory bank change over an input was 
added to the Z80 processor sensing the hidden line reset circuitry, and monitoring it 
after the frame update had been done. When the reset went active, the memory banks 
were changed over. This ensured tha t the beam gate was off when the memory banks 
were swapped over and hence any effects would not be visible. As predicted, little 
effect was seen, and as the time to transfer had now been increased by a small amount
117
in order to synchronize the signals, the modification was not left in place.
4 .4 .5  F uture w ork
Clearly the most obvious addition to the wire frame generator would be to fill in the 
lower half of the image. As mentioned in the software section, it is possible to see 
the under side of some surfaces when this type of projection is used. Because of this, 
minimum values, as well as maximum ones, have to be stored. This would be done by 
a set of components similar to those used to generate the top half, but looking at the
A < B  instead of A >  J5 output of the comparator. Clearly only one possible output 
will ever be active and hence there would be no need for extra logic and the data  busses 
of both top and bottom circuits could be wired in parallel to the output latches.
The adaptation of these techniques to grey-scale rendering is not so readily achiev­
able. The scanning methods available via an oscilloscope are not capable of doing this 
type of rendering with any degree of accuracy and hence it would be necessary to re­
turn to the normal type of raster scanned pixel format. The algorithms developed for 
grey-scale rendering would be easily implemented in silicon however, and, were facili­
ties available to do this type of development, a high speed shading system should be 
possible.
118
C hapter 5 
D isp laying Im ages B y  R andom  
Sequence Order Scanning
5.1 Introduction
Visual display units (vD U s) have conventionally been raster scanned. This chapter 
aims to look at adapting the principles of vector scanning used in chapter 4 to explore 
the possible improvements tha t such scanning can make to conventional VDUs.
Work done on this type of Human-Computer interface has shown that frame flicker 
in a normal computer screen will increase eye strain and can lead to mistakes of recogni­
tion [77, 78]. It is because of this tha t most computer companies operate their displays 
at frame rates greater than 70Hz, above which the human eye perceives a continuous 
image. Alternatives to this are to scan using Hilbert [79] or Piano [80] space filling 
curves, where the beam is localized to areas rather than lines and hence reduces the 
visibility of the flicker.
Recent work has also shown that such scanning patterns can greatly assist in real 
time video processing such as data compression [81, 82] and, when limited to Murray 
polygons [83], can be used to do half-toning and smoothing. Another method of re­
ducing the eyes detection of flicker is to use an alternative to the sequential vertical 
scanning used in a normal raster display. One such method, and its applications to 
computer security will be the subject of this chapter.
In 1989 a patent application [84] was filed with the U.K. Patent office tha t outlined 
a method of protecting computer video signals from surveillance equipment. The image 
to be displayed is read out of the normal random access display memory one line a t a 
time. Horizontally, the data is read out left to right, as normal, but the row order is not
119
Horizontal
Deflection
Pixel
Clock
Display
Data
Output VerticalDeflectionHorizontal
Line
Selection
Microprocessor 
Data Input /\ Vertical Line 
Selection
Horizontal
Blank
Vertical Blank
X-Axis
Ramp
Generator
Y-Axis
Drivers
X-Axis
Drivers
Random
Sequence
Generator
Video
RAM
Display
Video 
Controller 
and Signal 
Generator
Figure 5,1: Block diagram of the VDU security patent,
sequential from top to bottom (lines 1,2,3 etc.) but is defined by a random sequence. 
This sequence would ideally be changed after every frame has been fully displayed. 
The image is recreated by sending the display device two blocks of data per line. One 
representing the intensity of the pixels along the line and the other describing the 
vertical position the line should be displayed at. The vertical position is the random 
sequence value that was used to select which row was to be read out.
The block diagram outlining this invention is shown in Figure 5.1.
Apart from aiding in the reduction of flicker the primary aim of this patent appli­
cation is to protect displayed data from remote, clandestine sensing equipment. Video 
signals can be remotely detected in a number of ways. This patent aims to prevent 
all forms of detection tha t rely on the gun emissions of the display device, including 
normal gated magnetic or electrostatic deflection displays such as those used in IBM 
clones. Commercially available ‘off the shelf’ devices [85] allow a normal IBM VGA 
screen to be reproduced, in real time, from as far as 100m away. As these devices cost 
as little as ^3000 it is easy to see why some form of cheap protection is needed if data 
is to be kept secure.
There are now a number of journals dedicated to providing information on com­
puter security [86] and books have been published on the subjects of scrambling video
120
signals [87] and data theft [88]. All these publications have looked at preventing the 
interception of data while it is being transm itted rather than investigating the prob­
lems involved with the actual sending systems. Even so, they illustrate beyond a doubt 
tha t there is a huge, hidden problem to which a cheap and simple solution is urgently 
required.
There are only two competing protection system available today. One method is 
to radiate similar signals to those output from the scan coils and hence confuse the 
detector [89, 90] and the other, currently only available to the military, is known as 
tempest  This is based around a Faraday cage tha t encloses the screen, the computer 
generated signals and the connecting cables. In order to see the screen a set of optically 
transparent metal layers are used. This design is inherently bulky and at a cost of 
i ’SGGGO it is unlikely to be used by most PC owners. The MOD claim it is not detectable 
from more than IGcm away, but there are still commercial products (though in the 
i?3G0GG range) that are specified to receive tempest protected signals at reasonably 
large ranges.
Preliminary market research by Marconi Electronics illustrated the need for an 
inexpensive protection device by the legal profession. In particular the Law Society 
expressed some interest in the development of a cheap video protection system, as their 
members deal with many sensitive issues. There are a number of standards proposed 
for the protection of data via software scrambling algorithms but there is, as yet, no 
national or international agreement on the regulation of computer hardware methods 
of data encryption.
An implementation of random order scanning would provide a nearly secure system. 
Techniques such as character recognition and continuity analysis would allow computer 
unscrambling of the image but this is less significant than it may seem as to work 
successfully surveillance must be done in real time. For normal TV signals there are 
625 interlaced lines per screen and hence 625! =  614 xlG^ '^^’^ combinations. Even with 
image analysis it would take a very large amount of computer power to manage real 
time unscrambling.
The are, however, two weaknesses in such a system. Firstly, it is possible to detect 
the vertical positioning signals in much the same way as the surveillance devices receive 
the intensity data, and secondly it may be possible to decode the sequence generation
121
circuitry and hence be able to predict the ‘random’ scan order.
5.2 A n E lectrostatic  Im plem entation
5 .2 .1  S im plifications to  th e  invention  sp ecifica tion
For the initial prototype a reduced specification was decided upon. The use of an 
oscilloscope as a display device was chosen as it provided a good test bed for the digital 
circuitry and had the ability to display the horizontal deflections without the need 
for high power driver circuits which are required by the electromagnetic (rather than 
electrostatic) deflection mechanisms of a normal VDU. The oscilloscope also provides 
a very high input impedance, thus simplifying the output stages and protecting the 
development circuits.
Because the oscilloscope does not have built in horizontal frequency settings, relying 
on the input signal to provide the triggering, it is necessary to generate a trigger signal 
for the horizontal (ar-axis) flyback. The y  plates are then used to provide the vertical 
position of the beam. This vertical signal is changed at the end (r h s ) of a line and 
the flyback time is used to stabilize the beam position. As the flyback time is up to 
one fifth of the fine period (64^s for pa l  systems) stabilization has to be achieved 
within a maximum of 12yus. Most scopes, including the one used here, are slightly 
under-damped, and settle within 1 cycle of their 3dB frequency, i.e. at 60MHz they 
settle in qqxW “  17ns. Well within requirements.
The scope used was the Hameg 60MHz dual trace unit as used previously. The 
scrambling circuit was to be driven by the signals available from the timing and display 
circuits developed in chapter 1, the intensity signal being taken directly from the most 
significant bit of the video data output.
In using the available video circuits, it was also necessary to further modify the spec­
ification. The existing hardware generates signal outputs for a normal raster scanned 
image, it is not possible to extract information from randomly selected lines. Because 
of this it was decided to use a fixed line scrambling order, rather than change it a t the 
end of each frame which would be the ideal. This meant tha t the graphics software 
could create the image on the screen in a prescrambled order which, when read out 
sequentially, will be unscrambled by the vertical positioning circuits and will appear in
122
the correct vertical position. This is only possible for a ‘proof of principal’ circuit as, 
for a commercial product, the time overheads required to scramble in software would be 
unacceptable, particularly in a version where the random sequence is changed regularly.
One major penalty tha t such use of continually changing signals would incur is 
th a t the changing scan order leads to the possibility tha t one line may not be updated 
for almost 2 frame periods. This would lead to increased flicker in some instances. 
However, as the sequence is changing every frame, this effect should be minimal. If a 
full implementation were to be created further research in this area would be essential.
5 .2 .2  T h e gen eration  o f 2/-ax is w aveform s
In order to generate the vertical displacement signal, a method had to be found to 
map the video signal into a random sequence. By using the horizontal blank signal to 
clock a counter and using the vertical blank to reset it, it is possible to  extract the line 
number, (vertical height), of the beam. If this is then fed into the address inputs of a 
ROM the 8 bit data output provides a programmable mapping from raster line number 
to scrambled line number. By feeding this into a D/A converter and a buffer stage the 
scope input signal can be generated.
By using only the 8 data bits of a ROM, the output would be limited to only 256 
lines. One way to partially overcome this is by feeding the ninth bit output of the 
raster line counter into the ninth address input of the ROM and ensuring the first 56 
values of the sequence contains all the numbers 1 to 56. This has the effect of providing 
the extra 56 lines needed to make up the 312 lines normally displayed on a PAL video 
monitor, simply repeating the sequence used for the first 56 lines but shifted down to 
lines 256 onwards. This compromise is again adequate to prove the principal.
An early choice of the mapping sequence was to scramble over only 16 lines, then 
repeating the sequence for lines 16 to 31 and so on. For the electrostatic implementation 
this can be extended to scramble over all 256 lines. The random sequence was generated 
by a computer program , as discussed in section 5.4.
A number of suitable d /a  converters were considered. All had to be able to convert 
9 bits with a settling time such tha t the beam , and the d /a , can be stabilized in less 
than the frame flyback time. Because a magnetically scanned VDU would eventually 
be used instead of the electrostatic oscilloscope, the faster devices were to be preferred.
123
Device Speed Price
DAC HFIOBMC 
DAC IClOB 
DAC 6100 
DAC 7533
25ns
250ns
500ns
700ns
NA
.^15-08
£10-59
£5-77
Table 5.1: Datel DACs.
IlI
Figure 5.2: DAC610C implementation.
At the time of development the best supplier of cheap, low volume d /a  converters was 
Datel. Table 5.1 lists some parts tha t were considered.
Figure 5.2 shows a test circuit used for the DAC610C [91]. Though fast enough, it 
relied on an obsolete amplifier, the AM410 [92]. The circuit was also found to be very 
sensitive to local static and overloads. Because of these problems it was decided to  use 
a more stable device and consultation with Datel suggested the DACIClOB [93]. This 
was an expensive part, but it had the fastest response time and would be supported 
for some time to come -  an important issue when considering mass production. As it 
is a current converter, it requires a constant current input, and a current to voltage 
amplifier on the output. The existing, though obsolete, AM410 amplifier was re-used as
124
it has a suitably high input impedance. Any similar op-amp with the same bandwidth 
and input characteristics could be used in any future developments.
The final circuit is shown in figure 5.3. The constant current reference source was 
provided by the Zener diode and fine tuning of the DC offset was provided b y  the 
trim  facility on the AM410. A further buffer stage was also added to provide a gain 
stage, and a coarse DC offset adjust. The choice of a 2764 ROM allowed a number of 
different mappings to be investigated, the higher address bits being hardwired to give 
any desired page of ROM.
The ±15V supplies used in this circuit were developed using fixed voltage regulators 
similar to those used in the previous power supply circuits.
5 .2 .3  T h e gen eration  o f  trigger and æ-axis w aveform s
Because of the need to eventually drive an electromagnetic signal, coupled with the 
need for a trigger circuit, it was also necessary to generate a ramp voltage for the 
x-axis displacement of the beam. This circuit operated in a very similar way to the 
vertical waveform generator, the counter was clocked by the pixel clock, and reset by 
the horizontal blank. In order to make a flexible prototype capable of easy modification 
a ROM was inserted, similar to the y -a x is  system. This enabled distortion correction to 
be made on the horizontal travel of the beam , and also gave the ability to experiment 
with different waveforms for the triggering of the oscilloscope version.
The bandwidth in this circuit was a problem. Video rate circuitry is required 
because, even though the pixel rate is only 8MHz, the actual pixel positions need to be 
settled as fast as possible to avoid distortions and provide sharp edges for the triggering. 
To this end the PNA7518 [5], used previously, was an ideal choice. It provides sufficient 
bits of conversion (necessary to allow 300 or more pixels per line) and has a bandwidth 
of 30MHz. This was coupled with an NE5532 video op-amp to provide the driving 
voltages.
Figure 5.4 shows the final version of the beam deflecting circuit, incorporating the 
PNA7518.
125
1 ?s .
n « O
i
o o o o o o o o o o
- — 111
Figure 5,3: The final circuit for y-axis generation.
126
ry—n
3 O' 3 O et O' Df
Figure 5.4: x-axis deflection circuit.
127
Horizontal Horizontal Back PorchFront Porch
—  Horizontal Blank — >| Horizontal Sync----3>j --
--------------Line Period--------------- >|
Figure 5.5: Horizontal control timings.
5 .2 .4  Im p rovem en ts to  th e  original sp ecifications
Two methods of improving the invention were researched. Firstly, the circuitry driving 
the y-axls had to have an adequate bandwidth to settle the beam correctly even when 
it is moved from the bottom line to the top line in one flyback time. This means that 
there is no need for control signals such as the vertical synchronization, vertical blank 
and front/back porches. The removal of these means tha t a detection circuit that 
extracts the vertical signal from the beam would not be able to lock on to the frame 
frequency. The display driver of such a surveillance device would lose the vertical hold 
and the picture would scroll around from top to bottom.
This idea can be extended to remove part of the front and back porches and all 
of the synchronization signal from the horizontal blank time. This is possible, on 
an oscilloscope version, because the flyback time is greater than it is on a normal 
electromagnetic coil. Provided the blank period is long enough for the flyback and the 
beam position settling to occur it can be reduced to beyond the point where a normal 
system could lock onto it. Figure 5.5 shows the composite signal and where the various 
timing points are.
The second improvement was to vary the number of lines displayed in each frame. 
By removing the vertical synchronization signal, the concept of a frame has effectively 
been removed. This means that, provided flicker does not creep in, some lines can be 
missed out of some frames, some can be displayed more than once, or the blank periods 
can be randomly extended. All this would make any computer decoding much harder 
and would ensure tha t much more flexible (and hence expensive) circuitry would be 
needed to even correctly detect the scrambled signal let alone unscramble it.
128
5 .2 .5  R esu lts
Once a prototype had been designed and the construction verified, an emissions test was 
done by the Marconi Signals laboratory based at Edinburgh. The prototype circuitry 
was set up in a shielded lab, along with a number of aerials that, between them , 
covered most of the detectable radio frequencies. For test purposes, a standard monitor 
was driven with a normal image. This enabled the detection circuitry to find which 
frequencies were being emitted. The most obvious one was the pixel rate (8MHz) which 
had the intensity signal modulated onto it. Large emission intensities were also detected 
at the line rate, the PC processor clock rate (12Mhz) and the base frequency of the 
drivers which is three times the pixel rate (25MHz). There were also some intensities 
detected at lower rates, in particular the 50Hz mains frequency. Interestingly, some of 
the strongest signals were actually detected via harmonics of the pixel rate, some of 
which were in the GHz region. These strongest signals were easily detected and the 
displayed text was easily read on the detector screen, clearly illustrating the ease with 
which remote detection can be done.
The next stage was to scramble the display and connect up the unscrambfing circuit. 
This produced little change to the pattern of detected frequencies. The normal display 
was now turned off and the resultant emissions from just the scrambling circuitry were 
analysed.
W hat was seen was exactly as predicted. There were a number of detectable fre­
quencies some of which gave a very clear, but scrambled image. The mapping tested 
was using a full 256 line scramble and a number of possible pictures were analysed. 
Figure 5.6 show some text being displayed on the monitor, this is a version of what was 
seen by the Marconi test equipment, before the synchronization signals were removed. 
Figure 5.7 shows the unscrambled version that was displayed on the oscilloscope screen.
Once the synchronization modification, as described in section 5.2.4, were made 
the detected picture broke up. There was clearly something there, but the available 
adjustment to the Marconi scanning circuits was not able to find the line rate and 
hence the picture scrolled round vertically and jittered horizontally. Given time it 
may have been possible to make a locking circuit for the scanning equipment but, as 
there was over £100000 worth of detection equipment being used, it was clear tha t this 
scrambling device would defeat any small time criminal activities.
129
Figure 5.6: The scrambled text as seen by Marconi.
Figure 5.7: The readable version of the text.
130
Figure 5.8: A black and white scrambled graphics image.
Figures 5.8 and 5.9 show the results of the same tests but using a graphics image 
rather than text.
Both these two figures, and the previous two, only used one bit intensity output, as 
a variably gateable display was not available. Figure 5.10 shows the scrambled version 
of the grey-scale image shown in figure 4.10. These are both displayed on the monitor 
but serve to illustrate the type of effect a full grey-scale version would achieve.
5.3 In vestigation  o f E lectrom agnetic D eflection
5.3 .1  E x istin g  e lectro m a g n etic  d isp lays
Once the prototype had been shown to work well using electrostatic deflection, the next 
stage was to investigate the modifications needed to use a normal, magnetically scanned 
monitor. For computer applications the industry standard is now the IBM VGA format. 
VGA screens use a three colour input, with the synchronization signals being provided by 
a fourth input containing composite sync data. The decoding circuits simply remove the 
vertical and horizontal synchronization pulses and use them to lock in the vertical and 
horizontal driver frequencies. These drivers are complex, particularly in older designs,
131
Figure 5.9: The unscrambled black and white graphics image.
Figure 5.10: A grey-scale scrambled image.
132
where the beam deflection distance is not a linear function of the voltages produced 
by the drivers. For test purposes this is not a problem but, as will be discussed later, 
it would be a much more signiflcant factor when building to production standards.
The monitor chosen for testing was a simple 1 0  inch closed circuit unit, type TVM- 
10. This is a typical VDU unit and was preferred only because circuit diagrams and 
board layouts were available.
5.3 .2  Trials w ith  an ex istin g  m onitor
The first approach was to examine the built in drivers of the VDU and attem pt to use 
the high current stages directly. The driving stage for the vertical beam deflection was 
found to be a simple push pull, resonant current amplifier. Its inputs were flltered to 
remove RF interference and any DC component and the coil was used in parallel with 
a large capacitor and resistor to resonate at the required frame frequency. In most 
monitor designs the input waveform is also modified by the flnal stage circuitry to 
correct it for non linearities in the deflection system [94]. This is particularly noticeable 
in the horizontal axis deflection where the yoke voltage would normally be linearly 
increasing but, as the deflection is an angular displacement, corrections are needed 
for the edges of the screen. As the linearity problem is less severe in the vertical 
movement for this particular monitor, the vertical ramp input was found to be only 
slightly modified by the output stages. Clearly this is a problem specific to this make 
of monitor but it is likely that similar problems would be encountered with all forms 
of magnetic deflection.
Figure 5.11 shows the input waveform that drives the vertical push-pull stage, as 
can be seen it is slightly discontinuous in the centre of the sweep but a linear ramp can 
still be used as an approximating waveform.
By removing capacitors from the input circuit it was hoped to remove the filtering 
and so enable direct drive of the beam. The amplifler inputs were disconnected from 
the drive circuitry and a square wave was fed into them instead. By adjusting the 
frequency of the input signal to a multiple of the horizontal scan rate, the square wave 
appeared as a triangular waveform on the display screen. This is because the current, 
and therefore the beam , rise time was not fast enough to position the beam correctly, 
as defined by the square wave voltage, within the half period of the input square wave.
133
D r i v e  V o l t a g e
2 1 . 5 V
1 8 V
1 5 . 5 V
1 2 . 5 V
7 V
F r a m e  P e r i o d T i m e
Figure 5.11: Existing inputs to the vertical coil drivers.
This meant tha t while the square wave was in its positive cycle the beam was rising 
up the screen whereas when the square wave went negative, the beam started to sink 
down, never actually reaching its specified position.
When the frequency was increased to the next multiple of the line scan frequency 
it was found that the deflection of the beam was smaller because there was less time 
for the beam to get to the required position. It was also found th a t if the voltage was 
increased then the rate of deflection was greater. Clearly a trade off exists. By using 
higher voltages, it is possible to reduce the current rise time in the coil, but a t some 
point either the coil or the amplifier will break down due to excessive voltage levels. 
The conclusion had to be tha t the existing drivers were not capable of handling the 
rise times tha t are required to generate a full scale deflection of the beam within the 
flyback time.
5 .3 .3  Softw are correcting  th e  display
Three further developments were now considered. Since some beam deflection could be 
achieved it was possible to scramble in such a way tha t the beam never had to go more 
than say 16 line widths during any one flyback. This was the maximum deflection that 
could be stabilized using the existing hardware.
The second development would be to incorporate, an intelligent controller into the
134
”  : : ■« .
Figure 5.12: Text scrambled over 16 lines.
drivers tha t would specify a deflection of say 40 lines when only a 20 line deflection was 
needed. This would increase the voltage, and hence the rise time. When the beam got 
to the required position, the voltage offset would be returned to the correct value, and 
the beam stabilized. The latter method is best implemented by a current amplifier, 
and will be dealt with later.
Limiting the beam deflection has a very large effect on the scrambling. The number 
of permutations, p is given by
p ~  n\{t  div n) +  (£ mod n)!,
where n is the number of lines scrambled over (in this case 16), t  is the total number 
of lines on the screen and the ‘div’ and ‘mod’ are the integer division and remainder 
functions respectively.
For 16 line scrambling and a screen of 311 lines (as used by the test hardware in 
non-interlaced mode) this gives only 3-98x10^^ permutations. Experiments done with 
scrambling over 16 lines worked quite well, but, as the human eye is very good at 
character recognition even when the characters are not perfect, it was often possible 
to interpret the images. This was confirmed on the electrostatic prototype where some 
text examples was almost readable. One such example is given in figure 5.12 with the 
original text given in figure 5.13. The scrambled text, though not readable, shows some 
structure and the presence of spaces in the text is clearly seen. It is also possible to 
simply reconstruct letters where there are no interactions with other characters. The 
‘H’ in ‘HUMAN’ and the ‘T ’ in ‘THIS’ are good examples.
The third development was only possible because a fixed scrambling pattern and 
a known hardware setup were being used. Firstly a scrambling pattern could be pro­
grammed into the ROM, and an image displayed as if no scrambling had been used. 
This would give a picture, on the monitor, tha t represented the unscrambling algorithm
135
I " :  I
Figure 5.13: Example unscrambled text.
Figure 5.14: The effects of scrambling a diagonal line.
as the hardware operation assumes that the picture has been drawn in its scrambled 
version. If a diagonal line is drawn at 45 degrees, it is now possible to find out what 
the unscrambling algorithm actually is. In a perfect system this would be identical to 
the pattern programmed into the ROM but, as there is a limited rise time, the actual 
unscrambled picture is quite different. An example output from such a scrambled line, 
on an electromagnetic display is shown in figure 5.14. This has been programmed with 
a repeating sequence of 16 different scrambled values. The effects are quite good at 
the s tart of the sweep, but as the beam goes further down the screen, filtering effects 
s tart to remove the small changes and they soon vanish completely.
By manually working out the order in which the lines as displayed, it is possible to 
set up the software to use this ‘correct’ scrambling order. To assist in the analysis of
136
Line Number Expected Position Actual Position
0 0 1
1 3 9
2 1 1 5
3 13 1 2
4 14 3
5 1 0 6
6 5 4
7 1 1 1
8 6 7
9 1 2 2
1 0 7 13
1 1 8 0
1 2 4 8
13 2 14
14 9 1 0
15 15 15
Table 5.2: Visually determined line ordering for 16 line scrambling.
the screen, a program was written tha t displayed the diagonal line at half intensity, but 
allowed selection of one horizontal line of pixels to be displayed at full brightness. This 
program was then used to compile the mapping shown in table 5.2. In this example 
only 16 lines were scrambled over to simplify the analysis.
The biggest problem with this method of scrambling is tha t the beam is not stable 
while it is visible. The amplifiers will continue to move the beam vertically after the 
gun has started displaying the line. This means tha t the above set of data, while 
correct for the points used, may not be correct for all horizontal points on any given 
line. This could be corrected for if all the horizontal positions for every point were 
determined, but as nearly 1 0  thousand points would need to be plotted and used to 
map backwards, this solution is clearly not acceptable.
It can also be seen that, though the points are evenly spaced along their ^/-coordinate 
(which, if the beam is still rising, may well not be horizontal), they are not evenly 
spaced vertically. It might be possible to stabilize the beam at the start of each line, 
thus making all lines horizontal, but the complexity needed to ensure th a t this resulted 
in lines tha t were evenly spaced vertically would be unacceptable.
137
A l A4
A2
A n
An-1
A 3
T / N
Figure 5.15: The general form of the y-àxis waveform.
5 .3 .4  Fourier an alysis o f  y-aods w aveform s
In order to fully understand the driver circuitry, it was decided to look into the wave­
forms in more detail. The aim was to find the frequency components tha t had to be 
present and to see how the waveforms were affected by limited bandwidth. By Fourier 
Transform theory, coupled with the fact that it is possible to view the sequence of 
voltages used to drive the vertical coils as an infinitely repeating waveform, the drive 
signal can be expressed in the frequency domain rather than time domain.
Figure 5.15 represents an arbitrary form of the driving waveform where the Ai 
represent the amplitudes of the deflection waveform for each line period. For such a 
waveform te Fourier Series equations can be shown as
+ 00
s(t) =
n = — oo
0U = ^  r1 Jo
For the amplifier stages the amplitude spectrum is given by
\ P n \  =  (/?„).
In this case equation 5.1 can be solved to get
0 n  =  i f :
138
(5.1)
Q -jn w p ^  __ g - i n w ( p - l ) ^
Now since
(JÜ =  2 7 t/  =
the amplitude spectrum is given by
[l -p=i
This can be simplified to get
p—1
COS -  j  sin
p=i
+  sin1  — cos
Z 4
P = 1
+  cos^ +  sin'1  — 2  cos
P = l
Again, using the identity
(5.2)
(5.3)
(2'Kpn
139
it can be shown that
2  — 2  cos
p=l ^
^  Ap cos
p~i
2  — 2  cos
+  sincos cos sin
2  — 2  cos
2  — 2  cos
N  N - Ï  N  / 9 7 r r 7  \
\  Ë  +  2 E  E  ( p - ? ) ] .\ p = l  p=l q=,p+l  ^ /
Which is as far as it was possible to get analytically. However, since
E  V
p = i
E Ap—l C O S — zsin
C O S zsin
and
(5.4)
(5,5)
I  C O S  X  —  i  s i n  x \  =  ( ^ c o s ^  x  +  s i n ^  x ^  ^  ,  
=  1 ,
then
N
P=1
N
^  s  \^p\ •
P=1
By putting this back into equation 5.3 the result is
140
E K I
K l  <  ^ -------^ 2 - 2 c o s ( ^ ) .
27T71
By computer analysing this envelope a plot of the maximum amplitude spectrum 
for this waveform can be created. Such a plot is shown in figure 5.16 along with the 
amplitude spectrum of the waveform used to generate the full 256 line scrambling 
demonstrated earlier. As can be seen the required bandwidth for an amplifier being 
used on this example is as large as the envelope, since all frequencies appear at ap­
proximately the same amplitude. Reduction of the bandwidth would lead to loss of the 
higher frequency components and a corresponding reduction in the signal accuracy.
The final analytical result, equation 5.5, is not suitable for computational purposes 
because if has a nested sum making it 0 { N ^  (of order N^).  Because of this the 
program used equation 5.4 as this is only 0 { N } .
One interesting observation that can be made from this data  is tha t it is periodic, 
though not necessarily symmetric, within one period. Mathematically equation 5.2 
gives
p=l
-jn27T
An analysis of Pn+N leads to
=  q ^ T i V ) 2 .
N
[l - E (5.7)
p=l
and since =  1 equations 5.6 and 5.7 can be combined to get
i.e. the spectrum repeats but diminishes each cycle by an amount , ,
141
120 -
100 -
40
20 -
----
150 200 250
Normalized Frequency
50 100 300 350
(a) Fourier waveform and envelope.
8-
6 -
4 -
_1--------- 1— ...
150 200 250
Normalized Frequency
300 35050 100
(b) Magnified waveform.
Figure 5.16; The amplitude spectrum envelope and an example waveform.
142
A n a l o g
Switch
+ 1 5 V
- 1 5 V
C o m p a r a t o r
V a d c
E n a b l e
E n a b l e
E n a b l e
S e n s o r
R e s i s t o r
D e f l e c t i o n
Y o k e
Figure 5.17: A proposed schematic for a supply rail driver.
5 .3 .5  H ardw are im p lem en tation s
As mentioned previously the required driving stage for the electromagnetic screen would 
have to be one tha t gives a very small current rise time in the deflection yoke. Clearly 
the fastest rise-time would be when the coil is driven from the supply rail.
Figure 5.17 shows a suggested schematic for such a driver. There a re ,  however, 
a number of problems with this circuit. Firstly, the stabilizing effect of feedback is 
not available to the driver and hence it will suffer very strongly from overshoot and 
will need extensive damping in order to make it stable. The second problem, and the 
one tha t prevented this from being developed further, is tha t calculation showed that 
switches capable of reacting fast enough, and also capable of passing the large currents 
required, are simply not available. The use of f e t  switches would be ideal, but then 
the signals would have to be combined in a summing amplifier system with a resulting 
loss of the benefit of the directly driven output stage.
Because of this it was necessary to develop a current amplifier tha t could drive 
the input stages correctly. Two such circuits were investigated, the first is shown in 
figure 5.18 and the second, the Howland current source, is shown in figure 5.19.
The Howland has the big advantage of being able to drive the coil direct to ground. 
In a retrofit circuit, this would greatly simplify the modifications needed to existing
143
O . 3 5R
V i n
i O R
R s c  
O . 3 5R O . XOu.
Figure 5.18: A traditional current amplifier.
circuitry, but has the disadvantage tha t to get good stability the resistors must be very 
closely matched and this would usually call for precision tolerances. It was found tha t 
the Howland also gave worse rise times for the same amplifier. This, combined with 
the price premium of precision resistors, forced the decision to adopt the conventional 
amplifier for the prototype circuitry.
Theory states that, for this amplifier.
Short Circuit Limit 0-6R.or
yoke hiin■Rsense (5.8)
By analysing the scan coils, RjqI^q is found to be about lOH, and that a half scale 
deflection could be obtained by putting 20V DC across the coil. The amplification part 
of this signal is not needed here as there is ample output capability from the voltage
144
Vin >
»
Figure 5.19: The Howland current source.
sources developed earlier. Combining this data with equation 5.8, it can be shown that 
-^sense =  2-5Q. This leads to a power rating of 8 W.
The next decision tha t had to be taken was which amplifier to use. High current 
handling was essential, but there are a wide range of parameters tha t could affect the 
output, including slew rate and power bandwidth.
In order to evaluate the amplifiers ability to drive the coils they were fed from a 
square wave source. The output on the screen appeared as a set of diagonal lines (see 
section 5.3.2) which were then used to evaluate the rise time by measuring the angle 
of the lines relative to the horizontal. The larger the angle, the lower the rise time and 
hence the better the amplifier. Because the coil was not perfectly horizontal, it was 
also necessary to take into account the angle of the beam when no vertical deflection 
was present. Figure 5.20 shows this layout.
Given the period, T, of the square wave and L  the length of one half cycle of this 
square wave as measured on the screen, then the rise time in centimeters per //s can 
be found. This can then be used to find rise times for a square wave of any frequency. 
The rate of displacement, R,  is given by
145
S creen
Rise Time 
From a 
Square Wave
Beam Position 
with No S i g n a l \
Figure 5.20: Measurement of the rise time of the amplifier.
Device Bandwidth Imax "^supply Rise Time No. LinesEL2008CT 55MHz lA ±15V <0*03cm/i5~^^ 7-5
LM12C 300KHz ±25V 0*067cm/xs~^ 16-8
±15V 0-037cm/iS“ ^ 9-3
± 1 2 V 0'026cm^s"^ 6-5
M0S248 ±55V 0-074cm;us“ ^ 18-5
Table 5.3: Results and basic parameters of some amplifiers.
R y2Lx T
Table 5.3 show the results obtained for a selection of amplifiers and buffers, along 
with their basic parameters. The input square wave frequency was 16KHz, fed at 1-24V 
peak to peak. The amplifiers were chosen because they illustrate a good cross-section 
of the desired parameters.
Also included in table 5.3 are the number of lines each amplifier could scramble in 
a flyback time of 12^s. The calculation is based on a screen height of 14*4cm and 312 
lines per screen. In order to scramble the entire screen a rise time of i2 xto-« ~l*2cm/zs~^ 
would be needed. As can be seen all the amplifiers fall short of achieving this.
One further observation from this table is that the bandwidth is not important. 
The EL2008 had a much larger power bandwidth than the others but produced poor 
results. Clearly the input voltage, as would be expected, has the largest effect on the
146
12 -
10 -
8 -Iy 6 -
4 -
10 100 1000 10000 100000
Frequency (Hz)
Figure 5.21: Graph of input frequency against beam deflection.
deflection.
Figure 5.21 shows the peak deflection of the beam plotted against input frequency 
for a driver stage using the LM1 2  amplifier [95]. Above 50KHz oscillations occurred 
and the drivers became unstable. The tailing off of the deflection is clearly the major 
problem tha t must be overcome in supplying high frequencies within a square wave. 
The LHOlOl [96] is a higher bandwidth version of the LM12, this device could provide 
the added frequency response but, as it is now obsolete, having been superseded by 
the LM1 2 , it was not available for test.
There are a number of ways to improve the high frequency response of these coils. 
The most obvious, although beyond the development facilities available a t St. Andrews, 
is to redesign the yoke coils to optimize their bandwidth response. This would be 
unsuitable as a retrofit option in a commercial product but would solve the problem 
in the long term for specialized units. An alternative form of driving would be to use 
a secondary coil. This would contain as little as one turn , and would be wound in the 
same direction as the primary. By passing a high current through the secondary coil 
this coil could ‘prime’ the main coil. The secondary would be removed when the main 
coil current approached the correct level. This should accelerate the deflection and still
147
allow the normal coils to be left in place. This idea is based on work done by Rodime 
to  enable fast settling of hard disk drive heads and thus reduce seek time.
5 .3 .6  C olour sy stem s
In order to extend the application of video scrambling to a colour system it would 
be necessary to analyse the requirements of the three dot colour system used in most 
colour displays. In older systems three separate guns were used to create the three 
beams. This is easier to manufacture but is very bulky and has not proved adequate for 
modern display devices where many colours and higher resolution have made precision 
gun alignment essential and has led to the use of one gun and three beam gates. The 
extension of this invention to cover the older type of driving is, however, quite easy.
The three colour planes representing the red, green and blue images th a t are com­
bined to give the final colour image are stored in computer r a m  as three separate 
images. The three guns can be driven separately and the data removed from the three 
planes in the same way as has been specified for just one. If, however, the random 
sequence circuitry uses three separate sequences it would be possible to ensure that 
the guns were not necessarily at the same vertical position a t any one time. This would 
not only allow colour displaying, but would also hinder the detection of the vertical 
positioning signals by electronic surveillance.
It is theoretically possible, in a single gun system, to detect both the intensity and 
the vertical signals. The colour system has three intensity signals and three vertical 
signals.
If detection was attem pted at a distance greater than tha t needed to resolve the 
guns (the inverse square law applying to the gun emissions), the intensity received 
would be seen as the sum of the intensities from the three guns. As the displayed data 
does not have any correlation between the three guns (the red gun could be a t the 
bottom  of the screen and the blue at the top for instance), the three intensity signals 
cannot be separated. The vertical signals would be similarly overlayed, the single 
received waveform would have amplitude equal to the sum of the three amplitudes 
being displayed and no correlation exists tha t would enable the three values to be 
extracted.
Unfortunately the modern gun arrangement is to use three guns, but with common
148
vertical and horizontal deflection coils. The beams are much easier to align with each 
other, the system is cheaper and lower powers are needed. The mapping from one 
gun to three would now have to use the same vertical position for each beam. W ith 
modern systems allowing the use of up to lOOHz refresh rates it would be possible to 
scramble the beams sequentially, or even 2  at a time. This would reduce the quality of 
the display, but would render it almost perfectly secure.
5.4 G enerating R andom  Sequences
5.4 .1  R an d om  and p seudo-random  sequ en ce gen erators
In order to implement the full patent specification it is necessary to generate a con­
stantly changing scan order which in turn requires the generation of constantly c h a n g in g  
random sequences. It is necessary to insure that all the numbers from 1 to N (where 
N is the total number of horizontal lines to be displayed) are generated, once only, but 
in an order tha t cannot be predicted. There are a number of well known circuits to do 
some of this, the simplest being the maximal-length shift register sequence generators.
Such generators produces all the numbers from 0  to 2 ” — 1 but in a fixed order. 
They work by sta r tin g  at an arbitrary number then performing logical AND, OR and 
SHIFT operations on the bit pattern that represents this number. The result is the next 
number in the sequence. It doesn’t m atter where the start point is as the sequence is 
monotonie and the next number is defined by the current number being worked on, 
eventually the generator returns to the original start point, having generated all the 
numbers in the sequence.
This type of generator can easily be implemented in hardware. Figure 5.22 shows 
a simple implementation of a 50 bit sequence generator. Circuits of this type can 
easily be made into A S ic  designs to make them more secure. The major disadvantage, 
however, is tha t the circuit can only produce a few different sequences. The example 
in figure 5.22 will repeat when all of the 2^  ^ numbers have been generated. In reality, 
clocked at lOMHz, this will take 3-6 years.
In search of an alternative method, it became clear tha t a random number source 
would be easier to generate, and tha t algorithms that could generate random sequences 
from a random number or pseudo random number should be looked at.
149
Figure 5.22: A 50 bit fixed sequence generator.
One simple pseudo random source is to use the sequence generator given in fig­
ure 5.22. If, say, an 8  bit random number is required, then any 8  of the available 50 
bits could be used to make up an 8  bit word. W ith a repeating time of 3 6  years, this 
appears to be a good solution, and is in fact similar to most computer based pseudo 
random number generators. Alternatively, if an analog random source is preferable 
then just one bit could be fed out into a low pass filter circuit. By clocking the shift 
register at lOMHz, and filtering the output with a low pass filter set to cutoff a t IKHz, 
the output would contain uniformly random frequency components between DC and 
IKHz.
The problem with both of these techniques, from a security aspect, is tha t once 50 
bits of the register are known, it is possible to extrapolate forward and know what all 
the 50 internal bits are. This makes it possible to build a circuit tha t could synchronize 
its own shift register to the one being used to scramble the data. This also applies to 
the analog version though clearly a more complex decoder is necessary.
A more detailed look into the generation of genuine, uniform, random numbers will 
be covered in chapter 6 .
5.4 .2  Softw are so lu tions
Assuming a good, pseudo random number generator, a software algorithm can be 
developed tha t will produce a random sequence from a random number source.
Figure 5.23 is a program element illustrating how such a sequence is produced. In 
this case it is set to produce all numbers between 1 and 255.
150
(* ----------------------------------------------------------------------------------------------------------------*)
(*----- Program element that produces a random sequence of ----- *)
(*----- the numbers between 1 and max_value inclusive ----- *)
(*    *)
(* First create a flag for each possible v a l u e  *)
for i:=l to max_value do flags[i]:=0;
(* Next loop to output all max_value results *)
for i=max_value downto 1 do 
begin
(* choose a random number between 1 and i  *)
num:=l+trunc(random(i));
(* look for num flags that are still 0 ----- *)
count:=0; 
while num>0 do 
begin
count :“count+1;
if flags[count]=0 then num:=num-l; 
end;
(*----- count is the result, set its flag & print it ----- *)
flags[count]:=1; 
write(count, ’ ’); 
end;
Figure 5.23; Program to produce random sequences.
151
The algorithm works by choosing a random number between 1 and the number of 
numbers still to be produced. For the first choice, this will be between 1  and 255. Once 
the first number has been chosen the new range will be between 1 and 254 and so on.
The next stage, once this random number has been chosen, is to set a counter to 
look at a flag for the number 1 . If this number has already been output the flag will 
have been set. This will cause the counter to be moved on to the number 2. If, however, 
the flag has not been set, the chosen random number will be decremented by one, and 
then the counter will be incremented to now point to the flag for the number 2 . Once 
the original random number has been decremented to 0 , the current counter value will 
be output and then the flag that it is pointing to will be set. The next random number 
is now chosen, w ith the range reduced by one, and the process is repeated. Eventually 
all the flags will be set, indicating all the numbers have been output once and once 
only.
5 .4 .3  A  p rop osed  hardw are so lu tion
This system has the required ability to generate a random sequence, w ith the added 
advantages tha t it can operate for any number of elements in a sequence, and can be 
easily adapted to hardware implementation.
The software loops can be replaced with hardware counters and the software array 
can be implemented with a simple memory device. By adding a comparator, a clocked 
circuit can be built tha t will produce the required random sequence. Figure 5.24 shows 
a proposed implementation. It is designed to take an input between 0 and 255 inclusive, 
and produce a sequence ranging from 1  to 255. The multiplication required to generate 
a random number between 1 and M, from a random number tha t is always 8  bits, is 
accomplished by a ROM mapping. The ROM maps the input 8 bit number and the 
counter values (both fed into the address inputs) to produce an output according to 
the following equation.
f  random number \value =  1 + 1 -------- — -------   X counter j .y ^oo J
The principles are identical to those of the above program extract and for this 
reason it was felt unnecessary to develop this hardware any further. Once unscrambling 
hardware has been developed that extracts the data from the logical row, rather than 
use software scrambling, it might be interesting to research this idea further.
152
Figure 5.24: Proposed random sequence generator.
153
C hapter 6 
G enerating U niform ly D istrib u ted  
D igita l N um bers
6.1 Introduction
6.1 .1  O b jectives
There are many applications for random numbers including data protection, scrambling 
and cryptography [97]. In most cases a simple pseudo random number [98] will suffice 
but, particularly in the fields of security, a genuine random number generator is to be 
preferred.
There are a number of ways of generating such numbers and one of the most common 
is the use of a biased analog noise source [99, 100] to generate a random bit stream and 
then extracting words from this. Another commonly used method is to use a detuned 
FM receiver to generate high bandwidth white noise and extracting data from this. 
Systems such as these are good but suffer from the fact tha t an external source can 
interfere with them , in a known way. Though difficult, it is possible to predict their 
output when external conditions are changed from the norm.
Because of these problems there is a need to look at alternative methods of generat­
ing genuinely random numbers. It was noted that the generation of uniform numbers 
tended to rely on generating uniform bits and then building words from these.
A method is proposed here where a word is generated automatically from a random 
analog noise source. A conversion method is used to convert a Normally distributed 
voltage source into Uniformly distributed digital numbers. This provides an interesting 
offshoot into the theoretical analysis of the distribution and its underlying statistics.
154
This section will cover the theory used to produce these Uniform results. Later on 
analysis of the hardware needed to verify this theory will be undertaken and finally a 
detailed analysis of the distribution and the finite voltage cut-offs will be covered.
First however, it is necessary to look at the statistical conversion method used to 
get from Normally distributed samples to samples with a Uniform distribution.
6 .1 .2  B ox-M u ller  and N orm al d istr ib u tion  th eo ry
A well known piece of statistical theory allows for the conversion of observations from 
a Uniform, U{xmin^ ^max) distribution to observations from a Normal, Af{m,  cr )^ by the 
use of the Box-Miiller method [1 0 1 , 1 0 2 ].
If r i and rg are independent observations from U{0, 1 ) then it is possible to define
x i  ~  co s (2 7 rr2 ) \ / -2 1 n r i ,
and
X2 =  sin(27rr2)y^-21nri,
where xi  and X2 have an A^(0 , 1 ) distribution.
By looking at the sum of x\  and xl  it can be seen tha t by simple manipulation of 
these expressions a reading, r i , distributed as 7/(0 ,1 ), can be derived as
(6 .1)
In other words, with two independent observations from a Normal distribution it is 
possible to use equation 6 . 1  to get a single observation from a Uniform distribution. 
The equation of such a Normal distribution is given by
p{x) — — 2^^ , (6 .2 )crv27T
where m  is the mean and a is the standard deviation of the distribution.
The following work is based around these equations and their application to discrete 
distributions where the full theoretical requirements of the Box-Miiller conversions are 
not met.
155
Probabilty
Thermal source with delta functions at ±V
Digitisation curve
n '^ n+1 Voltage
6.2
6.2.1
Figure 6 .1 : Digitizing a real world voltage source.
C alculation O f T he T heoretical Param eters
C u t-off effects and scaling
The traditional Normal, or Gaussian, curve has the disadvantage in the electronics 
world of having limits at dboo. Because the output of any noise generator must be 
constrained by the amplifier supply voltages (±V) ,  a ‘cut-off’ form of the Normal 
curve must be generated when the voltage noise is sampled.
If a thermal noise source is used, the output voltage distribution will have this cut-off 
Normal probability function. This will have the same form as a true Normal function 
except a t the limits ± V .  At the upper limit, V, the remainder of the probability 
function between this cut-off point and -f-oo will appear as a delta function a t V  and 
similarly for the —V  cut-off point.
If this voltage source is now digitized, i.e. it is split up into, say, 256 separate, equal 
spaced voltage regions, then the resultant probability density function will have these 
delta function added into the normal values for 255 and 0  respectively. This effect is 
shown in figure 6 . 1
This is not a standard distribution though it has some of the properties of the 
Truncated Normal [103], the Winsorized Normal [104] and the Censored Normal [105] 
where either out-lying points are ignored, or treated as uncertain. These distributions 
are covered in the literature but their analysis tends to concentrate on the effects they 
have on the honesty condition rather than on how the use of the new distribution is
156
affected by their differences from the Normal.
It is convenient to express the cut-off point in terms of the number of standard 
deviations from the mean rather than as a voltage limit. An observation x  from an 8  
bit digitization will now be defined as
\ V -  1X  =  trunc —^  X  128 -i-128 
ICCTv J
where c is the cut-off point measured in standard deviations and ay  is the standard 
deviation of the voltage signal.
The effect of the trunc  function is to subtract 0-5 from the distribution parameter 
mean, hence the approximation for this distribution is A/’(127-5 ,(~)^).
In order to scale an observation from a Normal distribution, Af{m, to one from 
a distribution A/"(0,1) the readings must have the distribution mean, m, subtracted 
from them and then the result must be divided by the standard deviation, a. This will 
now allow the use of equation 6 .1 .
By substituting
X,
Xo =
(xi -  m)
a
{x2 -  m)
a
into equation 6 .1 , the result is an observation from the distorted uniform distribution 
&T(0,1).
This can be scaled to 7/(0, n) by simply multiplying the observations by n, and can 
be digitized by truncating the result. Equation 6 . 1  has now become
trunc mx e ' (6.3)
It should be noted at this point that the probability of getting an observation r = 1 
from a distribution VV(0 , 1 ) is zero (as there are an infinite number of points along the 
line between 0  and 1 ). This means tha t the above conversion, when truncated , will 
produce all the integers between 0  and (n — 1 ) inclusive, but not n  itself. This in turn 
means tha t in order to get an 8  bit result, the factor n must be 256 and not 255 as 
would be expected.
157
0.015-
iQ 0 .0 1 -
0.005-
0.0
0 50 100 150 200 250
8 bit output
Figure 6 .2 : Graph of the pseudo-Normal distribution results,
6 .2 .2  S im ulations
Having produced the above conversion theory, the next stage was to study the effect of 
the cut-off parameter to see how it could be optimized for this application. In order to 
achieve this a set of simulations were created that would take pseudo random , Normally 
distributed, numbers (from a simple Pascal function call) and map these to a Uniform 
distribution via the reversed Box-Miiller conversion.
The voltage source was simulated by generating a random , real number from a 
shift and divide algorithm using 8  bit uniform random integers. In this way an almost 
continuous set of uniform observations from t /( 0 , 1 ), were generated and these were then 
passed through the original Box-Miiller conversion. This resulted in observations from 
an jM(0,1) distribution. The correctness of this distribution was verified graphically 
and the results are shown in figure 6 .2 .
Readings from this distribution were then taken and processed via equation 6.3. 
This was done a large number of times for a fixed value of c. Other runs were then 
done using different c values.
In this way a visual representation could be analysed by eye and the most uniform 
distribution selected. The best value of c was found to be approximately 3*4 but the 
error on this was large and small variations in c caused a significant variation in the
158
‘evenness’ of the distribution. It was also necessary to look at a very large number of 
simulated points, over 1 0 0 0  in most cases, before a true impression of the distribution 
could be seen. For the detailed analysis between 3 3, 3 4 and 3-5 this had to be extended 
to over 50000 points before a truly stable distribution was seen (taking 2 5 hours to 
calculate on a ’286 Pc).
It was noted that the quality of this output was very dependent on the number of 
units used to digitize the original. Normally distributed, voltage source. In all cases the 
results were scaled from the t / (0 ,1) into a C/(0,256) distribution and then truncated 
to simulate the generation of 8  bit digital numbers.
6 .2 .3  E valuation  o f un iform ity
One problem facing any attem pt to optimize these equations using a computer based 
process is tha t the property of ‘uniformity’ for a distribution is very hard to define. 
W ithin statistical analysis there are a large number of methods of specifying such 
concepts, but only two are of any practical use in this situation, namely the maximum 
deviation from the mean and the sum of all the deviations squared.
The maximum deviation is of particular use when the distribution is close to the 
required format. All values will be close to the correct value (mean) and hence the 
worst case is a good measure of the quality of the distribution. However, if many of the 
points are correct but one or two are a long way out, then maximum deviation is not 
such a good measure and the sum of all the differences squared will be more relevant 
as it reduces the significance of individual values in relation to the whole.
For the initial work the sum of the différences squared was used to evaluate distri­
butions and then, as the precise details became known the maximum deviation could 
be seen to be a better measure and was used for most of the more complex analysis 
covered in later sections.
6 .2 .4  C alcu lating  a d istr ib u tion  an a ly tica lly
Figure 6.1 shows a Normal distribution curve. The area between Vn and Vk+i represents 
the probability of an observation being between these two values provided the to tal area 
under the graph is equal to 1 . As there is no explicit integral for the Normal density 
function, equation 6 .2 , then this area must be obtained by a very close approximating
159
equation.
The integral is known as the cumulative density function, # , and is defined as
r® 1  1 (=—^{x) — / — -==e2 " 7 2  d x =  P{x)dx .J—oo (J\/27r J~oo
Given this, and provided an approximation equation for ^{x)  can be found, then 
it is possible to find the probability of an observation being between Vn and Vn+i by
P (K  < Jv: <  K + i) =  P{x) dx = $ (K + i)  -  $(% .). (6.4)
If Vn and 1 4 -1-1 are chosen so tha t they are the limits between which the A/D con­
verter will give a reading of n, then, provided the Normal ‘tails’ are added into the 
probabilities of 0 and 255, this area corresponds to the probability tha t the input volt­
age will result in a digitized value of n  being returned. The probability of getting a 
reading of n is now defined as
f d>(n„iaa:) ~  0 >  % < 254
P(^7l) =  < ^{Timax) 71 = 0
[ I  — ^{rimin) n — 255.
This is now in a form tha t can be analysed computationally and will be used later 
to investigate possible optimization algorithms. First however, approximations to the 
cumulative distribution function have be investigated.
6 .2 .5  F in d in g  th e  cu m u lative d en sity  fu n ction , $
The limiting factor in calculations involving the cumulative distribution function, d>, 
is the accuracy of the function used to approximate the Normal distribution function. 
Hastings’ approximation [106] is the best known equation for this purpose. It states 
tha t
P{x)  =  1  — Z[x){bit  -f- 6 2 ^^  T  -j- 6 4 ^^  4- 6 5 # )^ -j- e(:r),
where
leWI < 7 -5 x 10 - ^
and
1 -{-px
160
and the constants are
bi =  0-319381530,
6 2  =  -0356563782,
6 3  == 1-781477937,
6 4  == -1 821255978,
6 5  =  1-330274429, 
p = 0-2316419.
Z{x)  is the equation describing the # (0 ,1 )  distribution,
This has the smallest error, e(æ), of all the approximations tha t were found for this 
calculation but, as it requires the value of Z{x)  (and hence the values for the constants 
e and tt) to be known to at least 1 0  digits, it is not the most suitable for computation 
in all cases. A better, ‘stand alone’, function [107] in these instances is defined as
P{x)  =  1 — — ^1 +  dix  T  d2x “^ +  d^x^ +  d^x^ +  d^x^ +  d^x^^ -T e(a:),
where
|e(a;)| <  1-5 x IQ-^
These new constants, d\ to dg are
d\ =  0-0498673470,
d2 =  0-0211410061,
(^ 3 =  0 0032776263,
c/4 =  0-0000380036,
ds =  0-0000488906,
dg =  0-0000053830.
Having written procedures to test both methods for accuracy it was found that 
they behaved identically provided both were implemented in extended arithmetic in 
Sun Pascal. Figure 6.3 shows the form of #(cr).
161
1.0-1
0.8-
!s 0.4-
0.2 -
0.0
•5 —4 —3 —2 — 1 2 3 40 1 5
Normalized reading
Figure 6.3: The Cumulative Distribution Function,
It was noted at this stage that there are a number of more complex approximations 
to this function where a set of 4 or even 6 equations are used to approximate different 
parts of the cumulative distribution. The Fortran n a g  library contains an implemen­
tation of Hastings’ algorithm given above but with a few extensions [108] to give better 
approximation values at the extreme points in the curve. It was decided for reasons 
of speed of execution tha t this should be used instead of the hand encoded versions 
though tests remain inconclusive as to which was the most accurate.
6 .2 .6  A n a lysin g  th e  effect o f  changing th e  cu t-o ff p oin t
W ith these approximations to <F(a;) it was possible to write a program tha t calculated 
the probability of obtaining any combination of inputs to equation 6.1.
By using two nested loops it is possible to enumerate these combinations and hence, 
using equation 6.4, calculate the probability of them occurring.
If these two input values are also passed through the Normal to Uniform conversion 
these probabilities will contribute to the probability of getting a particular results, n, 
from the conversion equation. If all combinations are enumerated and the probabilities 
of those combinations tha t produce an output value of n are summed, then the resulting 
to tal is the probability of getting n  as an output value from the conversion equation. 
When calculated for all values of n  (0 to 255) the probability density map has been
162
obtained.
As a check to the program , the honesty condition was invoked. This states that 
the sum of all the probabilities in both input and output distributions must be equal 
to 1. Having verified tha t this was so, the output distributions were compared to the 
simulation results found earlier. The correlation was very close and from this it was 
deduced th a t the routines were functioning correctly.
Having developed a method of calculating the distributions it was now possible to 
look at the effects of different cut-off values of the distribution, ±c. Figure 6.4 shows 
how these changing values effect the distribution.!
Clearly at low values of c the conversion equation cannot produce small values of 
output. This, as will be seen in section 6.4, can be used to find the lower limit for the 
optimum value of the cut-off parameter.
As the value of c increases the quality of the distribution gets better up to a point 
somewhere between c =  3 and c =  4. After this the maximum deviations get worse 
until, a t around c =  5 drop-outs appear where the equation cannot produce certain 
values.
Finally, a t around c =  16, the conversion maps all inputs to small numbers and the 
larger values are not obtained. This provides an upper limit on the optimum value of 
c.
This technique of finding the distribution can be applied to look at larger numbers 
of bits used in the digitization of the noise voltage source, while still truncating the 
output of the conversion to 8 bits. Figures 6.5 and 6.6 show the distributions a t c =  3*0 
for 9 bit and 16 bit digitizations respectively. As can be seen the increase in resolution 
causes a very significant improvement to the uniformity of the resultant distribution.
6 .2 .7  F in d in g  cq from  m axim u m  d ev iation s
The is clearly some optimum value, Cq for c. By computing all possible values of c, 
from 0-01 to 10, in steps of 0*01, it is possible to plot a graph of maximum deviation 
against c. This is shown in figure 6.7.
From visual analysis of this graph it can be seen tha t on the macro level, a value 
of c between 2*5 and 4-0 will produce the lowest deviations and hence the best conver-
^Note the different axes that have been used for these illustrations
163
0.1-
0 .0 8 -
«  0 .0 6 -
0 .0 4 -
0.0 2-
0.0
0 50 100 150 200 2 50
*10-'
1.4-
1.2-
1.0-
0.8 -
0 .4 -
0 50 100 ISO 200 250
Output Digital Number Output Digital Number
(a) c=1.0 (b) c=2.0
*10-'
100 150
Output Digital I t n t e r
100 150
Output Digital Number
(c) c=3.0 (d) c=4.0
100 150
Output Digital Number
100 ISO 200
Output DIgltd ttm b e r
(e) C=5.0 (f) c=10.0
Figure 6.4: A selection of distributions for varying cut-off values.
164
♦ 10"
7-,
6 -
5-
4-
2 -
150 2500 50 100 200
Output Digital Number
Figure 6.5: Distribution for 9 bits, c =  3.
* 10"
4H
f-
2 -
1 -
50
 1 1------------1—
100 150 200
Output Digitd Number
250
Figure 6.6; Distribution for 16 bits, c =  3.
165
1.0-
0.8 -
.2 0.6-1 a
.1 0.4-
0.2-
0.0-
2 3 4 5 6 7
Value of the cutoff constant
n
10
Figure 6.7: Graph of maximum deviation against c.
sion. As the gain settings for a simple hardware amplifier are only approximate this 
is more than accurate enough to specify the required value for experimental hardware 
verification.
6.3 Hardware Im plem entations
6.3 .1  N o ise  gen eration
There are very few (if any) truly random events that are measurable, hence the more 
useful sources are those tha t cannot be determined without affecting the result, i.e. 
though not truly random , they cannot be predicted. One such source is a thermally 
produced voltage signal in a p n  junction. Prediction of such a signal would require 
knowledge of the thermal states of every atom in the junction, which, even if it were 
possible to compute this prediction, could never be determined without affecting these 
states and hence the whole source is not deterministic.
There are some other systems tha t can provide pseudo-random output. These are 
mostly chaotic in nature [109] but have, as yet, no prediction method. However, in 
the analysis of such circuits their function is still deterministic relying on massive 
complexity to make them unpredictable.
Though there are many high frequency diodes that can be used to produce large
166
HFigure 6.8: Circuit diagram of the wideband noise generator.
amounts of thermal noise, there are some that are particularly useful for this applica­
tion. One such device is the BF173 transistor which, if reverse biased and left with a 
floating emitter, will produce noise at the collector-base junction which, amplified by 
the gain of the transistor, appears as a much larger signal at the emitter output.
The output of such a transistor based noise stage has a voltage distribution with 
standard deviation of 30/2V and a noise bandwidth of ~lG H z. In order to keep the 
bandwidth as high as possible, this had to amplified in small stages utilizing the higher 
small gain bandwidth of solid state amplifiers. The OPA620 was chosen as it had 
proved stable at many gain settings and has few pickup problems. It also has a wide 
full signal bandwidth.
Figure 6.8 shows the schematic of a circuit tha t implements this noise source.
A need for very good supply filtering was found, as the amplifiers became unstable 
a t the least opportunity. By laying the circuit out on a long thin circuit board, the 
feedback coupling was kept below the point required to start oscillation and a final 
voltage shifter was then added off board to generate the correct voltages for input into 
an a / d  converter. The total voltage gain was around x  20000 but the final stage was 
only a x 2 0  allowing an adjustable signal to be fed out to the converter and, coupled 
with the use of a multi-turn potentiometer, allowed accurate setting of the cut-off 
constant for the noise source.
167
N o i s e
S o u r c e
C l o c k
V i n
M - B i t
O u p u t
D a t a
Figure 6.9: Block diagram of the sampling hardware.
In order to protect this circuit from outside interference, such as the processor clock 
of the PC, it was mounted into a UHF module tha t provided shielded inputs for the 
power supplies and also provided BNC connection for the noise signals. These also 
served to protect the sampling circuitry from radiated noise interference.
Having built this unit it was tested on a Hewlett Packard wideband spectrum anal­
yser. The voltage output was seen to be proportional to the logarithm of the frequency, 
enabling accurate determination of the 3dB point of the circuit a t 1*7 ±  0 2MHz. It was 
also noted tha t the signal did not reach the background until approximately 15MHz. 
The conclusion was tha t it would provide valid noise with frequency components of up 
to 5MHz. As this was large compared to the 0*5MHz requirements of the a / d  convert­
ers being considered, it was valid to treat it as a source with infinite bandwidth as far 
as the input sampling circuitry was concerned.
6 .3 .2  8 B it hardw are
In order to obtain samples of this signal and then map them to Uniformly distributed 
observations, a sampling and mapping circuit had to be assembled. Figure 6.9 shows 
the block diagram of this circuit. The design is based around supplying the address
168
inputs of a normal ROM with two digitized noise signals. An input clock is divided into 
two phases, one latching a digitized signal to the top half of the address lines and then 
the other phase latching a digitized signal to the lower lines half a clock period later. 
This enables the ROM to be used as a mapping from two 8 bit inputs (the addresses) 
to one 8 bit output (the data lines). Once both data values have been latched, the 
corresponding output of the ROM is then also latched to give a valid continuous sequence 
of Uniform random numbers at the latch output.
Initially an 8 bit digitizer was used, the now familiar ADC304. This meant tha t a 
64k byte ROM was required as there are 16 input bits, leading to 2^ ® possible combi­
nations. As it was hoped to produce 8 bit values, a normal byte organized ROM was 
ideal and a 27C512 was chosen.
Figure 6.10 shows the final circuit diagram of the hardware tha t reflects the block 
diagram given in figure 6.9. A latch on th e  PC interface card, described in chapter 1, 
was now attached directly to  the A /D  output lines, allowing a p a s c a l  program to read 
this latch and produce a histogram of frequency of occurrence against reading for this 
circuit. This output was then used to calibrate the unit and set the c parameter.
6 .3 .3  S ettin g  th e  c am plification  param eter
In order to set the cut-off constant, it was necessary to analyse the results and feed back 
corrections to the amplification stages until the correct setting was achieved. This was 
done by collecting the data on the PC and plotting the distribution after every 10000 
observations (about 5 seconds of collecting). Such a distribution is shown in figure 
6 .11.
An interesting feature of this figure is that some points occur slightly more often 
than others, in particular the probabilities for 8, 16, 32 etc are unusually high. An 
investigation into the cause of this produced two possibilities. One is that, as the 
converter uses a two stage settling process, it is possible tha t it is not sampling the 
signal exactly at the start of the conversion process and hence the input is changing 
before the first 3 output bits have settled to their correct values. The other possibility is 
tha t the converter has slightly different voltage ‘windows’ for each conversion number. 
This would be possible as the ADC304 is only specified to ±0-5 units and hence the 
accuracy of each bit could be ca u sin g  the problem.
169
8 2 s  s  g g % B
S 8 3 8 3 3 S S &
Figure 6.10: Full circuit diagram for the 8 bit mapping.
170
8 .0* 10" -
Li_
4.0*10"-
0 50 150 250100 200
A /D  reading
Figure 6.11: Example distribution from the converter data lines.
Fortunately both of these problems can be affected by external influences and im­
proved results were obtained by reducing the input signal bandwidth. This was suffi­
cient to prove the principals of the circuit.
Once these problems had been minimized the midpoint of the distribution was 
set by balancing the heights of the integrated ‘tails’. This was found to be the best 
indication of where the midpoint was located. When both the ‘tails’ are the same 
height the distribution is exactly centered on the screen and hence correctly balanced 
with a mean of 127-5 as dictated by the theory.
Once the mean had been correctly set the peak height was measured, in millimeters, 
from the zero axis on the screen. The height of the distribution at z  =  1 (i.e. the first 
reading from the distribution tha t is not part of the ‘tails’) was also measured as this 
corresponds to the height of the distribution at the cut-off point. These two points 
correspond to f{fi) and f{xc)  respectively.
Because the cut-off point is defined in terms of the number of standard deviations 
it can be shown that
(ff5)
<7
It can also be seen that the measured distances on the screen, because they have
171
been scaled, do not satisfy the honesty condition for a distribution. Because of this a 
scaling constant was added into equation 6.2 to get
This can now be rearranged to get
-  ^ ( ^ ■ ^ )  =  [ f ' {x) .SaV^)  , (6.6)
and since
~  S a V ^ ’ (G 7)
equations 6.5, 6.6 and 6.7 can be combined to get
a/2  In / '( / i)  -  21n/'(a ;c).
As an example, the average of 6 such measurements of and f'{Xc) were 54*2 
and 5 3 respectively, and hence c =2-16. Clearly the gain was set slightly too high in 
this case as the cut-off point is too close to the mean.
Alternatively the reverse of this process gives
If c is set to 3, the ratio is equal to 90, i.e. the ratio of the peak reading to the 
minimum reading is 90:1.
Once the correct amplification and offset (mean adjustment) had been achieved, a 
much larger sample set, 10® measurements, was taken to verify the distribution.
6 .3 .4  G eneratin g  a m apping ROM
In order to build the mapping hardware a program had to be written to generate the 
complete 2^ ® values needed for the 27C512 EPROM (and later the 27C020 256kx8 bit 
component [110]). This program enumerated all the possible input values using two 
nested loops (X I and X2), running from 0 to 255. This in turn was used to generate 
the addresses by the equation A = 2®X1 -j- X2.
The equations given in the last section lead to the mapping from X I and X 2 to 
the output result, r. These were used to create the data values for the ROM cells.
172
5000n
4000*
o 3000- 
o
H 2000-I<u
U-
1000 -
n ----------- I-----------1—
50 100 150
ROM output value
200 250
Figure 6.12: Output from the Normal to Uniform mapping hardware.
As the addresses were generated sequentially, the program was able to directly cre­
ate Motorola ‘S’ record output tha t could be fed directly into the EPROM programmer.
By viewing this data as a contour map it can be seen tha t the middle point (127,127) 
has a very high probability of occurring but, as readings are taken further from this 
midpoint they reduce in probability. As the mapping is symmetrical in both X i  and 
Xg, any points on a circle around this midpoint will have the same probability. This 
is the inverse of the normal distribution curve, as would be expected.
6 .3 .5  R esu lts  from  th e  8 b it hardware
Once the parameters had been set for the ROM mapping, the distribution data could 
be downloaded into the PROM programmer and then into the ROM. By moving the 
8 bit sampler connections on the PC interface card to the output latch of the circuit 
the Uniform data could be sampled and uploaded into the PC in a similar way to the 
collection of Normal data used earlier. Figure 6.12 shows the output for 10® samples. 
As can be seen it is very close to the expected level of ‘uniformity’ predicted in earlier 
sections.
173
Device Resolution Conversion Method Price Speed
AD573JN
ZN502E
ADC1061CIN
MP7685KD
10 bit 
10 bit 
10 bit 
10 bit
Successive approximation 
Successive approximation 
Modified Successive approx. 
Flash Conversion
i^27-90
i?13-00
£19-90
£45-68
30/iS
20/zs
1-8/its
2/lls
Table 6.1: High resolution converters..
6 .3 .6  9 B it hardw are
The next stage was to look at generating a more Uniform output by using 9 bit inputs 
to the mapping ROM. This is about the limit of the hardware as the two 9 bit inputs 
require a ROM with 18 address lines. This corresponds to 256k bytes and was the 
maximum EPROM size available. To make use of the bandwidth available in the noise 
source the circuit also requires a fast 9 bit converter. Table 6.1 shows a selection of 
suitable converters. In the end it was decided to use the MP7685KD supplied by RS 
Components [111]. This had the required conversion rate and also had the advantage 
of using a full flash conversion process. It was also hoped tha t this would overcome 
some of the problems encountered with the earlier versions of the circuit using the 
ADC304.
An extra flip-flop was added to latch the extra two address bits in parallel with the 
8 bit latches used earlier. Another latch was also needed to enable all 9 bits to be read 
into the PC and stored.
Unfortunately the same problem of some values having unusually high probabilities 
reappeared for this version of the hardware. Again small changes in the surrounding 
circuitry helped to minimize the effect. A more detailed analysis of the distribution 
around the problem points showed that these peaks were set in slight troughs. This 
meant that for some reason values close to these peaks were sometimes converted as if 
they were on the peak. In fact the peaks always occurred on the borders of powers of 
two - for some reason the last few bits were going to zero in some instances.
Changes in the constant voltage reference supplies, in particular adding a high 
current driver, helped reduce the problem and showed tha t another possible cause of 
the problem was noise from this reference voltage. Large decoupling capacitors on this 
input made significant improvements and enabled the rest of the circuit to function
174
w ithout any degradation in performance.
This 9 bit conversion circuitry, including the high current drivers for the reference 
source, is shown in figure 6.13. Figure 6.14 shows an example output distribution from 
this hardware. If compared with tha t of figure 6.12 it can be seen tha t the improvement, 
predicted in the theory, has been shown in practice.
6.4 F inding A n E xact Value For Cq
6 .4 .1  A  m ore d eta iled  exam in ation  o f  th e  d istr ib u tion
When the equations for the distribution are analysed, more details of the structure of 
this distribution can be seen.
The conversion into a Uniform distribution maps pairs of input values to single 
output values in a many-to-one relationship. This is because the Normal distribution is 
symmetrical and any Uniform output value, generated by (iCi, Tg) will also be generated 
by (x2 yXi) and also by taking identical points mirrored about the mean of the Normals. 
This means tha t there are at least 4 pairs of inputs per possible output and in some 
cases there are more than this (though always in multiples of 2).
During the mapping process the input pairs form an output value on the real number 
axis. These values can be represented as delta-like functions with an area equal to their 
corresponding joint probability, p{r) — p(xi)  x p{x2). Figure 6.15 shows a section of 
the real axis illustrating how these delta functions occur.
From this diagram the next stage of the conversion can be seen. The truncation 
and probability summing operation is illustrated in this diagram by summing the areas 
of all the delta function between N  and N  + 1 where N is an integer.
W ith low values of the cut-off constant, all these delta functions have high positions 
on the real axis. They all start between 255 and 256 but as the cut-off value is increased 
these peaks begin to spread out down the axis, always keeping their same relative 
positions, but expanding downward. This expansion gradually moves peaks out of the 
255 to 256 band and some now fall in the range 254 to 255. Eventually the peaks 
spread out into the 0 to 1 band and all region values from 0 to 255 will have some 
peaks in them. The optimum positioning of these peaks is dependent on the area of 
the delta functions and the number of such functions, in each region.
175
H H '
il— y'— —I
■■I— — I'
Figure 6.13: Full circuit diagram of the 9 bit mapping hardware.
176
5000n
4000-IÜ 30004o
H 2000-I
1000 -
50 100 150 200
ROM output value
250
Figure 6.14: Results of the 9 bit Normal to Uniform conversion.
1.2 * 1 0
0 .0* 10“
0.2 0.225 0.230.205 0.21 0.215 0.22
The Red axis
Figure 6.15: Part of the real axis showing the distribution of the delta functions
177
This analysis shows tha t there is a minimum value of the distribution. Figure 6.4c 
shows th a t it is possible to have a distribution where the maximum deviation from the 
ideal Uniform is less than This implies that there must be a peak in every section 
of the real axis as, if a group had none, its probability would be 0.
From equation 6.3, the minimum value of r, before truncation, is found when the 
scaling value x' is a maximum and this occurs when x \ = X 2 = 0. By substituting this 
into equation 6.3 it can be shown that
256e /'æ - 1 2 7 - 5 \'I 128 )
for an 8 bit result.
From this, since this must be less than 1 for all groupings 0 to 255 to have some 
peaks in them , it follows that
- 0 . 9 9 2 2 c g < l n ( 5 ^ )
and hence
Co > 2 36.
Going back to figure 6.15, as the cut-off is increased the tail end of the real axis 
becomes less populated and finally it will fall outside the band 255 to 256. At this 
point there is a  similar definition for the maximum value of Cq.
For this scaled Normal, the result is
255 <  2 5 6 g - ^ ,
and hence
resulting in the maximum bound of
Co < 16 02.
6 .4 .2  A n alysis o f  th e  d istr ib u tion  using in tegers
For any given c value the distribution of the delta functions can be found and hence 
the groupings for values between say, 0 and 1 can also be determined. Having derived
178
the groupings for c =  2*36, the minimum value, the next possible grouping is when one, 
and only one, of the delta functions moves down the real axis, passing over an integer 
boundary and joining a lower group.
This value was found by looking at every delta function and calculating the corre­
sponding c value tha t would just put it into the next lowest group. This meant that, 
after a possible new c value had been found for every delta function, the minimum 
such value could be determined and hence a new c value could be used and the new 
distribution calculated.
This is clearly a long and complex process so a few improvements were needed in 
order to reduce computation time. Firstly, to reduce problems of calculating so many 
points an integer solution was sought.
By expanding the calculations, the position on the real axis of the resultant, r, is 
found to be
r = 256 * exp i f (0*5 -f 37i) -- 128"
2
+ '(0-5 +  %) -  128 ;
n 128 128 ^ j]
This is because the integer values have to be scaled to be from an W (0 ,1) distribu­
tion and also because the value representing any given region is taken to be half way 
through tha t band. For example when the integer value is 127, the actual range is 
between 127 and 128 and hence the mean of 127*5 is used.
This equation can be rearranged to generate integer solutions and the best reduction 
is found to be
65636
C2 [ln(r) -  ln(256)] =  510(æi -4- X2) -  2x\  -  2x] -  65025. (6.8)
Using this, integer solutions for all the peak positions can be found (the right hand 
side of the equation) and only the mapped integer values (i.e. the left hand side for 
r=0 , 1, 2 etc) need be found as real numbers.
It is now possible to look at only the nearest peak to the mapped integer value in 
each group rather than look at all possible peaks. This has to be carried out for all 
regions as some peaks move faster along the real line than others, though they never 
overtake each other.
In effect, now tha t integer solutions have been found, the peaks are fixed and it is 
the region boundaries tha t move.
179
Another improvement was to find both the nearest peak to a divider and also the 
second nearest. These two values were used to allow the dividing point to be set to half 
way between the two corresponding c values, ensuring the smallest effect of rounding 
errors. If the minimum value were used then the peak tha t is supposed to have moved 
into the next section may not actually do so when the calculation is done.
Because it is now possible to determine which peak crosses the divide first, provided 
a known grouping can be established at the start, then there is no need to actually work 
out the new locations. The heights (areas) of the peaks merely need to be recalculated 
for the new c value and the summing done by the known, rather than calculated, 
groupings.
In some cases the mathematical resolution was so poor, even using 32 bit arithmetic, 
th a t it was not possible for the analysis program to decide which peak moved into the 
next group first. One way to overcome this problem is to analyse all the possible 
combinations of moving one peak at a time. Only one of these combinations would 
be the correct one and the rest would give false values as the distribution would be 
momentarily wrong. Provided none of these combinations produces a minimum value 
for the deviation, this approach can be used to ensure tha t all possible distributions 
are examined.
This latter stage was not actually implemented as this program merely aimed to 
improve the known value and not deduce it precisely and the added processing time 
was not acceptable.
When run this program produced an answer of 3-11637552399035. This was found 
to be caused by the (89,123) peak passing from the 164 region to the 163 region. It 
also corresponds to a maximum deviation of 1-7252946484629 x 10“ .^
6 .4 .3  D ed u cin g  cq from  th e  m inim um  com b in ation
By considering the distribution around this point it can be seen tha t the maximum 
deviation grows smaller as c reduces over this range. This means tha t the minimum 
value occurs at the previous point where this peak just crosses the divide line. This 
can be calculated analytically by rearranging equation 6.8 to get
In i _________ ^ _________V256/ 2 [xi -  127-5)2 +  { ^ 2  -  127-5)2’
180
which yields a c value of 3-116373099.
6 .4 .4  F urther an alysis o f  th e  d istrib u tion
The problem with this approach is tha t it does not take into account the fact tha t 
the maximum deviation changes with c value within a grouping as well as between 
groupings. By looking at the distribution the major effect on the minimum deviation 
is found to be due to peaks moving between groups but there is still this small change 
within a group, caused by the A/’(0 ,1) scaling.
As the honesty condition must be satisfied for any distribution, this change is not 
linear, some peak areas increase and some decrease with c. The overall effect is tha t 
a program must be written to look at both the changes within a grouping and the 
different groupings themselves and then find the maximum point for each of these 
possible distributions. This would be far too time consuming with available computing 
facilities, since the previous program to calculate Cq for just the best grouping took 
over 11 days to run on a Sun Spark 2 system.
A program written in the Maple symbolic algebra package was able to find the 
minima by looking at the value changes. Unfortunately this is slow for one group (a 
few seconds) and could increase the total computing time to months if not years for a 
complete calculation
It is very unlikely tha t the results of this program would come up with any different 
answer from that already obtained. The effects on the distribution of changing c are 
small within a grouping while the difference between distributions when a peak changes 
region is much larger and hence the effect of altering c, when the groupings do not 
change, is not likely to be significant. However, until such a proof is obtained the value 
cannot be guaranteed as being correct.
6 .4 .5  O ne final im provem ent
Having calculated a possible value for the minimum deviation it is possible to reduce 
the original range by a small amount. For large values of c the largest peak is generated 
for Xi = 127 and X2 =  127. By symmetry this peak is in the same place as the peaks 
for (127,128), (128,128) and (128,127).
For smaller values of c the tail effects dominate and the largest peak is found to
181
be generated from rci =  0 ,0:2 =  0 and the four combinations of 0 and 255 (the other 
‘mirrored’ tail effect).
Given the largest peak, it is known that this cannot be larger than the maximum 
deviation possible, as this peak alone would contribute too much to the distribution. 
The value calculated in the previous section gives one possible minimum deviation for 
the distribution and hence the height of the largest peak must be less tha t ^  plus this 
value since the deviation, not the absolute value must be used.
Hence, for the first peak (127,127)
4 X P^(127) <  ^  +  1-72529464846290 x 10"^
and since 0(0) =  0*5 it can be seen that
/ - c \  +  1-72529464846290 x lQ-3$  ( — )  > -  V -^ ---------------2---------------------- +  0 ' '
and for the other peak
^  -1 2 7  \  +  1-72529464846290 x 10-»
128 /  “  2
A program was written that found the inverse of the cumulative density function, 
0 “ .^ This was then used to find both a minimum and maximum value of c depending 
on which peak is used. This resulted in the range of cq being improved at the upper 
limit and combining this with earlier results the range for cq is
2-36 <  Co <  12-06.
Clearly the Cq parameter does not, for all practical purposes, need to be precisely 
defined. Any value approximating the above calculated optimum will ensure tha t 
mapping hardware will produce useable Uniform distributions from the cut-off Normal 
inputs present in a real world thermal noise source.
182
C hapter 7 
C onclusions
7.1 P ossib le Future W ork
There are still a large number of alternative scanning methods available for both the 
capture and display of images. The ideas of using area CCDs as one dimensional devices 
can be taken much further and the applications of unusual scanning displays have only 
just been touched upon.
In order to do further work into novel scanning methods a full electromagnetic 
display system would be essential. The preliminary work done in chapter 5 shows 
some of the difficulties that such work would have to overcome and also points at 
some ways of overcoming them. High bandwidth coils are easy to design given the 
required simulation software and the expertise and facilities to build and test coils. It 
is doubtful tha t modifications to the existing coils could achieve the required bandwidth 
for anything other than specific, purpose built, devices but it would be interesting to 
see the limits of modern multi-scan monitors where y-axis scanning of over 200Hz is 
already available.
The uses of protection systems such as the random scanning system described earlier 
are numerous and many people have expressed interest in such devices including the 
Law Society and the American Embassy. The development of a VGA system would 
be advantageous for the marketing of such a system and the prototyping of a colour 
system would be essential.
The hardware developed to look at laser pulses needs some fine tuning to get the 
correct coupling and frame shifting tha t would be needed in a commercial product. 
Possible improvements, including the use of ground plane p c b s  and putting the supply
183
regulators onto the camera head itself, show that the design can be improved and the 
addition of automated software analysis would provide suitable driving for ease of use.
The x-ray one dimensional camera can also be improved by the use of commercial 
PCB design and would benefit from more work being done on the scanning and readout 
electronics, particularly with reference to the methods of recognizing a single X-ray 
event. It may be tha t a software algorithm could be developed to look at the resultant 
images or tha t some in-line circuitry could be used instead, possibly using a 3x3 grid 
to carry out signal processing.
There appears to be no reason why the replacement of the optical CCDs with x-ray 
sensitized devices should cause any problems.
The surface generation hardware should be easily adapted to work from a normal 
video signal, though this would limit the accuracy and applicability of the camera in 
the form it has been developed so far. Again the use of PCBs would enhance the quality 
and should also allow the device to run at its full crystal speed by reducing the crosstalk 
pickup on the output signal.
Finally the obvious improvement to the theoretical work is to prove tha t the deduced 
cut-off point is correct and to extend this proof to find such points for all numbers of 
quantization. It does not seem likely, due to the discontinuous nature of the conversion 
process, tha t an analytical solution can be found but there seems to be a good chance 
of finding a proof for any specific quantization level.
Such a proof may well be found by looking at the maximum possible change in the 
value of c between the limits for each possible grouping. This would allow a proof to 
be deduced if it can be shown tha t such limits confine the ‘looked for’ value to only one 
grouping. This would then lead to an analytical solution once this grouping is known.
To reduce the limits further it may be possible to scan through the possible group­
ings, looking at the total probability of peaks in the 0 to 1 group. This must always be 
less than the deviation used to deduce the upper limit in section 6.4.2. Such a program 
would reduce the limits still further but is still specific to the groupings for 8 bit values 
and is not as general as it could be.
184
7.2 C onclusions
All the projects here have proved the principles of their operation and have verified 
tha t the ideas can be made to work and that the results are as predicted.
The surface generation is a good example of turning computer programs into hard­
ware in such a way tha t a vast increase in throughput is obtained. It also illustrates 
how much can be done by approximations, particularly as no calculations are needed 
for the final result whereas many real number operations were needed for the original 
rendering.
The scanning methods used for the security project allowed further development and 
helped draw attention to the problems faced by bodies such as the Law Society. The 
continued interest in this project may well lead to some commercial realization, with 
a t least the verification of the idea clearly illustrated by this work and by subsequent 
testing done at Marconi Electronics.
Both the one dimensional cameras have proved that CCDs can be successfully used 
in one dimensional applications and tha t modification to the standard scanning meth­
ods can reveal very interesting properties of both CCDs and their associated output 
processing electronics. Both devices have obtained reasonable results and can easily 
be turned into commercially useful electronics.
The problems associated with dark current and digitization have been examined 
with some success and it is interesting to note the effects these have on the results, 
particularly since they are often ignored by people acquiring data without appreciating 
the errors inherent in their acquisition methods. It is hoped th a t some headway has 
been made into rectifying this.
The discovery of a constant defining the optimum cut-off point for digitized use of 
the Normal to Uniform conversion leaves open a number of interesting questions and 
proved a very challenging piece of research, with interesting results.
It is to be hoped tha t at least some of the right questions have been asked, and 
th a t some of them have, a t least in part, been answered.
185
A p p en d ix  A  
Charge C oupled D evices
A .l  Introduction
The CCD has largely taken over as the optically sensitive element in modern cam­
era systems providing normal t v  images to conventional displays using either p a l  
or NTSC encoding. There have been a large number of manufacturers interested in 
these devices, including Sony, RCA, EEV, Thomson-CSF, Schlumberger, Texas and 
Hamamatsu along with many smaller players in this large market.
Today there are hundreds of different devices on the market and they are almost 
all dedicated to the t v  or video camera markets. They have enabled high street shops 
to sell very high quality cameras for less than it would have cost for just the CCD five 
years ago.
This appendix aims to give a brief introduction to c c D  technology and the concepts 
behind driving their inputs and processing the resultant outputs.
There is now a wide range of applications for CCDs within the scientific community. 
Originally astronomy applications to o k  the lead, using the rigidity and re-usability of 
the CCD to replace photographic plates. In particular, the RGO [112], the K itt Peak 
observatory [113] and the Galileo Institute for astronomy [114] did some pioneering 
work on the cooling of CCDs to get long time exposures. The fixed arrangements 
of the cells is particularly useful to this application and allows correction of image 
plane curvature in telescopes with curved focal planes [115]. It was also within the 
astronomical community tha t the first work into thinning CCDs was done. This allows 
back illumination and hence reduces the photon loss through the front electrodes [116].
Large format c c D s  with anything up to 1242 x  1152 pixels, such as the EEV
186
CCD05-30 series [117], have recently been under development for dental and small area 
x-ray work. Small pixel (10/im) devices [118] have been developed for high definition 
cameras and ‘stackable’ devices have been used to create very large area sensors.
A .2 C C D  Structure
Both CCDs and their cousins the diode arrays [119] are based around silicon struc­
tures tha t have been sensitized to convert photons to electrons and then localize these 
electrons to store an image.
The structure of these devices has gone through many revisions since their invention 
in the late 1960s but all are based around the same basic principals. A typical device 
consisted of a silicon substrate with a set of parallel, equally spaced, vertical channels 
covering the whole surface. Onto this is laid a set of horizontal, parallel electrodes 
a t right angles to the channels, the result being a chequered effect of electrodes and 
channels covering the silicon surface.
The channels act as potential barriers tha t prevent horizontal drift of electrons 
stored in the silicon. The horizontal electrodes provide charge collection fields which 
are also used to move the electrons vertically across the surface.
There are a number of approaches to charge collection in these devices. Most are 
based on the fact tha t after an optical or x-ray photon has passed into the silicon 
(through the electrodes) its energy is absorbed by the doped silicon depletion layer 
and electrons are produced.
These electrons will be attracted to any electrode that has a positive charge ap­
plied to it. Traditionally the three phase model has been used to describe the charge 
collection strategy. There are however many other possibilities and Texas devices in 
particular have been leading the field in the use of two phase clocks.
The three phase model uses the electrodes in groups of three. The middle one is 
kept at a high potential and the outside two are held near ground to form an electron 
‘bucket’. The next group of three will have a similar pattern of voltages on them. 
When an electron is formed in the depletion layer it will be attracted to one of the 
positive electrodes. As there are two low voltage electrodes between each positive one 
the electrons will be kept separate once they have migrated in the positive field.
If the voltage levels on the electrodes are now changed so tha t the bottom  of the
187
three electrodes is positive and the top two are at a low potential, the electrons stored 
under the center electrode will be pulled down by the new field and will sit below the 
bottom  electrode.
Again the two low potential electrodes will prevent any mixing of stored electrons 
as they will always have a strong field either holding them in place or pulling them in 
one direction. In the ‘bucket’ analogy the ‘bucket’ has been moved down.
This system allows electrons in the entire image to be moved down one pixel row, 
th a t is through 3 electrodes for each full three phase clock cycle.
The normal frame based ccD has two silicon areas. The top half is a 388 x 288 
area segmented into pixels by the groups of three electrodes. This area is exposed to 
the outside and is where images are formed by an external leasing system in a camera.
Below this section is a similar area, the same size, but covered by an opaque metal 
shield. This prevents incident light from affecting the active silicon surface.
Electrons form in the top half of the sensor during the frame period (0 02 seconds 
for a normal PAL TV signal), crea tin g  an image of electrons in the silicon. The electrode 
shifting system can then be used to move the entire image, quicldy, into the lower half 
of the device. This process is done as fast as possible during a vertical blank period 
to minimize the smearing caused by incident photons falling on the sensor during the 
frame shift process.
Once resident in the storage area the image is shifted one row at a time into a 
bottom  row readout register. Here the electrodes are at right angles to the image 
movement (replacing the channels in the image areas) and allow the electrons to be 
shifted horizontally to a pixel output register. Here they are amplified by a f e t  tran­
sistor stage and then fed to user external circuitry, the nature of which will depend on 
the application.
This process of reading out one row and then shifting down the stored image to 
allow the next row to be output is done a t the pixel rate for the display system. For a 
PAL TV this is approximately 8MHZ.
Once the entire image has been read out the cycle repeats with the top image again 
being moved to the storage area.
188
Channels
II
12
1 3
Output
0l 02 03 Reset
Figure A.l: The electrode patterns on a ccD surface.
A  3 D riving CCD Inputs
As with all other aspects of CCD technology, there are many possible ways of driving 
the voltage and shifter inputs with the astronomical applications leading the field 
[120, 121, 122]. In order to drive the electrodes, three sets of three inputs are provided. 
All the top electrodes in a group of three within the imaging area are connected to an 
output pin, all the middle electrodes to another and the bottom electrodes to a third. 
These outputs are then mirrored for the bottom (storage) section so tha t the image 
and storage sections can be moved independently.
Finally the row readout electrodes are brought out in a similar way with every third 
electrode being connected together. A simplified example of this structure is given in 
figure A.I.
To ensure efficient transfer of electrons the driving waveforms must be sloped so 
th a t the electrical fields overlap slightly between the electrodes. This ensures accurate 
electron transfer, leading to good charge transfer efficiency. These slopes can be created 
by small capacitive filters attached to a digital, square wave driver or for more precise 
readouts a full ramp generator can be employed.
189
For scientific purposes CCD readout waveforms are usually of much lower frequency 
allowing more complex and more precise forming of the pulse shapes. Normal camera 
systems however usually rely on careful setting of low pass filters. In some cases special 
techniques such as slight negative biasing of the electrodes can be used to maximize 
the transfer efficiency and charge collection ability of the electrodes particularly while 
the electrons are not moving.
A .4 O utput P rocessin g  M ethods
There are a number of approaches to CCD output processing. Many companies are 
beginning to offer A S ic  signal processors and some useful work has been done into 
producing very low noise pre-amplification stages [123, 124] for CCDs and reticons.
Conventional CCDs have two signal outputs. These are both fed from identical 
transistor charge amplifiers on the silicon and hence have very similar output properties. 
One of these amplifiers is fed with the charge from the output register whereas the other 
is tied low and has no input charge. This second output acts as a dummy voltage level 
th a t can be used to correct for output distortions in the other, live, signal.
When the charge has been transferred to the c c D  output amplifiers it becomes 
the signal that is passed on to the outside processing electronics. This charge must 
be removed from the output amplifier before the next charge packet arrives. This is 
achieved by one extra waveform input tha t feeds in a positive signal to the charge 
input stage of the amplifier and removes the electrons tha t have been stored there. As 
this pulse is never perfect, this reset level changes slightly after each pixel is read out. 
This means tha t the output waveform is quite complex. During the reset pulse period 
the output is at its highest voltage level. Once the reset pulse is released, the output 
sinks to a quiescent state, with slight noise levels introduced by the imperfect charge 
removal of the reset pulse. The output remains at this level until another charge packet 
is transferred to the readout stage. This will appear as a negative voltage and will pull 
the output down. The required signal is the difference between this new low voltage 
and the final level of the quiescent state. An example output waveform is provided in 
figure A.2a along with the phases of the row readout waveforms and the column shift 
signals (figure A.2b).
The bias voltages to the base silicon and the electrodes are also quite complex,
190
40ns
15ns
R1
R2
R3 lOV
RESET
Output Signal Vreset (-17V)
Vsignal
(a) Row shifts
u
320ns
130ns
I/Sl
I/S2
[/S3 / t lOV
(b) Column shifts
Figure A.2: Typical CCD driving waveforms and output signals.
191
different levels being required for the gates, amplifiers, substrates and channels. One 
effect of this system is that it induces a large DC offset on the output drivers which 
can be as high as 17V. This, along with the reset noise, must now be removed by the 
user processing electronics before a valid signal can be obtained.
The advantage of the dummy output is now apparent. This output has both the 
17V DC offset as well as the reset noise found on the real signal output. A good 
differential amplifier stage attached to the real and dummy signals can now subtract 
the dummy signal and produce just a voltage representing the optical signal levels.
One problem with some implementations of this is tha t the DC offset cannot be 
handled by the outside video amplifiers and is often removed by capacitive DC blocking 
filters, even though distortions will be incurred by such filtering. This is fine for family 
camera systems but not of much use to scientific quality instrumentation. This is a 
major problem with many supposedly ‘high quality’ camera systems.
One other way of removing the reset noise is the double correlated sampler. Here 
the reset signal level is sampled in its quiescent period and fed into an integrator for a 
short period. The actual signal, including the reset noise is then negatively integrated 
for the same period. The result of this is tha t the output signal from the integrator has 
had the noise level removed (canceled out by the positive and then negative integration) 
but since the signal is only present for one half of the integration, it is still available as 
an integrated output.
The basic noise removal systems are improved by the reduction of the local tem­
perature. The thermal noise in the readout stages can be reduced to almost zero by 
cooling to liquid nitrogen temperatures and the best astronomical instruments used 
in this way reduce the total noise to just 3 or 4 electrons per pixel, almost achieving 
single photon counting [125]. Smaller temperature reductions can be achieved by using 
Peltier cooled CCDs tha t are now supplied by firms such as EEV [126] specifically for 
astronomical work.
CCDS are also sensitive to other parts of the spectrum [127]. They are particularly 
sensitive to infra-red radiation and, though sensitivity drops rapidly for ultra violet 
detection, special coatings [128] can be used to obtain good results for the higher optical 
frequencies. Sensitivity also improves for high energy radiation and peaks sharply for 
x-ray wavelengths. The silicon gives very high gains for the conversion of x-ray photons
192
into electrons, particularly in the soft x-ray regions and even to direct neutron radiation 
[129].
The problem with using such wavelengths, and in fact the direct illumination of 
CCDS with free electron beams [130], comes in the form of radiation damage to the CCD 
surface and in particular to the covering electrodes. The silicon is also not capable 
of trapping all the energy of the incident photons when it is optimized for optical 
sensitivity and this leads to the non-recording of some of the incident x-ray energy.
There are two techniques employed in CCD manufacture to improve their response 
to X-rays. Firstly the devices are thinned and irradiated from the back [131, 132], and 
secondly they are built from high resistivity silicon tha t traps more of the energy and 
is usually made as a thicker device to enable better localization of electrons. Both of 
these systems improve the application of cC D s to X-ray detection and are part of the 
reason tha t most of the significant advances into CCD uses today are in the areas of 
synchrotron radiation detection and medical imaging.
There are many more detailed works associated with CCDs. In particular manufac­
turers data sheets such as those produced by EEV [133] and RCA [134] provide very 
good insights to the field. There are also a number of review articles [135, 136, 137] and 
most modern electronics texts cover at least some aspects of CCD technology [138, 139].
1
193 I
R eferences
[1] Leggatt D. P. ‘The Evolution of television technology’, Electronic Eng. 60(735), 
14, 1988.
[2] Moffat B. ‘Television engineering research in the BBC, Today and Tomorrow’, 
SMPTE Journal-Society of motion picture and television engineers. 97(1), 17-24,
1988.
[3] ‘Advanced Video Display Controller (AVDC) SCN26?4 \  Mullard, Aug 1983.
[4] ‘CCD02-06 Series Scientific Image Sensor’ EEV  limited, (1), June 1990.
[5] ‘The PNA7518 8-bit Multiplying D A C ’, 289-293, Aug 1987.
[6] ‘LM733/LM733C Differential Video A m p’, National Semiconductor, 9-54 - 9-57.
[7] Bmar;/ Counter', (1483) 375-
379.
[8] ‘DS0026/DS0056 5MHz Two Phase MGS Clock Drivers’, National Semiconduc­
tor Corporation, 5-13 - 5-20.
[9] ‘ESB365089AA Buffer Hybrid’, EEV Company Ltd., March 1987.
[10] ‘ESB365091AA’, EEV Company Ltd., July 1987.
[11] ‘SHM-360, SHM-361 Video Speed Sample-Holds’, Datel Inc. 3-7 - 3-10.
[12] ‘Quad Differential Line driver Quad TTL to ECL Translator’, Signetics, P73.
[13] A/D% Datel Inc., 1-33 - 1-38.
[14] ‘Ultrahigh-Frequency Operational Amplifier AD5539’, Analog Devices, (9) Feb. 
1987.
[15] ‘HOS-050/HOS-050A/HOS-050C Fast Settling Video Operational Amplifiers’, 
Analog Devices, 2-254 - 2-250.
[16] ‘OPA620 Wideband Precision OPERATIONAL AM PLIFIE R’, Burr-Brown IC 
D ata Book, (33), 2-166 - 2-169.
[17] Arndt U. W. ‘The collection of single-crystal diffraction data with area detectors’, 
Journal De Physicque. 47(8), c5.1-c5.6, Aug 1986.
194
[18] Thomas D. J. ‘Calibrating an Area-Detector Diffractometer’, Modem Diffractom- 
etry series 2(2) 1988.
[19] Arndt U. W. ‘X-ray television area detectors’, Nucl. Intrum. and Meth. 201, 
13-20, 1982.
[20] Arndt U. W., In’T Veld G. A. ‘Further developments of an X-ray television 
detector’, Adv. Electronics and Electron Phys. 74, 285-296, 1988.
[21] Mathieson A. McL. ‘Small-Single-Crystal Diffractometry with Monochromated 
Synchrotron Radiation - the Wavelength-Dispersion Minimum Condition for  
Bragg Reflection Profile Measurement’, Acta. Cryst. A444, 239-243, 1988.
[22] Mathieson A. McL. ‘Concerning Single Crystal Reflectivity Curves’, Aust. J. 
Phys. 41, 393-402 1988.
[23] Arndt U. W. ‘Measurement of the 3d distribution around a single-crystal Bragg 
reflection’, Internal communication, July 1986.
[24] Germer R., Mayer-Lise W. ‘X-ray T V  camera at 4>5nm’, Rev. Sci. Instrum. 57(3), 
426-427, March 1986.
[25] Germer R. ‘High resolution X-ray-TV-sensors’, S.P.I.E., 491, 434-491, 1984.
[26] Naday L, Strauss M. G., et at. ‘Detector with charge-coupled-device sensor for 
protein crystallography with synchrotron x rays’, optical engineering 26(8), 788- 
794, Aug. 1987.
[27] Westbrook E. M., Deacon M. L. ‘CCD-Based area detectors for protein crystal­
lography’, A.C.A., July 26 1988.
[28] Borso C. S. ‘Optimization of monolithic solid state array detectors for the position 
encoding of small angle X-ray scattering from synchrotron sources’, Nuc. Instr. 
and Methods, 201, 65-7, 1982.
[29] Galileo Electro Optics Corporation. ‘Galileo Glass Capillary Arrays’.
[30] Bigler E., Polack P., Lowenthal S. ‘Scintillating Fiber Array As a X-ray Image 
Detector’, 1989.
[31] Strass, M.G., Naday, I. et. al. ‘CCD Sensors in Synchrotron X-ray Detectors’, 
Nucl. Instr. and Method in Phys. Research, 578-577, 1988.
[32] Arndt U.W. ‘X-ray Position-Sensitive Detectors’, J. Appl. Cryst., 19, 145-163, 
1986.
[33] Strauss, M.G., Naday, I. et. al. ‘CCD Sensors in Synchrotron X-ray Detectors’, 
Nucl. Instr. and Methods in Phys. Research, 266, 563-577, 1988.
[34] Lumb, D.H., Holland, A.D. X-ray imaging spectroscopy with E E V  CCDs’, 
S.P.I.E., 982, 116-122, 1988.
[35] Lumb, D.H., Chowanietz, E.G., Wells, A.A. ‘X-ray Imaging with G EC /E EV  
CCDs’, Conference paper.
195
[36] Kellog, E., Murray, S. et. al. ‘The Photicon’, S.P.I.E., 290, 28-33, 1981.
[37] Gruner, S.M. ‘CCD and Vidicon X-ray detectors: Theory and Practice (invited)’, 
Rev. Sci. lustrum., 60(7), 1545-1551, July 1989.
[38] Koppel L. N. ‘Soft X-ray response of a charge-coupled image sensor’, Rev. Sci. 
Instrum., 48(6), 669-672, June 1977.
[39] Lumb D. H., Hopkinson G. R., Wells A. A. ‘X-ray imaging and spectroscopy with 
CCDs’, Adv. in Electronics and electron Phys. 64(b), 497-507, 1985.
[40] Stern R. A., Liewer K., Janesick J. R. ‘Evaluation of a virtual phase charge 
coupled device as an imaging X-ray spectrometer’. Rev. Sci. Instrum. 54(2) 196- 
205, 1983.
[41] ‘Pixel Detector Workshop’, Synch. Rad. News, 3(3), 6-8, 1990.
[42] Catura R. C., Smithson R. C. ‘Single photon X-ray detection with a CCD image 
sensor’, Rev. Sci. Instrum. 50(2), 219-220, 1979.
[43] ‘Radiation damage effects in E E V  CCDs’, technical note 1991
[44] Magorrian B. G., Allinson N. MSSoft X-ray Damage In CCD Detectors’, Nuc. 
Instr. and Methods in Phys. Research A273, 599-604, 1988.
[45] Peckerar M. C., McCann D. H., Leepo Yu. ‘X-ray imaging with a charge coupled 
device fabricated on a high resistivity silcon substrate’, Appl. Phys. Lett. 39(1), 
55-57, July 1981.
[46] Walton D., Stern R. A. et al. ‘Deep-depletion CCDs for X-ray astronomy’, 
S.P.I.E. 501, 306-316, 1984.
[47] Griffiths R. E. ‘The Evaluation of Silicon CCDs for imaging X-ray Spectroscopy 
in the Range 1 to 8 keV ’, Adv. in Electronics and Electron Phys, 64(b), 483-496, 
1985.
[48] Lumb D. H., Hopkinson G. R., Wells A. A. ‘Performance of CCDs For X-ray 
imaging and spectroscopy’, Nuc. Instrum , and Meth. in Phys. Research. 221, 150- 
158, 1984.
[49] EG&G Reticon. ‘S  Series Solid State Line Scanners, 128, 256, 512, and 1024 
Elements’, 1-37 - 1-46, Sept. 1987.
[50] Zutavern F. J., Schnatterly S. E. et al. ‘A position-sensitive photon detector for  
the UV or X-ray range’, Nucl. Instrum , and Meth. 172, 351-355, 1980.
[51] Gamble R. C., Baldeschwieler J. D. ‘Linear position-sensitive X-ray detector in­
corporating a self scanning photodiode array’. Rev. Sci. Instrum. 50(11), 1416- 
1420, Nov 1979.
[52] Borso C. S., Danyluk S. S. ‘Application of a directly exposed self-scanning photodi­
ode array as a linear position sensitive detector in a small-angle X-ray scattering 
instrum ent’. Rev. Sci. Instrum. 51(12), 1669-1675, Dec 1980.
196
[53] W idom, J., Feng, H.-P. ‘High performance X-ray area detector suitable fo r  small- 
angle scattering, crystallographic, and kinetic studies’, Rev. Sci. Instrum., 60(10), 
3231-3238, Oct 1989.
[54] Chu, B., Wu, D.Q.. ‘Evaluation of a linear array detector for synchrotron small- 
angle X-ray scattering measurements’, Rev. Sci. Instrum. 60(10), 3224-3230, Oct 
1989.
[55] Luppino, G.A., Ceglio, N.M. et. at. ‘Imaging and nondispersive spectroscopy of 
soft X rays using a laboratory X-ray charge-coupled-device system ’. Optic. Eng., 
26(10), 1048-1054, Oct 1987.
[56] Jucha A., Bonin D., et al.. ‘Photodiode array for position-sensitive detection using 
high X-ray flux provided by synchrotron radiation’, Nucl. Instrum. Meth. in Phys. 
Research. 226, 40-44, 1984.
[57] Integrated Device Technology Inc. ‘High Speed Ik  x 9 Dual-Port Static R A M  with 
Busy - Preliminary, IDT7010S/L. ID T70104S/L’.
[58] ‘American institute of physics handbook’. Section 8.4.
[59] Fork R. L., Greene B. I., Shank C. V.Appl. Phys. Lett. 38, 671, 1981.
[60] Finch A., Sleat W. E., Sibbett W. ‘Subpicosecond synchroscan operation of a 
photochron IV  streak camera’. Rev. Sci. Instrum. 60(5), 839-844, May 1989,
[61] Sibbett W., Sleat W., Taylor J. R. ‘Application of synchronously scanning streak 
cameras to picosecond time resolved luminescence measurements’, Picosecond 
Chemsitry and Biology. 197, 1983.
[62] Sibbett W., Sleat W. E., Krause W. ‘A picosecond streak camera For spaceborne 
laser ranging’, Proc. 5th Int. Workshop on Laser Ranging and Instrumentation. 
1, 136-164, Sept 1984.
[63] Baggs M. R., Eagles R.T. et al. ‘Design & Applications of Photochron Streak 
Cameras’, Conf. on Photoelectronic Imaging. 48, 253, 1985.
[64] Diels J. C., Fontaine J. J., et al. Appl. Optics. 24, 1270, 1985.
[65] Eagles R. T., Sibbett W., Sleat W. E., Walker D. R. ‘Multiple-frame UV/X-ray 
picosecond framing camera’. Adv. in Electronics and Electron Phys. 74, 209-217, 
1989.
[66] Boyle W. S., Smith G. E. ‘Charge coupled semiconductor devices’. Bell systems 
tech. 587, 1970.
[67] Kosonocky W. F., Carnes J. E. ‘Two phase charge-coupled shift registers’. Digest 
of Tech. Papers, IEEE International Solid State Circuits Conference. 132, Feb 
1972.
[68] Jorden P. Private Communication 1989.
[69] Intel. ‘8255A/8255A-5 Programmable Peripheral Interface’. 8-85 - 8-105.
197
[70] Hawkins, G. A., Rivand, L., Kyan, J. ‘Characterization of dark current in CCD 
Imagers’, lEDM , 84, 556-559, 1984.
[71] Allan J. Private Communication 1991.
[72] Aikens, R., Duncan, R. et. al. ‘A New CCD with ultra low dark current and high 
dynamic range’, Pre-Publication Document, 164-169.
[73] Chen, J. Y., V iswanathan, C.R. ‘Ceometry Dependence of Dark Current in CCD’, 
IEEE Trans. Electron. Devices, 12, 1914-1917, Dec. 1984.
[74] NichoUs R. L., Teter W. D. ‘Computer graphics for convex polyhedra: Hidden 
line removal and shading’, Eng. Design Graphics Journal 52(3), 28-37, Fall 1988.
[75] ElGindy H., Avis D., Toussaint G. ‘Applications of a two-dimensional hidden-line 
algorithm to other geometric problems’, 31(3), 191-202, 1983.
[76] ‘Z 8 4 IO Z80 DMA Direct Memory Access Controller’, Zilog Prod. Spec., 27-43, 
Sept. 1983.
[77] Ostberg O., Shahnavaz H., Stenberg R. ‘CRT Flicker and Scan-Line Direction’, 
8(2), 75-78, April 1987.
[78] Guekos G., Ulmi R. ‘Room illumination and CRT/Flicker In visual Display Ter­
minals’, 2(1), 6-11, July 1983.
[79] Hilbert, D. ‘Ueber stetige Abbildung einer Unie auf ein Flachenstuck’, Math. Ann. 
38, 459-460, 1891.
[80] Peano, G. ‘Sur une courbe qui remplit totute une aire plaine’. Math. Ann. 36, 
157-160, 1890.
[81] Stevens, R. et al. ‘Data ordering and compression of multispectral images using 
the peano scan’, lEE International Conference on Electronic image processing. 
No. 214, 1980.
[82] Cole, A. J. ‘Compaction techniques for raster scan graphies using space filling 
curves’. Computer J., 30(1), 87-92, 1987.
[83] Cole A. J. ‘Murray polygons as a tool in raster scan graphics’. Pre-publication 
Document, 1988.
[84] Maitland A., Hirst P. F. ‘Security System for Visual Display Units and Personal 
Computers’, Jan. 1989.
[85] Lorraine Electronics. ‘The Company and The Products’.
[86] Turn, R. ‘Advances In Computer Security vols. I, II, IIP, ISBN 0-890060096-7, 
0-89006-156-4, 0-90006-315-X, 1983, 1984, 1988.
[87] Graf, R.F., Sheets, W. ‘Video Scrambling & Descrambling for satellite & cable 
T V ’, ISBN 0-672-22499-2, 1986.
198
[88
[89
[90
[91
[92
[93
[94
[95
[96
[97
[98
[99
[100
[101
[102
[103
[104
[105
[106
Cornwall, H. ‘Data Theft. Computer fraud, industrial espionage & information 
crime’, ISBN 0-435-90265-9, 1987.
‘Low-Cost Device Shields VDUs From Data Eavesdroppers’, Comput. Fraud & 
Secur. Bull, 8(9), 8-9, July 1986.
Marshall R. C. ‘VDU Security device to prevent Unauthorized, Remote Decoding’, 
July 1989.
Datel Intersil. ‘Microprocessor Compatible Double-Buffered D /A  Converters 
DAC-gJO, DAC-gJg', 1989.
Datel Intersil. ‘Wide Bandwidth, F E T Input Monolithic Operational Amplifier 
AM-410 & AM -4 1 1  SE R IE S’, 314C-317C.
Datel Intersil. ‘Low Cost, 10 B it Monolithic Digital-to-Analog Converter DAC- 
S'enes', 314C-317C, Oct 1979.
Adams W. O. ‘Magnetic Deflection Yokes’, Proc. of the SID., 24/4, 363-367, 
1983.
National Semiconductor Corporation. ‘LM  12(L /C /C L) 150W Op A m p ’, 2-272 
- 2-285.
National Semiconductor Corporation.
‘LHOIOI/LHOIOIC, LHOIOIA/LHOIOIAC Power Operational Amplifier’,
2-214 - 2-225.
Agnew, G.B. ‘Random Sources for Cryptographic System s’, 77-81.
‘A Simple Algorithm for Fast Real-Time Generation of Pseudorandom Poisson 
Integers with Rapidly Varying Means’, Proc. IEEE, 2088, 1969.
Nakamura, Shogo. ‘A Method Of Generating a Random Signal Using Operational 
Amplifiers’, Proc. IEEE, 651-653, May 1974.
Castanie, F. ‘Generation of Random Bits with Accurate and Reproducible Statis­
tical Properties’, Proc. IEEE, 807-809, 1978.
Box, G.E.P., Muller, M.E. Ann. Math. Statist. 29, 610-611, 1958.
Golder, E.R., Settle, J.G. Appl. Statist., 25, 12-20, 1976.
Encyclopedia of Statistical Sciences, Wiley, 9, 355-359, 1988.
Encyclopedia of Statistical Sciences, Wiley, 9, 348-349, 1988.
Encyclopedia of Statistical Sciences, Wiley, 1, 389-397, 1982.
Hastings C. Jr. ‘Approximations for digital computation’, Princeton University 
Press. Princeton N.J. 1955.
[107] Abramowitz M., Stegun A. I. ‘Handbook of Mathematical Functions’, 932.
199
108] Hawkes, A.G. ‘Approximating the Normal tail’, The Statist. 31(3), 231-236, 1982.
109] Lesurf J. C. G. ‘Chaos in electronics’, Elecr. World & Wireless World. 97(1664), 
467, 1991.
110] Intel. ‘27C020 2m (256k x 8) CMOS EPRO M ’, May 1990.
111] Micro Power Systems. ‘CMOS 11-Bit Monolithic A /D  Flash Converter MP7685’. 
2-68 - 2-74.
112] Jorden P. R., Thorne D. J., Van Breda I. G. ‘Royal Greenwich Observatory 
(RGO) charge-coupled device (CCD) camera’, S.P.I.E. 331, 87-95, 1982.
113] McGuire T. ‘The K itt Peak CCD Camera System ’, Pub. of the Astron. Soc. of 
the Pacific 95, 919-924, 1983.
114] Hlivak R. J., Pilcher C. B., et at. ‘The Galileo Institute for Astronomy (IFA) 
charge-coupled device (CCD) system ’, Proc. S.P.I.E. . 331, 1982.
115] Mackay C. D. ‘Drift Scan Observations with a Charge Coupled device (C C D )’, 
S.P.I.E. 331, 146-150, 1982.
116] Walker G. A. H., Johnson R. et a l.‘The CFHT CCD Detector’, Pre publication 
document.
117] ‘CCD05-30 Series Scientific Image Sensor’, EEV Limited, (1), June 1990.
118] ‘CCD 111 256-Element Line Scan Image Sensor’, Fairchild Weston Schlum- 
berger, 1986.
119] Livingston, W.C. ‘Diode Arrays - A Review’, K itt Peak Nat. Obs., 22-1 - 22-13.
120] Latham D.W. ‘Spectroscopy with Photon-counting reticons and solid state im ­
agers for astronomy’, Proc. lAU colloquium 67, Sept 1982.
121] Meyer, H.J., Schmidt, K.H., Rosenbauer, H. ‘Reticon Detector Electronics for the 
Hailey Multicolor Camera on the Giotto Space Mission’, Academic Press, ISBN 
0-12-014664-9, 223-230, 1985.
122] Mackay, C.D. ‘Low Noise CCD System Development at Cambridge’, Conference 
paper.
123] Geary, J.G. ‘A floating gate preamplifier design for reticon diode arrays’, S.P.I.E., 
172, 82-84, 1979.
124] Wood, B.C. ‘Preamplifier and clock drivers for the University of California at 
Los Angles reticon spectrometer’, S.P.I.E., 331, 338-356, 1982.
125] Wamsteker W. ‘Catching all the Photons: the CCD’, Messenger, 13, 10-11, 1978.
1261 ‘Peltier Cooled Package’, EEV Limited, A44-1A-Peltier, Aug 1990.
127] Bailey, P., Pool, P. ‘The P88000 Series of Large Area CCDs for Visible, Near 
Infra-red, and X -R A Y  Scientific imaging Applications’, EEV Publication 1191- 
23, Sept. 1989.
200
128] ‘UV Sensitive Coating for CCD Imagers’, EEV Limited, May 1990.
1291 Lehmann, M.S., Kiihs, W.F., et. al. ‘On the Use of Small Two-Dimensional 
Position-Sensitive Detector in Neutron Diffraction’, J. Appl. Cryst., 22, 562-568,
1989.
130] Lempnier, M., Richard, J.C., et. al. ‘Photon-in and Electron-in CCD Arrays for  
Image read-out tubes’, lEEED Conf., 253, 74-77, 1985.
131] Zucciuno, P., Long, D. et. al. ‘Evaluation of RCA thinned buried channel charge- 
coupled devices (CCDs) for Scientific applications’, S.P.I.E., 290, 174-176, 1981.
1321 ‘Thinned CCD Sensors for Back Illumination P86230/T Series’, EEV Limited, 
Feb 1990.
133] CCD / / / ',  EEV U.K., 1987
134] Castanie, F. ‘Charge-coupled devices and applications’, RCA, April 1981
135] Thorne, D.J, Jorden, P.R. et. al. ‘Laboratory and astronomical comparisons of 
RCA, GEC and Thomson CCDs’, S.P.I.E., 627, 530-542, 1986.
136] Mortara, L., Fowler, A. ‘Evaluation of charge-coupled device (CCD) performance 
for astronomical use’, S.P.I.E., 290, 28-33, 1981.
137] Kristian J., Blouke, M. ‘Charge-coupled Devices in Astronomy’, Scientific Amer­
ican, 48-56, Oct. 1982.
1381 Hall, I . k . ‘Applied Optics and Optical Engineering Vol. IIP, Academic Press Inc., 
Chap 8, ISBN 0-12-408608-X, 1980.
139] Fraser, D.A. ‘The Physics of Semiconductor Devices Fourth Edition’, Oxford 
Science Publications, ISBN 0-19-851866-8, 147-150, 1986.
201
3 S
8  ; — I l
3 3 s E
lïïïïïîllîÏÏm l
s s c
I
0s
G
1
(5
u
oI
Q
S'
8
I
Aaninoato a/v 9 n40JJ»«ri 0.1.
f u
l>
;
Hh
"1 , , x 1
J( I"
HI-
ü n n u ,( m u n
I "I i  'I ::| 1
’>
9
o
psi%
n
cm
r
I
si
a a 3 ; a g ,13
n n fi 0 n n 0  0
: II II II II II II II
u oooooooo
11
3 , ,
.SP
"X}9
A
u
«ontsano a^o
oXi
(S
Ci.
et(m
ü a a a 0 <y o (f
(I n ri n n  n r> n
H H i
HH"
A  I
inj—AAAf"'
n o n n n n n n
H H"
ij h| m| 4 .| .'I t,| !
13 g 3 3 S 3 fi S t,
5 |  j  I— 1 1 1
?| 1 I 11 '
O
>
s  ?  ^
Mf'ci[AiOX
<
Q
§
r
gï
wn 3g
«3
' 5 b
(d
oI
r&
I
11 :
•<<<:<<< 15 12 13s
’l-T  N
« : 2 g
-Tdg
o3S
H
>îs2
Kt=idi
2 2 2 ;i n R ü
aCAg%
<
i
ëp-
I
[131, — I I------ 11'
a 8 5 5 “ 5 &'8 88 8 88 888
5 8
a 8 i!
» -—jHi
I : ;1111%;&11:
n  3 3 Ï S 5 5 5 5 3 5 3
II
'oi
IÜ
>%
I
p-i1-3
ffciHIO
<
Qs
cr
1
Hi
^Hi'
g 8 n
I
'o
i
.15
Id0
>%
1H
fCi
W3Hi
<
n
cr(T)
