# Digital Recursive Oscillator with Reduced Frequency versus Temperature Dependency Utilizing a Dual-Mode Crystal Oscillator 

Vladimír Štofanik<br>Department of Thermophysics<br>Institute of Physics, Slovak Academy of Sciences<br>Bratislava, Slovak Republic<br>fyzistof@savba.sk

Anael E. Sam<br>Department of Electronics and Telecommunications Dar es Salaam Institute of Technology<br>Dar es Salaam, Tanzania

Igor Baláž, Marian Minárik<br>Department of Radio and Electronics<br>Faculty of Electrical Engineering and Information Technology, Slovak University of Technology<br>Bratislava, Slovak Republic


#### Abstract

The paper deals with a reduction of static frequency vs. temperature (f-T) dependency of digitally generated sinusoidal signals. The f-T dependency reduction is based on a self-temperature-sensing of a quartz crystal in dual-mode crystal oscillator, which produces the reference clock. We have proposed a digital oscillator, which automatically compensates the f-T dependency of its sampling clock over a wide range of operating temperatures. Numerical accuracy limitation of the oscillator due to finite word-length arithmetic is also analyzed in this article.


## I. Introduction

Digital sinusoidal oscillators are widely used in digital signal processing and they are essential elements in many applications. Usually, frequency stability of a digitally synthesized signal is determined by the frequency stability of the reference clock signal used. However, last year we have published an effective implementation of the clock signal static frequency vs. temperature (f-T) dependency compensation utilizing field programmable gate arrays (FPGA) and a single-chip direct digital synthesizer (DDS) [1]. In addition to DDS, digital sinusoidal signals can be flexibly synthesized using the digital recursive oscillator (second-order recursive system with zero damping).

Simple recursive oscillator can be characterized by the second-order difference equation with two initial conditions:

$$
\begin{aligned}
& y_{n}=2 \cos \left(2 \pi \frac{f}{f_{s}}\right) \cdot y_{n-1}-y_{n-2}, n=0,1,2,3, \ldots \\
& y_{-1}=1, y_{-2}=\cos \left(2 \pi \frac{f}{f_{s}}\right)
\end{aligned}
$$

In (1) $f_{S}$ represents the sampling clock frequency and $f$ the frequency of the generated sinusoidal signal.

We have designed a digital recursive oscillator, which automatically compensates the static f-T dependency of its sampling clock. The cosine coefficient of the recursive oscillator is automatically evaluated regarding to an actual sampling clock frequency. In this way, the stability of the recursive oscillator is improved.

The utilized crystal self-thermometry eliminates temperature offset and lag effects since no external temperature sensor is used [2], [3]. A dual-mode crystal oscillator (DMXO), which excites simultaneously fundamental and $3^{\text {rd }}$ overtone c -modes (i.e. slow-shear acoustic modes) of the stress compensated (SC) crystal, was originally published in [3]. Processing of the both c-modes actual frequencies enables prediction of their frequency shifts due to ambient temperature variations in a wide range.

## II. Functional Description

Block diagram of compensated recursive oscillator, we have designed, is shown in Fig. 1. We utilized a dual gain loop DMXO, which has been described in [3] and [4]. The sampling clock signal of a digital-to-analog converter (DAC) is directly driven from the $3^{\text {rd }}$ overtone part of the DMXO.

Interpretation of all registers and variables in FPGA is integer. Basic numerical precision was considered $b=30$ bits. It means that the real value 1.0 was in FPGA internally represented by the integer $2^{30}$. One more bit was utilized if negative integers (in twos complement representation) were necessary.


Figure 1. Block diagram of the recursive oscillator, which incorporates the sampling clock f-T dependency compensation.


Figure 2. The SC crystal 3rd overtone c-mode series resonant frequency vs. temperature.

The slow successive calculation unit evaluates the cosine coefficient $B(N)$ for the fast second-order recursive oscillator approximately twelve times per second regarding to the actual sampling clock frequency $f_{s}$. The sampling clock frequency depends on the $3^{\text {rd }}$ overtone c-mode series resonant frequency $f_{3}$ of the used crystal unit. Figure 2 captures the actual $f_{3}$ vs. temperature dependency. The actual fundamental c-mode series resonant frequency $f_{1}$ vs. temperature dependency is shown in Fig. 3.


Figure 3. The SC crystal fundamental c-mode series resonant frequency vs. temperature.

An effective internal clock forming circuits, digital mixer and gate counter implementations have been published in [1]. Subtracting one third of the sampling clock frequency (i.e. $f_{3} / 3$ ) from the fundamental frequency $f_{1}$ using a digital mixer yields the difference frequency $f_{\mathrm{d}}$. Figure 4 shows that the difference frequency is almost linear function of the temperature with the slope approximately -135 ppm per ${ }^{\circ} \mathrm{C}$. The difference frequency varies more than 18000 ppm over the temperature range between $-45^{\circ} \mathrm{C}$ and $+85^{\circ} \mathrm{C}$.


Figure 4. The difference frequency vs. temperature.

The gate counter produces the time interval $3068 / f_{d}$ during which the 15 -bit binary counter accumulates pulses with frequency $f_{3} / 3$. During the interval the 15 -bit binary counter 47 times overflows. After the accumulation the content of the 15 -bit binary counter is given by:

$$
\begin{align*}
N & =N_{H} \cdot 2^{8}+N_{L}=N_{T} \bmod 2^{15}= \\
& =\operatorname{int}\left(\frac{f_{3}}{3 f_{1}-f_{3}} 3068\right) \bmod 2^{15} \tag{2}
\end{align*}
$$

In (2) $N_{T}$ represents total amount of the pulses, $N_{H}$ represents seven most significant bits and $N_{L}$ represents eight least significant bits of the 15 -bit binary counter. Figure 5 illustrates total amount of the accumulated pulses $N_{T}$ vs. temperature. $N_{H}$ forms the address bus of two look-up tables, which store the set of pairs of coefficients: $C_{0}$ and $C_{1}$. An effective implementation of the two look-up tables has been illustrated in [1].

The successive calculation unit utilizes the $C_{0}$ and $C_{1}$ coefficients to calculate the correction factor $K(N)$ according to following formula:

$$
\begin{equation*}
K(N)=2^{b}+C_{0}\left[N_{H}\right]+C_{1}\left[N_{H}\right] \cdot N_{L} \tag{3}
\end{equation*}
$$

The coefficients $C_{0}$ are actually implemented as signed integers in 20-bit representation and the coefficients $C_{1}$ as signed integers in 10 -bit representation. The $K(N)=2^{b}$ in the case when the actual sampling clock frequency reaches its nominal value $f_{\text {Snom }}$. During the system calibration the value $f_{\text {Snom }}$ is used to determine the set of coefficients $C_{0}$ and $C_{1}$. The coefficients computation is made using a simple PC program we have developed. The computation is based on the data set representing the actual f -T characteristics of DMXO. During a prototype verification we considered $f_{\text {Snom }}=f_{3}\left(25^{\circ} \mathrm{C}\right)=29.879670 \mathrm{MHz}$.


Figure 5. Total amount of the pulses accumulated during the interval $3068 / f_{d}$ vs. temperature.

A user has to set an initial 32-bit value $R$ that represents the relative angular frequency of the required sinusoidal signal, which has to be generated. Considering the nominal sampling clock frequency $f_{\text {Snom }}$, the $R$ should be set according to following formula:

$$
\begin{equation*}
R=\operatorname{int}\left(2 \pi \frac{f_{\text {nom }}}{f_{\text {Snom }}} \cdot 2^{b}\right), \quad \frac{f_{\text {nom }}}{f_{\text {Snom }}} \leq 0.25 \tag{4}
\end{equation*}
$$

The successive calculation unit evaluates the compensated relative angular frequency according to the previously calculated correction factor:

$$
\begin{equation*}
R(N)=[R \cdot K(N)] \cdot 2^{-b} \tag{5}
\end{equation*}
$$

The most complicated task for the successive calculation unit is the evaluation of the cosine coefficient $B(N)$ required for the fast second-order recursive oscillator. The evaluation is based on the previously calculated value $R(N)$ and on the Taylor expansion of the cosine. In the integer representation it can be expressed by following formula:
$B(N)=2^{b}+\sum_{k=1}^{6}\left\{(-1)^{k} \cdot\left(\frac{R(N)^{2} \cdot 2^{-b}}{2}\right)^{k} \cdot \operatorname{int}\left(\frac{2^{b+k}}{(2 k)!}\right) \cdot 2^{-b}\right\}$

The successive calculation unit can be effectively implemented in Spartan-3 devices with "SRL16E" elements we have described in [1]. The modules realize the computation of (5) and (6) should be designed regarding to the maximum required alternating rate of generated sinusoidal signal frequency (i.e. alternating rate of the $R$ ). In general, a successive multiplication requires much longer computational time when compared with a parallel multiplication. On the other hand the successive multiplication can considerably save an FPGA resources. An example of the effective successive multiplication has been published in [1].

When the successive calculation unit has finished the new cosine coefficient $B(N)$ calculation it is written to the dedicated register. Simultaneously the two storage registers within the fast second-order recursive oscillator are initialized as follows:

$$
\begin{equation*}
y_{n-1}=2^{b} ; \quad y_{n-2}=B(N) \tag{7}
\end{equation*}
$$

Fast second-order recursive oscillator calculates one new value $y_{n}$ per one sampling clock period as follows:

$$
\begin{equation*}
y_{n}=\left[B(N) \cdot y_{n-1}\right] \cdot 2^{1-b}-y_{n-2} \tag{8}
\end{equation*}
$$

To calculate (8) a fast $(b+1) \times(b+1)$-bit multiplier and a fast $(b+1)$-bit subtracter has been utilized. The multiplier has been implemented with assistance of the four dedicated $18 \times 18$-bit hardware multipliers. It should be noted that the repetitive initialization of the storage registers removes the errors eventually accumulated during the continuous operation of the recursive oscillator. On the other hand the initialization produces a phase discontinuity of the generated sinusoidal signal.

The data for a DAC can be derived directly from the most significant part of the $y_{n-1}$ storage register:

$$
\begin{equation*}
y_{n-1} \cdot 2^{a-b} \approx \operatorname{int}\left\{\cos \left[R(N) \cdot 2^{-b} \cdot n\right] \cdot 2^{a}\right\} \tag{9}
\end{equation*}
$$

In this case, the generated sinusoidal signal is in the form of sequence of $a$-bit truncated signed integers.

The recursive oscillator we have designed occupies approximately one third of XC3S200 resources. The utilized FPGA-XC3S200 is the low-density ( 200000 equivalent system gates) member from the Spartan-3 FPGA family.

## III. Effect of The Cosine Coefficient Quantization

Limited numerical precision induces a quantization error of the cosine coefficient. An impact of the cosine coefficient least significant bit to the relative shift of sinusoidal signal frequency can be evaluated as follows:

$$
\begin{equation*}
\delta f=\frac{\arccos \left[\cos \left(2 \pi \frac{f}{f_{S}}\right) \cdot \frac{2^{b}-1}{2^{b}}\right]-\left(2 \pi \frac{f}{f_{S}}\right)}{\left(2 \pi \frac{f}{f_{S}}\right)} \tag{10}
\end{equation*}
$$

Figure 6 captures the mentioned impact in the cases of numerical precision: $b=24,26,28$ and 30 . It is evident that the error dramatically rises in the case of very low frequencies. In the case of basic numerical resolution $b=30$ bits, the usable range of the relative frequencies is approximately between 0.02 and 0.25 .


Figure 6. Relative shift of generated sinusoidal signal frequency due to quantzation of the cosine coefficient; error=-1LSB.


Figure 7. Residuals vs. temperature; $f_{\text {nom }}=1.000000 \mathrm{MHz}, b=30$ bits.


Figure 8. Residuals vs. temperature; $f_{\text {nom }}=7.000000 \mathrm{MHz}, b=30$ bits.

## IV. ReSUlts

Figure 7 and 8 illustrates the shift between frequency of generated sinusoidal signal and the nominal frequency in the case of $f_{\text {nom }}=1.000000 \mathrm{MHz}$ and $f_{\text {nom }}=7.000000 \mathrm{MHz}$ respectively.

Output power spectrum mostly depends on the characteristics of the utilized DAC. The power spectrum calculated with assistance of 2084-point fast Fourier transform in the case of 14-bit DAC (e.g. AD9744) is illustrated in Fig. 9. However, the noise close to the generated carrier particularly depends on the DMXO and SC crystal properties [5], [6].


Figure 9. Calculated spectrum of the recursive oscillator output signal with assistance of 2048-point FFT; $f_{\text {nom }}=1.458870 \mathrm{MHz}$,

> 14-bit DAC (AD9744).

## V. CONCLUSIONS

The presented compensation method can significantly reduce static $\mathrm{f}-\mathrm{T}$ dependency of the digital recursive oscillator over a wide range of operating temperatures without a need of stabilization of reference crystal oscillator temperature. There is also no need of tuning the crystal oscillator frequency.

Since the crystal self-thermometry is utilized and no external temperature sensor is used, the temperature offset and lag effects are eliminated.

## REFERENCES

[1] V. Stofanik, A. E. Sam, I. Balaz, and M. Minarik, "Direct Digital Synthesizer Clock Frequency versus Temperature Dependency Compensation using Two Look-Up Tables", in Proceedings of the 2004 IEEE International Frequency Control Symposium, 2004, pp. 770-774.
[2] J. A. Kusters, M. C. Fisher, and J. G. Leach, "Dual Mode Operation of Temperature and Stress Compensated Crystals," in Proceedings of the 32nd Annual Symposium on Frequency Control, 1978, pp. 389-397.
[3] S. S. Schodowski, "Resonator Self-Temperature-Sensing using a Dual-Harmonic-Mode Oscillator," in Proceedings of the 43rd Annual Symposium on Frequency Control, 1989, pp. 2-7.
[4] V. Stofanik, I. Balaz, and M. Minarik, "Temperature-Compensated Frequency Synthesizer," in Proceedings of the 2001 International Symposium on Signals, Systems, and Electronics ISSSE, 2001, pp. 432-435.
[5] V. Stofanik and I. Balaz, "Frequency Stability Improvement in Direct Digital Frequency Synthesis," in Radioengineering, vol. 13, No. 2, June 2004, pp. 17-19.
[6] V. Stofanik, I. Balaz, and M. Minarik, "Digitally TemperatureCompensated DDS," in Proceedings of the 2001 IEEE/EIA International Frequency Control Symposium, 2001, pp. 816-819.

