



# DW\_log2

### Base-2 Logarithm

Version, STAR and Download Information: IP Directory

#### **Features and Benefits**

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



## **Description**

DW\_log2 computes the base-2 logarithm ( $log_2$ ) 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,1).

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.

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    | $log_2(a)$ in the range (0,1)  |  |

**Table 1-2** Parameter Description

| Parameter | Values               | Description                                                                                                                         |  |
|-----------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|
| op_width  | 2 to 60              | Word length of a and z.                                                                                                             |  |
| arch      | 0 to 2<br>Default: 2 | Implementation selection 0 - area optimized 1 - speed optimized 2- 2007.12 implementation                                           |  |
| err_range | 1 or 2<br>Default: 1 | Error range of the result compared to the infinitely precise result 1 - 1 ulp 2 - 2 ulps Note: error range is 1 ulp when $arch = 2$ |  |

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                             |
|-----------------------------|--------------------------------------|
| DW04.DW_LOG2_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw02/src/DW_log2_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_log2.v        | Verilog simulation model source code |

The truth table for the function implemented by this component when  $op\_width=4$ , arch=2 and  $err\_range=1$  is shown in Table 1-5. Notice that the MS bit of the input vector is expected to be 1, when it is not, the component output will deliver a meaningless value. Observe that the error is always less than the weight of the LS bit position of the output, in the example, less than  $2^{-4}$ .

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 boundary and get an implementation with slightly better QoR. The error does not exceed 2 ulps when  $err\_range = 2$ , and it does not exceed 1 ulp when  $err\_range = 1$ . The error of 1 ulp corresponds to  $2^{-op\_width+1}$ .

Table 1-5 Truth Table (op\_width=4, arch=2, err\_range=1)

| a(3:0) | a value (decimal) | z(3:0) | z value (decimal) | log <sub>2</sub> (a) (8 bits) |
|--------|-------------------|--------|-------------------|-------------------------------|
| 1.000  | 1.0               | .0000  | 0.0               | .00000000                     |
| 1.001  | 1.125             | .0011  | 0.188             | .00101011                     |
| 1.010  | 1.25              | .0101  | 0.313             | .01010010                     |
| 1.011  | 1.375             | .0111  | 0.438             | .01110101                     |
| 1.100  | 1.5               | .1001  | 0.567             | .10010101                     |
| 1.101  | 1.625             | .1011  | 0.688             | .10110011                     |
| 1.110  | .175              | .1101  | 0.813             | .11001110                     |
| 1.111  | 1.875             | .1111  | 0.938             | .11101000                     |

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

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

where n corresponds to the number of zeros in MS bit positions. The value  $y=2^n$  is obtained using a normalization unit (DW\_norm). The block diagram for the circuit that computes  $log_2(x)$  for x in the range (0,2) is shown in Figure 1. Notice that x in the Figure must be in the format x.xxxxxx (1 integer bit and f fractional bits).

Figure 1-1 Block diagram of circuit to compute  $log_2(x)$ , with x in the range (0,2)



Consider the case when x = 0.0110 = 3/8. Using the proposed transformations we get y = 1.100 and n = 2. The base-2 logarithm of y is given as 0.1001 and thus 0.1001-(10.000) = 10.1001 which corresponds to the value - 1.4375. The 8-bit value of  $log_2(3/8)$  (excluding the sign bit) is obtained by other means as 10.1001011 (in two's complement).

### Alternative Implementation of Base-2 Logarithm with DW\_lp\_multifunc

The base-2 logarithm operation can also be implemented by DW\_lp\_multifunc component (a member of the minPower Library, licensed separately), which evaluates the value of base-2 logarithm with 1 ulp error bound. There will be 1 ulp difference between the value from DW\_lp\_multifunc and the value from DW\_log2. Performance and area of the synthesis results are different between the DW\_log2 and base-2 logarithm implementation of the DW\_lp\_multifunc, depending on synthesis constraints, library cells and synthesis environments. By comparing performance and area between the base-2 logarithm implementation of DW\_lp\_multifunc and DW\_log2 component, the DW\_lp\_multifunc provides more choices for the better synthesis results. Below is an example of the Verilog description for the base-2 logarithm of the DW\_lp\_multifunc. A new wire, no needs to be declared to be used in this instantiation as the output of DW\_lp\_multifunc is wider. This wire can be left unconnected.

For more detailed information, see the  $DW_lp_multifunc$  datasheet.

```
wire [1:0] nc; // no connection
DW_lp_multifunc #(op_width, 32) U1 (
    .A({a, 1'b0}),
    .FUNC(16'h0020),
    .Z({nc, z}),
    .STATUS(STATUS)
);
```

# **Related Topics**

- Application Specific Data Integrity 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_log2_inst is
      generic (
            inst_op_width : INTEGER := 8;
            inst_arch : INTEGER := 2;
            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_log2_inst;
architecture inst of DW_log2_inst is
begin
    -- Instance of DW_log2
    U1 : DW log2
        generic map (
                op_width => inst_op_width,
                arch => inst arch,
                err_range => inst_err_range
        port map (
                a => inst_a,
                z => z_inst
                );
end inst;
-- pragma translate_off
configuration DW_log2_inst_cfg_inst of DW_log2_inst is
for inst
end for; -- inst
end DW_log2_inst_cfg_inst;
-- pragma translate_on
```

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