Abstract:
Convolution and deconvolution place an important role in order to know more information about particular signals and determination of required data about unknown signals, hence necessitate in many DSP applications. In convolution and deconvolution multiplication and division are important elements. Traditional multiplication and division methods reduce the performance of the convolution and deconvolution. There by this paper proposes the advance Vedic methods for multiplication and division like Urdhwa Tiryakbyam Sutra and division by this fast and accuracy operation can be achieved. The coding is done by using Verilog HDL, simulated using Model-sim and synthesized using XILINX.

I. INTRODUCTION
Convolution provides the mathematical framework for DSP. It is the single most important technique in Digital Signal Processing. Convolution is a mathematical way of combining two signals to form a third signal. Using the strategy of impulse decomposition, systems are described by a signal called the impulse response. In signal processing, the impulse response, or impulse response function (IRF), of a dynamic system is its output when presented with a brief input signal, called an impulse.

More generally, an impulse response refers to the reaction of any dynamic system in response to some external change. It has applications that include statistics, computer vision, image and signal processing, electrical engineering, and differential equations.

One of the most important concepts in Fourier theory, and in crystallography, is that of a convolution. Convolutions arise in many guises, as will be shown below. Because of a mathematical property of the Fourier transform, referred to as the convolution theorem, it is convenient to carry out calculations involving convolutions.

The convolution of f and g is written f ∗ g, using an asterisk or star. It is defined as the integral of the product of the two functions after one is reversed and shifted. As such, it is a particular kind of integral transform:

\[ (f \ast g)(t) \overset{\text{def}}{=} \int_{-\infty}^{\infty} f(\tau) g(t - \tau) d\tau \]

While the symbol t is used above, it need not represent the time domain. But in that context, the convolution formula can be described as a weighted average of the function f(\tau) at the moment t where the weighting is given by g(−\tau) simply shifted by amount t. As t changes, the weighting function emphasizes different parts of the input function.

More generally, if f and g are complex-valued functions on \( \mathbb{R}^d \), then their convolution may be defined as the integral:

\[ (f \ast g)(x) = \int_{\mathbb{R}^d} f(y) g(x - y) dy = \int_{\mathbb{R}^d} f(x - y) g(y) dy. \]

There are two types of convolution. They are:

- Linear convolution
- Circular convolution

Linear convolution
Convolution is an integral concatenation of two signals. It has many applications in numerous areas of
signal processing. The convolution described above is nothing but linear convolution. The most popular application is the determination of the output signal of a linear time-invariant system by convolving the input signal with the impulse response of the system. Convolving two signals is equivalent to multiplying the Fourier transform of the two signals.

The linear convolution of two continuous time signals \( x(t) \) and \( h(t) \) is defined by

\[
y(t) = x(t) * h(t) = \int_{-\infty}^{\infty} x(\tau) h(t - \tau) \, d\tau
\]

For discrete time signals \( x(n) \) and \( h(n) \), the integration is replaced by a summation

\[
y(n) = x(n) * h(n) = \sum_{k=-\infty}^{\infty} x(k) h(n-k)
\]

II. PROPOSED CONVOLUTION DESIGN

Our proposed design consists multiplexer, SIPO (Serial input parallel output), binary multiplier, Output multiplexer and register.

The block diagram of the proposed architecture is shown in fig.1.

![Fig.1: Proposed convolution design](image)

Input multiplier is places at the input side in order to provide the synchronization between the both inputs and based on the user requirement the input can be sent at the any point of time (not exactly same order). In order to provide parallel data for the parallel multiplier we introduce the SIPO as the element in-between the MUX and the binary multiplier. In order to provide the output for the serial components register placed as final element.

The multiplier is important element for the calculation of the convolution output. In traditional convolution the multiplication it multiplies the all products even if the products sums are zero. Unlike the traditional convolution designs our proposed method designed in such a way that unwanted multiplications can be avoided hence causes the less power and the less area utilization.

Proposed multiplier design

Vedic Mathematics refers to the technique of Calculations based on a set of 16 Sutras, or aphorisms, as algorithms and their upa-sutras or corollaries derived from these Sutras. Any mathematical problems (algebra, arithmetic, geometry or trigonometry) can be solved mentally with these sutras. Vedic Mathematics is more coherent than modern mathematics.

Multiplier implementation using FPGA has already been reported using different multiplier architectures but the performance of multiplier was improved in proposed design.

![Fig.2: step by step method of multiplying two 8 bit numbers using the Urdhwa Tiryakbyam Sutra](image)
Let us consider two 8 bit numbers X7-X0 and Y7-Y0, where 0 to 7 represent bits from the Least Significant Bit (LSB) to the Most Significant Bit (MSB).

\[ P_0 = A_0 \times B_0 \] (1)

\[ C_{1P1} = (A_1 \times B_0) + (A_0 \times B_1) \] (2)

\[ C_{3C2P2} = (A_2 \times B_0) + (A_0 \times B_2) + (A_1 \times B_1) + C_1 \] (3)

\[ C_{5C4P3} = (A_3 \times B_0) + (A_2 \times B_1) + (A_1 \times B_2) + C_2 \] (4)

\[ C_{7C6P4} = (A_4 \times B_0) + (A_3 \times B_1) + (A_2 \times B_2) + (A_1 \times B_3) + (A_0 \times B_4) + C_3 + C_4 \] (5)

\[ C_{10C9C8P5} = (A_5 \times B_0) + (A_4 \times B_1) + (A_3 \times B_2) + (A_2 \times B_3) + (A_1 \times B_4) + (A_0 \times B_5) + C_5 + C_6 \] (6)

\[ C_{13C12C11P6} = (A_6 \times B_0) + (A_5 \times B_1) + (A_4 \times B_2) + (A_3 \times B_3) + (A_2 \times B_4) + (A_1 \times B_5) + (A_0 \times B_6) + C_7 + C_8 \] (7)

\[ C_{16C15C14P7} = (A_7 \times B_0) + (A_6 \times B_1) + (A_5 \times B_2) + (A_4 \times B_3) + (A_3 \times B_4) + (A_2 \times B_5) + (A_1 \times B_6) + (A_0 \times B_7) + C_9 + C_{11} \] (8)

\[ C_{19C18C17P8} = (A_7 \times B_1) + (A_6 \times B_2) + (A_5 \times B_3) + (A_4 \times B_4) + (A_3 \times B_5) + (A_2 \times B_6) + (A_1 \times B_7) + C_{10} + C_{12} + C_{14} \] (9)

\[ C_{22C21C20P9} = (A_7 \times B_2) + (A_6 \times B_3) + (A_5 \times B_4) + (A_4 \times B_5) + (A_3 \times B_6) + (A_2 \times B_7) + C_{13} + C_{15} + C_{17} \] (10)

\[ C_{25C24C23P10} = (A_7 \times B_3) + (A_6 \times B_4) + (A_5 \times B_5) + (A_4 \times B_6) + (A_3 \times B_7) + C_{16} + C_{18} + C_{20} \] (11)

\[ C_{27C26P11} = (A_7 \times B_4) + (A_6 \times B_5) + (A_5 \times B_6) + (A_4 \times B_7) + C_{19} + C_{21} + C_{23} \] (12)

\[ C_{29C28P12} = (A_7 \times B_5) + (A_5 \times B_6) + (A_5 \times B_7) + C_{22} + C_{24} + C_{26} \] (13)

\[ C_{30P13} = (A_7 \times B_6) + (A_6 \times B_7) + C_{25} + C_{27} + C_{28} \] (14)

\[ P_{14} = (A_7 \times B_7) + C_{29} + C_{30} \] (15)

\[ P_{15} = (A_7 \times B_7) \] (16)

III. DECONVOLUTION

Straight method of deconvolution of two finite length discrete-time sequences proposed. Computing of the deconvolution is almost like the traditional long-hand division and polynomial division. Many methods were designed for the calculation of the deconvolution but in our designed an alkalic recursive deconvolution method used for finite length sequences is calculated. The long division recursion method can be accomplished in below manner.

Fig.3: proposed Deconvolution method

For implementation of division operation vedic mathematic Nikhilam algorithm can be used moreover vedic multiplication based partial products design adopted for the multiplication. For instance, the first example in subsection A may be retrot, solving for \( f(n) \) given \( g(n) \) and \( y(n) \). The sequences are set up in a standardized long division fashion, as shown in Fig.3, but where no carries are executed out of a column [11]. In our proposed algorithm the operation involves normal addition as the part of the operation procedure and the stepwise subtraction which is much different
from the traditional methods, to fulfill overall design of the long grain deconvolution proposed multiplication can be utilized.

IV RESULTS AND DISCUSSION

The fig shows the vedic multiplier based convolution result. By this the partial products can be reduced and as well as the operation time also will be reduced.

Different inputs applied to the convolution and the outputs of convolution applied to the deconvolution, hence the applied inputs at convolution reproduced at the deconvolution output. Not only for the simulation has it given the better results even for the synthesis. Algorithm coding written in verilog, simulated by Model-sim and synthesized using XILINX.

CONCLUSION

Convolution and deconvolution algorithms designed by using the advanced methods. This will be suited for the many applications even if the serial and parallel processing circuits. In our design we used the advance multiplication and division methods. Vedic methods are the well suited and it meets the all basic requirements like area, power and speed.

REFERENCES


