



# DW\_fp\_log2

## Floating-Point Base-2 Logarithm

Version, STAR, and myDesignWare Subscriptions: 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 60 bits
- A parameter controls the use of denormal values



## **Description**

This component computes the base-2 logarithm of a floating-point input a, delivering an output z 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 *ieee\_compliance* = 0, the operator takes NaN values as infinities, and denormals as zeros. When *ieee\_compliance* = 1, 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 the *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    | log <sub>2</sub> (a)                                                                                                                                                                            |
| status   | 8-bits                           | Output    | <ul> <li>Status flags for the result; for details, see STATUS         Flags in the Datapath Floating-Point Overview</li> <li>status[7]: Divide-by-zero flag for logarithm functions.</li> </ul> |

**Table 1-2** Parameter Description

| Parameter | Values       | Description                                                                           |
|-----------|--------------|---------------------------------------------------------------------------------------|
| sig_width | 2 to 59 bits | Word length of fraction field of floating-point numbers $\mathtt{a}$ and $\mathtt{z}$ |
| exp_width | 3 to 31 bits | Width of input and output data buses                                                  |

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                                 |  |
| extra_prec      | 0 to (59 - <i>sig_width</i> )<br>Default: 0 | Internal extra precision (in bits) used in the computation of the FP output                                      |  |
| arch            | 0 to 2<br>Default: 2                        | Implementation selection:  ■ 0 = Area optimized  ■ 1 = Speed optimized  ■ 2 = Implementation released in 2007.12 |  |

Table 1-3 Synthesis Implementations

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

Table 1-4 Simulation Model

| Model                          | Function                             |
|--------------------------------|--------------------------------------|
| DW04.DW_FP_LOG2_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw04/src/DW_fp_log2_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_fp_log2.v        | Verilog simulation model source code |

Differently from other FP components, DW\_fp\_log2 does not have rounding mode control, given the properties of algorithms used to compute the logarithms and the goal to deliver the best possible QoR.

The component is able to deliver outputs with a maximum of 2 ulps error for most of the FP range. The special case when the input is in the vicinity of 1.0, and therefore the output approaches 0.0, requires extra hardware just to deal with it. For this reason a new parameter (*extra\_prec*) was introduced.

When the *extra\_pre* parameter is 0, the implementation uses the minimum number of bits required to guarantee a maximum error of 2 ulps for most of the calculated values. When the input value is near 1.0, the output may exhibit larger relative errors.

By using non-zero values for *extra\_prec* the designer gets smaller errors when the input is near 1, but the error bound for other input values continues to be a maximum of 2 ulps. The designer should consider using values of *extra\_prec* in the range [0,*sig\_width*]. When *extra\_prec* = *sig\_width*, the error is bounded to a maximum of 2 ulps for all inputs. Values larger than *sig\_width* do not improve accuracy in any way.

The use of *extra\_prec* affects QoR and the designer must experiment with it to reach a good compromise between accuracy around the input value 1.0 and QoR.

The *arch* parameter controls implementation alternatives for this component. Different values result in different numerical behavior. 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 Logarithm with DW\_Ip\_fp\_multifunc

The floating-point base-2 logarithm operation can also be implemented by DW\_lp\_fp\_multifunc component, which evaluates the value of floating-point base-2 logarithm with a maximum of 2 ulps error bound. There will be a maximum of 2 ulps difference between the value from DW\_lp\_fp\_multifunc and the value from DW\_fp\_log2. Performance and area of the synthesis results are different between the DW\_fp\_log2 and base-2 logarithm 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 logarithm implementation of DW\_lp\_fp\_multifunc and DW\_fp\_log2 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 logarithm of the DW\_lp\_fp\_multifunc. For more detailed information, see the DW\_lp\_fp\_multifunc datasheet.

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

#### Simulation

In most cases, the simulation model for DW\_fp\_log2 delivers results that are bit-accurate with the synthesis model. Note the following details.

For Verilog simulations:

- When using VCS:
  - Results are bit-accurate with the synthesis model for all component configurations.
- When using simulators other than VCS:
  - $\Box$  If (sig width + extra prec + 1) <= 38, results are bit-accurate with the synthesis model
  - □ If (sig\_width + extra\_prec + 1) > 38, results are not bit-accurate with the synthesis model This scenario arises inside the DW\_log2 component, which is a submodule of DW\_fp\_log2. For information about the DW\_log2 component, see the datasheet.

For VHDL simulations:

- When (sig width + extra prec + 1) <= 38, results are bit-accurate with the synthesis model
- When (sig\_width + extra\_prec + 1) > 38, results are not bit-accurate with the synthesis model

This scenario arises inside the DW\_log2 component, which is a submodule of DW\_fp\_log2. For information about the DW\_log2 component, see the datasheet.

## **Related Topics**

- Datapath Floating-Point Overview
- DesignWare Building Block IP User Guide

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

```
library IEEE, DWARE;
use IEEE.std logic 1164.all;
use DWARE.dw foundation comp.all;
entity DW fp log2 inst is
      generic (
         inst sig width : POSITIVE := 23;
         inst exp width : POSITIVE := 8;
         inst ieee compliance : INTEGER := 0;
         inst extra prec : 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 log2 inst;
architecture inst of DW fp log2 inst is
begin
    -- Instance of DW fp log2
    U1 : DW fp log2
    generic map ( sig width => inst sig width,
                   exp width => inst exp width,
                   ieee compliance => inst ieee compliance,
                   extra prec => inst extra prec,
                   arch => inst arch)
    port map ( a => inst a, z => z inst, status => status inst );
end inst;
-- pragma translate off
configuration DW fp log2 inst cfg inst of DW fp log2 inst is
 for inst
 end for; -- inst
end DW fp log2 inst cfg inst;
-- pragma translate on
```

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

```
module DW_fp_log2_inst( inst_a, z_inst, status_inst );

parameter sig_width = 10;
parameter exp_width = 5;
parameter ieee_compliance = 0;
parameter extra_prec = 0;
parameter arch = 2;

input [sig_width+exp_width : 0] inst_a;
output [sig_width+exp_width : 0] z_inst;
output [7 : 0] status_inst;

// Instance of DW_fp_log2
DW_fp_log2 #(sig_width, exp_width, ieee_compliance, extra_prec, arch)
U1 ( .a(inst_a), .z(z_inst), .status(status_inst) );
```

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                                                                                                                                                                                                                                       |
|----------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| October 2022   | DWBB_202203.5 | ■ Clarified error bounding in ulps on page 2 and page 3                                                                                                                                                                                       |
| September 2022 | DWBB_202203.4 | <ul> <li>Added "Simulation" on page 3 to explain how results from the simulation<br/>model match the synthesis model</li> </ul>                                                                                                               |
| January 2020   | DWBB_201912.1 | <ul> <li>Corrected port names for DW_lp_fp_multifunc in "Alternative<br/>Implementation of Floating-point Base-2 Logarithm with<br/>DW_lp_fp_multifunc" on page 3</li> </ul>                                                                  |
| December 2019  | DWBB_201912.0 | ■ Adjusted the upper value bound of <i>extra_prec</i> in Table 1-2 on page 1                                                                                                                                                                  |
| July 2019      | DWBB_201903.3 | <ul> <li>Removed reference to minPower library in "Alternative Implementation of Floating-point Base-2 Logarithm with DW_lp_fp_multifunc" on page 3</li> <li>Added this Revision History table and the document links on this page</li> </ul> |

## **Copyright Notice and Proprietary Information**

© 2022 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.

### Free and Open-Source Software Licensing Notices

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

### **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. www.synopsys.com