Signal processing algorithms sometimes involve computation of exponential. Thus it is important to implement the exponential function. In this work, design of digital hardware for exponential function is discussed. Like other elementary functions, exponential function is also computed using the iterative formulas. In this work, computation of the exponential function is shown for three cases.
- When
is positive.
- When
is negative.
- When
is positive or negative.
1. Computation of
when
is Positive
The computation of is governed by the following two equations.
(1) data:image/s3,"s3://crabby-images/0c4c5/0c4c569a9ce8f7661333deb77f8e539798e8448d" alt="Rendered by QuickLaTeX.com \begin{eqnarray*} x_{i+1} = x_i - ln(1 + s_i2^{-i})\\ y_{i+1} = y_i \times (1 + s_i2^{-i}) \end{eqnarray*}"
where varies from
to
which is the total number of iterations. Initially,
and
. A new parameter
is defined to find the values of
. It is computed as
.
(2) data:image/s3,"s3://crabby-images/40ea9/40ea9dc694f80096bace0d67a0eac6664b8b6738" alt="Rendered by QuickLaTeX.com \begin{equation*} s= \begin{cases} 1,& \text{if } D\geq 0\\ 0, & \text{otherwise} \end{cases} \end{equation*}"
When the equations (1) is modified as
(3) data:image/s3,"s3://crabby-images/5d613/5d613eb6601e26b1d3260efe30ef86d200316c67" alt="Rendered by QuickLaTeX.com \begin{eqnarray*} x_{i+1} = x_i - ln(1 + 2^{-i})\\ y_{i+1} = y_i \times (1 + 2^{-i}) \end{eqnarray*}"
and when the equation (1) becomes
(4) data:image/s3,"s3://crabby-images/1f0dc/1f0dcacad258669a02242f01a09edbdd77d5a8e4" alt="Rendered by QuickLaTeX.com \begin{eqnarray*} x_{i+1} = x_i \\ y_{i+1} = y_i \end{eqnarray*}"
After iterations the final values of
and
are
(5) data:image/s3,"s3://crabby-images/57c00/57c007c9111b3aaf29d934281f9a73a87f2ee404" alt="Rendered by QuickLaTeX.com \begin{eqnarray*} x_m = 0 \hspace{2pt} \\ y_m = y_0\times e^{x_0} \end{eqnarray*}"
In other way, the following equation is also true
(6) data:image/s3,"s3://crabby-images/acb33/acb334ebeca8fd9e4eab19fe80d54a436a16e277" alt="Rendered by QuickLaTeX.com \begin{equation*} \sum_{i=0}^{m-1}ln(1 + s_i2^{-i}) = x_0 \end{equation*}"
Implementation of Exponential Function for Positive Values
Based on the above equations, a serial architecture is developed in this work to compute when
is positive. The architecture is shown in Figure 1. The minimum data-width which is required in this architecture is 14 to support all the results. Out of 14-bits, 10-bits are used for fractional part. Total 11 iterations are required. The values of
for 10-bit precision is shown in Table 1. These values are stored in ROM and size of it is
. Initially a
signal loads
in a register and starts the counter. The delayed version of
signal chooses initial value ‘1’ for the multiplier and also chooses
as initial value to the subtracter. A Serial Input Serial Output (SISO) is used to generate the values of
. The symbol
in Figure 1 indicates concatenation operation. This operation take place like the following way
Where signal indicates iteration zero or first iteration. Computation of next data is started by clearing the final values of
and
. The new value of
is again stored in the register. At least 12 clock cycles are required in computation of one exponential function.
data:image/s3,"s3://crabby-images/68a5c/68a5ca65607e04b163f38aae4a695cea33735110" alt=""
data:image/s3,"s3://crabby-images/12d72/12d7205a8c4f0e03c591de22a75775d724d7318e" alt="Rendered by QuickLaTeX.com e^{x_0}"
data:image/s3,"s3://crabby-images/922de/922dec47d9bc85ed1c122a01b453991b2957bf93" alt="Rendered by QuickLaTeX.com x_0"
data:image/s3,"s3://crabby-images/f59bf/f59bf2012f72f218e96625988cf53bea85fc78f8" alt=""
2. Computation of
when
is Negative
The computation of when
is negative is done in the same way as it was computed in the previous section. The parameter
is computed as
.
(7) data:image/s3,"s3://crabby-images/023b0/023b0a81e26f2639c3a4aef281991378cf8de14d" alt="Rendered by QuickLaTeX.com \begin{equation*} s= \begin{cases} 1,& \text{if } D\leq 0\\ 0, & \text{otherwise} \end{cases} \end{equation*}"
When the equations (1) is modified as
(8) data:image/s3,"s3://crabby-images/f5041/f5041dda76aa2393d50f656378bf277718462cd4" alt="Rendered by QuickLaTeX.com \begin{eqnarray*} x_{i+1} = D\\ y_{i+1} = y_i \times (1 - 2^{-i}) \end{eqnarray*}"
The equation (1) when is same for both the cases. The final equations are also same.
The range of is is controlled by the following equation
(9) data:image/s3,"s3://crabby-images/94af5/94af57f0e5c2bc4a4b33f32b8072a6f860a1a4c0" alt="Rendered by QuickLaTeX.com \begin{equation*} \sum_{i=0}^{m-1}ln(1 - s_i2^{-i})\leq x_0 \leq \sum_{i=0}^{m-1}ln(1 + s_i2^{-i}) \end{equation*}"
thus the range of is
.
Implementation of Exponential Function for Negative Values
Architecture to compute when
is negative is very similar to the architecture discussed previously. The architecture is shown in Figure 2. Here ROM stores the values of
as shown in Table 1. The size of the ROM is 1-bit higher than the ROM which was previously used to store
. In place of subtracter, an adder is used here. The concatenation operation take place like the following way
In order to compute the exponential of next value of , the values of
and
must be cleared. The SISO is also needed to cleared.
data:image/s3,"s3://crabby-images/b08b0/b08b0196dc51cfdb155730df7fcd0543ae5c541d" alt=""
data:image/s3,"s3://crabby-images/12d72/12d7205a8c4f0e03c591de22a75775d724d7318e" alt="Rendered by QuickLaTeX.com e^{x_0}"
data:image/s3,"s3://crabby-images/922de/922dec47d9bc85ed1c122a01b453991b2957bf93" alt="Rendered by QuickLaTeX.com x_0"
3. Computation of
when
can be +ve or -ve
It is important to compute by a same hardware when
can be both positive or negative. Thus Figure 1 and Figure 2 is combined and a new architecture is developed which is shown in Figure 3. Two ROMs are used here. ROM 1 stores values of
and ROM 2 stores values of
. If
is negative then data is read from ROM 1. An adder/subtracter is used here which is controlled by invert of the MSB of
.
data:image/s3,"s3://crabby-images/c29af/c29afc25e90a2806e28f288bc23b594d0be9f43c" alt=""
data:image/s3,"s3://crabby-images/12d72/12d7205a8c4f0e03c591de22a75775d724d7318e" alt="Rendered by QuickLaTeX.com e^{x_0}"
data:image/s3,"s3://crabby-images/922de/922dec47d9bc85ed1c122a01b453991b2957bf93" alt="Rendered by QuickLaTeX.com x_0"
Conclusion
Computation of exponential function can be done by other methods also like CORDIC but this method is more accurate than the CORDIC based method. The range of exponential function can be increased by scaling of input data and by including a post scalar block.