[Lf] DDS Sources in receivers]
Andre' Kesteloot
akestelo at bellatlantic.net
Fri Jul 14 19:09:22 CDT 2000
Klaus von der Heide wrote:
> Andy, G4JNT wrote:
>
> > A DDS does indeed generate spurious products, but these are precisely
> > characterisable and at a level defined by the chip manufacturer. Apart
> > from image and harmonics, they are a function of the DDS process and NOT
> > SUBJECT to poor layout construction etc whereas a phase locked loop
> > synthesizer is unbelievably sensitive to noise etc in the control
> > circuitry caused by poor design. Furthermore, the spurs are usually
> > well away from the wanted frequency so properly applied filtering will
> > eliminate any possible spurious responses.
>
> In my previous mail I pointed out, that the spurs generated by a DDS
> are due to an imprecise implementation of the sine function. This
> imprecision is a result of a compromise between the diverging goals,
> speed and precision.
> The spurs can be made as low as you want. They are a consequence of
> the DDS-IMPLEMENTATION, not of the DDS-PRINCIPLE. If you base
> the design on a loadable sine table of variable length, you will
> be able to work entirely without spurs in almost all cases.
>
> Example: You want to generate 19.200 kHz on a DSP at a sample rate
> of 48.000 kHz. Generate a sine table of the 5 values
> sin(2*pi*k/5) with k = 0,1,2,3,4 and wrap around in this table
> at a step of 2. Interpolation is not neccessary, so no spurs.
>
> Hardware implementations mostly use ROM-sine-tables of fixed size.
> Then sine values at phases between adjacent table points have to be
> computed. Example:
> The same situation as above; use a sine table of 256 values.
> Let the first phase be 0, then the second is p = (0 + step)mod 256
> where step = 256*19.2/48.0 = 102.4
> To calculate sine(2*pi*p/256) the nearest table point p0 to p
> is chosen, i.e. in the above example: p = 102.4; p0 = 102;
> p1 = 0.4 with p = p0 + p1
> Let s = table(p0) (the sine value from the table)
> and c = table((p0+64)mod 256) (the correspondent cosine value)
> and dp = p1*2*pi/256 .
> Then compute x = s + dp*(c - dp*(s/2 + dp*c/6)) (Taylor-series)
> Using this simple algorithm the value x never differs from the exact
> sin(2*pi*p/256) by more than 5e-9. Spurs are less than -165 dB.
>
> Implementation of this algorithm on a DSP costs about 30 instruction
> cycles in contrast to only one if simply the nearest lower table
> point is taken. The gain achieved by this factor 30 in computational
> effort is about 130 dB in spur suppression.
>
> It is this hardware (or software) simplification that causes the
> spurs, not the DDS in principle. Surely future DDS-chips will
> use advanced algorithms to minimize spurs.
>
> > Any one who advocates using a PLL just to 'clean up' a DDS is
> asking for
> > the worst of all worlds.
>
> The phase noise of a PLL is proportional to the frequency division
> factor used in the PLL. A clean-up-PLL will not use any divider.
> So the phase noise could be kept low. But, off course, it will be
> present at the win of very low spurs. Nevertheless, I prefer a more
> precise DDS-implementation instead of such a clean-up which would
> reduce the usable frequency range.
>
> Two years ago I made my own board with four synchronous AD9850
> driven individually via the printer port. That is very valuable
> for many purposes. In fact, I also use this board in receiver
> applications, especially where frequency stability is the main
> point.
>
> 73 de Klaus, DJ5HG
More information about the lf
mailing list