



# DWF\_dp\_rndsat functions

# Arithmetic Rounding and Saturation

Version, STAR and Download Information: IP Directory

### **Description**

The DWF\_dp\_rndsat functions truncate the lower bits of argument a below the bit position specified by argument lsb, round according to the rounding mode specified by argument mode, truncate the upper bits above the bit position specified by argument msb and return a saturated value if an overflow (or underflow) occurs. Argument a and the return value are both either signed (two's complement) or unsigned.

**Table 1-1** Function Names

| Function Name     | Description                                               |  |
|-------------------|-----------------------------------------------------------|--|
| DWF_dp_rndsat     | VHDL unsigned rounding and saturation                     |  |
| DWF_dp_rndsat     | VHDL signed (two's complement) rounding and saturation    |  |
| DWF_dp_rndsat_uns | Verilog unsigned rounding and saturation                  |  |
| DWF_dp_rndsat_tc  | Verilog signed (two's complement) rounding and saturation |  |

Table 1-2 Argument Description

| Argument Name | Туре    | Width / Values   | Description                                     |
|---------------|---------|------------------|-------------------------------------------------|
| а             | Vector  | width            | Input data                                      |
| msb           | Integer | > lsb, ≤ width-1 | MSB index of return value (VHDL only, constant) |
| Isb           | Integer | ≥ 1, < msb       | LSB index of return value (VHDL only, constant) |
| mode          | Vector  | 4                | Rounding mode (values in DWF_dp_rnd: Table 4)   |
| DWF_dp_rndsat | Vector  | msb-lsb+1        | Return value                                    |

Table 1-3 Parameter Description (Verilog)

| Parameter | Values           | Description               |
|-----------|------------------|---------------------------|
| width     | ≥ 1              | Word length of input a    |
| msb       | > lsb, ≤ width-1 | MSB index of return value |
| Isb       | ≥ 1, < msb       | LSB index of return value |

Verilog Include File: DW\_dp\_rndsat\_function.inc

### **Functional Description**

DWF\_dp\_rndsat is functionally equivalent to rounding followed by saturation (also requires special handling of rounding overflow).

#### **Unsigned / Signed Rounding**

```
t[width-lsb-1:0] = a[width-1:lsb]+1 if a[lsb-1:0] > threshold(mode)
= a[width-1:lsb] else
```

Find more information on rounding and rounding modes in the DWF\_dp\_rnd Datasheet.

#### **Unsigned Saturation**

```
z[msb-lsb:0] = 2^{msb-lsb+1}-1 if t[width-lsb-1:0] > 2^{msb-lsb+1}-1
= t[msb-lsb:0] else
```

#### Signed Saturation

```
z[msb-lsb:0] = 2^{msb-lsb}-1 if t[width-lsb-1:0] > 2^{msb-lsb}-1
= -2^{msb-lsb} else if t[width-lsb-1:0] < -2^{msb-lsb}
= t[msb-lsb:0] else
```

For more information about the DesignWare datapath functions, refer to the topic titled DesignWare Datapath Functions Overview.

# **Related Topics**

- DesignWare Datapath Functions Overview
- DesignWare Building Block IP Documentation Overview

## **VHDL Example**

```
library IEEE, DWARE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
use DWARE.DW_dp_functions.all;
-- DWARE.DW_dp_functions_arith package if IEEE.std_logic_arith is used
entity DWF_dp_rndsat_test is
  port (a, b, c : in signed(7 downto 0);
        z : out signed(7 downto 0));
end DWF_dp_rndsat_test;

architecture rtl of DWF_dp_rndsat_test is
begin
  z <= DWF_dp_rndsat (a * b, 11, 4, DW_dp_rnd_near_even) + c;
end rtl;</pre>
```

SolvNet

DesignWare.com

### **Verilog Example**

```
module DWF_dp_rndsat_test (a, b, c, z);
input signed [7:0] a, b, c;
output signed [7:0] z;

// Passes the parameters to the function
parameter width = 16;
parameter msb = 11;
parameter lsb = 4;

// add "$SYNOPSYS/dw/sim_ver" to the search path for simulation
'include "DW_dp_rndsat_function.inc"

assign z = DWF_dp_rndsat_tc (a * b, DW_dp_rnd_near_even) + c;
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