

**IP Core Specification** 

#### Sine / Cosine Table

Author: Gerhard Hoffmann OpenCores@hoffmann-hochfrequenz.de

> Rev. [0.1] January 18, 2011



This page has been intentionally left blank.

#### **Revision History**

| Rev. | Date        | Author   | Description     |
|------|-------------|----------|-----------------|
| 0.1  | 2011/jan/18 | Gerhard  | Initial version |
|      |             | Hoffmann |                 |
|      |             |          |                 |
|      |             |          |                 |
|      |             |          |                 |
|      |             |          |                 |
|      |             |          |                 |
|      |             |          |                 |
|      |             |          |                 |
|      |             |          |                 |

#### Contents

| INTRODUCTION                   | 1 |
|--------------------------------|---|
| ARCHITECTURE                   | 2 |
| IOPORTS AND GENERICS           | 3 |
| PERFORMANCE / CHARACTERIZATION | 4 |
| ТОДО                           | 5 |

#### Introduction

This block is a sine / cosine table that can be synthesized. It is pure VHDL, no other tools or silicon vendor macros are required. The pipeline delay can be selected from purely combinatorial to 10 stages at compile time via a generic, so it is easy to meet a required clock frequency with the minimum possible latency.

The width of the phase input and the sin/cos outputs is automatically determined by the connected bus.

Currently, there are 2 versions of the sine entity. The simple version "sintab" only provides sine values. The somewhat bigger version "sincostab" provides both sine and cosine values without requiring a bigger ROM. The additional effort consists only of some multiplexers and another conditional inversion stage.

#### Architecture

The phase theta of a sine wave can take on values from 0 to a little less than 2 Pi. Because of symmetry, only a quarter wave must be stored. This entity consists of 3 building blocks:

- 1. address range reduction by mirroring
- 2. The ROM access itself
- 3. conditional output sign inversion.

There may be pipeline stages at the input, the output, between 1 and 2 and between 2 and 3. The total number of pipe delays may be given as a generic; a table in the entity ensures a sensible distribution.

The sine table is computed at compile time and stored in ROM(s).

#### **IO Ports And Generics**

| Port        | Туре      | Width/   | Directi | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|-----------|----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |           | Range    | on      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| clk         | std_logic | 1        | Input   | clock input that controls all activities.<br>Rising edge is active but is ignored for a<br>pipeline delay of 0 clocks.                                                                                                                                                                                                                                                                                                                                                    |
| се          | std_logic | 1        | Input   | Must be high to qualify a clock edge as<br>active.<br>Defaults to '1' and is completely ignored for<br>a pipeline delay of 0 clocks.                                                                                                                                                                                                                                                                                                                                      |
| rst         | std_logic | 1        | Input   | Synchronous reset. Defaults to '0'.<br>Overrides CE. Forces the internal memories<br>to zeros. This is not of much use because a<br>zero output is not necessarily more correct<br>than anything else, especially if both sin<br>and cos are zero at the same time. It helps<br>people who are offended by red traces in a<br>Modelsim wave display. After a few<br>clocks, the output reflects the input history<br>only. If the pipeline delay is 0, rst is<br>ignored. |
| theta       | unsigned  | variable | Input   | The phase that is to be converted to sine<br>and cosine. The length is taken from the<br>connected signal. The range is from 0000 =<br>0 to 1111 = 2 pi                                                                                                                                                                                                                                                                                                                   |
| sin,<br>cos | signed    | variable | Output  | Computed sine and cosine outputs. Length<br>is taken from connected signals. Cos is only<br>available from entity sincostab.                                                                                                                                                                                                                                                                                                                                              |
| n_stages    | integer   | 010      | generic | Amount of delay in clock cycles.<br>For 0 clocks delay, the pipeline is<br>transparent.<br>Clk, ce and rst are don't cares in this case.                                                                                                                                                                                                                                                                                                                                  |

Table 1: List of IO ports

#### Performance / Characterization

This block was compiled into an otherwise empty Xilinx XC6SLX45T-3FGG448 FPGA. Without tuning, a table with 16 bit phase and 18 bit for sin and cos was estimated by the ISE tools to run at 230 MHz. Just increasing the theta bus to 18 Bit dropped the speed to 140 MHz and quadrupled the ROM requirements. The  $18 \rightarrow 18 + 18$  bit version uses about half the block rams of this chip vs. 1/8 for the 16 bit phase version.

*The latency-free version (pipeline delay=0) cannot use Block ROMs but generates large amounts of distributed ROMs and takes a large hit in both cycle- and routing time.* 

*Nevertheless, the generated hardware is exactly that what is required.* 

This design has not yet been tried on actual silicon.

The following wave picture is the result of the testbed for 8 bit phase and amplitude. There are 4 pseudo-analog traces. The top one is the phase ramp from 0 to 0xff. 0xff is just a little bit less than 2 pi for a 8 bit theta.. The next is the sinewave from the sine-only entity.

The remaining two analog traces are the sine and cosine output of the sincostab entity.

The test bed checks the deviation of the computed values from the ideal ones and complains if the deviation is more than 0.5 LSB of the chosen word length. In the example shown, the worst deviation is 0.488 LSB.

|          |                |                                                             |                                            | 0000       |                                   | 0000                                        |        |                  |                      | ł                    |                       | ł | -                                     | 54 102406001           |   | *                                             |                                         |
|----------|----------------|-------------------------------------------------------------|--------------------------------------------|------------|-----------------------------------|---------------------------------------------|--------|------------------|----------------------|----------------------|-----------------------|---|---------------------------------------|------------------------|---|-----------------------------------------------|-----------------------------------------|
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      |                       |   | -                                     | 100200<br>1766 ps      |   |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      |                       |   | 250000                                | 2563                   |   |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      |                       |   | -                                     |                        |   |                                               |                                         |
|          |                |                                                             | 127 ()()()()()()()()()()()()()()()()()()() |            |                                   | 27 1332000                                  |        |                  |                      |                      |                       |   | 200000 ps                             |                        |   |                                               | 0 ns                                    |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      |                       |   | - 50                                  |                        |   |                                               | 0 ps to 2940 ns                         |
|          |                |                                                             | 000000000000000000000000000000000000000    |            |                                   |                                             |        | /                |                      |                      | <b>1</b>              |   |                                       |                        |   |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      |                       |   | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                        |   |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      | )0.488416             |   | -                                     |                        |   |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      | /                    | ļ<br>                 |   | 1 1 1 1<br>100000 ps                  |                        |   |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      |                       |   |                                       |                        |   |                                               |                                         |
|          |                |                                                             | 33330CC(127_)                              |            |                                   | XXXXQCXTZ2_X                                |        | <br>             |                      |                      |                       |   |                                       |                        |   |                                               |                                         |
|          |                |                                                             | 000000000000000000000000000000000000000    |            |                                   |                                             |        |                  |                      |                      | 416                   |   | <br>50000 ps                          |                        |   |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      | 315 <u>)</u> 0.488416 |   | -                                     |                        |   |                                               |                                         |
|          |                |                                                             | 2 00000                                    |            |                                   | 2 1000000000000000000000000000000000000     |        |                  |                      |                      | 0 00.441515 (         |   | - 8                                   | 69872 ps               | - |                                               |                                         |
|          |                |                                                             |                                            |            |                                   |                                             |        |                  |                      |                      |                       |   | 2800000 ps<br>171548027 ps            | 2563766 ps<br>69872 ps |   |                                               | sim:/sincos_tb                          |
|          | <u> </u>       | 1<br>250                                                    | -17                                        | ę          | <del>م ہ</del>                    | 17                                          | 250    | -17              | -17                  | 126                  | 0.488416              |   |                                       |                        | • | n 😰 Wave 🛛                                    | sim:/s                                  |
| Messages |                |                                                             |                                            |            | ivert<br>dress                    | bs_sin                                      |        |                  |                      |                      |                       |   | Now 1                                 | Cursor 2<br>Cursor 3   |   | 🛁 sincos.vhd 📶 Library 🎬 Project 🛃 sim 📰 Wave | elta: 3                                 |
|          | jast ja        | /ce<br>ltheta                                               |                                            | /del_theta | /sincos_tb/u_sin/piped_invert<br> | <pre>* /sincos_tb/u_sin/piped_abs_sin</pre> | /theta | 4                | /o_sin               | so0                  | /sincos_tb/worsterror |   |                                       |                        |   | Library 🎦 P                                   | Project : sincos Now: 2,800 ns Delta: 3 |
|          | /sincos_tb/clk | <ul> <li>/sincos_tb/ce</li> <li>/sincos_tb/theta</li> </ul> |                                            |            | <pre>/sincos_tt /sincos_tb</pre>  | /sincos_tt                                  | •      | 🗉 🔶 /sincos_tb/y | ∎-� /sincos_tb/o_sin | 🖬 🔶 /sincos_tb/o_cos | /sincos_tt            |   | • •                                   |                        |   | in bhy.so                                     | sincos No                               |

## 5. ToDo

- 1. A version for the new VHDL-2008 types ufixed / sfixed
- 2. Sunderland ROM decomposition

# Index