

# A Novel CORDIC algorithm for fixed angle rotation

Vangapandla Shirisha

MTech Student Department of ECE AnuBose Institute Of Technology(ABIT) Paloncha, Khammam, India

**ABSTRACT:** Rotation of vectors through fixed and known angles has wide applications in robotics, digital signal processing, graphics, games, and animation. But, we do not find any optimized coordinate rotation digital computer (CORDIC) design for vector-rotation through specific angles. Therefore, in this paper, we present optimization schemes and CORDIC circuits for fixed and known rotations with different levels of accuracy. For reducing the area- and time-complexities, we have proposed a hardwired pre-shifting scheme in barrelshifters of the proposed circuits. Two dedicated CORDIC cells are proposed for the fixed-angle rotations. In one of those cells, micro-rotations and scaling are interleaved, and in the other they are implemented in two separate stages. Pipelined schemes are suggested further for cascading dedicated single-rotation units and bi-rotation CORDIC units for high-throughput and reduced latency implementations. We have obtained the optimized set of micro-rotations for fixed and known angles. The optimized scale-factors are also derived and dedicated shift-add circuits are designed to implement the scaling. The fixed-point meansquared-error of the proposed CORDIC circuit is analyzed statistically, and strategies for reducing the error are given. We have synthesized the proposed CORDIC cells by Synopsys Design Compiler using TSMC 90-nm library, and shown that the proposed designs offer higher throughput, less latency and less area-delay product than the reference CORDIC design for fixed and known angles of rotation. We find similar results of synthesis for different Xilinx field-programmable gate-array platforms.

M.Shoban Babu

Assistant Professor Department of ECE AnuBose Institute Of Technology(ABIT) Paloncha, Khammam, India

Index Terms—Coordinate rotation digital computer (CORDIC), digital arithmetic, digital signal processing (DSP) chip, VLSI.

# **INTRODUCTION:**

CORDIC stands for coordinate rotation digital computer. The key concept of CORDIC arithmetic is based on the simple and ancient principles of 2-D geometry. But the iterative formulation of a computational algorithm for its implementation was first described in 1959 by Volder [1], [2] for the computation of trigonometric functions, multiplication, and division. Not only a wide variety of applications of CORDIC have been suggested over the time, but also a lot of progress has taken place in the area of algorithm design and development of architectures for highperformance and low-cost hardware solutions [3]-[12]. Rotation of vectors through a fixed and known angle has wide applications in robotics, graphics, games, and animation [4], [13], [14]. Locomotion of robots is very often performed by successive rotations through small fixed angles and translations of the links. The translation operations are realized by simple additions of coordinate values while the new coordinates of a rotational step could be accomplished by suitable successive rotations through a small fixed angle which could be performed by a CORDIC circuit for fixed rotation [4]. Similarly, interpolation of orientations between key-frames in computer graphics and animation could be performed by fixed CORDIC rotations [14]. There are plenty of examples of uniform rotation starting from electrons inside an atom to the planets and satellites. A simple example of uniform rotations is the hands of an animated mechanical clock which perform one degree rotation each time. There

International Journal & Magazine of Engineering, **Technology, Management and Research** 

A Peer Reviewed Open Access International Journal

are several cases where high-speed constant rotation is required in games, graphic, and animation

### **Existing System:**

The rotation-mode CORDIC algorithm to rotate a vector through an angle to obtain a rotated vector is given by [1], [2] In case of fixed rotation, could be precomputed and the sign-bits corresponding to could be stored in a sign-bit register (SBR) in CORDIC circuit. The CORDIC circuit therefore need not compute the remaining angle during the CORDIC iterations [3]. A reference CORDIC circuit for fixed rotations according to (1a) and (1b) is shown in Fig. 1. and are fed as set/reset input to the pair of input registers and the successive feedback values and at the iteration are fed in parallel to the input registers. Note that conventionally we feed the pair of input registers with the initial values and as well as the feedback values and through a pair of multiplexers. We show here that for rotation of a vector through a known and fixed angle of rotation using a rotation-mode CORDIC circuit, we can find a set of a small number of predetermined elementary angles for , where is the elementary angle to be used for the th micro-rotation in the CORDIC algorithm (1), and is the minimum necessary number of micro-rotations. Meanwhile, it is well known that the rotation through any angle, can be mapped into a positive rotation through without any extra arithmetic operations [10]. Hence, as a first step of optimization, we perform the rotation mapping so that the rotation angle lies in the range of . In the The simple pseudo code to optimize a set of microrotations is described in Algorithm 1. If the maximum accuracy which is defined as the maximum tolerable error between desired angle and approximated angle is given as an input, the optimization algorithm searches the parameters and that can minimize an objective function. The algorithm starts with the single microrotation, i.e., , then if the micro-rotation that has smaller angle of deviation than cannot be found, the number of micro-rotations is increased by one and the optimization algorithm is run again. Exhaustive search is employed in the optimization algorithm to search the entire parameter space for all the combinations of and.

Based on the obtained micro-rotations, the parameters for scaling operation can be searched with the different objective function, which is described in Section IV. The sub-optimal set of micro-rotations may be used in some cases, if the optimal set of micro-rotations cannot satisfy the design constraint for scaling. We have used sub-optimal solutions particularly for the rotation with the angle of 31 and 35 in Table I since the scaling requires more terms in these two cases if optimal solutions are used.

**ISSN No: 2348-4845** 

### **Proposed System:**

Since the elementary angles and direction of microrotations are predetermined for the given angle of rotation, the angle es-



Fig. 2. CORDIC cell for constant complex multiplications.



Fig. 3. Hardwired pre-shifting in basic CORDIC module.

timation data-path is not required in the CORDIC circuit for fixed and known rotations. Moreover, because only a few elementary angles are involved in this case, the corresponding control-bits could be stored in a ROM of few words. A CORDIC circuit for complex constant multiplications is shown in Fig. 2. The ROM contains the control-bits for the number of shifts corresponding the micro-rotations to be implemented by the barrel-shifter and the directions of micro-rotations are stored in the sign-bit register (SBR). The major contributors to the hardwarecomplexity in the implementation of a CORDIC circuit

Volume No: 2 (2015), Issue No: 7 (July) www.iimetmr.com

International Journal & Magazine of Engineering, Technology, Management and Research

A Peer Reviewed Open Access International Journal

are the barrel-shifters and the adders. There are several options for the implementation of adders [22], from which a designer can always choose depending on the constraints and requirements of the application. But, we have some scope to develop techniques for reducing the complexity of barrel-shifters over the conventional designs as discussed in the followings.

# SCALING OPTIMIZATION AND IMPLEMENTATION

The generalized expression for the scale-factor given by (2) can be expressed explicitly for the selected set of microrotations as

$$K = \prod_{i=0}^{m_1-1} \left[ (1+2^{-2k(i)}) \right]^{-1/2}$$



7ig. 6. Two-stage cascaded bi-rotation CORDIC circuit. SBR is sign-bit regster of 2-bits size.

### **Implementation of Scaling**

Scaling and micro-rotations could be implemented either in the same circuit in interleaved manner or in two separate stages. The implementation of scaling as well as the micro-rotation would however depend on the level of desired accuracy, and the implementation of scaling also depends on the implementation of micro-rotations. Therefore, we discuss here the

> Volume No: 2 (2015), Issue No: 7 (July) www.iimetmr.com

realization of the scaling circuits corresponding to different implementations of micro-rotations.

**ISSN No: 2348-4845** 



Fig. 8. CORDIC circuit for interleaved implementation of micro-rotations as well as scaling circuit. (a) The CORDIC circuit. (b) Structure and function of linechanger. For control-bit it performs micro-rotations and for control-bit it performs the shift-add operations for scaling.

#### **COMPLEXITY CONSIDERATIONS**

We discuss here the hardware and time complexities of the proposed design. In the existing literature we do not find similar work on CORDIC implementation of known and fixed rotations. Therefore, we compare the proposed design with the conventional CORDIC design for the rotation of unknown angle. We have used the basic CORDIC processor in [3, Fig. 2] for the implementation of conventional CORDIC. In addition, we have designed a reference architecture (see Fig. 1) for straightforward implementation of fixed rotations, and we have compared the complexities and speed performance of the proposed design with the conventional and reference design. The maximum deviation of amounting to is assumed to be accuracy level-1 (AL-1) and that amounting to is assumed to be accuracy level-2 (AL-2), so that AL-1 and AL-2 would

**July 2015** 



A Peer Reviewed Open Access International Journal

correspond to the proposed CORDIC implementations of rotation through four and six micro-rotations, respectively.

# CONCLUSION

The number of micro-rotations for rotation of vectors through known and fixed angles are optimized and several possible dedicated circuits are explored for rotation-mode CORDIC processing with different levels of accuracy. The proposed CORDIC cell with interleaved scaling involves more area, but offers more throughput and involves nearly less latency and less ADP, than the reference design for known and fixed rotations. The proposed single-rotation cascade and birotation cascade require, respectively, and times more area over the reference design, but offer nearly 16.3 and 7.0 times more throughput, and involve nearly 4.6 and 2.5 times less ADP with nearly half and two-thirds of the latency of the other. With progressing scaling trends, since the silicon area is getting continually cheaper, it appears to be a good idea to use the cascaded designs for their potential for highthroughput and low-latency implementation. It is found that higher accuracy could be achieved in case of smaller angles of rotation when the same number of micro-rotations are used. The small angle rotators could therefore be very much useful for shape design and curve tracing for animation and gaming devices. The fixed-angle CORDIC rotation would have wide applications in signal processing, games, animation, graphics and robotics, as well.

# REFERENCES

[1] J. E. Volder, "The CORDIC trigonometric computing technique," IRE Trans. Electron. Comput., vol. EC-8, pp. 330–334, Sep. 1959.

[2] J. S. Walther, "A unified algorithm for elementary functions," in Proc. 38th Spring Joint Comput. Conf., 1971, pp. 379–385.

[3] Y. H. Hu, "CORDIC-based VLSI architectures for digital signal processing," IEEE Signal Process. Mag., vol. 9, no. 3, pp. 16–35, Jul. 1992.

[4] P. K. Meher, J. Valls, T.-B. Juang, K. Sridharan, and K. Maharatna, "50 years of CORDIC: Algorithms,

architectures and applications," IEEE Trans. Circuits Syst. I, Reg. Papers, vol. 56, no. 9, pp. 1893–1907, Sep. 2009.

[5] Y. H. Hu and S. Naganathan, "An angle recoding method for CORDIC algorithm implementation," IEEE Trans. Comput., vol. 42, no. 1, pp. 99–102, Jan. 1993.

[6] Y. H. Hu and H. H. M. Chern, "A novel implementation of CORDIC algorithm using backward angle recoding (BAR)," IEEE Trans. Comput., vol. 45, no. 12, pp. 1370–1378, Dec. 1996.

[7] C.-S. Wu, A.-Y. Wu, and C.-H. Lin, "A highperformance/low-latency vector rotational CORDIC architecture based on extended elementary angle set and trellis-based searching schemes," IEEE Trans. Circuits Syst. II, Analog Digit. Signal Process., vol. 50, no. 9, pp. 589–601, Sep. 2003.

[8] T.-B. Juang, S.-F. Hsiao, and M.-Y. Tsai, "Para-CORDIC: Parallel cordic rotation algorithm," IEEE Trans. Circuits Syst. I, Reg. Papers, vol. 51, no. 8, pp. 1515–1524, Aug. 2004.

[9] T. K. Rodrigues and E. E. Swartzlander, "Adaptive CORDIC: Using parallel angle recoding to accelerate CORDIC rotations," in Proc. 40th Asilomar Conf. Signals, Syst. Comput. (ACSSC), 2006, pp. 323–327.

[10] K. Maharatna, S. Banerjee, E. Grass, M. Krstic, and A. Troya, "Modified virtually scaling free adaptive CORDIC rotator algorithm and architecture," IEEE Trans. Circuits Syst. for Video Technol., vol. 15, no. 11, pp. 1463–1474, Nov. 2005.

[11] C. Y. Kang and E. E. Swartzlander, Jr., "Digitpipelined direct digital frequency synthesis based on differential CORDIC," IEEE Trans. Circuits Syst. I, Reg. Papers, vol. 53, no. 5, pp. 1035–1044, May 2006. [12] L. Vachhani, K. Sridharan, and P. K. Meher, "Efficient CORDIC algorithms and architectures for low area and high throughput implementation," IEEE Trans. Circuits Syst. II, Exp. Briefs, vol. 56, no. 1, pp. 61–65, Jan. 2009.

[13] B. G. Blundell, An Introduction to Computer Graphics and Creative 3-D Environments. London, U.K.: Springer-Verlag, 2008.

Volume No: 2 (2015), Issue No: 7 (July) www.ijmetmr.com



[14] T. Lang and E. Antelo, "High-throughput CORDIC-based geometry operations for 3D computer graphics," IEEE Trans. Comput., vol. 54, no. 3, pp. 347–361, Mar. 2005.

[15] M.-P. Cani, T. Igarashi, and G. Wyvill, Interactive Shape Design. San Rafael, CA: Morgan & Claypool, 2007.

[16] K. J. Jones, "2D systolic solution to discrete Fourier transform," IEE Proc. Comput. Digit. Techn., vol. 136, no. 3, pp. 211–216, May 1989.

[17] P. K. Meher, J. K. Satapathy, and G. Panda, "Efficient systolic solution for a new prime factor discrete Hartley transform algorithm," IEE Proc. Circuits, Devices Syst., vol. 140, no. 2, pp. 135–139, Apr. 1993.

[18] S. Freeman and M. O'Donnell, "A complex arithmetic digital signal processor using cordic rotators," in Proc. IEEE Int. Conf. Acoust., Speech, Signal Process. (ICASSP), 1995, pp. 3191–3194.

[19] J. R. Cavallaro and F. T. Luk, "CORDIC arithmetic for a SVD processor," J. for Parallel Distrib. Comput., vol. 5, pp. 271–290, 1988.

[20] C. H. Lin and A. Y. Wu, "Mixed-scaling-rotation CORDIC (MSRCORDIC) algorithm and architecture for high-performance vector rotational DSP applications," IEEE Trans. Circuits Syst. I, Reg. Papers, vol. 52, no. 11, pp. 2385–2396, Nov. 2005.

[21] S. Y. Park and N. I. Cho, "Fixed-point error analysis of CORDIC processor based on the variance propagation formula," IEEE Trans. Circuits Syst. I, Reg. Papers, vol. 51, no. 3, pp. 573–584, Mar. 2004.

[22] A. R. Omondi, Computer Arithmetic Systems: Algorithms, Architectures, and Implementations. New York: Prentice-Hall, 1994.

[23] A. K. Jain, Fundamentals of Digital Image Processing. Englewood Cliffs, NJ: Prentice-Hall, 1989.

[24] Signal Compression : Coding of Speech, Audio, Text, Image And Video, ser. Selected Topics in Electronics and Systems, N. E. Jayant, Ed. Singapore: World Scientific, 1997, vol. 9.