



# DW\_sincos

### Sine and Cosine

Version, STAR and Download Information: IP Directory

## **Features and Benefits**

- Parameterized word length
- sine or cosine output by controlling SIN\_COS port.
- DesignWare Datapath generator is employed for better timing and area.



## **Description**

DW\_sincos is a fixed point sine and cosine unit that calculates WAVE =  $\sin(\pi A)$  or  $\cos(\pi A)$  where A and WAVE are fixed point value by controlling the SIN\_COS pin. DW\_sincos has two additional parameters: *arch* is for the implementation between the area-optimized and the speed-optimized, and *err\_range* allows users to choose the error range between 1 ulp error and 2 ulp error.

Table 1-1 Pin Description

| Pin Name | Width           | Direction | Function                                               |
|----------|-----------------|-----------|--------------------------------------------------------|
| А        | A_width bits    | Input     | Input data (radian)                                    |
| SIN_COS  | 1 bit           | Input     | Function select: 0 = sine function 1 = cosine function |
| WAVE     | WAVE_width bits | Output    | Sine or cosine value                                   |

**Table 1-2** Parameter Description

| Parameter  | Values               | Description                                                                                        |
|------------|----------------------|----------------------------------------------------------------------------------------------------|
| A_width    | 2 to 34 bits         | Word length of A                                                                                   |
| WAVE_width | 2 to 35 bits         | Word length of WAVE                                                                                |
| arch       | 0 or 1<br>Default: 0 | Select the implementation 0: area-optimized implementation 1: speed-optimized implementation       |
| err_range  | 1 or 2<br>Default: 1 | Select the error range 1 : Itrue value - calculatedl < 1 ulp 2 : Itrue value - calculatedl < 2 ulp |

Table 1-3 Synthesis Implementations

| Implementation Name | Function        | License Feature Required |
|---------------------|-----------------|--------------------------|
| rtl                 | Synthesis model | DesignWare               |

#### Table 1-4 Simulation Models

| Model                         | Function                             |
|-------------------------------|--------------------------------------|
| DW02.DW_SINCOS_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw02/src/DW_sincos_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_sincos.v        | Verilog simulation model source code |

### **Functional Description**

The input angle A is treated as a binary fixed point number which is converted to radians when multiplied by  $\pi$ . When A is interpreted as unsigned, the input angle A is a binary subdivision of the range  $0 \le A < 2$ . When A is interpreted as signed (two's complement), the range is  $-1 \le A < 1$ .

Table 1-5 Operations of DW\_sincos

| sin_cos <b>input</b> | a <b>input</b>                   | wave <b>output</b> |
|----------------------|----------------------------------|--------------------|
| 0                    | A (unsigned or two's complement) | sin(πa)            |
| 1                    | A (unsigned or two's complement) | cos(πa)            |

## **Input Data Format**

The input value a is interpreted with the MSB as the only bit to the left of the decimal point. For example, if  $A\_width = 6$ , the input value 111000 is interpreted as 1.11000.

The sine (or cosine) value calculated by DW\_sincos is the same whether A is interpreted is an unsigned number or as a signed (two's complement) number. For example, consider the case where SIN\_COS = 0 and the input value A is 1.10000. Interpreted as an unsigned number, the decimal equivalent of A is 3/2, the angle is  $3\pi/2$ , and the sine value is -1 (decimal).

When 1.10000 is interpreted as a signed number, the MSB becomes the sign bit (1 in this example, indicating a negative number) and .10000 is the two's complement of .10000. The decimal equivalent is (-1/2). DW\_sincos calculates the sine of  $(-\pi/2)$ , which is also -1 (decimal).

Similarly, when SIN\_COS = 1, DW\_sincos calculates the cosine. If the input value (A = 1.10000) is interpreted as an unsigned number, DW\_sincos calculates the cosine of  $3\pi/2$ , which equals 0. If the input value (A = 1.10000) is interpreted as a two's complement number, DW\_sincos calculates the cosine of  $(-\pi/2)$ , which also equals 0.

SolvNet

DesignWare.com

### **Output Data Format**

The output value WAVE is of the form SX.XXXX, where S is the sign bit and X.XXXX is the two's complement of the binary value of the sine or cosine. For example, the sine value 1 (decimal) is represented as 01.0000 (when  $WAVE\_width = 6$ ), and the sine value -1 is represented as 11.0000.

Table 6 shows the bit assignments for the input and output pins. Table 7 shows input and output values for an example implementation where  $A\_width = 6$ ,  $WAVE\_width = 6$ 

Table 1-6 Input and Output Data Format

| Pin                     | Range (binary)                                                                                              | Range (decimal) |
|-------------------------|-------------------------------------------------------------------------------------------------------------|-----------------|
| A (unsigned)            | 1.111111 (< 2)<br>1.111110<br><br>1.000000 (= 1)<br><br>0.000001<br>0.000000 (= 0)                          | 0 ≤ A < 2       |
| A (two's complement)    | 0.111111 (< 1)<br>0.111110<br><br>0.000000 (= 0)<br>1.111111 (< 0)<br><br>1.000001<br>1.000000 (= -1)       | -1 ≤ A < 1      |
| WAVE (two's complement) | 01.000000 (= 1)<br>00.111111<br><br>00.000000 (= 0)<br>11.111111 (< 0)<br><br>11.000001<br>11.000000 (= -1) | -1 ≤ WAVE ≤ 1   |

Table 1-7 Sample Data Value for A\_width = 6 and WAVE\_width = 6

| Value of A                 | SIN_COS | Function  | Value of WAVE |
|----------------------------|---------|-----------|---------------|
| 1.00000 (unsigned)         | 0       | sin(π)    | 00.0000       |
| 1.10000 (unsigned)         | 0       | sin(3π/2) | 11.0000       |
| 1.00000 (two's complement) | 1       | cos(-π)   | 11.0000       |
| 0.10000 (two's complement) | 0       | sin(π/2)  | 01.0000       |

### Alternative Implementation of Sine and Cosine with DW\_Ip\_multifunc

The sine and cosine operation can also be implemented by DW\_lp\_multifunc component (a member of the minPower Library, licensed separately), which evaluates the value of sine and cosine with 1 ulp error bound. There will be 1 ulp difference between the value from DW\_lp\_multifunc and the value from DW\_sincos. Performance and area of the synthesis results are different between the DW\_sincos and sine and cosine implementation of the DW\_lp\_multifunc, depending on synthesis constraints, library cells and synthesis environments. By comparing performance and area between the sine and cosine implementation of DW\_lp\_multifunc and DW\_sincos component, the DW\_lp\_multifunc provides more choices for the better synthesis results. Below is an example of the Verilog description for the sine and cosine of the DW\_lp\_multifunc. For more detailed information, see the DW\_lp\_multifunc datasheet.

```
DW_lp_multifunc #(op_width, 24) U1 (
    .A(A),
    .FUNC(FUNC),
    .Z(Z),
    .STATUS(STATUS)
);
```

## **Related Topics**

- Datapath Floating Point Overview
- DesignWare Building Block IP Documentation Overview

## **HDL Usage Through Component Instantiation - VHDL**

```
library IEEE, DWARE;
use IEEE.std logic 1164.all;
use DWARE.DWpackages.all;
use DWARE.DW Foundation comp arith.all;
entity DW_sincos_inst is
      generic (
        inst_A_width : INTEGER := 24;
        inst_WAVE_width : INTEGER := 25;
        inst_arch : INTEGER := 0;
        inst_err_range : INTEGER := 1
        );
      port (
        inst_A : in std_logic_vector(inst_A_width-1 downto 0);
        inst_SIN_COS : in std_logic;
        WAVE_inst : out std_logic_vector(inst_WAVE_width-1 downto 0)
    end DW_sincos_inst;
architecture inst of DW_sincos_inst is
begin
    -- Instance of DW_sincos
    U1 : DW sincos
    generic map (
          A_width => inst_A_width,
          WAVE width => inst WAVE width,
          arch => inst_arch,
          err range => inst err range
          )
    port map (
          A \Rightarrow inst A,
          SIN_COS => inst_SIN_COS,
          WAVE => WAVE_inst
          );
end inst:
```

## **HDL Usage Through Component Instantiation - Verilog**

endmodule

## **Copyright Notice and Proprietary Information**

© 2018 Synopsys, Inc. All rights reserved. This Synopsys software and all associated documentation are proprietary to Synopsys, Inc. and may only be used pursuant to the terms and conditions of a written license agreement with Synopsys, Inc. All other use, reproduction, modification, or distribution of the Synopsys software or the associated documentation is strictly prohibited.

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### **Disclaimer**

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### **Trademarks**

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at https://www.synopsys.com/company/legal/trademarks-brands.html.

All other product or company names may be trademarks of their respective owners.

#### **Third-Party Links**

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

Synopsys, Inc. 690 E. Middlefield Road Mountain View, CA 94043

www.synopsys.com