



# DW\_fp\_exp2

# Floating-Point Base-2 Exponential (2<sup>a</sup>)

Version, STAR and Download Information: IP Directory

#### **Features and Benefits**

### **Revision History**

- The precision is controlled by parameters, and covers formats in the IEEE Standard 754
- Exponents can range from 3 to 31 bits
- Fractional part of the floating-point number can range from 2 to 58 bits
- A parameter controls the use of denormal values.



#### **Description**

The DW\_fp\_exp2 component computes the Base-2 exponential of a floating-point input a, delivering an output  $z=2^a$  that is also a floating-point value.

The parameter ieee\_compliance controls the use of denormals and NaNs, as done for other FP operators in this library. When <code>ieee\_compliance = 0</code>, the operator takes NaN values as infinities, and denormals as zeros. When <code>ieee\_compliance = 1</code>, the component accepts and generates denormalized values, handles NaN inputs, and delivers NaN outputs when appropriate. Independently of the value of this parameter, the floating-point format can be adjusted to match one of the formats defined in the IEEE Standard 754.

The output status is an 8-bit value that carries the status flags for the FP operation, as described in *Datapath Floating-Point Overview*.

Table 1-1 Pin Description

| Pin Name | Width                          | Direction | Function                                                 |
|----------|--------------------------------|-----------|----------------------------------------------------------|
| а        | sig_width + exp_width + 1 bits | Input     | Input data                                               |
| z        | sig_width + exp_width + 1 bits | Output    | Base-2 exponential = 2 <sup>a</sup>                      |
| status   | 8 bits                         | Output    | See STATUS Flags in the Datapath Floating-Point Overview |

**Table 1-2** Parameter Description

| Parameter | Values               | Description                                                           |
|-----------|----------------------|-----------------------------------------------------------------------|
| sig_width | 2 to 58 <sup>a</sup> | Word length of fraction field of floating-point numbers a and $z$ .   |
| exp_width | 3 to 31              | Word length of biased exponent of floating-point numbers a and $ z. $ |

Table 1-2 Parameter Description (Continued)

| Parameter       | Values               | Description                                                                                         |
|-----------------|----------------------|-----------------------------------------------------------------------------------------------------|
| ieee_compliance | 0 or 1               | When 1, the generated architecture is capable of dealing with denormals and NaNs.                   |
| arch            | 0 to 2<br>Default: 2 | Implementation selection 0: Area optimized 1: Speed optimized 2: Implementation released in 2007.12 |

a. The synthesis model fully supports this range, as does the Verilog simulation model in VCS, but the VHDL simulation model (in all simulators) and the Verilog simulation model in non-VCS simulators are limited to a range of 2 - 36.

Table 1-3 Synthesis Implementations

| Implementation Name | Function                                                                                     | License Feature Required |
|---------------------|----------------------------------------------------------------------------------------------|--------------------------|
| rtl                 | Implement using the Datapath Generator technology combined with static DesignWare components | DesignWare               |

Table 1-4 Simulation Model

| Model                          | Function                             |
|--------------------------------|--------------------------------------|
| DW02.DW_FP_EXP2_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw02/src/DW_fp_exp2_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_fp_exp2.v        | Verilog simulation model source code |

Given the properties of algorithms to compute the exponential function, and the goal to have a component with good QoR, this component does not have rounding mode control as other FP components in the library. The output is bounded to have 1ulp error.

The *arch* parameter controls implementation alternatives for this component. Different values result in different numerical behavior, but the error on the computed values is always bounded by 1 ulp. You should experiment with this parameter to find out which value provides the best QoR for your design constraints and technology. Using arch = 0 (area optimized implementation) usually provides the best QoR for most time constraints.

### Alternative Implementation of Floating-point Base-2 Exponential with DW\_lp\_fp\_multifunc

The floating-point base-2 exponential operation can also be implemented by DW\_lp\_fp\_multifunc component (a member of the minPower Library, licensed separately), which evaluates the value of floating-point base-2 exponential with 1 ulp error bound. There will be 1 ulp difference between the value from DW\_lp\_fp\_multifunc and the value from DW\_fp\_exp2. Performance and area of the synthesis results are different between the DW\_fp\_exp2 and base-2 exponential implementation of the DW\_lp\_fp\_multifunc, depending on synthesis constraints, library cells and synthesis environments. By comparing performance

and area between the base-2 exponential implementation of DW\_lp\_fp\_multifunc and DW\_fp\_exp2 component, the DW\_lp\_fp\_multifunc provides more choices for the better synthesis results.

Below is an example of the Verilog description for the floating-point base-2 exponential of the DW\_lp\_fp\_multifunc. For more detailed information, see the DW\_lp\_fp\_multifunc datasheet.

```
DW_lp_fp_multifunc #(sig_width, exp_width, ieee_compliance, 64) U1 (
    .A(A),
    .FUNC(16'h0040),
    .RND(3'h0),
    .Z(Z),
    .STATUS(STATUS)
);
```

For more information on the floating-point system defined for all the floating-point components in the DesignWare Library, including status bits and floating-point formats, refer to the *Datapath Floating-Point Overview*.

#### **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.DW_Foundation_comp_arith.all;
entity DW_fp_exp2_inst is
     generic (
        inst_sig_width : POSITIVE := 10;
        inst_exp_width : POSITIVE := 5;
        inst_ieee_compliance : INTEGER := 0;
        inst arch : INTEGER := 2
        );
     port (
        inst_a : in std_logic_vector(inst_sig_width+inst_exp_width downto 0);
       z_inst : out std_logic_vector(inst_sig_width+inst_exp_width downto 0);
        status_inst : out std_logic_vector(7 downto 0)
   end DW_fp_exp2_inst;
architecture inst of DW_fp_exp2_inst is
begin
    -- Instance of DW_fp_exp2
    U1: DW fp exp2
        generic map (
                sig_width => inst_sig_width,
                exp_width => inst_exp_width,
                ieee_compliance => inst_ieee_compliance,
                arch => inst arch
        port map (
                a => inst a,
                z \Rightarrow z_{inst}
                status => status_inst
                );
end inst;
-- pragma translate_off
configuration DW_fp_exp2_inst_cfg_inst of DW_fp_exp2_inst is
 for inst
 end for; -- inst
end DW_fp_exp2_inst_cfg_inst;
-- pragma translate_on
```

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

endmodule

### **Revision History**

For notes about this release, see the *DesignWare Building Block IP Release Notes*.

For lists of both known and fixed issues for this component, refer to the STAR report.

For a version of this datasheet with visible change bars, click here.

| Date      | Release       | Updates                                                                                                                                                                                         |
|-----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| July 2018 | O-2018.06-SP1 | ■ For STAR 9001366624, in Table 1-2 on page 1, clarified the range of<br>sig_width for the VHDL simulation model (in all simulators) and the Verilog<br>simulation model for non-VCS simulators |
|           |               | ■ Added this Revision History table and the document links on this page                                                                                                                         |

#### **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