# Effective FPGA implementation of algorithms

for

Insitute of Electronic Systems Warsaw University of Technology Warsaw, Poland

Email: @stud.elka.pw.edu.pl

Abstract—This paper describes the implementation of

The main goal of this work is to investigate the properties of proposed implementation such as efficiency, speed of the system, energy consumption and use of embedded logic resources. Final result should confirm that FPGA implementation of this algorithm can be much more effective in many ways, than created for microcontrollers, so they could be substituted by FPGA chips in a few branches of industry.

#### I. Introduction

Nowadays, there is a large need for real-time determining

$$\phi = \arctan \left( \frac{A_x}{\sqrt{A_y^2 + A_z^2}} \right)$$
(3)

There are two basic solutions, which can provide values

$$\varphi(t) = \int_{0}^{t} \omega(\tau)d\tau$$
 (1)

to local electromagnetic interferences, which can also increase a measurement error. [2]

#### II. SENSOR FUSION

To reduce limitations related to each sensor, many engineers are using special signal processing algorithms, which combine data from all three sensors [3]. This operation is called sensor



$$\theta = \arctan \left(\frac{A_y}{A_z}\right)$$
(2)





III. FILTER

uses quaternion arithmetic. A quaternion [6] is a four-dimensional extension of complex number that can be used to represent the orientation of a ridged body or coordinate frame in three-dimensional space. In this work quaternion  $\hat{q}$  is represented as four element vector:

$$\hat{q} = [q_1 \ q_2 \ q_3 \ q_4]$$
 (5)

where  $q_1$  is a real part and  $q_2$ ,  $q_3$ ,  $q_4$  are imaginary parts. In this work quaternions describe rotation of one frame relative to the second frame and some vector described in that frame. Denoting first frame by B, second by A and vector by  $^A\vec{n}$  this relation can be described as:

$$q_B^A = \left[\cos\frac{\alpha}{2} - n_x \sin\frac{\alpha}{2} - n_y \sin\frac{\alpha}{2} - n_z \sin\frac{\alpha}{2}\right]$$
 (6)

where  $\alpha$  is a rotation angle.

#### IV. FPGA IMPLEMENTATION

square roots) [5]. This algorithm is sequential, but it can be splitted to few subsequent rounds. As was said before this algorithm comes down to transforming and multiplying of matrices. With FPGA chips many operations can be done in parallel for each round, so each filter update on FPGA should be much more faster than on CPU or MCU. Moreover, splitting algorithm to rounds in hardware opens possibility to use pipeline-processing, which can also increase speed of computations.

by 30. The divisions and square roots (which are very computational expensive) are used to normalise quaternions, in other words to calculate an inverted square root. This operations can be completely removed, by replacing them with Newton-

Last problem which must be solved is an effective implementation of inverse trigonometric functions arctan and

arithmetic, typically used in FPGA chips.

Raphson Method [7], which is the best method for fixed-point

The main goal of this work is to investigate how efficient would be implementation in medium-class FPGA using proposed solutions, compared to the MCU version.

#### V. DEVICE ARCHITECTURE

## A. Component Selection

In this work it is assumed that FPGA chips would be medium-class. Searching of a proper circuit was constrained to products offered by three biggest FPGA companies: Altera, Xilinx and Lattice Semiconductor. Finally it was decided to





Fig. 3. Device architecture block scheme

### B. Device Architecture

Figure 3 shows the architure of the whole device, built



#### VI. RESULTS

At this moment implementations of an UART and I<sup>2</sup>C in FPGA are done. Implementation of the first version of which don't use pipeline processing is still in progress. There is also a reference version implemented on STM32F303VCT6 MCU, to compare with FPGA version.

#### REFERENCES



- [6] K. Shoemake, "Quaternions," University on Pensylvania, Tech. Rep., .
- [7] P. C. K. Piromsopa, C. Apomtevan, "Fpga implementation of fixed-point square operation," Chulalongkom University, Tech. Rep., .
- [8] R. Andraka, "A survey of cordic algorithms for fpga based computers," Andraka Consulting Group Inc., Tech. Rep., .