## **Scholars Journal of Engineering and Technology**

Abbreviated Key Title: Sch J Eng Tech ISSN 2347-9523 (Print) | ISSN 2321-435X (Online) Journal homepage: <u>https://saspublishers.com</u>

# **FPGA Implementation of Efficient CDF-9/7 Discrete Wavelet Transform**

Roopa K.  $C^{1*}$ , Chetan S<sup>2</sup>

<sup>1</sup>M. Tech Student, Department of Electronics and Communication, Dr. Ambedkar Institute of Technology, Bengaluru-560056, Karnataka, India
<sup>2</sup>Assistant Professor Department of Electronics and Communication, Dr. Ambedkar Institute of Technology, Bengaluru-560056,

Karnataka, India

DOI: 10.36347/sjet.2023.v11i10.001

| Received: 22.08.2023 | Accepted: 30.09.2023 | Published: 03.10.2023

#### \*Corresponding author: Roopa K. C

M. Tech Student, Department of Electronics and Communication, Dr. Ambedkar Institute of Technology, Bengaluru-560056, Karnataka, India

| Abstract | Original Research Article |
|----------|---------------------------|
|          |                           |

Architecture CDF-5/3 DWT is utilized to derive CDF-9/7 DWT. Because of the prevalence of fractional parts in the generic CDF 9/7 architecture and the occurrence of truncation errors, the design is difficult to execute. Since the CDF-5/3 DWT filter allows for the employment of merely a shifter, attempted to design the CDF-9/7 DWT filter in this manner so that the truncation error is as little as possible, if not eliminated.

Keywords: CDF-5/3 DWT, CDF 9/7, Truncation error, Employment of merely

Copyright © 2023 The Author(s): This is an open-access article distributed under the terms of the Creative Commons Attribution 4.0 International License (CC BY-NC 4.0) which permits unrestricted use, distribution, and reproduction in any medium for non-commercial use provided the original author and source are credited.

## **1. INTRODUCTION**

Almost every modern technology relies on methods of digital signal processing. Any application using digital signal processing relies on accurate analysis of the input signal's stated properties. Once natural signals are sampled and held in digital form, they exist only in the temporal domain. However, several computational challenges make it difficult to extract most of the properties from time domain data. Domain approaches such as frequency domain, z-domain, and sdomain have been developed to address this issue. Frequency domain processing makes detection and processing simpler since it uses most of the available processing domains. Because of this, it is the most often used DSP application domain.

Several methods exist for transitioning from the time domain to the frequency domain. DFT, DWT, DCT, etc., are some of the most commonly used methods. The Discrete Wavelet Transform (DWT) is a famous domain transform method with many benefits over competitors.

The primary drawbacks of DWT are the need for a sizable multiplier and a massive quantity of storage to keep track of the values for each twiddle factor. The multiplier and memory components scale with the DWT's number of points. This meant the building needed plenty of room yet could run at a snail's pace. The discrete wavelet transform, a novel method developed to solve these issues, is also utilized for picture compression and feature extraction.

#### 2. Needed computer systems and applications

Hardware and software are chosen for the project. Spartan 6 FPGA (ATLYS) hardware from Xilinx. It is common practice to use Xilinx ISE 14.5 and the MATLAB system generator to write HDL and VHDL code, respectively.

#### 2.1. Xilinx Spartan-6 FPGA

The Xilinx Spartan-6 FPGA Project Board is a digital system development board with a Spartan-6 FPGA, 4MB of external non-volatile memory, and sufficient I/O devices and external connectors to interface a range of digital applications.

Due to their ability to begin system software development concurrently with hardware, enable system performance simulations at a very early stage of the development, and permit various system trials and design iterations before finalizing the system architecture, FPGAs have a remarkable role in embedded system development.

#### 2.2. Xilinx ISE 14.5

A software program used for circuit design and synthesis is called Xilinx ISE. Following the simulation of the RTL code, RTL diagrams are produced. The synthesis, design, and timing analysis of circuits are some of the key functions of Xilinx ISE. Spartan 6 is supported by the ISE design suite. Both Linux and Windows 10 support the ISE design suite. It is used in

Citation: Roopa, K. C & Chetan S. FPGA Implementation of Efficient CDF-9/7 Discrete Wavelet Transform. Sch J Eng Tech, 2023 Oct 11(10): 225-238.

this project to write the code for a highly detailed language.

#### 2.3. System Generation using MATLAB

MATLAB, short for "Mathematical Arrays and Matrix Laboratory," is a suite of programming languages and a desktop environment for doing iterative design and analysis. The MATLAB add-ons have been meticulously crafted, thoroughly examined, and meticulously documented. As will be shown, toolkits are essential for the implementation of the proposed specific solutions. MATLAB's features include ICC color management, multidimensional image processing, the presentation of pictures and videos through the sequential application of DCT and FFT transforms, and the processing and display of images of larger sizes to predict histogram and entropy Roopa K. C & Chetan S, Sch J Eng Tech, Oct, 2023; 11(10): 225-238 values. MATLAB-created software is mostly utilized for testing purposes.

#### 2.4. Architectures

Most of the new FPGA architectures consist of configurable logic blocks (CLBs)/logic array blocks (LABs), I/O pads and configurable routing logics. The I/O pads are mainly used to connect input/output to/form the FPGA chip. The I/O pads consist of some buffer cells for good voltage level and minimize fan-in/fan-out problem.

The programmable routing logic is one of the most complicated designs in whole FPGA. The interconnect lines inside the FPGA is made in such way that any line can works as both input/output/in out line. To make that different techniques are used. One such technique is shown in Fig 1.



Fig 1: (a) Basic FPGA block

Comprehensive FPGA design is presented.





#### 2.5 Design and Implementation

The flowchart illustrates the process by which an FPGA is developed and put into operation. Fig 2 *FPGA* flow Chart.



Fig 2: FPGA flow Chart

#### Roopa K. C & Chetan S, Sch J Eng Tech, Oct, 2023; 11(10): 225-238

## 2.6 Basic Structure of XILNX FPGA XILINX FPGA's fundamental internal

architecture is seen in Fig.3 below. The logic blocks, I/O

ports, and the interface of this FPGA are all configurable. The programmable is created by putting the whole setup into RAM.



Fig 3: FPGA Fundamentals Using XILINX

#### 2.7 Xilinx ATLYS FPGA

ATLYS FPGA board is a Xilinx Spartan-6 FPGA (xc6slx45-2csg324). Fig 4 is a schematic representation of the functionality of this board. This is

the bare minimum needed for any DSP-based program. This board is ideal for DSP implementations since it has all the necessary internal peripherals.



Fig 4: ATLYS FPGA Functional Block Diagram

#### 2.8 Generator System Fundamentals

Xilinx's system generator is a tool that lets you use the Simulink IDE for FPGA layout. In the Simulink modeling system, designs are stored as blocks. Human interaction is required at any stage of the FPGA implementation process. Registers, multipliers, and adders are just a few of the more than eighty DSP building blocks provided by Xilinx in their DSP block set for Simulink. It also provides:

- A unified platform for FPGA design.
- Facilitating the integration of RTL, Simulink.
- The associated simulation and application environments.

The system generator maintains a black box that allows RTL to be imported into Simulink and cosimulated using modelsim, Xilinx, or ISE. Fig 5: shows the flow System generator flow design.



Fig 5: System generator flow design

#### 3. METHODOLOGY 3.1 1D-DWT

At the next-to-lowest resolution level, the 1D-DWT iteratively decomposes the input signal So(n) in approximation and detail. The approximate signal at level n is denoted by Si (n), whereas the exact signal at level n is denoted by Wi (n). The approximate and finetune the signal at the 'i+1' level using these values.  $si + 1(n) = \Sigma(k = 0)^{(L-1)g(k)si}(2n - k)$ wi + 1(n) =  $\Sigma(k = 0)^{(L-1)h(k)si}(2n - k)$ 

The low pass and high pass filter coefficients, g(K) and h(K), and the filter length, L, are defined as follows. Fig 6 below depicts the three-level 1D DWT.



Fig 6: Three 1D-DWT Levels

#### 3.2. 2D-DWT

In many fields, including image compression, computer vision, and multi-resolution analysis, use the 2D-DWT. Separately and non-separable 2D filters are used here. Separatability is defined as the ability to write a 2D filter f(n1, n2) as f(n1, n2) = f1(n1). Whereas f1(n1) and f2(n2) are 1D filters, f2(n2) is a 2D filter. Separate 2D discrete wavelet transforms may break down an approximation picture Si(n1, n2) into the original image and three details.

$$\begin{split} & \text{Si+1(n1, n2)} = \sum_{k=0}^{\infty} (K1=0) \land (L-1) \sum_{k=0}^{\infty} (K2=0) \land (L-1)[g(K1)] g(K2) \text{ Si}(2n1-K1, 2n2-K2) \\ & \text{W1i+1 (n1, n2)} = \sum_{k=0}^{\infty} (K1=0) \land (L-1) \sum_{k=0}^{\infty} (K2=0) \land (L-1) [g(K1)] h(K2) \text{ Si}(2n1-K1, 2n2-K2) \end{split}$$

1D wavelet filters G(Z) and H(Z) are available. Si+1(n1, n2), with its lesser resolution, is close to Si (n1, n2). This estimate is derived from Si (n1, n2) by low pass filtering and decimation by '2' along the row and column. The one level 2D DWT is shown in the Fig 7 below.



Fig 7: 2D-DWT

#### 3.3 Hardware implementation of controller structure:

| 0 128 256   | 32640 |
|-------------|-------|
| 1 129 257   | 32641 |
| 2 130 258   | 32642 |
| 3 131 259   | 32643 |
|             |       |
|             |       |
|             | ·     |
|             |       |
| 124 252 380 | 32764 |
| 125 253 381 | 32765 |
| 126 254 382 | 32766 |
| 127 255 383 | 32767 |

RAM only has enough for one dimension of data storage. The numbers in the above graph stand for RAM addresses. The column address is used while storing data in RAM. However, an address is now

required whenever data is read from memory. The Fig 8 below depicts the three linked counters required to produce such addresses.

© 2023 Scholars Journal of Engineering and Technology | Published by SAS Publishers, India



Fig 8: Controller Architecture Realized in Hardware

#### **Counter 1:**

Using "clk\_ div" as clock 1, it counts up to 32367; at 32768, the wr \_ address is frozen. To clarify, rd = wr = '1' under the current circumstances. As long as rd wr = '0' before the counter reaches 32768.

#### **Counter 2:**

The primary "clk" signal. This block's "rst" terminal connects to counter 1's "rd\_wr" terminal. When  $rd_wr = 1$ , just this counter activates. Otherwise, off. So just this block activates when counter 1 hits 32768. Equation used:

$$y = y + '1'$$
; [initial  $y = '0'$ ]

If spike is 0, then y will continue at the same rate as before. The above 'x' equation should be carried out.

#### Counter 3:

This uses primary "clk" and "rd\_wr" as "rst" like counter 2. It outputs "spike" and "y". It utilizes equation:

a:=a + '1'

when a = 128 make a = 0 & y = y + '1'else y = previous y and run first 'a' equation.

#### 3.4 The 2D-DWT Hardware Architecture

The Fig 9 the Hardware Structure of 2D-DW below depicts the fundamental hardware configuration of 2D-DWT. 1D-DWT, memory, a controller, mux and demux nodes round up the whole architecture. In the beginning, each signal is a 0. The '0' on the "Select" line causes the 0th terminal to be selected by the mux or demux. When this flag is set to 1, the first 1D-DWT block will become active and begin processing the picture data in serial form. Because of the de-mux setting, both the LP and HP data enter the memory block simultaneously at the clock signal specified by the 1st 1D-DWT block, which is simply clk/2. At that moment, the memory was in a writeable state (rd wr = 0). The rd wr, rd addr, and wr address are supplied by the controller block. When the address in the write-protected region of memory (wr\_addr) exceeds "32768," the controller switches the memory to reading mode (rd\_wr = "1"). In the meanwhile, controller will produce rd\_address. This block is only activated when rd wr = '1', and its "LP" coefficients are listed in the second 2D-DWT, whose "rst" is wired to the rd wr line. Meanwhile, the "HP" block's information is being sent via the second Mux terminal. The de-mux's choose line is also wired to the rd\_wr line. That's how the acquire of HL, HH, LH, LL pieces.After processing one picture frame (256 by 256 pixels), a separate counter is utilized to reset the whole block.

Roopa K. C & Chetan S, Sch J Eng Tech, Oct, 2023; 11(10): 225-238



Fig 9: The 2D-DWT Hardware Architecture

For the 60th LPF and HPF side, there are pixels in the picture where the 1D-DWT before right shift yields a negative value. The difficulty in obtaining a '-ve' value is greater on the HPF side than on the LPF. It can ignore the negative numbers and treat them as zeros are know that the majority of an image's useful information is on the LPF side. "buffer-unit" is the term used for this function. This will check the most significant bit (MSB) to see whether the integer is negative. If the most significant bit is 1, the number is negative, and the buffer-unit's output is 0. In every other case, the number is positive and the output of buffer-unit is the actual number if the MSB unit is 0.

# 3.5 CDF-9/7 Using the CDF-5/3 Discrete Wavelet Transform

DWT Filter using a CDF-9/7 Basis: The Fig 10 below depicts the CDF-9/7's fundamental lifting design.



Fig 10: Input DWT Filter CDF-9/7 Base

The coefficients at the top of the picture are the lifting coefficients, whereas K is the scaling coefficient. All of the scaling and lifting factors have the values of

 $\begin{array}{l} \alpha = 1.586134342 \\ \beta = 0.6529801185 \\ \gamma = 0.882911076 \\ \delta = -0.443506852 \\ K = 1.149604398 \\ 1/K = 0.869864452 \end{array}$ 

All of the fractional coefficients, The Fractional parts are difficult to implement in hardware because they cause transaction errors and are inherently unstable.

This is why working on a CDF-5/3 DWT filter implementation, as this is the only filter type that requires just a shifter, and it should allow us to get the best possible transaction error performance.

#### 4. Applications of FPGAS

Spartan-6 ATLYS (XC6SLX45-3CSG324) FPGA Board will be used throughout this chapter to explain the implementation of all recommended designs.

#### 4.1 Top RTL Schematic

Fig 11 depicts the suggested 1D Top RTL schematic.



Fig 11: Top Level RTL Schematic of 1D-DWT 5/3 Block

#### 4.2 Elaborated RTL Schematic

From top RTL schematic it is difficult to understand the internal components. So, Fig 12 shows the elaborated RTL schematic.



Fig 12: Elaborated RTL Schematic of 1D-DWT 5/3 Block

#### 4.3 Technology Schematic

Each logic function will be represented by a set of LUTs and flip-flops in the FPGA. The technology

diagram demonstrates the LUTs and flip-flops pairs used internally to achieve the suggested paradigm. In Fig 13 below, a technology plan for a 1D-DWT 5/3 block.



Fig 13: Technology Schematic of 1D-DWT 5/3 Block

#### 4.4 Synthesis Result

Table 1 displays the results of the synthesis of the suggested CORDIC block.

| Table 1. Synthesis Res            | unto or 1 | D-D 11 3/3 |             |
|-----------------------------------|-----------|------------|-------------|
| Device Utilization Summary (estim | ated val  | lues)      |             |
| Logic Utilization                 | Used      | Available  | Utilization |
| Number of Slice Registers         | 40        | 69120      | 0%          |
| Number of Slice LUTs              | 107       | 69120      | 0%          |
| Number of fully used LUT-FF pairs | 18        | 129        | 13%         |
| Number of bonded IOBs             | 28        | 640        | 4%          |
| Number of BUFG/BUFGCTRLs          | 2         | 32         | 6%          |

#### Table 1: Synthesis Results of 1D-DWT 5/3

#### 4.5 Technology Schematic

Every logic function may be represented by a combination of LUTs and flip-flops in any FPGA. The

technology diagram demonstrates how the suggested model is implemented internally using LUTs and flip-flops Fig 14 shows below.



Fig 14: Technology Schematic of 2D DWT-9/7 Block

#### 4.6 Synthesis Result

Table 2 displays the outcomes of the suggested block's synthesis.

| Table 2: Analysis Results         | of 2D E  | OWT-9/7 blo | ck          |
|-----------------------------------|----------|-------------|-------------|
| Device Utilization Summary (estim | ated val | lues)       |             |
| Logic Utilization                 | Used     | Available   | Utilization |
| Number of Slice Registers         | 301      | 69120       | 0%          |
| Number of Slice LUTs              | 9424     | 69120       | 13%         |
| Number of fully used LUT-FF pairs | 229      | 9496        | 2%          |
| Number of bonded IOBs             | 44       | 640         | 6%          |
| Number of BUFG/BUFGCTRLs          | 3        | 32          | 9%          |

## **5. RESULTS**

#### Simulation Result of 1D DWT-5/3 ٠

The simulation waveform of the proposed 1D DWT-5/3 block is shown in Fig 15.

| Nar | ne          | Value    | ûns       | 1             |        | 100 ns   |       |         | 200 ns |          |         | 300     | ns      | 1    |        | 400 ns |       |         | 500     | 8   |              |      | 600 ns  | 1      |            | 700 rs  |       |         | 800 r  | 8   | 1.  |          | 900 ns  |           |
|-----|-------------|----------|-----------|---------------|--------|----------|-------|---------|--------|----------|---------|---------|---------|------|--------|--------|-------|---------|---------|-----|--------------|------|---------|--------|------------|---------|-------|---------|--------|-----|-----|----------|---------|-----------|
|     | a[7.0]      | 01101011 | K ( ) (10 | 10            | 100    | 11100 10 | 01100 | 011_ 1  | 011111 | 1010.    | )10_(   | 0))     | 000     | 000  | 10     | XXX    | 000   | 000     | XØX     | 01  | 01_          | 01   | 01_01   | 01_\   |            | 00      | 00 01 | 01 (0   | 110000 | 100 | 01_ |          | 01_01_  |           |
| 1   | e ck        | 0        | JUUL      |               | JUU.   | JUU      |       |         | JU     | W        | UUU     | JUL     |         |      | NU     | ЛП     | M     |         | UU      |     | $\mathbb{N}$ |      | Ŵ       | M      |            | IN      | UUL   | M       | LU.    | UUU |     | W        | JUU     |           |
| 1   | e ist       | 1        |           |               |        |          |       |         |        |          |         |         |         |      |        |        |       |         |         |     |              |      |         |        |            |         |       |         |        |     |     |          |         |           |
| 1   | e ck_out    | 0        | ЛЛ        | ЛГ            | UT.    | ЛП       |       | ΠΠ      | Л      | Л        | Л       | Г       |         | ЛГ   | Π.     | Л      | Τ     |         | Т       | Г   | Л            |      | LT I    | Т      |            |         | Τ     | ЛГ      | Ш      |     | Π   | Л        | ЛЛ      |           |
| 1   | e rst_out   | 1        |           |               |        |          |       |         |        |          |         |         |         |      |        |        |       |         |         |     |              |      |         |        |            |         |       |         |        |     |     |          |         |           |
|     | [p_out[7:0] | 01101000 | mmm       | 11_1          | 1_10_  | 10_10    | _ 10_ | 1001110 | 0      | 10., 10. | )0)     | 1010000 | 10_10_  | 10/1 | 1. 11. | 0      | 11_/1 | 0100000 | 10.)01  | 01  | 01           | 010  | 01      | 01_\0  | 1011010 01 |         | 01 01 | 01_0    | 1)01   | 01_ | 01_ | 01_01_   | 01_01_  | 01_01_    |
|     | hp_out[7:0] | 00000000 |           | 11_(          | 000    | 00000    | 11_   | 000000  | )11_)  | 00000    | 000     | 1)0     | L)11_   | X    | 00000  | 000    | (1    | L)00_   | 0.)11   | )11 | )11          | 00 0 | L) ( 00 | 000000 | 11_0       | L)IL)   |       | 000     | 0000   |     |     | 11111111 | 0000000 | (1111111) |
| 1   | e in p      | 1101100  | K (10 (1  | <b>_</b> )()( | 100111 | 00 1001  | 10011 | L) 100  | 1111   | 1010     | 10 10_  | XXX     | 000     |      |        | XXX    | 000   | 000     | X)      | DX  | 11(          | 10/1 | 1011    | 200    | 11.00      | ()11001 | 11    | 11_ 110 | 0001   | 001 |     | III)()(  | 1.11.   |           |
| 1   | Q.Q0 B      | 1100111  | 10000000  | 0000 11       | 1      | 10_(10   | _ 10_ | 10 10   | 11101  | 1010.    | .)10_)( | 0 1     | 0100000 | 1011 | D 10_  | )11    | 10/1  | 1       | 10) II  | 11  | )11          | 1011 | 1)10_)  | 1011   |            | 0 (10_) | 11_11 | 11/1    | 1)(11  | 11_ | 11_ | 11_10_   | 11 11   |           |
| 1   | ck_period   | 10000 ps |           |               |        |          |       |         |        |          |         |         |         |      |        |        |       | i       | 0000 ps |     |              |      |         |        |            |         |       |         |        |     |     |          |         |           |
|     |             |          |           |               |        |          |       |         |        |          |         |         |         |      |        |        |       |         |         |     |              |      |         |        |            |         |       |         |        |     |     |          |         |           |

Fig 15: Simulation Waveform of CORDIC Block

#### Simulation Result of 2D DWT-5/3 •

The simulation waveform of the proposed 2D DWT-5/3 is shown in Fig 16.

© 2023 Scholars Journal of Engineering and Technology | Published by SAS Publishers, India

Roopa K. C & Chetan S, Sch J Eng Tech, Oct, 2023; 11(10): 225-238

| Name           |              | Value    |      | 263,620 ns | 263,640 ns | 263,660 ns  | 263,680 ns  | 263,700 ns | 263,720 ns | 263,740 ns | 263,760 ns  | 263,780 ns | 263,800 ns     | 263,820 ns  | 253,840 ns    | 263,860 n |     | 263,880 ns    | 263,900 ns 2 |
|----------------|--------------|----------|------|------------|------------|-------------|-------------|------------|------------|------------|-------------|------------|----------------|-------------|---------------|-----------|-----|---------------|--------------|
| ►₩             | data_in(7:0) | 01100001 |      |            |            |             |             |            |            |            | 01100001    |            |                |             |               |           |     |               |              |
| U,             | đk           | 1        | ЛГ   | JUUU       | uuu        |             | JUUUU       | JUUUU      | JUUUU      | ww         | JUUUU       | JUUUU      | uuu            | JUUUU       | ww            | ЛЛ        | Π   |               |              |
| ų.             | rst          | 1        |      |            |            |             |             |            |            |            |             |            |                |             |               |           |     |               |              |
| 1              | ck_out1      | 1        | Л    |            |            |             | uu          |            |            | лп         | UU          |            |                |             |               | Л         |     |               |              |
| ▶ 👹            | h(7:0)       | 0000000  | 000. | 0000001 (0 | <u></u>    |             |             |            |            |            |             | 0000000    |                |             |               |           |     |               |              |
| ►₩             | 1(7:0)       | 10011000 | )    | 10000011   | 10         | 1 1000010 ( | 10010000100 | 1000       | 101 100.   | 100 1000   | 10000 10000 | 011 (100_) | 100_/1000_/011 | 011 011     | 011_0110_011  | 100       | 100 | 001010100.    | 0000         |
| ▶ 🕌            | h(7:0)       | 00000000 |      |            |            |             |             |            |            | 0000000    |             |            |                |             |               |           |     | 0000_000.     | 000_000000   |
| ▶ 👹            | hh[7:0]      | 00000000 |      |            |            |             |             |            |            |            | 0000000     |            |                |             |               |           |     |               |              |
| U              | rst_out1     | 1        |      |            |            |             |             |            |            |            |             |            |                |             |               |           |     |               |              |
| ų              | in p         | 1101010  |      |            |            |             |             |            |            |            | 1101010     |            |                |             |               |           |     |               |              |
| U              | op_p0        | 10001110 | 100. | ) 10       | 000011     | 100_ ( 1000 | 10 1000 10  | 000100     | 10000101   | 100_100_(  | 10000010    | 10000011   | 100_/1000_/100 | )111 (111 ) | 111_)110_(10. | 111       | 100 | 00_)1001_\101 | (100_100_)   |
| ų.             | op_p1        | 0        |      |            |            |             |             |            |            | 0          |             |            |                |             |               |           |     | 1             |              |
| 1 <sub>8</sub> | op_p2        | 0        | 11   | 10 1       |            | X           |             |            |            |            |             | 0          |                |             |               |           |     |               |              |
| U,             | op_p3        | 0        |      |            |            |             |             |            |            |            | 0           |            |                |             |               |           |     |               |              |

Fig 16: The Waveform of a 2D DWT-5/3 Block Simulation

## • Simulation Result of Memory Architecture

The simulation waveform of the proposed block are shown in Fig 17.

| Name               | Value           | 0 ps |      |      | 20 ps | du   | . 14 | ]ps |      | 60 ps |     |    | 80 ps | d    |    | 100 ps |      |     | 20 ps  | L  | 14    | 0 ps | 1    | 15   | lps  |      | 180 p | ;<br> | . P | 00 ps |      | 220 ps | ;    | . P | 40 ps |     | 260 p | s  |       | 280 ps | Lu   | ß   | 00.ps |      |
|--------------------|-----------------|------|------|------|-------|------|------|-----|------|-------|-----|----|-------|------|----|--------|------|-----|--------|----|-------|------|------|------|------|------|-------|-------|-----|-------|------|--------|------|-----|-------|-----|-------|----|-------|--------|------|-----|-------|------|
| lig ist            | 0               |      |      |      |       |      |      |     |      |       |     |    |       |      |    |        |      |     |        |    |       |      |      |      |      |      |       |       |     |       |      |        |      |     |       |     |       |    |       |        |      |     |       |      |
| li∦ ak             | 1               |      | Ul   | ЛЛ   | π     | π    | Л    | ЛЛ  | Π    | Π     | Π   | Π  | U     |      | Л  | π      | Π    | Л   | Π      | Π  | Πh    | Л    | Π    | υ    | Π    | Л    | Т     | ЛП    | Л   | UU    | ЛП   | π      | ЛП   | Л   | Л     | Π   | LT.   | Ul | Π     | U      | ЛЛ   | Л   | Π     | Π    |
| 🗽 ckóv             | 0               |      |      | Л    |       | Л    | Л    | Л   | Л    | ٦     | Л   |    |       |      | Ц  |        | Л    | Л   | Л      |    |       | U    |      |      | Л    | Л    | Л     | Л     | Л   | Л     | Л    | П      | Л    | Л   | Л     | Л   |       |    |       | L      | Т    | Ц   | U     |      |
| leg rd_wr          | 0               |      |      |      |       |      |      |     |      |       |     |    |       |      |    |        |      |     |        |    |       |      |      |      |      |      |       |       |     |       |      |        |      |     |       |     |       |    |       |        |      |     |       |      |
| 🕨 🙀 rd_addr(14:0)  | 00000000000000  | Ξ    | 000_ | 000_ | 000_  | 000_ | 000  | 000 | 000. | 000   | 000 | 00 | _ 00  | )(0) | 0_ | 000_   | 000_ | 000 | 000    | 00 | 00    | 00   | 000_ | 000_ | 000  | 000  | 000   | 000   | 000 | 000   | 000  | 000    | 000  | 000 | 000   | 000 | 000   | 0  | 0     | 0_0    | 0000 | 0_0 | 00_   | 000_ |
| 🕨 🙀 wr_addr(140)   | 000000000000000 | Ð    | 000_ | 000_ | 000_  | 000_ | 000. | 000 | 000. | 000   | 000 | 00 | _ 00  | ) (0 | 0_ | 000_   | 000_ | 000 | 000    | 00 | 00    | 00   | 000  | 000_ | 000_ | 000_ | 000.  | 000_  | 000 | 000_  | 000_ | 000    | 000_ | 000 | 000   | 000 | 000   | 00 | 0. 00 | 0_0    | 0000 | 0(  | 000   | 000_ |
| 🕨 🙀 data_in1[7:0]  | 0000000         | Ξ    | 000_ | 000_ | 000_  | 000_ | 000  | 000 | 000. | 000.  | 000 | 00 | 00    | 0    | 0_ | 000_   | 000_ | 000 | 000    | 00 | 0. 00 | 00   | 000  | 000_ | 000_ | 000_ | 000   | 000_  | 000 | 000   | 000_ | 000    | 000_ | 000 | 000   | 001 | 001   | 00 | 1_00  |        | 0100 |     | 001   | 001  |
| 🕨 🙀 data_in2(7:0)  | 00000000        | Ð    | 000_ | 000_ | 000_  | 000_ | 000  | 000 | 000. | 000   | 000 | 00 | _)00  | )(0) | 0_ | 000_   | 000_ | 000 | _ \000 | 00 | 00    | 0    | 000_ | 000_ | 000_ | 000  | 000   | 000_  | 000 | 000   | 000_ | 000    | 000_ | 000 | 000.  | 001 | 001   | 00 | 1 0   |        | 110  |     | 01_   | 001  |
| 🕨 🙀 data_out1(7:0) | 00000000        | C    |      |      |       |      |      |     |      |       |     |    |       |      |    |        |      |     |        |    |       |      | 00   | 0000 | Û    |      |       |       |     |       |      |        |      |     |       |     |       |    |       |        |      |     |       |      |
| 🕨 🙀 data_out2(7:0) | 00000000        | C    |      |      |       |      |      |     |      |       |     |    |       |      |    |        |      |     |        |    |       |      | 00   | 0000 | 0    |      |       |       |     |       |      |        |      |     |       |     |       |    |       |        |      |     |       |      |
| 👔 ck period        | 8 ps            | C    |      |      |       |      |      |     |      |       |     |    |       |      |    |        |      |     |        |    |       |      |      | 8ps  |      |      |       |       |     |       |      |        |      |     |       |     | t     |    |       |        |      |     |       |      |
| 🔓 ckóv period      | 8 ps            | C    |      |      |       |      |      |     |      |       |     |    |       |      |    |        |      |     |        |    |       |      |      | 8ps  |      |      | t     |       |     |       |      |        |      |     |       |     | t     |    |       |        |      |     |       |      |
|                    |                 |      |      |      |       |      |      |     |      |       |     |    |       |      |    |        |      |     |        |    |       |      |      |      |      |      |       |       |     |       |      |        |      |     |       |     |       |    |       |        |      |     |       |      |

Fig 17: The Waveform of a 2D DWT-5/3 Block Simulation

## • Simulation Result of Controller

The simulation waveform of the proposed block is shown in Fig 18.



Fig 18: Simulation Waveform of Controller Block

236

#### Simulation Waveform of 1D DWT-9/7

The simulation waveform of the proposed 1D DWT-9/7 block is shown in Fig 19.

| Nar | me            | Value    | Ons                                     | 100 ns                                  | 200 ns                   | 300 ns             | 400 ns                      | 500 ns            | 600 ns                                    | 700 ns               | 800 ns 90                               | 00 ns           |
|-----|---------------|----------|-----------------------------------------|-----------------------------------------|--------------------------|--------------------|-----------------------------|-------------------|-------------------------------------------|----------------------|-----------------------------------------|-----------------|
|     | 🙀 a[7.0]      | 01101011 |                                         | 011100 (10011 (10011 )                  | 011111 (1010             | 00000000           | 000000000                   |                   |                                           | 01100_01_01_01       | 0001)()(01)(01)()                       |                 |
|     | lý dk         | 0        |                                         |                                         |                          |                    |                             |                   |                                           |                      |                                         |                 |
|     | le ist        | 1        |                                         |                                         |                          |                    |                             |                   |                                           |                      |                                         |                 |
|     | lig cit_out   | 0        | JUUU                                    |                                         | JUUU                     | JUUU               | nnn                         | nnn               | nnn                                       | JUUU                 | nn                                      |                 |
|     | lg rst_out    | 1        |                                         |                                         |                          |                    |                             |                   |                                           |                      |                                         |                 |
|     | 🙀 lp_out(7:0] | 01101001 | XXXXXXXX (1)                            | ( <u>n n n n n</u>                      | 10000)10_(10_(10_)10.    | 000011 (10 (10 (10 | <u>/10_(10_)10_(1010001</u> | (10)01)01(01)01   | 01_01_01_0101110                          | 01 01 01 01 01       |                                         | 01_01_01_01_    |
|     | 🙀 hp_out[7:0] | 01111111 |                                         | ()))))))))))))))))))))))))))))))))))))) | 00000000                 |                    |                             | 0000000000        |                                           | )()()()(0)(0111111)  | 000000000000000000000000000000000000000 |                 |
|     | lýing         | 1101100  |                                         | 100/1001_0001_000                       | <u>0111 (010_(10_)0_</u> | 0000000            | 000000000                   | 0.00/00/00/00     |                                           | )1001_(11_(111000    |                                         |                 |
|     | lg op.p       | 1100110  | 100000000000000000000000000000000000000 | 0.0.0.0.0                               | 1010000 (10_10_10        | 0.0.000011.0.0     | 10.0.0.0                    | 00011/00_01_01_00 | )10 (10 (11 (11 (11 (11 (11 (11 (11 (11 ( | 1100 (11 (11 (11 (11 |                                         | 11)11(11)11)    |
|     | lig op_p0     | 1111110  | 100000000000000000000000000000000000000 |                                         | 0 (11 (11 ) 0            |                    | 1111111 (11                 | (10)(11)(11)(0)   | )11. 0 )11                                | 01101111             | 0 (1111                                 | 1111 0 (111110) |
|     | 🔓 ck_period   | 10000 ps |                                         |                                         |                          |                    | 100                         | Ŵ ps              |                                           |                      |                                         |                 |
|     |               |          |                                         |                                         |                          |                    |                             |                   |                                           |                      |                                         |                 |

Fig 19: Simulation Waveform of CORDIC Block

#### Simulation Result of 2D DWT-9/7

Fig 20 displays the simulated waveform of the proposed two-dimensional discrete wavelet transform (2D DWT-9/7).

| 600 ns 1400 ns 1500 ns 1500 ns 1500 ns 1500 ns 1500 ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mmm)a)000000m(00000000000000m(mmm00m0(0mmmm00m00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| and montaine and a contraction of the second s |
| 0@0@000000000@000@000@0000@0000@0000@0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Emm400000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| and amanda a summaria a sa a a a a a a a a a a a a a a a a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| (CO)COC THE COCCEPTION COCCEPTION CONTRACTOR (COCCEPTION)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1000ps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Fig 20: Simulation Wave of 2D DWT-9/7 Block

#### 5.1 Comparison of Proposed Technique with Existing

This module provides a comparison of the proposed architecture to several already-existing ones.

#### 5.2 2D DWT

In Table 3, how the proposed 2D DWT stacks up against the already-existing 2D DWT hardware. It can

be seen from the table that the suggested 2D DWT design makes good use of the available hardware resources. The primary cause of this is the use of shifter modules in lieu of traditional multipliers and divisions for calculations requiring constant inputs.

| Parameters                 | Yasodai and Ramaprasad | Rudagi and Vinayak | Proposed  |
|----------------------------|------------------------|--------------------|-----------|
| Board                      | Virtex-4               | Virtex-6           | Spartan-6 |
| Number of Slices           | 520                    | 965                | 475       |
| Number of Slice Flip Flops | 936                    |                    | 418       |

#### **6. CONCLUSION**

In this work, a new approach to memoryefficient DWT architecture implementation. Furthermore, the suggested design may be scaled up to a considerably larger number of DWTs without significantly altering the twiddle factor generators. In addition to cutting down on hardware needs, the butterfly diagram's use of intermediate phases allows more precise processing with fewer components. A face detection utilizing the suggested DWT architecture, where the proposed DWT is utilized to extract database and test features, to demonstrate the practical uses of the

© 2023 Scholars Journal of Engineering and Technology | Published by SAS Publishers, India

proposed architecture. In the future, to optimize data precision and hardware parameters and update the DWT architecture to support more butterflies.

#### REFERENCE

- Suresh, K. D., Vijaya, B. B., & Suryaprakash, R. (2012). Implementation of Higher Order DWT Processor Using FPGA, *IJERT*, *1*(6), 1-4.
- Aniket, S., Mayuresh, D. (2012). Comparative Study of Various DWT Algorithm Implementation on FPGA, *IJETS*, *1*(1), 19-22.
- Gupta, A., Jain, A., Bhalla, A. V., & Malviya, U. (2012). Design Of High Speed FFT Processor Using Vedic Multiplication Technique. *International Journal of Engineering Research and Applications* (*IJERA*), 2(5), 1501-1504.
- Sri, T. S., Kumar, K. S., & Muttaiah, R. (2013). Review of CORDIC Architectures. *International Journal of Engineering and Technology*, 5(2), 578-585.
- Narayanam, R., & Muni, G. P. (2013) Performance Evaluations of Grigoryan DWT and Cooley-Tukey DWT onto Xilinx Virex-II pro and Virtex-5 FPGA, *International Journal of Scientific and Research Publications*, 3(1), 1-6.
- Sneha, K. (2015). Design and Implementation of DWT, *International Journal of Electronics, Communicatin and Soft Computing Science and Engineering*, pp. 248-252.
- Patrikar, M., & Tehre, V. (2017). Design and Power Measurement of 2 and 8 Point FFT using Radix-2 Algorithm for FPGA Implementation. *IOSR Journal* of VLSI and Signal Processing, 7(1), 44-48.
- Amaresh, K., Tripathi, U. N., Roopak, K. V., & Manish, M. (2014). 64-Point Radix-4 DWT

Butterfly Realization using FPGA, International Journal of Engineering and Innovative Technology, 4(4), 57-60.

- Gitla, S., Masthaniah, P., Veeranth, P., & Durga, G. R. (2013). VLSI Implementation of a Flexible and Synthesizable DWT Processor, *IRD India*, 1(3), 73-77.
- Yasodai, A., & Ramprasad, A. V. (2013). A New Memory Reduced Radix-4 CORDIC Processor for DWT Operation, *IOSR Journal of VLSI and Signal Processing*, 2(5), 9-16.
- Rudagi, J. M., & Vinayak, D. (2013). Radix-2 CORDIC Method with Constant Scale Factor, International Journal of Advanced Research in Electrical, Electronics and Instrumentation Engineering, 2(7), 3408-3413.
- Arman, C., Yousuef, S. K., Otto, S., & Radha, R. (2011). Implementing DWT Algorithm on FPGA, *International Journal of Computer Science and network Security*, 11(11), 148-156.
- Akashadip, A. J., Prashant, R. I., & Ravindra, D. K. (2017). Design and Simulation of Floating Point DWT Processor based on Radix-4 Algorithm using VHDL, *International Journal of innovative Research in Computer and Communication Engineering*, 4(7), pp. 13223-13229.
- Patrikar, M., & Tehre, V. (2017). Design and Power Measurement of 2 and 8 Point FFT using Radix-2 Algorithm for FPGA Implementation. *IOSR Journal of VLSI and Signal Processing*, 7(1), 44-48.
- Anilkumar, P. H., & Beulet, P. A. S. (2015). Liftingbased discrete wavelet transform for real-time signal detection. *Indian Journal of science and technology*, 8(25), 1-6.