

(An ISO 3297: 2007 Certified Organization)

Vol. 3, Issue 8, August 2015

# Direct Digital Frequency Synthesizer Based On CORDIC Algorithm

Noble G

M.Tech, VIT University, Tamil Nadu, India

**ABSTRACT**: Direct Digital frequency synthesizer (DDFS) is a signal generation method and an essential part for local oscillators, mixers and modulators. This paper will introduce a DDFS architecture which is based on the scale free micro-rotation CORDIC algorithm and its hardware realization is comparing with the pipelined CORDIC based DDFS. The frequency of the waveforms can be varied depending upon the applications. The design involves only shifting and addition/subtraction operations and hence the complexity is reduced. The rotational mode operation of the CORDIC algorithm is used for computing sine and cosine values.

KEYWORDS: Angle rotator, CORDIC algorithm, Direct Digital Frequency Synthesizer, Pipelined Architecture

### I. INTRODUCTION

Direct Digital Frequency synthesis is one of the most recently developed frequency synthesis technique. It is possible to realize a DDFS in different ways. Most methods are using a look up table based approach [1]. That means, the sine and cosine values will be pre-calculated and stored it in the memory. This requires only less logic computations but needed a large memory. DDFS using CORDIC (COordinate Rotational Digital Computer) architecture can be implemented to overcome this problem. Here the sine values are computed using CORDIC algorithm.

The CORDIC algorithm uses only two operations for its functioning: addition/subtraction and shifting. It is possible to realize all mathematical functions like multiplication, division, exponential, trigonometric etc by using this algorithm. Since CORDIC is a repetitive algorithm, DDFS using CORDIC architecture can be implemented.

A frequency control word (FCW) is used for controlling the frequency in DDFS. It is an input parameter and it will be incremented by itself till an overflow is encountered. This section is called the phase accumulator. During an overflow, the phase value is given to the cordic processor and it will calculate the corresponding sine value. This sine value is passed through a digital to analog converter and a low pass filter in order to get the required sine waveform. The remaining portion of this paper is discussed as follows. Section II will cover basics of CORDIC theory along with equations. Section III contains pipelined CORDIC architecture and its advantages. Section IV

reviews the micro-rotation based cordic architecture and section V will discuss DDFS based on the previous two algorithms. Section VI will compare all the realized structures and section VII concludes the paper.

### II. CORDIC THEORY[LITERATURE SURVEY]

CORDIC theory was introduced by Volder [2] in 1959. Because of the simplicity of the algorithm, it has got a wide spread acceptance and now a days it is commonly used for the calculation of mathematical functions. It is a rotation based algorithm. That means an initial vector (Xo,Yo) is chosen and is subjected to rotation.

The rotation of the initial vector can be done by two ways. Either can make the Yo value to zero by rotation or can rotate the vector till a particular angle is reached [3]. Based on the above two methods, the CORDIC is classified into two: Rotational mode CORDIC and vectoring mode CORDIC [4]. The first described method is known as vectoring and second one is rotational mode. These two methods are just opposite to each other. For example, it is possible to find out multiplication by rotational mode and division by vectoring mode. Similarly sine values can be calculated by rotational mode and inverse sine values can be calculated by vectoring mode.



(An ISO 3297: 2007 Certified Organization)

### Vol. 3, Issue 8, August 2015

In this paper, rotational mode is described. That means, the initial vector (Xo,Yo) will rotates n times and hence obtain Xn and Yn [5].

 $\begin{aligned} X_n &= X_o \cos \Theta - Y_o \sin \Theta \\ Y_n &= X_o \sin \Theta + Y_o \cos \Theta \end{aligned}$ 

In general, it can written as

The above equation contains four multiplications and two additions. Hence it is not feasible to use directly in the system. To make it more simple, we take the  $\cos\Theta$  term outside.

$$\begin{split} X_{i+l} &= \cos \, \Theta_{i+1} \left( Xi - Y_i tan \, \Theta_{i+1} \right) \\ Y_{i+l} &= \cos \, \Theta_{i+1} \left( Yi + X_i tan \, \Theta_{i+1} \right) \end{split}$$

The term  $\cos\Theta$  is independent of iterations and having a constant value of 0.60725. In order to convert the multiplication of  $\tan \Theta$  to addition, the term  $\tan\Theta$  is restricted to  $\pm 2^{-i}$ . So multiplication can be replaced with arithmetic right shift.

CORDIC is not a unidirectional rotational algorithm. For obtaining the desired angle, it is possible to rotate in both clockwise and anticlockwise directions [6]. Hence requires an extra variable to represent the direction of rotation and variable 'd' is included for that. Variable 'd' can be either positive or negative.

 $X_{i+1} = K_i (X_i - Y_i d_i 2^{-i})$  $Y_{i+1} = K_i (Y_i + X_i d_i 2^{-i})$ 

The value of d is decided by the rotation angle. Let us consider the rotation for an angle of 15 degree. It requires an initial rotation of 45 degree (pre-calculated) in anti-clockwise direction and then will calculate the difference. Thus a negative value is obtained and the next iteration will be a clockwise one. For this the variable Z is introduced.

 $Z_{i+1} = Z_{i} - d_i \Theta$ Where  $\Theta = \tan^{-1}(2^{-i})$ .

#### III. PIPELINED CORDIC ARCHITECTURE

Because of the iterative behavior of the CORDIC, we can easily implement the algorithm in a pipelined architecture [7]. The basic block diagram of the pipelined CORDIC is shown in Figure 1.

Each stage consists of a CORDIC rotator along with a fixed angle for the rotation. The given input vector is rotated by the angle, which is stored in the ROM and is given to the input of the next stage. The vector is rotated further in each stage and finally will reach the exact angle that needed.

Here each stage always needs to rotate only by a fixed angle. So the performance of the circuit will be much higher than any other implementation. But the replication of the same stage will increase the consumption of the silicon area. The structure is realized in Verilog HDL and the obtained output waveform is shown in Figure 2. All the input angles are represented in radians with an 8 bit length and the output will be in the sign magnitude form.



(An ISO 3297: 2007 Certified Organization)

#### Vol. 3, Issue 8, August 2015



Fig.1. Pipelined CORDIC Architecture

This architecture has a scaling factor and angles required for iteration needs to be stored initially. Scaling free micro rotation based CORDIC can be used to avoid these problems.

| /cordic5/clk          |          | h        |                                          |     | <u> </u> |           |       | 1    |           |          |          | ٦    |          |       |       |
|-----------------------|----------|----------|------------------------------------------|-----|----------|-----------|-------|------|-----------|----------|----------|------|----------|-------|-------|
| /cordic5/rst_n        |          | <u> </u> |                                          |     |          |           |       |      | ~~~~      |          |          |      | 1        | -     |       |
| /cordic5/ena          | -        | <u> </u> |                                          |     |          |           | +     |      |           | -        |          |      | †        |       |       |
| /cordic5/phase_in     |          | 00101010 |                                          | -   |          |           |       |      |           |          |          |      | 1        |       |       |
| /cordic5/sin_out      | 00000000 | 1        |                                          |     | 22       |           |       |      |           |          |          |      | 11111000 | 0110  | 01110 |
| /cordic5/cos_out      | 00000000 | t        |                                          |     |          |           | 1     |      |           |          |          |      | 01111101 | 0100  | 00000 |
| /cordic5/z_out        | 00000000 | -        |                                          | j   | 11111111 |           | -     | _    | (11111110 |          | (0000    | 0000 |          | 30332 |       |
| /cordic5/phase_in_reg | 00000000 |          | 001010                                   | 10  |          |           |       |      |           |          | (12)<br> |      | 1        |       |       |
| /cordic5/x0           | 00000000 | -        | 010011                                   | 01  |          |           |       |      |           | •        |          |      | 1        |       |       |
| /cordic5/y0           | 00000000 |          | 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. |     |          |           |       |      |           | •        |          |      | 1        |       |       |
| /cordic5/z0           | 00000000 |          |                                          |     | 00101010 |           |       |      |           | 8        |          |      | 1        |       |       |
| /cordic5/x1           | 00000000 | -        |                                          |     | 01001101 |           |       |      |           |          |          |      | -        |       |       |
| /cordic5/y1           | 00000000 | -        |                                          | - 1 | 01001101 |           |       |      |           | -        |          |      | 1        |       |       |
| /cordic5/z1           | 00000000 | -        | 1110000                                  | 00  |          | 00001010  | )     |      |           | -        |          |      | 1        |       |       |
| /cordic5/x2           | 00000000 | -        |                                          |     |          | 01110011  | 0010  | 0111 |           |          |          |      | 1        |       |       |
| /cordic5/y2           | 00000000 |          |                                          |     |          | 00100111  | 01110 | 0011 |           |          |          |      | -        |       |       |
| /cordic5/z2           | 00000000 |          | 1110111                                  | 10  | 11110010 |           | 11111 | 000  |           | -        |          |      | t        |       |       |
| /cordic5/x3           | 00000000 |          | -                                        |     |          |           | 01111 | 100  | 01000011  | -        |          |      | 1        |       |       |
| /cordic5/y3           | 00000000 | -        |                                          | -   |          |           | 0000  | 1011 | 01101010  |          |          |      | 1        |       |       |
| /cordic5/z3           | 00000000 |          | 1111011                                  | 11  |          | 11111011  |       |      | 00000001  |          |          |      | -        |       |       |
| /cordic5/x4           | 00000000 | -        |                                          |     |          |           |       |      | (01111101 | 00110110 |          |      | 1        |       |       |
| /cordic5/y4           | 00000000 | -        |                                          |     | 36)      |           |       |      | (11111100 | 01110010 |          |      | 1        |       |       |
| /cordic5/z4           | 00000000 | -        | 1111110                                  | 00  | 11111011 |           | 11111 | 111  |           | 11111101 |          |      | 1        |       |       |
| /cordic5/x5           | 00000000 | -        |                                          | -   |          |           |       |      |           | 01111100 | 0011     | 1101 | 1        |       |       |
| /cordic5/y5           | 00000000 | -        |                                          |     |          |           |       |      |           | 11110101 | (0110    | 1111 | 1        |       |       |
| /cordic5/z5           | 00000000 |          | (1111111                                 | 0   |          | (11111101 |       |      | 00000001  |          | (11111   | 111  |          |       |       |
| /cordic5/x6           | 00000000 |          |                                          | -   |          |           | -     | _    |           |          | 01111    | 1101 | 01000000 |       | -     |
| /cordic5/y6           | 00000000 |          |                                          |     |          |           | -     | _    |           |          | 11111    | 000  | 01101110 |       | -     |
| /cordic5/z6           | 00000000 |          | 1111111                                  | 1   | -        |           | 11111 | 110  |           | 00000000 |          |      |          |       |       |
|                       | 28 285   |          | 152                                      | 1.6 |          |           |       |      |           | 2        |          |      |          |       |       |

Fig.2. Pipelined CORDIC Simulation Waveforms



(An ISO 3297: 2007 Certified Organization)

#### Vol. 3, Issue 8, August 2015

#### IV. SCALING FREE-MICRO ROTATION CORDIC ARCHITECTURE

This algorithm is a modified form of the basic CORDIC algorithm with rotation angles limited to either clockwise or anticlockwise direction. Here the concept of Taylor series along with a generalized micro rotation concept is combined together [8][9]. The Taylor series expansion of the sine and cosine terms will avoid the scaling operation that is required in previous algorithm and provide a good range of convergence.

In this algorithm, the maximum rotation angle is limited to 45 degree. But by using the octant symmetry of the trigonometric functions, it is possible to extend the results into 360 degree.

The cordic function can be represented by using Taylor series as

 $\begin{array}{l} X_{i+1} = ( \ 1 \ {\textbf{-}} {\boldsymbol{\Theta}_i}^2 {2^{-1}} \ ) X_i \!\!-\!\! ( \ {\boldsymbol{\Theta}_i} \!\!-\!\! {\boldsymbol{\Theta}_i}^3 {2^{-3}} ) Y_i \\ Y_{i+1} \!\!=\!\! ( {\boldsymbol{\Theta}_i} \!\!-\!\! {\boldsymbol{\Theta}_i}^3 {2^{-3}} ) X_i + ( \ 1 \!\!-\!\! {\boldsymbol{\Theta}_i}^2 {2^{-1}} ) Y_i \end{array}$ 

Assign  $\Theta_i=2^{-i}$ 

$$\begin{split} X_{i+1} &= [X_i - X_i^{-(2i+1)}] - [Y_i 2^{-i} - Y_i 2^{-(3i+3)}] \\ Y_{i+l} &= [X_i 2^{-i} - X_i \ 2^{-(3i+3)}] + [Y_i - Y_i 2^{-(2i+1)}] \end{split}$$

Block diagram of the above CORDIC can be represented as in figure 3.



Fig.3.Cordinate Calculation

Rotations of this algorithm consist of two sections: basic shift and micro-rotation. Algorithm will perform multiple basic shift (n1 times) initially and then do unidirectional micro-rotations(n2 times). The total rotation angle is the sum of basic shift and micro-rotations (n1+n2).

The micro-rotation is identified from the bit representation of the required angle using most significant -1 detector. The algorithm which performs the micro-rotation is given below.

IV. a. Algorithm for Micro-rotation

Step 1: Let  $\Theta$ i be the angle to be rotated

Step 2: Detect the Most Significant - 1 location (M) of  $\Theta$ i.

Step 3: If M == (Data width -1), do step 4 else go to step 5.



(An ISO 3297: 2007 Certified Organization)

#### Vol. 3, Issue 8, August 2015

Step 4: Micro rotation=0.25 radian, shift=2 and  $\Theta_{i+1}=\Theta_i$ -0.25

Step 5: Shift = Data width -M,  $\Theta_i+1=\Theta_i$  with  $\Theta_i(M)=0$ .

Step 6: Repeat Step 2 to Step 5 till  $\Theta_i=0$ .

The scaling free cordic architecture consists of three stages: One for generating shift values, second one for generating the micro-rotations and finally a cordic calculation circuit. Fig. 3 shows the simulation results obtained from ModelSim.

| /cordic10/clk      |                                         |                                         |                                         |                                         |                                         |                  |                                         |             |               |       |  |
|--------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|------------------|-----------------------------------------|-------------|---------------|-------|--|
| /cordic10/rst_n    |                                         |                                         |                                         |                                         |                                         |                  |                                         |             |               |       |  |
| /cordic10/ena      | 6                                       | [                                       |                                         |                                         |                                         |                  |                                         | [           |               | [     |  |
| /cordic10/phase_in | 010110010101                            | 0001                                    |                                         |                                         |                                         |                  |                                         | -           |               |       |  |
| /cordic10/sin_out  | <u></u>                                 |                                         |                                         | I                                       |                                         | İ                |                                         | -           | (00101010101  | 01101 |  |
| /cordic10/cos_out  |                                         | †                                       |                                         |                                         |                                         | İ                |                                         |             | 011110000101  | 11111 |  |
| /cordic10/z_out    |                                         | ţ                                       |                                         |                                         |                                         | İ                |                                         |             | -{00000000000 | 00000 |  |
| /cordic10/z        | 0101100101010001                        | 0001100101010001                        | 0000100101010001                        | 00000001010100001                       | 0000000001010001                        | 0000000000010001 | 000000000000000000000000000000000000000 | 00000000000 | 000000        |       |  |
| /cordic10/y        | 000000000000000000000000000000000000000 | 0001111011000010                        | 0010011001010000                        | 0010101000010000                        | 0010101010001000                        | 0010101010100110 | 0010101010101                           | 01101       |               | -     |  |
| /cordic10/x        | 100000000000000000000000000000000000000 | 01111100000000000                       | 0111100111010110                        | 011110001001010101                      | 0111100001101011                        | 0111100001100001 | 01111000010                             | 11111       |               | -     |  |
| /cordic10/y1       |                                         | 000000000000000000000000000000000000000 | 0000000111101100                        | 0000000100110010                        | 0000000000101010                        | 000000000001010  | 000000000000000000000000000000000000000 | 00000000000 | 000000        | -     |  |
| /cordic10/y2       |                                         | 000000000000000000000000000000000000000 | 00000                                   |                                         |                                         |                  |                                         | -           |               |       |  |
| /cordic10/x1       | s                                       | 1000000000000000000                     | 0111110000000000                        | 0111100111010110                        | 011110001001010101                      | 0111100001101011 | 0111100001100001                        | 01111000010 | 11111         | -     |  |
| /cordic10/x2       |                                         | 000001000000000                         | 0000000000111110                        | 000000000001111                         | 000000000000000000000000000000000000000 | 00000            | A                                       | -           |               |       |  |
| /cordic10/y11      |                                         | 000000000000000000000000000000000000000 | 0001111011000010                        | 0010011001010000                        | 0010101000010000                        | 0010101010001000 | 0010101010100110                        | 0010101010  | 101101        |       |  |
| /cordic10/y22      | <u></u>                                 | 0000000000000000                        | 0000000000001111                        | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 00000            |                                         | -           |               |       |  |
| /cordic10/x11      |                                         | 0001111100000000                        | 0000011110011101                        | 0000001111000100                        | 0000000001111000                        | 000000000011110  | 0000000000000111                        | 00000000000 | 000000        |       |  |
| /cordic10/x22      |                                         | 0000000000111110                        | 000000000000000000000000000000000000000 | 00000                                   |                                         | 1                |                                         | İ           |               | 1     |  |
| /cordic10/n        | <u>)</u> 7                              | 6                                       | 5                                       | 4                                       | 3                                       | 2                | χ1                                      | 0           | )9            |       |  |
| /cordic10/i        | <u>a</u>                                | 16                                      | (16                                     | 16                                      | 16                                      | 16               | <b>(</b> 16                             | 16          | <b>)</b> 16   |       |  |
| /cordic10/m        |                                         | 0000000000001110                        | 0000000000001100                        | 0000000000001011                        | 000000000000000000000000000000000000000 | 0000000000000110 | 000000000000000000000000000000000000000 | 00000000000 | 000000        |       |  |
| /cordic10/s        |                                         | 000000000000000000000000000000000000000 | 00000000000000000                       | 0000000000000101                        | 0000000000001000                        | 000000000001010  | 000000000001100                         | 0000000000  | 010000        |       |  |
| /cordic10/s_rot    |                                         | 0000000000000100                        | 000000000000000000000000000000000000000 | 0000000000001010                        | 0000000000010000                        | 000000000010100  | 000000000011000                         | 0000000000  | 100000        |       |  |
| /cordic10/s_2      | <u> </u>                                | 000000000000101                         | 0000000000000111                        | 0000000000001000                        | 0000000000001011                        | 000000000001101  | 0000000000001111                        | 00000000000 | 010011        |       |  |
| /cordic10/s_out1   |                                         | 5                                       | 9                                       | 11                                      | 17                                      | 21               | <b>)</b> 25                             | 33          |               | 1     |  |
| /cordic10/s_out2   |                                         | 9                                       | (15                                     | 18                                      | 27                                      | 33               | (39                                     | 51          |               |       |  |
|                    |                                         |                                         |                                         | 23                                      |                                         |                  |                                         | ~           |               |       |  |

Fig.4.Scale free micro rotation cordic simulation waveforms

#### V. DIRECT DIGITAL FREQUENCY SYNTHESIZER

DDFS is a technique used for generating sine and cosine values. It is different from traditional wave generators[10].Normal DDFS consists of a ROM Look-up table which will contain the sine and cosine values of all the phases. But the usage of large ROM's inside the DDFS will reduce the performance of the system and raise the consumption of power. So a scaling free micro-rotation CORDIC based DDFS architecture, which does not require any Look-up tables, is proposed here.

In the proposed method the sine wave generator is replaced with scaling free CORDIC architecture. That means the sine and cosine values are calculating only by using addition and shifting operations.

The architecture of the DDFS is shown in figure 4. It contains 4 sections: The phase accumulator will control the frequency of the output signal. It is possible to change the frequency by varying the FCW value. The frequency will be directly proportional to the value of FCW.



(An ISO 3297: 2007 Certified Organization)

Vol. 3, Issue 8, August 2015



Fig.4. DDFS Architecture

Phase accumulator is basically an adder, which will increment by itself in terms of FCW till an overflow condition is reached. When an overflow is occurred in the accumulator, the phase value will be given to the CORDIC section, which is developed based on the previously discussed Scaling free micro-rotation based CORDIC algorithm. It will provide the sine and cosine values of the given phase angle and this value is given to the Digital to Analog Converter (DAC).

Because of the usage of the efficient CORDIC algorithm in the DDFS architecture, it is possible to achieve higher performance with lesser hardware requirements.



Fig.5. DDFS using scale free micro-rotation based CORDIC

#### VI. COMPARISON AND DISCUSSION

The Direct Digital frequency Synthesizers using pipelined CORDIC architecture and scaling free CORDIC architecture is implemented using Verilog HDL.Both architectures are simulated using ModelSimand synthesized using Xilinx ISE. The synthesis results obtained from Xilinx ISE for Spartan 3E series FPGA XC 3s250e is shown in table I.

TADICI

| I ADLE I                    |                     |                        |                    |                |                  |                           |  |  |  |  |  |  |
|-----------------------------|---------------------|------------------------|--------------------|----------------|------------------|---------------------------|--|--|--|--|--|--|
|                             | Number<br>of Slices | Slice<br>Flip<br>Flops | 4<br>input<br>LUTs | Bonded<br>IOBs | Max.Freq.<br>MHz | Slice<br>Delay<br>Product |  |  |  |  |  |  |
| Pipelined<br>CORDIC<br>DDFS | 547                 | 237                    | 1055               | 38             | 58.54            | 4.04                      |  |  |  |  |  |  |
| Proposed<br>DDFS            | 355                 | 160                    | 624                | 25             | 52.28            | 3.06                      |  |  |  |  |  |  |

It is found that the proposed DDFS architecture using scalingfreeCORDIC has the least slice-delay product. Both the designs are analyzed in view of area and performance. In view of slices, the newly proposed DDFS requires lowest number.



(An ISO 3297: 2007 Certified Organization)

#### Vol. 3, Issue 8, August 2015

#### VII. CONCLUSION

This paper presents an efficient hardware implementation for DDFS with good numerical properties. Compared with the previous one, the proposed DDFS is ROM-less and consumes less area. Due to its highperformance and less area, it meets the needs of signal generation, local oscillators, mixers and modulators in engineering systems. We can further improve our design by using differential cordic algorithm [11] or higher radix cordic algorithm [12].

#### REFERENCES

- 1. Weibo Hu, Chung Len Leeand Xin'an Wang Arbitrary Waveform Generator Based on Direct Digital Frequency Synthesizer" 4th IEEE International Symposium on Electronic Design, Test & Applications, vol. 2 pp.567-570, 2008
- 2. J. E. Volder, "The CORDIC trigonometric computing technique," *IRE Trans. Electron. Computers*, vol. EC-8, pp. 330–334, Sept. 1959.
- 3. KoushikMaharatna, Swapna Banerjee, Eckhard Grass, Milos Krstic, and Alfonso Troya," Modified Virtually Scaling-Free Adaptive CORDIC Rotator Algorithm and Architecture" *IEEE Transactions on Circuits and Systems for Video Technology*, vol. 15, NO. 11, NOVEMBER 2005.
- P. K. Meher, J. Valls, T. B. Juang, K. Sridharan and K. Maharatna, "50 Years of CORDIC: Algorithms, Architectures, and Applications," *IEEE Transactions on Circuits and Systems—I*: Regular Papers, Vol.56(9), pp.1893-1907, Sept. 2009.
- 5. Ray Andraka "A survey of CORDIC Algorithms for FPGA based Computer" ACM 1998.
- 6. M. Chakraborty, A. S. Dhar and Moon Ho Lee, "A Trigonometric Formulation of the LMS Algorithm for Realisation of Pipelined CORDIC," *IEEE Trans. Circuits and Systems*, vol. 52, no. 9, pp. 530- 534, Sep.2005.
- 7. E. O. Garcia, R. Cumplido and Miguel Arias, "Pipelined CORDIC Design on FPGA for a Digital Sine and Cosine Waves Generator," 2006 3rd International Conference on Electrical and Electronics Engineering(ICEEE), pp.104-107, Sept.2006
- 8. SupriyaAggarwal, Pramod K. Meher, and KavitaKhare "Area-Time Efficient Scaling-Free CORDIC Using Generalized Micro-Rotation Selection" *IEEE Transactions on Very Large Scale Integration (VLSI) Systems*, vol. 20, no. 8, august 2012
- 9. D. Fu and A. N. Willson, Jr., "A two-stage angle-rotation architecture and its error analysis for efficient digital mixer implementation,"
- IEEETrans.Circuits Syst. I: Reg. Papers, vol. 53, no. 3, pp. 604–614, Mar. 2006. 10. Martin Kumm, HaraldKlingbeil, and Peter Zipf "An FPGA-Based Linear All-Digital Phase-Locked Loop" IEEE TRANSACTIONS ON
- CIRCUITS AND SYSTEMS—I: Regular Papers, vol. 57, no. 9, September 2010
  11. C. Y. Kang and E. E. Swartzlander, Jr., "Digit-pipelined direct digital frequency synthesis based on differential CORDIC," *IEEE Trans. CircuitsSyst. I, Reg. Papers*, vol. 53, no. 5, pp. 1035–1044, May 2006.
- E. Antelo, T. Lang, and J. D. Bruguera, "Very-high radix circular CORDIC: Vectoring and unified rotation/vectoring," *IEEE Trans. Computers*, vol. 49, no. 7, pp. 727–739, July 2000.