



# DW In

#### Natural Logarithm: In(a)

Version, STAR, and myDesignWare Subscriptions: IP Directory

#### **Features and Benefits**

### **Revision History**

- Parameterized word width
- Supports up to 60 bits of precision



## **Description**

DW\_ln computes the natural logarithm (ln) of an input a in fixed-point format. The input must be in the range [1,2) (normalized input) and therefore the output is in the range [0, ln(2)).

The number of bits used as input and output is defined by a parameter (*op\_width*). The input has 1 integer bit and *op\_width-1* fractional bits. The output has *op\_width* fractional bits.

The component implements the logarithm function using different algorithms depending on the number of input bits. The selection of the algorithm is done automatically to deliver the best QoR. The user can control the type of architecture to be implemented by using the parameter *arch*, as shown in Table 1-2. This parameter is effective only for values of *op\_width* in the range [19,39].

Table 1-1 Pin Description

| Pin Name | Width         | Direction | Function                      |
|----------|---------------|-----------|-------------------------------|
| а        | op_width bits | Input     | Input data in the range [1,2) |
| z        | op_width bits | Output    | In(a) in the range [0,In(2))  |

Table 1-2 Parameter Description

| Parameter | Values               | Description                                                           |  |
|-----------|----------------------|-----------------------------------------------------------------------|--|
| op_width  | 2 to 60 bits         | Word length of a and z                                                |  |
| arch      | 0 or 1<br>Default: 0 | Implementation selection  ■ 0 = Area optimized  ■ 1 = Speed optimized |  |

Table 1-2 Parameter Description (Continued)

| Parameter | Values               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|-----------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| err_range | 1 or 2<br>Default: 1 | <ul> <li>Error range of the result compared to the infinitely precise result</li> <li>1: <ul> <li>Maximum error is 1 ulp for op_width &lt; 56</li> <li>Maximum error is 2 ulps for op_width = 56 or 57</li> <li>Maximum error is 4 ulps for op_width = 58</li> <li>Maximum error is 7 ulps for op_width = 59</li> <li>Maximum error is 12 ulps for op_width = 60</li> </ul> </li> <li>■ 2: <ul> <li>Maximum error is 2 ulps for op_width &lt; 58</li> <li>Maximum error is 4 ulps for op_width = 58</li> <li>Maximum error is 7 ulps for op_width = 59</li> <li>Maximum error is 12 ulps for op_width = 60</li> </ul> </li> </ul> |  |

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_LN_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw02/src/DW_ln_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_ln.v        | Verilog simulation model source code |

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

Another parameter, *err\_range*, can be used to relax the error boundaries and get an implementation with slightly better QoR. The error of 1 ulp corresponds to 2<sup>(-op\_width)</sup>. For details about *err\_range*, see Table 1-2 on page 1.

Table 1-5 shows valid values for the function implemented by this component when  $op\_width = 4$  and  $err\_range = 1$  (it may not correspond to the actual component output). Since the infinite precision value of ln(a) is usually in between two finite precision results with  $op\_width$  fractional bits, there are usually two valid outputs for any value of the input when  $err\_range = 1$  (does not apply for a = 1). When  $err\_range = 2$ , the number of valid alternatives for the output increases to four. Also, notice that the MS bit of the input vector is expected to be 1, when it is not, the component output carries a meaningless value. The error is

always less than the weight of the LS bit position of the output, in the example, less than  $2^{-4}$ , which corresponds to 1 ulp when  $op\_width = 4$ .

Table 1-5 Valid Values of In(a) (op\_width = 4, err\_range=1)<sup>a</sup>

| a(3:0) | value of 'a' (decimal) | In(a) | z(3:0)         | value of 'z' (decimal) | In(a) (8 bits) |
|--------|------------------------|-------|----------------|------------------------|----------------|
| 1.000  | 1.0                    | 0.0   | .0000          | 0.0                    | .00000000      |
| 1.001  | 1.125                  | 0.118 | .0001 or .0010 | 0.063 or 1.125         | .00011110      |
| 1.010  | 1.25                   | 0.223 | .0011 or .0100 | 0.118 or 0.25          | .00111000      |
| 1.011  | 1.375                  | 0.318 | .0101 or .0110 | 0.313 or 0.375         | .01010001      |
| 1.100  | 1.5                    | 0.405 | .0110 or .0111 | 0.375 or 0.438         | .01100111      |
| 1.101  | 1.625                  | 0.486 | .0111 or .1000 | 0.438 or 0.5           | .01111100      |
| 1.110  | 1.75                   | 0.560 | .1000 or .1001 | 0.5 or 0.563           | .10001111      |
| 1.111  | 1.875                  | 0.629 | .1010 or .1011 | 0.625 or 0.688         | .10100000      |

a. The values shown in the table may not correspond to the actual outputs generated by DW\_In, which may use another valid value within the error bounds defined for the implementation.

The computation of the logarithm for other ranges of the input operand can be accomplished using mathematical transformations. For example, to compute the  $\ln$  of a value x in the range (0,2) the designer may use the following identity:

$$\ln(x) = \ln\left|\frac{x2^n}{2^n}\right| = \ln\left|\frac{y}{2^n}\right| = \ln(y) - n\ln(2)$$

where n corresponds to the number of zeros in MS bit positions. The value  $y = x2^n$  may be obtained using a normalization unit (DW\_norm).

## **Related Topics**

- Application Specific Data Integrity Overview
- DesignWare Building Block IP User Guide

## **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 ln inst is
      generic (
        inst_op_width : INTEGER := 8;
            inst arch : INTEGER := 0;
            inst_err_range : INTEGER := 1
        );
      port (
        inst_a : in std_logic_vector(inst_op_width-1 downto 0);
        z_inst : out std_logic_vector(inst_op_width-1 downto 0)
        );
    end DW_ln_inst;
architecture inst of DW ln inst is
begin
    -- Instance of DW ln
    U1 : DW ln
    generic map (
          op width => inst op width,
                arch => inst arch,
                err range => inst err range
          )
    port map (
          a => inst a,
          z \Rightarrow z inst
          );
end inst;
-- pragma translate off
configuration DW ln inst cfg inst of DW ln inst is
for inst
end for; -- inst
end DW ln inst cfq 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 2023 | DWBB_202212.5 | ■ Clarified the settings for <i>error_range</i> in Table 1-2 on page 1                                                 |  |
|           |               | <ul> <li>Corrected the weight of the LS bit position of the output cited just above<br/>Table 1-5 on page 3</li> </ul> |  |
|           |               | ■ Added this Revision History table and the document links on this page                                                |  |

#### **Copyright Notice and Proprietary Information**

© 2023 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