#### Wright State University

#### **CORE Scholar**

Browse all Theses and Dissertations

Theses and Dissertations

2006

# Design and Evaluation of a Discrete Wavelet Transform Based **Multi-Signal Receiver**

**Tony Chiang** Wright State University

Follow this and additional works at: https://corescholar.libraries.wright.edu/etd\_all



Part of the Electrical and Computer Engineering Commons

#### **Repository Citation**

Chiang, Tony, "Design and Evaluation of a Discrete Wavelet Transform Based Multi-Signal Receiver" (2006). Browse all Theses and Dissertations. 30.

https://corescholar.libraries.wright.edu/etd\_all/30

This Thesis is brought to you for free and open access by the Theses and Dissertations at CORE Scholar. It has been accepted for inclusion in Browse all Theses and Dissertations by an authorized administrator of CORE Scholar. For more information, please contact library-corescholar@wright.edu.

# DESIGN AND PERFORMANCE EVALUATION OF A DISCRETE WAVELET TRANSFORM-BASED MULTI-SIGNAL RECEIVER

A thesis submitted in partial fulfillment of the requirements for the degree of

Master of Science in Engineering

By

#### **TONY CHIANG**

B.S. ELECTRICAL & COMPUTER ENGINEERING, University of Rochester, 2003

2006

Wright State University

# WRIGHT STATE UNIVERSITY SCHOOL OF GRADUATE STUDIES

July 7, 2006

I HEREBY RECOMMEND THAT THE THESIS PREPARED UNDER MY SUPERVISION BY <u>Tony Chiang ENTITLED Design</u> and <u>Evaluation of a Discrete Wavelet Transform-Based Multi-Signal Receiver</u> BE ACCEPTED IN PARTIAL FULFILLMENT OF THE REQUIREMENTS FOR THE DEGREE OF <u>Master of Science in Engineering</u>

|                                                                      | Chien-In Henry Chen, Ph.D<br>Thesis Director |
|----------------------------------------------------------------------|----------------------------------------------|
|                                                                      | Fred Garber, Ph.D.<br>Department Chair       |
| Committee on<br>Final Examination                                    |                                              |
| Chien-In Henry Chen, Ph.D.                                           |                                              |
| Raymond Siferd, Ph.D.                                                |                                              |
| Marty Emmert, Ph.D.                                                  |                                              |
| Dr. Joseph F. Thomas, Jr., Ph.D.<br>Dean, School of Graduate Studies |                                              |

#### **Abstract**

General purpose receivers of today are designed with a broad bandwidth so that the receiver can accept a wide range of signal frequencies. These receivers usually accept one signal along with any interference that is included. To increase the signal detection capabilities of the wideband receiver, a design for a receiver that can detect two signals is needed. One of the requirements for this receiver is that the second weak signal needs to be processed in a timely manner so that the receiver can recognize it. To remedy the problem, a module was developed using wavelet-based techniques to remove spurs from the incoming signals to allow easier detection. The main basis for this concentration on wavelets comes from the way wavelets break down signals into portions (called resolutions) that allow easier determination of detail importance. Utilizing the multi-resolution attributes of the discrete wavelet transform, a way to remove signal spurs is made possible. When removing the signal noise from the signal, the two signal dynamic range of the system is increased, as this module is applied to multiple receiver systems for comparison of performance. Implementation of this system was originally done in C as well as MATLAB, but later is being implemented in VHDL with simulations done for verification of functionality.

# **Table of Contents**

| Chapter 1: Introduction                                | 1        |
|--------------------------------------------------------|----------|
| Chapter 2: Theory and Background                       | 7        |
| 2.1: Haar Wavelet Transform                            | 8        |
| 2.2: Daubechie's Wavelet Transform Method              | 9        |
| 2.3: Thresholding and Noise Reduction                  | 11       |
| 2.4: Hardware Implementations                          | 13       |
| Chapter 3: Methodology                                 |          |
| 3.1: Data Generation                                   | 20       |
| 3.2: ADC Background                                    | 20       |
| 3.3: Fourier Transform                                 | 21       |
| 3.4: Compensation Matrix                               | 21       |
| 3.5: De-noising Function                               | 22       |
| 3.5.1: Discrete Wavelet Transform                      | 22       |
| 3.5.2: Thresholding                                    | 23       |
| 3.5.3: Inverse Wavelet Transform                       | 24       |
| 3.6: Signal Detection (Frequency Selection)            | 24       |
| 3.7: Hardware Implementation                           | 25       |
| Chapter 4: Results and Discussion                      | 27       |
| 4.1: Simulation Environment                            | 27       |
| 4.2: Determination of Placement of De-noising Function | 31       |
| 4.3: Determination of Threshold Type                   | 33       |
| 4.4: Determining Performance Improvement in Monobit    | 34       |
| 4.5: Determining Performance Improvement in ROC        | 41       |
| 4.6: Hardware Implementation                           | 45       |
| 4.6.1: VHDL vs. AMS Verilog                            | 45       |
| 4.6.2: Hardware Implementation of De-noising Module    | 46       |
| 4.6.2.1: Look Up Table Implementation                  | 50       |
| 4.6.2.2: Decimal Representation in Binary              | 52       |
| 4.6.2.3: Look Up Table Configuration                   | 53       |
| 4.6.2.4: Simulation                                    | 54       |
| Chapter 5: Conclusion and Recommendations              | 57       |
| 5.1: Conclusion                                        | 57       |
| 5.2: Recommendations                                   | 57       |
| References                                             | 59       |
| Appendix A (MATLAB & C++ DWT Code)                     | 61<br>73 |
| Appendix B (VHDL Code for De-noising Function)         |          |
| Appendix C (C Code to Generate VHDL)                   | 173      |

# **List of Figures**

| 1.1: Block Diagram of Receiver Design                                 | 3  |
|-----------------------------------------------------------------------|----|
| 2.1: Signal, Sample, and Approximation for Haar Wavelet               | 8  |
| 2.2: Daubechie's Wavelet                                              | 10 |
| 2.3: Discrete Wavelet Transform Hardware Block Diagram                | 15 |
| 2.4: Lifting Based DWT Design                                         | 16 |
| 3.1: Block Diagram of Steps                                           | 19 |
| 3.2: ADC Block Diagram                                                | 20 |
| 3.3: Discrete Wavelet Transform of a Sinusoidal Signal                | 23 |
| 3.4: Signal Detection Through Thresholding                            | 25 |
| 4.1: General Flow of Receiver Design Without De-noising               | 30 |
| 4.2: Flow Chart for Determining Placement of DWT De-noising           | 31 |
| 4.3: Graph of Signal Detection Types, Percentages and Threshold Types | 36 |
| 4.4: Graph of False Alarms in Mono-bit Receiver Simulations           | 38 |
| 4.5: Graph of Percentage Missed vs. Threshold Type                    | 40 |
| 4.6: Signal Detected Using De-noising Function                        | 42 |
| 4.7: De-noising Function Interfaces                                   | 47 |
| 4.8: De-noising Function Details                                      | 48 |
| 4.9: De-noising Function Block Diagram                                | 49 |
| 4.10: Look Up Table Configuration for DWT LUT and IDWT LUT            | 51 |
| 4.11: De-noising Function in VHDL Simulation                          | 55 |

# **List of Tables**

| 4.1: Comparison of Second Signal Missed Signal and                    | 32 |
|-----------------------------------------------------------------------|----|
| False Alarm Based on Placement of DWT De-noising                      |    |
| 4.2: Results of Simulations Testing Threshold Values                  | 33 |
| 4.3: Results of Simulations Using Random Generation                   | 35 |
| of Signals in Mono-bit Receiver                                       |    |
| 4.4: Table of Results, Specifically False Alarms                      | 37 |
| 4.5: Table of Results, Specifically Missed Signals                    | 39 |
| 4.6: Table of Isolated Cases and Results from New Configuration       | 41 |
| 4.7: Simulations with De-noising Function, Specifically Second Signal | 42 |
| 4.8: Table of Acceptable Results with Different Configurations        | 44 |
| 4.9: Component Requirements for De-noising Function                   | 56 |

# Acknowledgements

This work was supported in part by the program of Receiver and Processing Concepts Evaluation (RAPCEval), DoD, Air Force Research Lab, USA.

I would like to thank my advisor, Dr. Chien-In Henry Chen, for his dedication, his vision, and his support throughout the thesis process. It has proven to be an arduous, but worthy rite of passage that has conditioned me for the road ahead.

I would like to also thank the members of the thesis committee in taking time out of their busy schedules to read and evaluate my thesis. Their advise and help have proven a key instrument in the completion of this thesis work.

I would also like to thank numerous individuals from the Wright Patterson Air force Base for giving me the opportunity to work with them and to develop a technology they may consider for future use.

To the students in the lab, I am especially grateful for all the help and encouragement that you have given me throughout this process. You've shown me that research can be fun too!

Last but not least, I would like to thank my family, who has been providing me a way to worry only about the task on hand. I greatly treasure and appreciate the time and effort that has gone into giving me peace of mind while working on this thesis.

# Dedication

This thesis is dedicated to my parents, Win and Lancy Chiang, who taught us that innovation and "thinking outside the box" is what sets one person apart from the crowd.

# **Chapter 1: Introduction**

General purpose receivers of today are designed with a broad bandwidth so that the receiver can accept a wide range of signal frequencies. These receivers usually accept one signal along with any interference that is included. However, when such a receiver receives two simultaneous main signals compounded with the noise from both signals, the receiver chooses the signal closest to it so that only one signal is received while the other signal is simply not processed as a signal, but rather as interference or noise. To increase the signal capabilities of the wideband receiver, a design for a receiver that can detect two signals is needed. One of the requirements for this receiver is that the second main signal needs to be processed so that it can be recognized by the receiver. To make this two main signal receiver design for general purpose, the signal frequencies should be variable, and not known to the system previously. wideband receiver must be able to discern a signal from the compounded noise from two signals. To solve this problem, a wideband receiver requires signal processing in the forms of modulation or through the process of removal of noise and signal recognition to successfully detect two signals at the same time.

In digital signal processing, a common way of remedying this problem is to use modulation through convolution [1]. From this signal, it can be reconstructed by using the same pattern of impulses when used at the same frequency. This method allows the noise in the signal to be virtually ignored. In the case where the frequencies are known, a radio system using FM modulation

is the preferred method for achieving this ability. This solution, however, requires the prior knowledge of the frequencies that the signals are being received at, which cannot make this receiver a general-purpose receiver.

To deal with the noise and signal detection in a more direct fashion, there are many designs for filters that would shape the signal to the function that the filter is implemented [1]. However, this function is not acceptable for a general-purpose wideband receiver as the signals themselves would be distorted, and finding a very weak signal would be impossible. There is a need, then, for a more dynamic method to which the signal can be directly affected by the processing without resorting to a signal shaping method.

A method for removing noise from a signal is using two threshold values obtained from large volume of radar data simulation; the large threshold is used for detection of the first strong signal and the second threshold is used for detection of the second weak signal. This method has been used in a mono-bit receiver design [2], which precedes the general-purpose wideband receiver, and has moderate performance improvement. However, with the mono-bit receiver, a strong and a weaker signal can be only detected with very little difference, up to 5 dB direct range difference, between the strong and weak signal due to the lower resolution (2 bits) of the ADC in the system. Another method for removing noise from a signal is the compensation matrix, which has a matrix of stored coefficients that have been pre-calculated to match the signal behavior and uses those coefficients to delete the predicted noise from the actual signal,

thereby exposing any weak signals. A further improvement upon the design brings us to a 1 GHz input bandwidth receiver on a chip (ROC) design. The ROC design is a design that incorporates all the functions of a receiver onto one chip, and this particular design utilizes a super-resolution block, which based on the input signals, suppresses spurious signals and exposes the true signals [3].



Figure 1.1: Block Diagram of Receiver Design

The receiver design can be separated into two areas: the signal sampler and formatting system, and the super resolution and frequency measurement section [3]. The signal sampler and formatting system portion comprises of an ADC that operates at 2.5 times the input bandwidth and samples the signal at 0.4 ns to produce 4 bit amplitude measurements. Each bit is then passed into a windowing circuitry, which converts the serial data stream to parallel and slows down the data rate by a factor of 16. This process is achieved by using a clock divider to slow the data stream. The slowing of the data rate is necessary to accommodate the speed at which the detection circuit can receive data.

The super-resolution and frequency measurement system relies on a 256 point FFT, a compensation block and a frequency selection logic block. The 256 point FFT is designed by using a 12 point kernel approximation which is fed the input data stream from the windows. Once all the data is collected after the FFT, it is input into the compensation block. The compensation process is essentially the comparison of a stored pre-calculated value that approximates the first detected frequency and the associated noise, then subtracts that value from the original signal response. This method assumes that if the pre-calculated signal response is the same as the actual signal response, the side lobes and spurs will be taken out while exposing any signal that is left behind to be detected as a secondary signal. In actual performance, the compensation must calculate the response close enough so that there won't be any kind of misinterpretation on the part of the detection module that would mistake an uncalculated spur as a second signal.

It is after the compensation block for which the frequency selection takes place to detect the signal. This takes place by the selection of a frequency bin that is closest to the frequency that the signal is detected at. This frequency bin is of a 10 MHz bandwidth [3].

The system performance with the compensation matrix was proven to receive a signal in acceptable specifications with a strong to weak signal dynamic range (also known as a two signal dynamic range) of 18 dB [3]. There is a need for the system performance to increase beyond that of 18 dB, however, to make the

receiver design more robust. This system performance, however, decreases exponentially when the two signal dynamic range reaches beyond 18 dB. To improve the performance of the receiver beyond 18 dB is impossible using only the current compensation matrix. Therefore, a different system approach may be more applicable to further improve the performance of the wideband receiver so that any signal, from a strong signal to a weak signal, can be detected.

The main basis for this concentration on wavelets comes from the way wavelets break down signals into portions (called resolutions) that allow easier determination of detail importance [4] [5] [6] [7] [8]. There are multiple versions contained within one wavelet transformation, so there can be a choice of how many to contain to maintain the details of each. In the example of a picture, there are many different resolutions that may contain very little information significant to the picture; therefore, the user can specify the amount of detail required for the picture by removing the less significant resolutions from the transform [5]. The same principle can be applied to a 1D signal such as the signals received by the wideband receiver. A signal can be broken down into different resolutions, where the signal can be discerned easily from the noise [6] [7] [8]. From these resolutions, a noise threshold can be specified so that only signals above the threshold will be kept while the rest of the signal will be removed or reduced in amplitude [9]. Variations in the threshold types as well as the variability of the threshold value can be analyzed and customized to fit the signal condition. When paired with the compensation matrix, an added

performance boost can be expected from this method. Since the application of this type of technology to a receiver design has not been documented before, the theory appears to be promising for the further performance boost of the receiver.

This thesis aims to solve the following problems:

- Implement the discrete wavelet transform and thresholding technology into a module to be placed into the system to improve receiver system performance beyond 18 dB two signal dynamic range.
- 2 Investigate hardware implementations of the system by using simulations to further verify that the theoretical and experimental data from the software is viable in the hardware implementation.
- Consider the hardware implementation of discrete wavelet transform based module for integration with a receiver on chip design.

# **Chapter 2: Theory and Background**

Wavelets are small waves that are used to derive a signal depiction through stretching and shrinking the wavelet. Wavelets are localized functions in time with mean zero; the wavelet basis is derived from the wavelet (small wave) by its own dilations and translations. A general definition of a wavelet equation is:

$$W_{j,k}(t) = 2^{\frac{-j}{2}} w(2^{-j}t - k)$$

Let the original wavelet (also known as the mother wavelet) start at t=0 and end at t=N. The shifted wavelet  $w_{0,k}$ , starts at t=k. and ends at t=k+N. The rescaled wavelet  $w_{j,0}$  starts at t=0, and ends at  $t=N/2^{j}$ .

The choice of the basis is related to the choice of the filters. The basis must present two main properties: linear independence and completeness. In the creation of the wavelet, there are two major components that define the wavelet transform: the details and the overall structure of the wavelet, based on the dilations and translations. The complexity of the wavelet transform theory utilized determines the closeness of the wavelet adhesion to the original signal depiction [8]. This depiction of a signal requires a criteria for the different resolutions of the signal in the transform domain to be formed so that the performance of the wideband receiver will be improved.

There are a few wavelet transform schemes that are available for usage in a system integration with varying degrees of complexity, making the choice of transforms a balance between hardware complexity and accuracy to the original signal, making a thresholding cut a more accurate removal of noise [9].

#### 2.1: Haar Wavelet Transform

This wavelet transform relies on a rectangular function, which utilizes the basic approximating functions that would estimate the shape and detail of the waveform that is being transformed [6]. Simplified, the Haar wavelet transform uses an approximating function that is a variation of a step function.



Figure 2.1: (a) Signal, (b) Sample (c) Approximation for Haar Wavelet [7].

Haar's basic transformation expresses the approximating function f with wavelets by replacing an adjacent pair of steps by one wider step and one wavelet. The wider step measures the average of the initial pair of steps, while the wavelet, formed by two alternating steps, measures the difference of the initial pair of steps [6][7].

This method is the basic wavelet transformation, and is not suitable for higher definition signals, as is expected in a wideband receiver design. While acceptable for lower (4 to 6 dB) two signal dynamic ranges, similar performance at 18+ dB cannot be expected as the resulting signal is depicted as step functions. This transform method, then, is not a viable candidate for improving system

performance based on a more accurate depiction, and therefore more accurate de-noising, of the signal spectrum.

#### 2.2: Daubechies Wavelet Transform Method

Ingrid Daubechies introduced a new series of algorithms that transformed using wavelets that contrast from Haar's wavelet transform in that the Daubechies wavelet transform is a continuous signal rather than Haar's discontinuous step design [6] [7] [8]. As a consequence of the continuity, continuous signals have a more accurate representation; however, this continuity has the cost of using complex equations and implementations, resulting in more complex hardware. Some of these functions are based on matrix calculations.

In order to design continuous wavelets that are time-efficient and implementable in a system use, Daubechies introduced a basic building block or scaling function as denoted by  $\phi$ . An example of how Daubechies' wavelets are calculated is noted below for initial conditions:

$$\varphi(0) := 0,$$

$$\varphi(1) := \frac{1 + \sqrt{3}}{2},$$

$$\varphi(2) := \frac{1 - \sqrt{3}}{2},$$

$$\varphi(3) := 0.$$
These conditions satisfy the condition that:

$$\varphi(r) = \frac{1+\sqrt{3}}{4}\varphi(2r) + \frac{3+\sqrt{3}}{4}\varphi(2r-1) + \frac{3-\sqrt{3}}{4}\varphi(2r-2) + \frac{1-\sqrt{3}}{4}\varphi(2r-3).$$
 It is also

required that the initial values add up to 1 so that the values of  $\phi$  may serve as averaging or weighting factors.

$$\varphi(0) + \varphi(1) + \varphi(2) + \varphi(3) = 0 + \frac{1 + \sqrt{3}}{2} + \frac{1 - \sqrt{3}}{2} + 0 = 1$$

The function  $\phi$  serves as the basic building block for its associated wavelet, denoted by  $\psi$ , and defined by the following notation:

$$\begin{split} &\psi(r) \coloneqq -\frac{1+\sqrt{3}}{4}\varphi(2r-1) + \frac{3+\sqrt{3}}{4}\varphi(2r) - \frac{3-\sqrt{3}}{4}\varphi(2r+1) + \frac{1-\sqrt{3}}{4}\varphi(2r+2) \\ &= -h_0\varphi(2r-1) + h_1\varphi(2r) - h_2\varphi(2r+1) + h_3\varphi(2r+2) \\ &= (-1)^{(1)}h_{1-1}\varphi(2r-1) + (-1)^{(0)}h_{1-0}\varphi(2r-0) + (-1)^{-1}h_{1-[-1]}\varphi(2r-[-1]) + (-1)^{-2}h_{1-[-2]}\varphi(2r-[-2]) \end{split}$$



*Figure 2.2: Daubechies Wavelet [7]* 

The Daubechies wavelet is calculated in this fashion. It can be seen that the Daubechies' wavelet method utilizes vanishing moments. Vanishing moments are described as a point in the function where it dips below the frequency axis. Vanishing moments contribute to the smoothness of the transformed wavelet because they allow the system to compensate for the differences in the transfer function without sacrificing expensive hardware implementation [8]. The signal adhesion is more apparent in the Daubechies wavelet transform than that of the Haar wavelet [10], making the Daubechies wavelet transform one of the more popular implementations of the discrete wavelet transform. This method for

transform and thresholding is much more promising for improving system performance of the receiver than the Haar wavelet transform.

## 2.3: Thresholding and Noise Reduction

As discussed before, the wavelet transform separates the time-based signal into details and a general form for the signal. It is in the details that most of the noise creates a problem because the details are so much smaller in terms of frequency amplitude. Adding a zero where the noisy coefficients are is a possible solution to create a cleaner signal [9]. The main motivations of this method can be summarized with the following assumptions and observations:

- 1. The de-correlating property of the wavelet transform creates a sparse signal: most of the untouched coefficients are close to zero or at zero.
- 2. Noise is spread equally throughout all coefficients.
- 3. The noise level is not too high so that the signal cannot be differentiated from the noise.

Adding a threshold that adds a zero below a certain value allows the signal to be cleaned with a simple and efficient design. This simplicity is what makes thresholding a common solution to reducing noise in a signal.

Replacing small coefficients with a zero if under a certain threshold value is called hard thresholding. Another method, which coefficients above a coefficient are reduced by an absolute value, lends itself to more continuity in the coefficients. There is a clean transition between the noise coefficients and the signal coefficients. This method, called soft thresholding, is particularly effective

in maintaining mathematical controllability; for example, a discontinuous signal is not useable for use in a system that is made for continuous signals or may cause some un-desirable results. For these cases, a soft threshold, which maintains continuity, would be clearly a better choice than the discontinuous hard threshold method [9].

However, setting the type of threshold is only one parameter that needs to be set. An important parameter is the threshold selection. This threshold can be based on a few items: variance deviations, namely mean absolute deviation and numerical standard estimate; or threshold estimators using mean squared error. Mean squared error is primarily used as a threshold estimator for soft thresholding and applications include image processing as well as sound processing [9].

For this design, however, an absolute median of the signal is used as an estimator for the threshold. The basis for this design is because per input signal after the discrete wavelet transform, the majority of the important details (the main part of the true signal) will be contained in the first half of the transform while the second half will contain the majority of the details, which includes the noise in the signals. Following this logic, the second half of the data is sorted, then a median is found. From the median, the threshold can be estimated because all the small details should have amplitude with much less fluctuation than in the first half of the data. Another method that could be used in estimating the threshold is the use of a statistical standard deviation method.

This method is more complicated, and may require more hardware or computation time. In a system design that requires as little computation as possible to reduce power consumption as well as hardware real estate, a simplistic approach using the median would be more appropriate for this application.

#### 2.4: Hardware Implementations

The major considerations for the design deal with the design of the discrete wavelet transform itself. In the transform, there are many recursive processes that occur; these processes rely heavily on memory to store previous values for recalculation. Another major consideration is the filters that would be used to implement the discrete wavelet transform. These filters differ based on different types of wavelet transforms; like in most cases, a more complex filter will produce better results, but also result in complex filter hardware implementation, requiring more space and power.

The discrete wavelet transform implemented in this design is a Daubechies Wavelet Filter, using a 4 -tap design, which is simple to implement because of its orthogonal properties as well as the simple shortness of the filter. It also satisfies the perfect reconstruction conditions [7][8]. In designs such as the ones used in [4] and [12], the filters were implemented directly in the system since they could vary based on the inputs of the chip. The most important characteristic of the FIR filters obtained from Daubechies functions is that they are Power Symmetric, which allows implementation of those filters using a Lattice Structure, as

described in chapter 6.4 of [10]. The Lattice Structure has many advantages, such as better coefficient quantization response as well as a reduction by a factor of two of the stages needed for a given filter order [11].

Another method of implementing the filters is described in [13], using a different method for implementing a DWT system, and compares the convolution-based, lifting-based, and b-spine based designs. For one dimensional DWT, the architectures are mainly convolution-based and lifting-based, while other designs, including the b-spline based architecture, is more suitable for two dimensional DWT. Traditionally, a convolution-based system is used for the filter system. This system provides an accurate transform and reconstruction of the signal when processed in a transform and an inverse transform. However, this method also requires space and some complex arithmetic to take place; therefore, some other methods are investigated [17].

When composing a DWT design, the input is divided into an even and odd signal, which is processed so that the output of the transform is a high pass sequence and a low pass sequence. This concept is illustrated below:



Figure 2.3: Discrete Wavelet Transform Hardware Block Diagram [16]

The filters here determine the complexity of the circuit. For the lifting-based concept, factorization of the filter coefficients using a lifting scheme allows for hardware cost to be reduced and for complexity to also be reduced. However, the cost for using a lifting-based scheme may result in a longer critical path [15]. This is because the factorization may result in different stages to connect differently from the convolution-based scheme. Optimized correctly, however, should maintain the critical path while reducing hardware.



Figure 2.4: Lifting-Based DWT Architecture [12]

The lifting based scheme has three simple steps, applied repetitively on the samples: the split phase, predict phase, and the update phase. The split phase needs to split the incoming signal into two separate types, ideally, the odd and even signals. The first stage is called the lazy wavelet transform because it simply sub samples the signal into even and odd samples. During the Predict Phase, the even subset is used to predict the odd subset of the system. The purpose of this predict phase is to eliminate the need for the odd samples by predicting it using the even samples. To denote correlation differences between the odd and even channels, the predicted values are subtracted from the actual values. The more correlation between the even and the odd samples, the better the calculations. The Update Phase is where the samples are lifted with the help

of the neighboring wavelet coefficients so that the mean of the samples is preserved. The lifting wavelet transform requires less calculations than a convolution method because it eliminates the need to preserve the odd samples and uses lifting, which preserves the mean of the values in the transform [12].

There are other methods of implementing the discrete wavelet transform, including a design that would utilize look up tables (LUT) for storing the values of the coefficients or possibly the products of the coefficient and a number, which would be the input address. This method takes advantage of the space efficiency of the look up tables and is a viable alternative to multipliers, which take up a large amount of space.

The memory is also used to store the values for the calculation of the compensation table, so allocating some memory for the calculation of the DWT and the inverse DWT is easily accomplished. For the threshold estimation, the temporary storing and replacing of values will require some memory as well, but these operations may utilize the same memory area and will not require much more memory. Pipelining of the sorting algorithm blocks, however, may be needed to compensate for the large amount of data being input into the system and will also require hardware space, both in terms of the blocks as well as memory.

Implementations of the discrete wavelet transform are largely done on FPGAs because FPGAs have integrated multipliers and adders [11][14][15]. This attribute of FPGAs is attractive because multipliers and memory units are

expensive in terms of hardware real estate in ASIC design. Also, FPGAs provide a faster development cycle than ASIC. However, ASIC provides a faster performance speed and also takes up less space than the FPGA design. For the video applications of the DWT, ASIC is a preferable implementation scheme and provides the throughput that FPGA may not be able to offer [15]. For the receiver design, either path can be followed, but it remains to be seen which technology would be more practical for implementation.

## **Chapter 3: Methodology**

The methodology for developing a receiver design improvement requires several different steps, and use of different types of equipment. The advantages and disadvantages of some of the steps are explained as well as the steps that were taken for the implementation of the receiver design. The steps are as follows:

- 1. Data Generation
- 2. ADC Background
- 3. FFT
- 4. Compensation Matrix
- 5. DWT De-noising
- 6. Frequency Selection (Signal Detection)



Figure 3.1: Block Diagram of Steps

The block diagram above depicts the flow of the system as it is being used for simulations. Each block is described in the next sections. The receiver is also designed and implemented in hardware. The detailed implementation of the hardware is described in Section 3.7.

#### 3.1: Data Generation

The data sets for the simulation of the receiver design are generated frequencies using MATLAB, ranging from 125 MHz to 1125 MHz. These signals are generated with a minimum of 10 MHz difference between one another, and also have one signal generated as a strong signal and another signal generated as a weak signal. These signals are also generated with random noise added to the spectrum. This represents a typical signal input data for the receiver.

#### 3.2: ADC Background

The ADC is used to convert the generated continuous time signal into a digital signal so that it can be processed easier. The highest frequency that can be received by the ADC is 1.125 GHz, so the 2.5 GHz sampling rate of the ADC corresponds with the Nyquist rate. In the MATLAB simulations, a simple quantizer is used for the function that the ADC would perform. However, a ADC design is required for the hardware implementation, which has the general design shown Figure 3.2.



Figure 3.2: ADC Block Diagram

The ADC design is programmed in AMS Verilog and interfaces with the FFT in the receiver design.

#### 3.3: Fourier Transform

The next step is to transform the digital data after the ADC into frequency domain for processing. The Fast Fourier Transform was chosen for the implementation of the Fourier Transform. The Fast Fourier Transform (FFT) is designed to generate 256 points. Each point generated by the FFT is approximated by a unit circle with 12 points on it and choosing the point closest to the point generated. This approximation is the 12 point kernel FFT. The 12 point kernel 256 point FFT is designed and written in MATLAB code for simulation use as well as for ease of numerical handling.

#### 3.4: Compensation Matrix

The incoming 256 points from the FFT is a mirrored spectrum, so half of the spectrum (128 points) is used for processing the signal. To remove the noise from the incoming 128 points from the FFT, a compensation matrix, which contains pre-calculated noise in the matrix, is used to process the signal. This calculation comes from previous data patterns that were generated and stored in memory. An algorithm selects the compensation row. The compensation matrix is implemented in MATLAB code by using variables to denote the memory slots and implementing a separate algorithm to search and select a specific row for use in the signal processing. The information in the compensation row is used to subtract from the FFT signal, theoretically "exposing" any second signal that is

possibly overshadowed by the noise in the system. Theoretically, the noise should be completely removed from the signal, but in reality, this is not the case.

### 3.5: De-noising Function

The de-noising function is composed of three sections: the discrete wavelet transform (using the Daubechies implementation), thresholding, and an inverse wavelet transform. Further removal of signals requires the Daubechies wavelet transform, thresholding, and an inverse transform. The main inputs of this system are the filter coefficients, threshold value set by the user, and the signal from the compensation matrix. The filter coefficients are precalculated and stored in memory, then input into the de-noising function. The filter coefficients are calculated using MATLAB code and insert the values generated into the different components as matrixes.

#### 3.5.1: Discrete Wavelet Transform

The discrete wavelet transform mainly utilizes the filtering coefficients to process the incoming signal from the compensation matrix. Based on these inputs, the discrete wavelet transform can calculate the Daubechies wavelet based on the coefficients that are provided by the user. The software implementation of this module is in C++ and is compiled in MATLAB for compatibility with the other modules. Mathematically, the Daubechies wavelet is calculated as explained in Chapter 2.2. From the mathematical calculation, the output signal is broken down into a signal like the one shown, using the coefficients [0.4830, 0.8365, 0.2241, -0.1294]:



Figure 3.3: Discrete Wavelet Transform of a Sinusoidal Signal

The benefit of using the DWT comes from virtually the second half of the wavelet signal in that the small details can be removed as "noise" from the signal. To achieve that, thresholding is required.

#### 3.5.2: Thresholding

The signal is sent to the thresholding section, which has inputs of the signal and the threshold value that is selected by the user. The user-defined threshold value, however, is only a component for the application of the threshold to the wavelet domain. This threshold value is used for estimating the threshold value that will be cut from the signal. This estimation is done by using the Mean Average Deviation, which utilizes an absolute median function. The median is based on the input signal, specifically, the small detail section of the discrete

wavelet transform. This used in the threshold by multiplying the value by the user-defined input to properly define and specify the wavelet domain value. Once the threshold is properly defined, the values below the threshold are removed from the signal (replaced by 0). The threshold element is implemented using MATLAB code that reads the output of the C++ DWT portion and also reads in the threshold set by the user from the header MATLAB file.

#### 3.5.3: Inverse Wavelet Transform

The signal, now in the wavelet format, is inverse transformed into the original frequency domain signal. The inverse wavelet transform utilizes the same filter coefficients which are inversed for perfect reconstruction. The purpose of performing the inverse transform is to allow the system to recognize and properly detect peaks in the system. The inverse wavelet transform is implemented using C++ code and utilizes the same compiler for MATLAB compatibility. It also reads in the filter coefficients from the header MATLAB file. The coefficients for the inverse wavelet transform are the same as the filter coefficients, only reordered and also two coefficients are negated.

# 3.6: Signal Detection (Frequency Selection)

To detect the two originally transmitted signals, the two highest amplitude peaks in the compounded signal from the inverse wavelet transform are assumed to be the originally transmitted signals. However, since sorting the values in the signal require too much processing, a simpler method of using a threshold is utilized. The two signals from the compounded signal are detected

based on a threshold where frequencies above a certain threshold are assumed to be detected while the frequencies below the threshold are ignored. For the signals that are detected, they are still in the frequency domain. Signal detection is implemented in the software by using MATLAB code, which deals directly with the output of the C++ inverse transform function. An example of signal detection through thresholding is shown below:



Figure 3.4: Signal Detection Through Thresholding

This figure is an example of signal detection through thresholding, using a threshold of -22 dBm. As shown above, the two highest peaks are detected as the two signals.

# 3.7: Hardware Implementation

Hardware implementation for this receiver is done in two languages, AMS Verilog and VHDL. The ADC is implemented in AMS Verilog, because AMS Verilog is able to deal with both the analog and digital portions of the ADC. The simulations for the hardware are done using Synopsis for VHDL and Cadence Custom IC tools for AMS Verilog. Cadence Custom IC Software used IBM's 0.13

micron technology for simulation of the receiver as a whole. This software runs on the Sun machines, using Solaris 8.0. Cadence can use Verilog, AMS-Verilog, and VHDL among other languages for hardware implementation. Usually, a receiver receives the signal as an analog signal, then an ADC is used to convert the analog signal into a digital signal. Both signal processing steps need simulation for complete system verification. As a result, for simulations with the whole system, AMS-Verilog was used for it's flexibility with both the analog and digital parts of the system. The Fast Fourier Transform, the compensation matrix, de-noising function, and the frequency selection are all implemented in VHDL as well, since they all deal with digital signals.

The denoising function is originally implemented in C, but to transfer the same functionality from C to VHDL requires directly translating the function of the C code to VHDL using a structural approach. Because the discrete wavelet transform requires multiplication, look-up tables were used to take the input value and search for the value in the look up table that would be equal to the input value multiplied times a coefficient, for example. This eliminated the requirement of using multipliers with a more hardware efficient result.

## **Chapter 4: Results and Discussion:**

#### 4.1: Simulation Environment

A large portion of the simulations required for the design of the receiver on chip was performed by using MATLAB, an industry and educational standard tool for math, applied science and engineering. MATLAB has the capability to work with numerical processing and has many tools and utilities that are highly suited for signal processing, as well as compatibility with different programming languages. This makes the MATLAB environment an attractive choice for prototyping different signal processing designs. The implementations of the software in the MATLAB environment can be pure MATLAB native code, or a mixture of MATLAB code and other language code. The native MATLAB code is a simple design, which each command calls a function that is in the MATLAB library. However, MATLAB code is an interpreted language, which performs like a script. For example, each command calls a function in the MATLAB library, and each value that is achieved is re-inserted into another function. The nested functions causes the run-time to be relatively slow and processor intensive, as the functions continuously call one another and swap inputs and output data. To overcome this deficiency in speed, MATLAB also has the capability to interpret and use other programming languages, which may be compiled languages. This provides a significant benefit in speed, as the program need not call another function in MATLAB, but have all the functionality available in the compiled program already. This capability is significantly

important to complicated computational programs, which does not need to be recompiled every simulation run. MATLAB only requires that there be a header program that simply denotes the inputs and outputs of the function. This is why there is a mixture of MATLAB code and other code: to allow the interfacing of MATLAB's powerful mathematical capabilities with the practical functionality of other languages.

From the simulation perspective, any machine could be used for simulation. MATLAB is a program that is ported to all the major operating systems, so the simulations were run on three different machines, all using different configurations. The Sun machines, using a 64-bit architecture but with slower clock speed, processed simulations about the same speed as an Intel Pentium 3, which had a higher clock speed, but 32-bit architecture. Running the simulation on an IBM PowerPC G4 processor yielded similar performance. This performance similarity can be attributed to the way MATLAB was designed, and how the GUI interacts with the main core of the program. For the Solaris and Apple Mac OS X versions, both had a GUI that would access the main core program with every command. Through the console, both the Solaris and Mac OS X versions could be accessed through the UNIX prompt and without using the actual GUI. This yielded much faster simulation times than the Windows version, which requires the GUI to interact with the main core system. From this consideration perspective, using the UNIX based system, such as Mac OS X and

Solaris, produced faster simulation runtimes and therefore was the choice of operating system for MATLAB simulations.

Of the languages that MATLAB can use, the easiest to program with the best performance results would be C++. Because C++ is a compiled language, the performance is better than an interpreted language, such as Java. For the signal processing purposes, C++ was the choice of programming languages to implement the discrete wavelet transform (DWT) and it's inverse transform. To properly use the C++ programs with MATLAB, the programs needed to be compiled into MATLAB-compatible files (MEX files). Using MATLAB's C/C++ compiler and MEX file creator, the binaries for the DWT and the IDWT can be implemented for compatibility with MATLAB.

The choice of programming languages was based on the capabilities of the languages to deal with the simulation data and to do numerical processing. MATLAB's native language is able to deal with the numerical processing from the different functions that are implemented in the system. However, to access many of the DWT's architectural designs without re-compiling the DWT software each simulation, C++ was used to design the main computationally intensive modules. Once the modules are compiled, they don't need to be compiled again, thus alleviating extra processing.

In the design of the simulations, there are signals to be generated. To generate the signals to be received by the simulated receiver, two frequencies are designated at random as the two signals and are generated within a 1GHz

bandwidth (from 125 MHz to 1.125 GHz) and have at least 10 MHz separation between them. The strength of these frequencies are defined based on the scenario that is being investigated – for example, where the dynamic range between the highest signal and the second signal is 18 dB, 20 dB, etc. This dynamic range is called the "two-signal dynamic range."

Generated with these signals is random noise, which the receiver must be able to compensate for, especially for greater two signal dynamic ranges (i.e. >18 dB). As mentioned in Chapter 2, scenarios where the noise becomes similar in amplitude and power as the second signal will require some form of signal processing for noise reduction. For each simulation, a randomly generated signal set (1 signal at a "close" range, and 1 signal at a very "far" range, with a difference in 18+ dB between the close and far signal) is done 1000 times, with each time recording the statistical data (1st signal detected, missed, 2nd signal detected, missed, or false alarm). For further proof of concept, a run of 10,000 times is done to further investigate the system performance.

As previously mentioned in Chapter 2, the compensation matrix relies on a set of calculated outcomes of the FFT, and therefore, subtracts the value that is pre-calculated from the actual signal data, exposing the second signal and reducing the actual noise in the signal.



Figure 4.1: General Flow of Receiver Design without De-noising

The de-noising function utilizes a discrete wavelet transform, a threshold, and an inverse transform, as covered in Chapter 2. This method of removing noise from an input signal is based on the use of the inherent properties of the wavelet transform as well as the thresholding methods, which require the use of either a hard or soft threshold. Hard (all values below the threshold are set to 0) and soft (all values are reduced by a certain value) have their own applications for different cases; for the receiver design, both would be investigated to further improve results of the simulation.

## 4.2: Determination of Placement of De-noising Function

Purpose of experiments: To determine the proper placement of the discrete wavelet transform-based de-noising module for effective use in the receiver design.

The first experiments with the de-noising function that uses the discrete wavelet transform dealt with verification of the functionality of the module in a system performance level.



Figure 4.2: Flow Chart for Determining Placement of DWT De-noising

As can be observed from the diagram shown in figure 4.2, there are two methods for the application of this module in the system: placing the module before the compensation matrix or after the compensation matrix. The reason for placing the de-noising function in these two different areas is because the signal

coming from the fast-Fourier transform is a good signal for which the de-noising function can work with. Because the wavelet domain is unknown to the compensation matrix, and thus, renders it useless, there is a need for the FFT to remain in the design.

For 1,000 runs, a test of the different placements of the de-noising function is performed. The frequency of missing the second signal by using two alternatives, placing the de-noising module before or after the compensation matrix, in the system was counted as "2<sup>nd</sup> Missed" in the 1000 runs. Likewise, the frequency of mistakenly counting the noise as the second signal was counted as "2<sup>nd</sup> False Alarm" in the testing. The results can be seen in Table 4.1.

|                             | Before Comp. | After Comp | Difference ( $\Delta$ ) |
|-----------------------------|--------------|------------|-------------------------|
| 2 <sup>nd</sup> Missed      | 53%          | 18%        | 35%                     |
| 2 <sup>nd</sup> False Alarm | 30%          | <1%        | 29%                     |

Table 4.1: Comparison of Second Signal Missed Signal and False Alarm Based on Placement of DWT De-noising

Comparing the two configurations, there is a clear difference in performance between setting the de-noising function before the compensation matrix and setting the de-noising function after the compensation matrix. According to set design specifications, the system must have less than 20% second signal missed, and less than 1% second signal false alarms. As noted by the results above, the best method for using the de-noising function is to place it after the compensation matrix to act as an additional filter.

# 4.3: Determination of Threshold Type

Purpose of Experiments: To determine the best threshold type and threshold value for the best performance in the receiver design.

After observing that the hard thresholding produced more missed signals, but less false alarms from experimental results, it can be concluded that there is a balance to be struck, depending on the threshold value and the type of threshold. In the case of the receiver design, the least number of false alarms is desired, so the hard thresholding was chosen initially.

The following table shows the results by using the 5 different threshold values. Each of the threshold values were tested by using 3 sets of 1,000 random generations of two signal frequencies compounded with random noise using MATLAB. The various threshold values were tested for performance at a two signal dynamic range of 18 dB.

| Threshold Value | False Alarm % |
|-----------------|---------------|
| 2.2             | 1.3 %         |
| 2.3             | 0.93 %        |
| 2.4             | 0.68 %        |
| 2.5             | 0.77 %        |
| 3.0             | 1.6 %         |

Table 4.2: Results of Simulations Testing Threshold Values

From Table 2, it is easy to see that the threshold value of 2.4 would be the best choice for the system to run on at the 18 dB two signal dynamic range. When running through further 10,000 random signal generations, the results showed the false alarm percentage at 0.68% and missed signal at 18.21 %. In comparison

with the compensation matrix alone (0.9 % false alarm percentage), the denoising module is able to effectively aid the performance of the system.

After the threshold value being set, various different experiments were performed using the new threshold value with higher dynamic ranges and further exploring the design. However, at this point, an error was discovered with the compensation matrix, skewing the results so that it would register unacceptable results. This problem was solved by using a different set of rules for the compensation table. While the problem was being addressed, consideration of using the de-noising function with older receiver designs to further prove the effectiveness of the wavelet-based de-noising function in different applications.

# 4.4: Determining Performance Improvement in Mono-bit Receiver

Purpose of Experiments: To determine the performance improvement of the de-noising function when added to the mono-bit receiver design by examining the false alarm cases.

Previous designs of the receiver utilized either the compensation matrix, or did not have any additional technology to detect two signals. To further verify the functionality of the de-noising function in the system, the de-noising function was put into the previous designs, such as the monobit receiver. The main performance specification for the mono-bit receiver is the false alarm rate not to go beyond 1%. There is no specification for the second missed signal as the signal can always be sent again. The mono-bit receiver design has a 2 bit ADC,

and a 4 point kernel FFT. The results for the mono-bit receiver using the denoising function are as follows in Table 4.3:

| dB | Threshold | Hard/Soft | 1st Detect | 2 <sup>nd</sup> Detect | 2 <sup>nd</sup> Miss | 1st False | 2 <sup>nd</sup> False |
|----|-----------|-----------|------------|------------------------|----------------------|-----------|-----------------------|
| 4  | 2.4       | Hard      | 99.96%     | 30.19%                 | 68.96%               | 0.04%     | 0.85%                 |
| 4  | 2.4       | Soft      | 99.95%     | 27.24%                 | 72.47%               | 0.05%     | 0.29%                 |
| 4  | 1.6       | Hard      | 99.98%     | 29.83%                 | 69.29%               | 0.02%     | 0.88%                 |
| 4  | 1.6       | Soft      | 99.99%     | 27.90%                 | 71.66%               | 0.01%     | 0.44%                 |
| 4  | 3.0       | Soft      | 99.95%     | 27.93%                 | 71.82%               | 0.05%     | 0.25%                 |
| 5  | 2.4       | Hard      | 99.99%     | 24.44%                 | 74.73%               | 0.01%     | 0.83%                 |
| 5  | 2.4       | Soft      | 99.95%     | 23.27%                 | 76.50%               | 0.05%     | 0.23%                 |
| 5  | 1.6       | Hard      | 99.99%     | 23.47%                 | 75.76%               | 0.01%     | 0.77%                 |
| 5  | 1.6       | Soft      | 99.99%     | 23.84%                 | 75.81%               | 0.01%     | 0.35%                 |
| 6  | 1.6       | Hard      | 99.99%     | 19.80%                 | 79.38%               | 0.01%     | 0.82%                 |
| 6  | 1.6       | Soft      | 99.99%     | 19.77%                 | 79.98%               | 0.01%     | 0.25%                 |
| 6  | 2.4       | Hard      | 100%       | 19.68%                 | 79.69%               | 0%        | 0.63%                 |
| 6  | 2.4       | Soft      | 99.98%     | 20.94%                 | 78.71%               | 0.02%     | 0.25%                 |

Table 4.3: Results of Simulations Using Random Generation of Signals in Mono-bit Receiver

From these results it can be seen that the soft threshold seems to create more missed signals, but less false alarms than hard threshold, which seems to decrease missed signals, but increase false alarms. The two threshold values were alternated between 2.4 and 1.6 to further test the validity of having a single threshold value.



Figure 4.3: Graph of Signal Detection Types, Percentages and Types of Threshold

Figure 4.3 shows the performance of the system using the de-noising function in terms of first signal detection and second signal detection for different threshold values and types of threshold in the mono-bit receiver design. As can be determined from Figure 4.3, the second signal detection is around 30% while the second signal false alarms remains less than 1%. Looking closer at the different thresholds and types of thresholds, the general trend of the results shows that at 4 dB, the 2.4 hard threshold provides a better result than the 2.4 soft threshold or the 1.6 hard and soft thresholds, as the second missed signal is the lowest at that setting. But as the two signal dynamic range gets larger, the

different types of thresholds provide less and less of a difference. As can be seen with the 6 dB results in Figure 4.3, the second missed signal is virtually the same, no matter which threshold setting is used. This shows that as the two signal dynamic range increases, the difference in using different types of thresholds and threshold values significantly reduces the effect on simulation results.

A closer look at the behavior of the module in the system reveals a better comparison as shown in Table 4.4:

| DR   | Threshold | Hand/Caft | 1st False | 2nd False |
|------|-----------|-----------|-----------|-----------|
| DK   | Threshold | Hard/Soft | 1st raise | Zhu raise |
| 4 dB | 2.4       | Hard      | 0.04%     | 0.85%     |
| 4 dB | 1.6       | Hard      | 0.02%     | 0.88%     |
| 4 dB | 2.4       | Soft      | 0.05%     | 0.29%     |
| 4 dB | 1.6       | Soft      | 0.01%     | 0.44%     |
| 4 dB | 3         | Soft      | 0.05%     | 0.25%     |
| 5 dB | 2.4       | Hard      | 0.01%     | 0.83%     |
| 5 dB | 1.6       | Hard      | 0.01%     | 0.77%     |
| 5 dB | 2.4       | Soft      | 0.05%     | 0.23%     |
| 5 dB | 1.6       | Soft      | 0.01%     | 0.35%     |
| 6 dB | 2.4       | Hard      | 0%        | 0.63%     |
| 6 dB | 1.6       | Hard      | 0.01%     | 0.82%     |
| 6 dB | 2.4       | Soft      | 0.02%     | 0.25%     |
| 6 dB | 1.6       | Soft      | 0.01%     | 0.25%     |

Table 4.4: Table of Results, Specifically False Alarms



Figure 4.4: Graph of False Alarms in Mono-bit Receiver Simulations

The comparison table in Table 4.4 was graphed in Figure 4.4, which clearly shows a relation between the percentages of false alarm signals when using the de-noising function. This further narrows the threshold selection and type of threshold selection for this system, and possibly for the whole system in general. When the design performance is determined by the second signal false alarms, the general trend shown in the graph clearly denotes that the 1.6 soft threshold is the best selection for the monobit receiver design.

Purpose of experiments: To determine the performance improvement of the de-noising function in the mono-bit receiver design by examining the second missed signal.

To further investigate the usefulness of the de-noising function, a close look at the second signal missed signal rate is needed so that a deficit in performance would not be present as a result of using the module. Investigations of the second missed signal reveals the results in Table 4.5 below:

| DR   | Threshold | Hard/Soft | 2nd Miss |
|------|-----------|-----------|----------|
| 4 dB | 2.4       | Hard      | 68.96%   |
| 4 dB | 1.6       | Hard      | 69.29%   |
| 4 dB | 2.4       | Soft      | 72.47%   |
| 4 dB | 1.6       | Soft      | 71.66%   |
| 4 dB | 3         | Soft      | 71.82%   |
| 5 dB | 2.4       | Hard      | 74.73%   |
| 5 dB | 1.6       | Hard      | 75.76%   |
| 5 dB | 2.4       | Soft      | 76.50%   |
| 5 dB | 1.6       | Soft      | 75.81%   |
| 6 dB | 2.4       | Hard      | 79.69%   |
| 6 dB | 1.6       | Hard      | 79.38%   |
| 6 dB | 2.4       | Soft      | 78.71%   |
| 6 dB | 1.6       | Soft      | 79.98%   |

Table 4.5: Table of Results, Specifically Missed Signals

While the second signal is not detected most of the time, the percentage missed seems to marginally increase with the use of the soft thresholding. Figure 4.5 shows the percentage of 2<sup>nd</sup> signal missed in various thresholds and thresholding values. It shows a trend of increasing percentages of 2<sup>nd</sup> signal missing in the monobit receiver with the increase of 2 signal dynamic range.



Figure 4.5: Graph of Percentage Missed vs. Threshold Type

These simulations were conducted using just one DWT de-noising function just before normalization (so there is no visible change to the signal). Some considerations would be to include a combination of hard and soft thresholding in the middle of the function. However, because the performance concerns and the space required would be effectively doubled for the including of both types of thresholds, this idea was abandoned.

# 4.5: Determining Performance Improvement in Receiver on a Chip

Purpose of Experiments: To determine performance improvement of integrating the denoising function in the receiver on a chip design by applying isolated cases where the previous design fails.

After verification that the module works with the monobit receiver in improving performance, further research was done to see if previously unable to detect cases could be detected using the de-noising function integrated into the system. For this, oscilloscope-generated values were imported into the MATLAB simulation. Table 4.6 represents 9 different cases where the system is tested to see if the performance increased at 21 dB 2 signal dynamic range.

| Case # | Freq1 (MHz) | Freq2 (MHz) | Detect With Denoise? |
|--------|-------------|-------------|----------------------|
| 1      | 237.6334    | 863.8414    | Yes, sometimes       |
| 2      | 637.8826    | 612.5074    | No, not at all       |
| 3      | 149.7103    | 1037.336    | Yes, everytime       |
| 4      | 1067.777    | 143.6644    | Yes, everytime       |
| 5      | 129.7335    | 649.8135    | No, not at all       |
| 6      | 852.8769    | 994.1029    | Yes, everytime       |
| 7      | 744.9261    | 1089.383    | Yes, sometimes       |
| 8      | 375.7071    | 863.9413    | Yes, sometimes       |
| 9      | 247.1928    | 746.8173    | Yes, everytime       |

Table 4.6: Table of Isolated Cases and Results from New Configuration

From Table 4.6, it can be seen that while all 9 cases failed for the receiver using the compensation table, sometimes or every time, the de-noising function could detect some of the cases. It further proves that the de-noising function is effective in detecting signals that the compensation matrix by itself could not.

One such case is displayed below in Figure 4.6:



Figure 4.6: Signal Detected Using De-noising Function

In figure 4.6, the peak at the frequency bin 90 is the main signal and after compensation, the peak is removed along with its sidelobes to provide the processing for the second signal. To investigate the performance boost of the denoising function, the second signal detection in general must be taken into consideration. For this purpose, Table 4.7 displays the results at various two-signal dynamic ranges.

| Dynamic Range | Threshold | 2 <sup>nd</sup> Detect | 2 <sup>nd</sup> Missed | 2 <sup>nd</sup> False Alarm |
|---------------|-----------|------------------------|------------------------|-----------------------------|
| 18 dB         | 1.6 Soft  | 82.1%                  | 17.1%                  | 0.8%                        |
| 18 dB         | 2.4 Hard  | 80.68%                 | 18.92%                 | 0.4%                        |
| 19 dB         | 1.6 Soft  | 84%                    | 14.4%                  | 1.6%                        |
| 19 dB         | 2.4 Hard  | 79%                    | 19.5%                  | 1.5%                        |
| 20 dB         | 1.6 Soft  | 78.7%                  | 18.2%                  | 3.1%                        |
| 21 dB         | 1.6 Soft  | 62.2%                  | 33.4%                  | 4.4%                        |

Table 4.7: Simulations with De-noising Function, Specifically Second Signal

As can be seen from Table 4.7, the performance of the receiver can be pushed beyond the 18 dB range of the previous design and still meet the specifications of the design. However, once reaching beyond the 20 dB range, the number of missed signals increases beyond the specification. As can be seen from the data, however, the performance can be tweaked using either a hard or soft threshold.

In Table 4.8 the results are summed up for successful simulations of the receiver design using different components for investigation of the de-noising method as a viable source for reducing noise.



Table 4.8: Table of Acceptable Results with Different Configurations

# 4.6: Hardware Implementation

As an industry standard, VHDL was used to implement the module in a hardware description language. VHDL is a language that is used in industry for describing hardware designs. Therefore, since the signal that is being analyzed with the de-noising function is digital, VHDL is the logical choice. Synopsis tools were used to compile and analyze the VHDL code and also for synthesis. Because the industry standard is to use Synopsis for VHDL synthesis, these tools were used for implementing the system into hardware.

## 4.6.1: VHDL vs. AMS Verilog

AMS Verilog is a flexible language that allows top-down and down-up development techniques for both analog and mixed-signal designs. It is also flexible in that it allows different levels of abstraction for each block, which gives an optimized balance between accuracy and speed. Also, another part of AMS Verilog acts as a script, a command that creates netlists for an entire library. The netlists are created as AMS Verilog netlists, which means if there is code using other analog libraries, the analog libraries used are converted automatically and without destroying any information. Because of this ability, both analog and digital interfaces for different components in a system are accurately inserted into the design so that accuracy is maintained throughout simulation. AMS Verilog also allows for both text and schematic data entry, making either form of entering information readily available.

The environment for entering the AMS Verilog design allows for debugging the mixed signal, analog and digital signals in the system, while also allowing for stand-alone simulation. Because AMS Verilog has so many advantages, mostly based on flexibility, the AMS Verilog language and design environment is very attractive for implementation uses. AMS Verilog was used in the implementation of the ROC, and has direct interface with the de-noising function, which is described next.

## 4.6.2: Hardware Implementation of De-noising Module

For the hardware implementation of the module, a behavioural code, based on the functional C++ code and the MATLAB interface was investigated. Because VHDL implements vectors and arrays differently than C++ and is more rigid as a result (only 1 dimensional arrays can be declared and used), a more structural design was pursued, but still maintaining the behavioural design for flexibility for working with different types.

The design of the de-noising function is shown as programmed in C++ and MATLAB in Figure 4.7:



Figure 4.7: De-noising Function Interfaces

The diagram in Figure 4.7 shows the different functions that are implemented outside of the de-noising function, as well as some of the internal functions of each of the different modules. Most notable are the Daubechie's coefficient calculations of the filter coefficients, which includes adders, multipliers, memory, and some other mathematical operations. These operations, however, are redundant in this design as only one set of coefficients are generated for this application, so instead of using the mathematical operations, the coefficients are stored in memory as an alternative. Further examination of the de-noising function code shows a design flow as shown below:



Figure 4.8: De-noising Function Details

The de-noising function is broken down into several blocks, each containing different elements that would require multiplication, memory and have some recursive processes. These processes will require many resources, especially space in terms of multiplication and memory. To design the de-noising function effectively, considerations of processing intensity and space requirement are important factors in the design. The de-noising function, then, needs to be considered from the basic building blocks of the system and to consider different alternative implementations of each of the different blocks.

The de-noising function is broken up in to 4 separate blocks, as shown below:



Figure 4.9: De-noising Function Block Diagram

The inputs to the discrete wavelet transform is 128 element set of 8 bit data from the compensation table. Each element of the data is assumed to be a positive number because of normalization from the compensation block. However, after a discrete wavelet transform, there are some coefficients that will be negative because of the filter coefficient values used. For negative numbers, the numbers are represented by 2's complement scheme, so the output of the discrete wavelet transform requires 9 bits.

After the discrete wavelet transform, there is a high-pass and a low-pass breakdown of the signal. Both the high-pass and the low-pass signals are transmitted to the thresholding block, where selection of signal removal takes place. In addition, the low-pass component also passes into the threshold estimator unit, which finds the median of the low-pass signal elements and

multiplies that value with a separate coefficient. This allows the thresholding value to be determined for the best possible cut. This value is then passed into the thresholding unit.

Once the signal has been processed through the thresholding unit, the highpass and low-pass signals are passed into the inverse discrete wavelet transform to bring the signal back from the wavelet domain to the frequency domain. From the inverse discrete wavelet transform, the signal is then sent to the frequency selection, which can be easily changed to accommodate the 9 bit outcome of the de-noising function.

## 4.6.2.1: Look Up Table Implementation

There are several methods of hardware implementation of the discrete wavelet transform and it's inverse, as discussed in Chapter 2; however, all the implementations require repeated multiplications in the process. To alleviate any use of multipliers, look up tables can be used to accept the 8 bit value as an address, then output the 9 bit value at the location as the result. This 9 bit value is the calculated coefficient multiplied times every possible input combination, each stored in the address that corresponds with the 8 bit combination. Because look up tables are simpler than multipliers and take up less space, the use of look up tables for the discrete wavelet transform and it's inverse is used in this design.

For the implementation of the inverse discrete transform, look up tables are also used, but in order to access the negative numbers (which are represented with 2's complement) in the table, the order of the table has to be changed to

match the address that is coming into the look up table, as the look up table only accesses addresses as unsigned numbers. For example, the number -5 is "111111011" in 2's complement. When this value is read by the look up table, it will not consider the number as a 2's complement, but rather as an unsigned value, which means the actual value that the look up table interprets the address as is 507. This means that the value that is at the address 507 must have the value -5 multiplied times the coefficient stored in that location. Since the value "100000000" represents the value of negative 0 in 2's complement and is considered 256 in the look up table, this value is stored at position 256. The other values, however, appear in reverse order, from -255 down to -1, at look up table addresses 257 to 511. A diagram of this setup is shown in Figure 4.10.



Figure 4.10: Look Up Table Configuration a) DWT LUT, b) IDWT LUT

#### 4.6.2.2: Decimal Representation in Binary

The numbers represented in the system are normalized numbers, meaning the highest number is 1, being the first signal peak. All the other values are below 1 in amplitude: there is a requirement, then, for a scheme for representing the values in the 8 bit binary for the signal data. The scheme used for the compensation matrix number representation is the biased number representation. For example, the number 0.056202 can be represented with the binary number 00001110 with a bias of 8. The number 00001110 represents the value  $(2^1+2^2+2^3)$ , but with a bias of 8, the formula becomes :

$$00001110 = (2^{1} + 2^{2} + 2^{3}) \times 2^{-8} = (2^{-7} + 2^{-6} + 2^{-5}) = 0.0546875$$
$$0.056202 \approx 0.0546875$$

With this representation scheme, any bias of any number can be used to represent small numbers of this type. The greater the number of biases, the more likely the number will match the intended number. However, the cost of using more bits in a signal is directly proportional to this representation. For the use of this denoising function, a bias of 8 is chosen for the inputs, as the inputs to the denoising function are the outputs from the compensation matrix, which have a bias of 8. For within the look up tables, the values are generated using C code, which utilizes the values from 0 to 255 (all the possible values from the 8 bit input) and multiplies those values with the coefficient required. However, to get the binary representation of the coefficient without hand calculation, the following process was used:

$$h_3 = 0.2241$$
  
 $0.2241 \times 2^8 = 57.3696$   
 $57.3696 \approx 57 = (00111001)_{binary}$ 

This process takes the coefficient and multiplies it with 256 or 28 (which is the bias) and rounds off the result to the nearest integer. This is the approximate binary value of the number using a bias of 8. Throughout the denoising process, the bias of 8 was used to maintain simplicity in the processing circuitry.

## 4.6.2.3: Look Up Table Configuration

There are several coefficients required for the transform process. coefficients are from the discrete wavelet transform based on the Daubechie's wavelet theory. These coefficients are 0.483, 0.8365, 0.2241, and -0.1294, and are referred to as h<sub>1</sub>, h<sub>2</sub>, h<sub>3</sub>, and h<sub>4</sub>, respectively. As previously mentioned, the representation of the numbers uses a bias of 8. However, since h<sub>4</sub> is a negative coefficient, the system requires the use of 2's complement, and thus requires 9 bits for processing within the denoising function. For the inverse transform, there are 6 tables required to be created. Four look up tables are represent the same coefficients as the discrete wavelet transform, but have an addition of 2's complement values. Another two look up tables contain the negative coefficients of h<sub>1</sub> and h<sub>3</sub> for reconstruction, as well as the addition of positive values for any positive value inputs. There is also a look up table for thresholding because there is a coefficient of 1.6/0.67 or 2.388 that is multiplied with the median of the incoming 64 samples from the low-pass signal of the DWT. This provides a viable value to compare the samples from the transform to for cutting. The VHDL code for the different blocks are included in Appendix B.

#### 4.6.2.4: Simulation

To test the functionality of the VHDL, the same inputs for the MATLAB are put in to the system to see the differentiation from the MATLAB due to bit truncation. This bit truncation is due to the default bias of 8 in the numbers on the output of the compensation matrix. Representing the numbers in binary is similar to how the coefficients are represented in binary. The numbers can be quickly generated to provide a speedier way to provide a relatively accurate representation of the number through the same process as how coefficients are represented in binary. VHDL code can be quickly generated, especially if it is redundant code, through the use of a program written in C. This program uses file input and output commands to generate the code, and is included in Appendix C.

When the data is input into the de-noising function, the peak of the data is noted first. For this simulation, the second signal that is generated is at 700 MHz, which corresponds with the 72<sup>nd</sup> frequency bin. The peak in the data, therefore appears at the 72<sup>nd</sup> sample. From Figure 4.11 shows below, it is shown that the peak value from the VHDL implementation of the DWT based de-noising function is at frequency bin 72, which matches the input data. However, the spurs in the signal are reduced to very low values due to the thresholding unit in the de-noising function implemented in the VHDL. The threshold value that was implemented in the LUT was 1.6, which was observed to be the best overall threshold value for this application.



Figure 4.11: De-noising Function in VHDL Simulation

From this simulation, it can be seen that the de-noising module is effectively implemented in VHDL, which can be used for hardware simulation and implementation on a chip or an FPGA. In terms of hardware cost, the number of LUTs along with the sizes of each, the size and number of adders, and the size and number of muxes are the important features to consider. The component breakdown can be seen in Table 4.9:

| Module/Component                      | Number | Size      |
|---------------------------------------|--------|-----------|
| DWT:                                  |        |           |
| LUT (8-b in/ 9-b out)                 | 4      | 256 x 9-b |
| Adder (8-b)                           | 256    |           |
| Adder (9-b)                           | 128    |           |
| Threshold Estimator:                  |        |           |
| <i>Mux</i> (9- <i>b</i> 2 <i>x</i> 1) | 1      |           |
| Comparators                           | 128    |           |
| Thresholding:                         |        |           |
| LUT (9-b in/ 9-b out)                 | 1      | 512 x 9-b |
| <i>Mux</i> (9- <i>b</i> 2 <i>x</i> 1) | 128    |           |
| IDWT:                                 |        |           |
| LUT (9-b in/ 9-b out)                 | 6      | 512 x 9-b |
| Adder (9-b)                           | 256    |           |
| Adder (10-b)                          | 128    |           |
| Total Component Costs:                |        |           |
| LUT (8-b in/ 9-b out)                 | 4      | 256 x 9-b |
| Adder (8-b)                           | 256    |           |
| Adder (9-b)                           | 384    |           |
| Adder (10-b)                          | 128    |           |
| LUT (9-b in/ 9-b out)                 | 7      | 512 x 9-b |
| <i>Mux</i> (9- <i>b</i> 2 <i>x</i> 1) | 129    |           |
| Comparators                           | 128    |           |

Table 4.9: Component Requirements for De-noising Function

Storage for the values while processing the different elements are also required, but can be allocated dynamically with the memory that is allocated for the compensation matrix operations. The hardware requirements for the denoising function can easily be implemented using pipeline structures in ASIC. Furthermore, the LUTs can be implemented efficiently in an FPGA configuration, which would further reduce the hardware implementation requirements so that the actual hardware cost of the de-noising function in relation to the receiver on chip design is relatively small, especially when considering the size of the FFT and compensation matrix.

# **Chapter 5: Conclusion and Recommendations**

#### 5.1: Conclusion

For effective signal processing that performs beyond a receiver on chip design with a compensation table, the discrete wavelet transform-based de-noising function is a valid solution. The discrete wavelet transform breaks down the incoming signal into high pass and low pass components. Low pass components are considered small details while high pass components are considered large Because spurious signals are considered small details in a discrete wavelet transform domain, thresholding is required to remove the spurious signals. When the thresholding is completed, the inverse transform reassembles the signal to the original signal domain. For the receiver on chip design, the denoising function is effective for improving performance of the receiver for detecting the second signal from two-signal dynamic ranges of 18 dB to 22 dB. This thesis describes the investigation and implementation of a de-noising module that utilizes a configuration that is effective for increasing the two signal dynamic range beyond 18 dB. By using look up tables, the de-noising function is implemented in VHDL in an efficient design that eliminates the need for multipliers and thus, reduces the hardware cost of the module.

### **5.2:** Recommendations

I recommend an implementation of the discrete wavelet transform with greater number of bits for better precision and for the design to further improve performance of the receiver on chip design. Because the maximum number of bits for the coefficients to have perfect precision is 19 bits, I would recommend that a 19 bit design be pursued to have a complete design. The only drawback to this design would be that the increase in bits will require a larger space for the LUTs because the values required will be stored as 256 values, each being 19 bits. For negative numbers, there will be 512 values, each being 19 bits.

I also recommend implementation of this design in ASIC to investigate the speed benefits of ASIC design and to also investigate new designs for different registers, such as double-edge trigger D-flip flops, new ADC designs, and possibly new compensation matrix calculations. It would be interesting to see what effect the newer components in the receiver design would have on the denoising process.

# **References:**

- [1] J. Proakis and D. Manolakis. "Digital Signal Processing: Principles,
  Algorithms, and Applications, Third Edition" New York: Prentice Hall,
  1998.
- [2] D. Pok, C.-I. H. Chen, J. Schamus, C. Montgomery, and J. B. Y. Tsui, "Chip design for monobit receiver," IEEE Trans. Microwave Theory Tech., Vol. 45, No. 12, pp 2283-2295, December 1997.
- [3] C. H. Chen, and K. George. "Design and Performance Evaluation of a 2.5-GSPS Digital Receiver." IEEE Transactions on Instrumentation and Measurement. Vol. 54, No. 3, pp 1089-1099, June 2005.
- [4] J. Särelä and H. Valpola. "De-noising Source Separation." Journal of Machine Learning Research 6. (March 2005): 233-272.
- [5] G. Dimitroulakos, M. D. Galanis, A. Milidonis, and C. E. Goutis, "A high-throughput, memory efficient architecture for computing the tile-based 2D discrete wavelet transform for the JPEG2000." Integration, Journal 39, pp 1-11, 2005.
- [6] A. Jensen, and A. la Cour-Harbo. <u>Ripples in Mathematics: The Discrete Wavelet Transform</u>. New York: Springer-Verlag, 2001.
- [7] Y. Nievergelt. Wavelets Made Easy. Boston: Birkhäuser, 2001.
- [8] D. Walnut. An Introduction to Wavelet Analysis. Boston: Birkhäuser, 2002.
- [9] M. Jansen. <u>Noise Reduction by Wavelet Thresholding</u>. New York: Springer-Verlag, 2001.
- [10] P. Vaidyanathan. "Multirate Systems and Filter Banks." New York: Prentice Hall, 1993.
- [11] V. Herrero, J. Cerdà, R. Gadea, M. Martinez, and A. Sebastià.

  "Implementation of 1-D Daubechies Wavelet Transform on FPGA."
- [12] G. Kuzmanov and B. Zafarifar. "Reconfigurable DWT Unit Based on Lifting."

- [13] C. Huang, P. Tseng, and L. Chen. "Analysis and VLSI Architecture for 1-D and 2-D Discrete Wavelet Transform." IEEE Transactions on Signal Processing, Vol. 53, No. 4, pp. 1575 – 1586, April 2005.
- [14] M. Nibourche, A. Bouridane, F. Murtagh, and O. Nibouche. "FPGA-Based Discrete Wavelet Transforms System."
- [15] B.-F. Wu and Y.-Q. Hu. "An Efficient VLSI Implementation of the Discrete Wavelet Transform Using Embedded Instruction Codes for Symmetric Filters." IEEE Transactions on Circuits and Systems for Video Technology, Vol. 13, No. 9, pp. 936 – 943, September 2003.
- [16] F. Maire. "Low Power Implementation for a Class of Orthogonal Wavelet Transform Using Synthesizable VHDL." Master of Science Thesis in Electronic System Design, University of Stockholm, Stockholm, Norway, September 1999.
- [17] C.-T. Huang, P.-C. Tseng and L.-G. Chen. "Flipping Structure: An Efficient VLSI Architecture for Lifting-Based Discrete Wavelet Transform." IEEE Transactions on Signal Processing, Vol. 52, No. 4, pp. 1080 – 1089, April 2004.

# Appendix A:

%File Name: denoise.m

```
Denoising Function MATLAB Code:
function [xd,xn,option] = denoise(x,h,type,option)
   [xd,xn,option] = denoise(x,h,type,option);
%
   DENOISE is a generic program for wavelet based denoising.
% The program will denoise the signal x using the 2-band wavelet
   system described by the filter h using either the traditional
   discrete wavelet transform (DWT) or the linear shift invariant
   discrete wavelet transform (also known as the undecimated DWT
   (UDWT)).
%
%
   Input:
%
            : 1D or 2D signal to be denoised
     x
%
            : Scaling filter to be applied
%
            : Type of transform (Default: type = 0)
%
            0 --> Discrete wavelet transform (DWT)
%
            1 --> Undecimated DWT (UDWT)
%
     option : Default settings is marked with '*':
%
            *type = 0 --> option = [0 \ 3.0 \ 0 \ 0 \ 0]
%
            type = 1 --> option = [0 3.6 0 1 0 0]
%
     option(1): Whether to threshold low-pass part
%
            0 --> Don't threshold low pass component
%
            1 --> Threshold low pass component
%
     option(2): Threshold multiplier, c. The threshold is
%
            computed as:
%
             thld = c*MAD(noise\_estimate)).
%
            The default values are:
%
             c = 3.0 for the DWT based denoising
%
             c = 3.6 for the UDWT based denoising
%
     option(3): Type of variance estimator
%
            0 --> MAD (mean absolute deviation)
%
            1 --> STD (classical numerical std estimate)
%
     option(4): Type of thresholding
%
            0 --> Soft thresholding
%
            1 --> Hard thresholding
%
     option(5): Number of levels, L, in wavelet decomposition. By
%
            setting this to the default value '0' a maximal
%
            decomposition is used.
%
     option(6): Actual threshold to use (setting this to
%
            anything but 0 will mean that option(3)
%
            is ignored)
%
%
   Output:
%
          : Estimate of noise free signal
%
     xn : The estimated noise signal (x-xd)
     option: A vector of actual parameters used by the
%
          program. The vector is configured the same way as
%
          the input option vector with one added element
          option(7) = type.
```

```
%Last Modification Date: 04/15/97
                                         10:44:28
%Current Version: denoise.m 2.4
%File Creation Date: Mon Feb 20 08:33:15 1995
%Author: Jan Erik Odegard <odegard@ece.rice.edu>
%Copyright (c) 2000 RICE UNIVERSITY. All rights reserved.
%Created by Jan Erik Odegard, Department of ECE, Rice University.
%This software is distributed and licensed to you on a non-exclusive
%basis, free-of-charge. Redistribution and use in source and binary forms,
% with or without modification, are permitted.
if (nargin < 2)
 error('You need to provide at least 2 inputs: x and h');
end;
if(nargin < 3),
 type = 0;
 option = [];
elseif(nargin < 4)
 option = [];
end;
if(isempty(type)),
 type = 0;
end;
if(type == 0),
 default_opt = [0 \ 3.0 \ 0 \ 0 \ 0];
elseif(type == 1),
 default opt = [0.3.60100];
 error(['Unknown denoising method',10,...
         'If it is any good we need to have a serious talk :-)']);
end;
option = setopt(option,default_opt);
[mx,nx] = size(x);
dim = min(mx,nx);
if(dim == 1),
 n = max(mx,nx);
else,
n = dim:
end;
if(option(5) == 0),
L = floor(log2(n));
else
 L = option(5);
end;
if(type == 0),
                                 % Denoising by DWT
 xd = mdwt(x,h,L);
 if (option(6) == 0),
  tmp = xd(floor(mx/2)+1:mx,floor(nx/2)+1:nx);
  if(option(3) == 0),
   thld = option(2)*median(abs(tmp(:)))/.67;
  elseif(option(3) == 1),
   thld = option(2)*std(tmp(:));
```

```
else
   error('Unknown threshold estimator, Use either MAD or STD');
  end;
 else,
  thld = option(6);
 end;
 if(dim == 1)
  ix = 1:n/(2^L);
  ykeep = xd(ix);
 else
  ix = 1:mx/(2^L);
  jx = 1:nx/(2^L);
  ykeep = xd(ix,jx);
 end;
 if(option(4) == 0),
  xd = SoftTh(xd,thld);
 elseif(option(4) == 1),
  xd = HardTh(xd,thld);
 else,
  error('Unknown threshold rule. Use either Soft (0) or Hard (1)');
 end;
 if (option(1) == 0),
  if(dim == 1),
   xd(ix) = ykeep;
  else,
   xd(ix,jx) = ykeep;
  end;
 end;
 xd = midwt(xd,h,L);
elseif(type == 1),
                                          % Denoising by UDWT
 [xl,xh] = mrdwt(x,h,L);
 if(dim == 1),
  c_offset = 1;
 else,
  c_{offset} = 2*nx + 1;
 end;
 if (option(6) == 0),
  tmp = xh(:,c_offset:c_offset+nx-1);
  if(option(3) == 0),
   thld = option(2)*median(abs(tmp(:)))/.67;
  elseif(option(3) == 1),
   thld = option(2)*std(tmp(:));
  else
   error('Unknown threshold estimator, Use either MAD or STD');
  end;
 else,
  thld = option(6);
 end;
 if(option(4) == 0),
  xh = SoftTh(xh,thld);
  if(option(1) == 1),
   xl = SoftTh(xl,thld);
  end;
```

```
elseif(option(4) == 1),
  xh = HardTh(xh,thld);
  if(option(1) == 1),
   xl = HardTh(xl,thld);
  end;
else,
  error('Unknown threshold rule. Use either Soft (0) or Hard (1)');
xd = mirdwt(xl,xh,h,L);
else,
                                        % Denoising by unknown method
error(['Unknown denoising method',10,...
     'If it is any good we need to have a serious talk :-)']);
end;
option(6) = thld;
option(7) = type;
xn = x - xd;
Daubechie's Wavelet Coefficient Calculations:
function [h_0,h_1] = daubcqf(N,TYPE)
   [h_0,h_1] = daubcqf(N,TYPE);
%
   Function computes the Daubechies' scaling and wavelet filters
   (normalized to sqrt(2)).
%
%
   Input:
%
     N : Length of filter (must be even)
%
     TYPE: Optional parameter that distinguishes the minimum phase,
%
         maximum phase and mid-phase solutions ('min', 'max', or
%
         'mid'). If no argument is specified, the minimum phase
%
         solution is used.
%
%
   Output:
%
     h_0: Minimal phase Daubechies' scaling filter
     h_1: Minimal phase Daubechies' wavelet filter
   Reference: "Orthonormal Bases of Compactly Supported Wavelets",
%
          CPAM, Oct.89
%
%File Name: daubcqf.m
%Last Modification Date: 01/02/96
                                       15:12:57
%Current Version: daubcqf.m 2.4
%File Creation Date: 10/10/88
%Author: Ramesh Gopinath <ramesh@dsp.rice.edu>
%Copyright (c) 2000 RICE UNIVERSITY. All rights reserved.
% Created by Ramesh Gopinath, Department of ECE, Rice University.
if(nargin < 2),
TYPE = 'min';
end;
if(rem(N,2) \sim= 0),
error('No Daubechies filter exists for ODD length');
end;
```

```
K = N/2;
a = 1:
p = 1;
q = 1;
h_0 = [1 1];
for j = 1:K-1,
 a = -a * 0.25 * (j + K - 1)/j;
 h_0 = [0 h_0] + [h_0 0];
 p = [0 - p] + [p 0];
 p = [0 - p] + [p 0];
 q = [0 \ q \ 0] + a*p;
end;
q = sort(roots(q));
qt = q(1:K-1);
if TYPE=='mid',
 if rem(K,2) == 1,
  qt = q([1:4:N-2 : 2:4:N-2]);
 else
  qt = q([1 4:4:K-1 5:4:K-1 N-3:-4:K N-4:-4:K]);
 end;
end;
h_0 = conv(h_0, real(poly(qt)));
h_0 = sqrt(2)*h_0/sum(h_0);
                                 %Normalize to sqrt(2);
if(TYPE=='max'),
h_0 = fliplr(h_0);
end;
if(abs(sum(h_0 .^2))-1 > 1e-4)
 error('Numerically unstable for this value of "N".');
end;
h_1 = rot90(h_0,2);
h_1(1:2:N)=-h_1(1:2:N);
Discrete Wavelet Transform C++ Code:
File Name: MDWT.c
Last Modification Date: 06/14/95
                                         13:15:44
Current Version: MDWT.c
                                 2.4
File Creation Date: Wed Oct 19 10:51:58 1994
Author: Markus Lang <lang@jazz.rice.edu>
Copyright (c) 2000 RICE UNIVERSITY. All rights reserved.
Created by Markus Lang, Department of ECE, Rice University.
%y = mdwt(x,h,L);
% function computes the discrete wavelet transform y for a 1D or 2D input
% signal x.
%
%
   Input:
%
        x : finite length 1D or 2D signal (implicitely periodized)
%
     h : scaling filter
%
     L : number of levels. in case of a 1D signal length(x) must be
%
          divisible by 2<sup>L</sup>; in case of a 2D signal the row and the
```

```
%
         column dimension must be divisible by 2<sup>L</sup>.
% see also: midwt, mrdwt, mirdwt
*/
#include <math.h>
#include <stdio.h>
#define max(A,B) (A > B? A : B)
#define mat(a, i, j) (*(a + (m*(j)+i))) /* macro for matrix indices */
#ifdef STDC
MDWT(double *x, int m, int n, double *h, int lh, int L, double *y)
MDWT(x, m, n, h, lh, L, y)
double *x, *h, *y;
int m, n, lh, L;
#endif
 double *h0, *h1, *ydummyl, *ydummyh, *xdummy;
 long i, j;
 int actual_L, actual_m, actual_n, r_o_a, c_o_a, ir, ic, lhm1;
 xdummy = (double *)mxCalloc(max(m,n)+lh-1,sizeof(double));
 ydummyl = (double *)mxCalloc(max(m,n),sizeof(double));
 ydummyh = (double *)mxCalloc(max(m,n),sizeof(double));
 h0 = (double *)mxCalloc(lh,sizeof(double));
 h1 = (double *)mxCalloc(lh,sizeof(double));
 /* analysis lowpass and highpass */
 if (n==1){
  n = m;
  m = 1;
 for (i=0; i<lh; i++){
  h0[i] = h[lh-i-1];
  h1[i] = h[i];
 for (i=0; i<1h; i+=2)
  h1[i] = -h1[i];
 lhm1 = lh - 1;
 actual_m = 2*m;
 actual_n = 2*n;
 /* main loop */
 for (actual_L=1; actual_L <= L; actual_L++){</pre>
  if (m==1)
   actual_m = 1;
  else{
   actual m = actual m/2;
   r_o_a = actual_m/2;
```

```
actual_n = actual_n/2;
  c o a = actual n/2;
  /* go by rows */
  for (ir=0; ir<actual_m; ir++){
                                     /* loop over rows */
   /* store in dummy variable */
   for (i=0; i<actual_n; i++)
        if (actual L==1)
         xdummy[i] = mat(x, ir, i);
         xdummy[i] = mat(y, ir, i);
   /* perform filtering lowpass and highpass*/
   fpsconv(xdummy, actual_n, h0, h1, lhm1, ydummyl, ydummyh);
   /* restore dummy variables in matrices */
   ic = c_o_a;
   for (i=0; i < c_o_a; i++)
        mat(y, ir, i) = ydummyl[i];
        mat(y, ir, ic++) = ydummyh[i];
   }
  }
  /* go by columns in case of a 2D signal*/
  if (m>1){
   for (ic=0; ic<actual_n; ic++){</pre>
                                      /* loop over column */
        /* store in dummy variables */
        for (i=0; i<actual_m; i++)
         xdummy[i] = mat(y, i, ic);
        /* perform filtering lowpass and highpass*/
        fpsconv(xdummy, actual_m, h0, h1, lhm1, ydummyl, ydummyh);
        /* restore dummy variables in matrix */
        ir = r_o_a;
        for (i=0; i<r_o_a; i++){
         mat(y, i, ic) = ydummyl[i];
         mat(y, ir++, ic) = ydummyh[i];
#ifdef STDC
fpsconv(double *x_in, int lx, double *h0, double *h1, int lhm1,
        double *x_outl, double *x_outh)
#else
fpsconv(x_in, lx, h0, h1, lhm1, x_outl, x_outh)
double *x_in, *h0, *h1, *x_outl, *x_outh;
int lx, lhm1;
#endif
 int i, j, ind;
 double x0, x1;
```

```
for (i=lx; i < lx+lhm1; i++)
  x_{in}[i] = *(x_{in}+(i-lx));
 ind = 0;
 for (i=0; i<(1x); i+=2){
  x0 = 0;
  x1 = 0;
  for (j=0; j<=lhm1; j++){}
   x0 = x0 + x_{in}[i+j]*h0[lhm1-j];
   x1 = x1 + x_{in}[i+j]*h1[lhm1-j];
  x_{outl[ind]} = x0;
  x \text{ outh[ind++]} = x1;
Inverse DWT C++ Code:
File Name: MIDWT.c
Last Modification Date: 06/14/95
                                          13:01:15
Current Version: MIDWT.c
File Creation Date: Wed Oct 12 08:44:43 1994
Author: Markus Lang <lang@jazz.rice.edu>
Copyright (c) 2000 RICE UNIVERSITY. All rights reserved.
Created by Markus Lang, Department of ECE, Rice University.
description of the matlab call:
%v = midwt(x,h,L);
% function computes the inverse discrete wavelet transform y for a 1D or 2D
% input signal x.
%
%
   Input:
%
        x : finite length 1D or 2D input signal (implicitely periodized)
%
     h : scaling filter
     L : number of levels. in case of a 1D signal length(x) must be
%
%
          divisible by 2<sup>L</sup>; in case of a 2D signal the row and the
%
          column dimension must be divisible by 2<sup>L</sup>.
%
% see also: mdwt, mrdwt, mirdwt*/
#include <math.h>
#include <stdio.h>
#define max(A,B) (A > B ? A : B)
#define mat(a, i, j) (*(a + (m*(j)+i))) /* macro for matrix indices */
#ifdef __STDC__
MIDWT(double *x, int m, int n, double *h, int lh, int L, double *y)
MIDWT(x, m, n, h, lh, L, y)
double *x, *h, *y;
```

```
int m, n, lh, L;
#endif
 double *g0, *g1, *ydummyl, *ydummyh, *xdummy;
 int actual_L, actual_m, actual_n, r_o_a, c_o_a, ir, ic, lhm1, lhhm1, sample_f;
 xdummy = (double *)mxCalloc(max(m,n),sizeof(double));
 ydummyl = (double *)mxCalloc(max(m,n)+lh/2-1,sizeof(double));
 ydummyh = (double *)mxCalloc(max(m,n)+lh/2-1,sizeof(double));
 g0 = (double *)mxCalloc(lh,sizeof(double));
 g1 = (double *)mxCalloc(lh,sizeof(double));
 if (n==1){
 n = m;
  m = 1;
 /* synthesis lowpass and highpass */
 for (i=0; i<lh; i++){
  g0[i] = h[i];
  g1[i] = h[lh-i-1];
 for (i=1; i<=1h; i+=2)
  g1[i] = -g1[i];
 lhm1 = lh - 1;
 lhhm1 = lh/2 - 1;
 /* 2^L */
 sample f = 1;
 for (i=1; i<L; i++)
  sample_f = sample_f*2;
 if (m>1)
  actual_m = m/sample_f;
 else
  actual_m = 1;
 actual_n = n/sample_f;
 for (i=0; i<(m*n); i++)
  x[i] = y[i];
 /* main loop */
 for (actual_L=L; actual_L >= 1; actual_L--){
  r_o_a = actual_m/2;
  c_o_a = actual_n/2;
  /* go by columns in case of a 2D signal*/
  if (m>1){
   for (ic=0; ic<actual_n; ic++){
                                      /* loop over column */
        /* store in dummy variables */
        ir = r_o_a;
        for (i=0; i < r \ o \ a; i++)
         ydummyl[i+lhhm1] = mat(x, i, ic);
         ydummyh[i+lhhm1] = mat(x, ir++, ic);
```

```
/* perform filtering lowpass and highpass*/
        bpsconv(xdummy, r_o_a, g0, g1, lhm1, lhhm1, ydummyl, ydummyh);
        /* restore dummy variables in matrix */
        for (i=0; i<actual_m; i++)
         mat(x, i, ic) = xdummy[i];
  /* go by rows */
  for (ir=0; ir<actual_m; ir++){</pre>
                                      /* loop over rows */
   /* store in dummy variable */
   ic = c o a;
   for (i=0; i < c_o_a; i++)
        ydummyl[i+lhhm1] = mat(x, ir, i);
        ydummyh[i+lhhm1] = mat(x, ir, ic++);
   /* perform filtering lowpass and highpass*/
   bpsconv(xdummy, c_o_a, g0, g1, lhm1, lhhm1, ydummyl, ydummyh);
   /* restore dummy variables in matrices */
   for (i=0; i<actual_n; i++)
    mat(x, ir, i) = xdummy[i];
  if (m==1)
   actual_m = 1;
   actual_m = actual_m*2;
  actual n = actual n*2;
#ifdef __STDC_
bpsconv(double *x_out, int lx, double *g0, double *g1, int lhm1,
        int lhhm1, double *x_inl, double *x_inh)
#else
bpsconv(x_out, lx, g0, g1, lhm1, lhhm1, x_inl, x_inh)
double *x_inl, *x_inh, *g0, *g1, *x_out;
int lx, lhm1, lhhm1;
#endif
 int i, j, ind, tj;
 double x0, x1;
 for (i=lhhm1-1; i > -1; i--){
  x_{inl[i]} = x_{inl[lx+i]};
  x_{inh[i]} = x_{inh[lx+i]};
 ind = 0;
 for (i=0; i<(lx); i++)
  x0 = 0;
  x1 = 0;
  t_i = -2;
  for (j=0; j<=lhhm1; j++){
   tj+=2;
```

```
x0 = x0 + x_{inl}[i+j]*g0[lhm1-1-tj] + x_{inh}[i+j]*g1[lhm1-1-tj];
   x1 = x1 + x_{inl}[i+j]*g0[lhm1-tj] + x_{inh}[i+j]*g1[lhm1-tj];
  x_{out}[ind++] = x0;
  x_{out}[ind++] = x1;
Hard Thresholding MATLAB Code:
function x = HardTh(y,thld)
% x = HardTh(y,thld);
% HARDTH hard thresholds the input signal y with the threshold value
% thld.
%
% Input:
%
     y: 1D or 2D signal to be thresholded
%
     thld: threshold value
%
% Output:
     x: Hard thresholded output (x = (abs(y)>thld).*y)
%File Name: HardTh.m
%Last Modification Date: 8/15/95
                                        17:49:37
%Current Version: HardTh.m 2.4
%File Creation Date: Mon Jan 31 09:42:50 1994
%Author: Haitao Guo <a href="mailto:harry@jazz.rice.edu">harry@jazz.rice.edu</a>
%Copyright (c) 2000 RICE UNIVERSITY. All rights reserved.
%Created by Haitao Guo, Department of ECE, Rice University.
x = (abs(y) > thld).*y;
Soft Thresholding MATLAB Code:
function x = SoftTh(y,thld)
   x = SoftTh(y,thld);
%
   SOFTTH soft thresholds the input signal y with the threshold value
%
   thld.
%
% Input:
     y : 1D or 2D signal to be thresholded
%
     thld: Threshold value
%
% Output:
     x : Soft thresholded output (x = sign(y)(|y|-thld)_+)
%
   Reference:
     "De-noising via Soft-Thresholding" Tech. Rept. Statistics,
%
     Stanford, 1992. D.L. Donoho.
%File Name: SoftTh.m
%Last Modification Date: 8/15/95
                                        17:49:48
%Current Version: SoftTh.m
```

```
%File Creation Date: Mon Mar 7 10:38:45 1994  
%Author: Haitao Guo <a href="harry@jazz.rice.edu">harry@jazz.rice.edu</a>
```

$$x = abs(y);$$
  
 $x = sign(y).*(x \ge thld).*(x - thld);$ 

## Appendix B:

```
-Daubechies Wavelet Transform using LUT design
-- This design does not incorporate any safety nets for overflow.
-- h1 values are in lut_h1, lut_h2, lut_h3, lut_h4
-- h0 values are in lut_h4, lut_h3, lut_h2, lut_h1, respectively for each of
-- the coefficients.
library ieee;
use ieee.std logic 1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_signed.all;
entity dwt is
        port (
                xin 0 : in std logic vector(7 downto 0);
                xin_1 : in std_logic vector(7 downto 0);
                xin 2 : in std logic vector(7 downto 0);
                xin 3 : in std logic vector(7 downto 0);
                xin_4 : in std_logic_vector(7 downto 0);
                xin_5 : in std_logic_vector(7 downto 0);
                xin_6 : in std_logic_vector(7 downto 0);
                xin 7 : in std logic vector(7 downto 0);
                xin 8 : in std logic vector(7 downto 0);
                xin 9 : in std logic vector(7 downto 0);
                xin_10 : in std_logic_vector(7 downto 0);
                xin 11 : in std logic vector(7 downto 0);
                xin 12 : in std logic vector(7 downto 0);
                xin_13 : in std_logic_vector(7 downto 0);
                xin_14 : in std_logic_vector(7 downto 0);
                xin_15 : in std_logic_vector(7 downto 0);
xin_16 : in std_logic_vector(7 downto 0);
xin_17 : in std_logic_vector(7 downto 0);
                xin 18 : in std logic vector(7 downto 0);
                xin_19 : in std_logic vector(7 downto 0);
                xin 20 : in std logic vector(7 downto 0);
                xin 21 : in std logic vector(7 downto 0);
                xin_22 : in std_logic_vector(7 downto 0);
                xin_23 : in std_logic_vector(7 downto 0);
                xin_24 : in std_logic_vector(7 downto 0);
                xin_25 : in std_logic_vector(7 downto 0);
                xin 26 : in std logic vector(7 downto 0);
                xin 27 : in std_logic_vector(7 downto 0);
                xin_28 : in std_logic_vector(7 downto 0);
                xin_29 : in std_logic_vector(7 downto 0);
                xin 30 : in std logic vector (7 downto 0);
                xin 31 : in std logic vector (7 downto 0);
                xin_32 : in std_logic_vector(7 downto 0);
                xin_33 : in std_logic_vector(7 downto 0);
                xin_34 : in std_logic_vector(7 downto 0);
xin_35 : in std_logic_vector(7 downto 0);
xin_36 : in std_logic_vector(7 downto 0);
                xin_37 : in std_logic_vector(7 downto 0);
                xin 38 : in std logic vector(7 downto 0);
                xin 39 : in std logic vector (7 downto 0);
                xin 40 : in std logic vector (7 downto 0);
                xin 41 : in std logic vector(7 downto 0);
                xin_42 : in std_logic_vector(7 downto 0);
                xin_43 : in std_logic_vector(7 downto 0);
xin_44 : in std_logic_vector(7 downto 0);
                xin_45 : in std_logic_vector(7 downto 0);
                xin 46 : in std logic vector (7 downto 0);
                xin 47 : in std logic vector(7 downto 0);
```

```
xin 48 : in std logic vector(7 downto 0);
xin 49 : in std logic vector(7 downto 0);
xin 50 : in std_logic_vector(7 downto 0);
xin_51 : in std_logic_vector(7 downto 0);
xin_52 : in std_logic_vector(7 downto 0);
xin_53 : in std_logic_vector(7 downto 0);
xin 54 : in std logic vector(7 downto 0);
xin 55 : in std logic vector(7 downto 0);
xin 56 : in std logic vector(7 downto 0);
xin 57 : in std logic vector(7 downto 0);
xin 58 : in std logic vector(7 downto 0);
xin_59 : in std_logic_vector(7 downto 0);
xin_60 : in std_logic_vector(7 downto 0);
xin_61 : in std_logic_vector(7 downto 0);
xin_62 : in std_logic_vector(7 downto 0);
xin_63 : in std_logic_vector(7 downto 0);
xin_64 : in std_logic_vector(7 downto 0);
xin_65 : in std_logic_vector(7 downto 0);
xin_66 : in std_logic_vector(7 downto 0);
xin 67: in std logic vector (7 downto 0);
xin 68 : in std logic vector (7 downto 0);
xin 69 : in std logic vector(7 downto 0);
xin_70 : in std_logic_vector(7 downto 0);
xin_71 : in std_logic_vector(7 downto 0);
xin_72 : in std_logic_vector(7 downto 0);
xin_73 : in std_logic_vector(7 downto 0);
xin 74 : in std logic vector (7 downto 0);
xin 75 : in std logic vector(7 downto 0);
xin 76 : in std logic vector(7 downto 0);
xin 77 : in std logic vector (7 downto 0);
xin 78 : in std logic vector(7 downto 0);
xin_79 : in std_logic_vector(7 downto 0);
xin_80 : in std_logic_vector(7 downto 0);
xin_81 : in std_logic_vector(7 downto 0);
xin_82 : in std_logic_vector(7 downto 0);
xin 83 : in std logic vector (7 downto 0);
xin 84 : in std logic vector(7 downto 0);
xin 85 : in std logic vector(7 downto 0);
xin 86 : in std logic vector(7 downto 0);
xin 87 : in std logic vector(7 downto 0);
xin_88 : in std_logic_vector(7 downto 0);
xin_89 : in std_logic_vector(7 downto 0);
xin_90 : in std_logic_vector(7 downto 0);
xin_91 : in std_logic_vector(7 downto 0);
xin_92 : in std_logic_vector(7 downto 0);
xin 93 : in std logic vector(7 downto 0);
xin 94 : in std logic vector (7 downto 0);
xin 95 : in std logic vector (7 downto 0);
xin 96 : in std logic vector(7 downto 0);
xin 97 : in std_logic_vector(7 downto 0);
xin_98 : in std_logic_vector(7 downto 0);
xin_99 : in std_logic_vector(7 downto 0);
xin_100 : in std_logic_vector(7 downto 0);
xin_101 : in std_logic_vector(7 downto 0);
xin 102 : in std logic vector(7 downto 0);
xin_103 : in std_logic_vector(7 downto 0);
xin 104 : in std logic vector(7 downto 0);
xin 105 : in std logic vector(7 downto 0);
xin 106 : in std logic vector(7 downto 0);
xin_107 : in std_logic_vector(7 downto 0);
xin_108 : in std_logic_vector(7 downto 0);
xin_109 : in std_logic_vector(7 downto 0);
xin_110 : in std_logic_vector(7 downto 0);
xin 111 : in std logic vector(7 downto 0);
```

```
xin 112 : in std logic vector(7 downto 0);
xin 113 : in std logic vector(7 downto 0);
xin_114 : in std_logic_vector(7 downto 0);
xin_115 : in std_logic_vector(7 downto 0);
xin_116 : in std_logic_vector(7 downto 0);
xin_117 : in std_logic_vector(7 downto 0);
xin_118 : in std_logic_vector(7 downto 0);
xin 119 : in std logic vector(7 downto 0);
xin 120 : in std logic vector(7 downto 0);
xin 121 : in std logic vector(7 downto 0);
xin 122 : in std logic vector(7 downto 0);
xin_123 : in std_logic_vector(7 downto 0);
xin_124 : in std_logic_vector(7 downto 0);
xin_125 : in std_logic_vector(7 downto 0);
xin_126 : in std_logic_vector(7 downto 0);
xin 127 : in std logic vector(7 downto 0);
yl 0 : out std logic vector(8 downto 0);
yl_1 : out std_logic_vector(8 downto 0);
yl 2 : out std logic vector(8 downto 0);
yl 3 : out std logic vector(8 downto 0);
yl 4 : out std logic vector(8 downto 0);
yl_5 : out std_logic_vector(8 downto 0);
yl_6 : out std_logic_vector(8 downto 0);
yl_7 : out std_logic_vector(8 downto 0);
yl 8 : out std logic vector(8 downto 0);
yl 9 : out std logic vector(8 downto 0);
yl 10 : out std_logic_vector(8 downto 0);
yl_11 : out std_logic_vector(8 downto 0);
yl_12 : out std logic vector(8 downto 0);
yl 13 : out std logic vector(8 downto 0);
yl 14 : out std logic vector(8 downto 0);
y1_15 : out std_logic_vector(8 downto 0);
yl_16 : out std_logic_vector(8 downto 0);
yl_17 : out std_logic_vector(8 downto 0);
yl_18 : out std_logic_vector(8 downto 0);
yl 19 : out std logic vector (8 downto 0);
y1_20 : out std_logic_vector(8 downto 0);
yl 21 : out std logic vector(8 downto 0);
yl 22 : out std logic vector(8 downto 0);
yl 23 : out std logic vector(8 downto 0);
yl_24 : out std_logic_vector(8 downto 0);
yl_25 : out std_logic_vector(8 downto 0);
yl_26 : out std_logic_vector(8 downto 0);
yl_27 : out std_logic_vector(8 downto 0);
yl_28 : out std_logic_vector(8 downto 0);
yl 29 : out std logic vector(8 downto 0);
yl 30 : out std logic vector(8 downto 0);
yl 31 : out std logic vector (8 downto 0);
yl 32 : out std logic vector(8 downto 0);
y1_33 : out std_logic_vector(8 downto 0);
yl_34 : out std_logic_vector(8 downto 0);
y1_35 : out std_logic_vector(8 downto 0);
y1_36 : out std_logic_vector(8 downto 0);
y1_37 : out std_logic_vector(8 downto 0);
yl 38 : out std logic vector(8 downto 0);
yl 39 : out std logic vector(8 downto 0);
yl_40 : out std_logic_vector(8 downto 0);
yl 41 : out std logic vector (8 downto 0);
yl 42 : out std logic vector(8 downto 0);
yl_43 : out std_logic_vector(8 downto 0);
yl_44 : out std_logic_vector(8 downto 0);
yl_45 : out std_logic_vector(8 downto 0);
yl_46 : out std_logic_vector(8 downto 0);
y1_47 : out std_logic_vector(8 downto 0);
```

```
yl 48 : out std logic vector(8 downto 0);
yl 49 : out std logic vector(8 downto 0);
yl_50 : out std_logic_vector(8 downto 0);
yl_51 : out std_logic_vector(8 downto 0);
yl_52 : out std_logic_vector(8 downto 0);
yl_53 : out std_logic_vector(8 downto 0);
yl 54 : out std logic vector(8 downto 0);
yl 55 : out std logic vector(8 downto 0);
yl_56 : out std logic vector(8 downto 0);
yl 57 : out std logic vector(8 downto 0);
yl 58 : out std logic vector(8 downto 0);
yl_59 : out std_logic_vector(8 downto 0);
yl_60 : out std_logic_vector(8 downto 0);
y1_61 : out std_logic_vector(8 downto 0);
y1_62 : out std_logic_vector(8 downto 0);
y1_63 : out std_logic_vector(8 downto 0);
yh 0 : out std logic vector(8 downto 0);
yh_1 : out std_logic_vector(8 downto 0);
yh 2 : out std logic vector(8 downto 0);
yh 3 : out std logic vector(8 downto 0);
yh 4 : out std logic vector(8 downto 0);
yh_5 : out std_logic_vector(8 downto 0);
yh_6 : out std_logic_vector(8 downto 0);
yh_7 : out std_logic_vector(8 downto 0);
yh 8 : out std logic vector(8 downto 0);
yh 9 : out std logic vector(8 downto 0);
yh 10 : out std logic vector(8 downto 0);
yh 11 : out std logic vector(8 downto 0);
yh 12 : out std logic vector (8 downto 0);
yh 13 : out std logic vector(8 downto 0);
yh 14 : out std logic vector(8 downto 0);
yh_15 : out std_logic_vector(8 downto 0);
yh_16 : out std_logic_vector(8 downto 0);
yh_17 : out std_logic_vector(8 downto 0);
yh 18 : out std logic vector(8 downto 0);
yh 19 : out std logic vector (8 downto 0);
yh 20 : out std logic vector(8 downto 0);
yh 21 : out std logic vector(8 downto 0);
yh 22 : out std logic vector(8 downto 0);
yh 23 : out std logic vector(8 downto 0);
yh_24 : out std_logic_vector(8 downto 0);
yh_25 : out std_logic_vector(8 downto 0);
yh_26 : out std_logic_vector(8 downto 0);
yh_27 : out std_logic_vector(8 downto 0);
yh_28 : out std_logic_vector(8 downto 0);
yh 29 : out std logic vector(8 downto 0);
yh_30 : out std logic vector(8 downto 0);
yh 31 : out std logic vector (8 downto 0);
yh 32 : out std logic vector(8 downto 0);
yh_33 : out std_logic_vector(8 downto 0);
yh_34 : out std_logic_vector(8 downto 0);
yh_35 : out std_logic_vector(8 downto 0);
yh_36 : out std_logic_vector(8 downto 0);
yh_37 : out std_logic_vector(8 downto 0);
yh 38 : out std logic vector(8 downto 0);
yh 39 : out std logic vector(8 downto 0);
yh_40 : out std logic vector(8 downto 0);
yh 41 : out std logic vector (8 downto 0);
yh_42 : out std_logic_vector(8 downto 0);
yh_43 : out std_logic_vector(8 downto 0);
yh_44 : out std_logic_vector(8 downto 0);
yh_45 : out std_logic_vector(8 downto 0);
yh_46 : out std_logic_vector(8 downto 0);
yh_47 : out std_logic_vector(8 downto 0);
```

```
yh 48 : out std logic vector(8 downto 0);
                yh 49 : out std logic vector(8 downto 0);
                yh_50 : out std_logic_vector(8 downto 0);
                yh_51 : out std_logic_vector(8 downto 0);
                yh_52 : out std_logic_vector(8 downto 0);
yh_53 : out std_logic_vector(8 downto 0);
yh_54 : out std_logic_vector(8 downto 0);
                yh 55 : out std logic vector(8 downto 0);
                yh 56 : out std logic vector(8 downto 0);
                yh 57 : out std logic vector(8 downto 0);
                yh 58 : out std logic vector(8 downto 0);
                yh_59 : out std_logic_vector(8 downto 0);
                yh_60 : out std_logic_vector(8 downto 0);
                yh_61 : out std_logic_vector(8 downto 0);
yh_62 : out std_logic_vector(8 downto 0);
yh_63 : out std_logic_vector(8 downto 0)
                );
        end entity;
        architecture behavioral of dwt is
        component lut h1
                port (
                        address : in std_logic_vector(7 downto 0);
                        result : out std logic vector(8 downto 0)
                );
        end component;
        component lut h2
                port (
                        address: in std logic vector(7 downto 0);
                        result : out std logic vector(8 downto 0)
                );
        end component;
        component lut h3
                port (
                        address : in std logic vector(7 downto 0);
                        result : out std logic vector(8 downto 0)
        end component;
        component lut h4
                port (
                        address: in std logic vector(7 downto 0);
                        result : out std_logic_vector(8 downto 0)
                );
        end component;
        signal x0 0, x0 1, x0 2, x0 3, x0 4, x0 5, x0 6, x0 7, x0 8, x0 9, x0 10,
x0 11,
                        x0_12, x0_13, x0_14, x0_15, x0_16, x0_17, x0_18, x0_19, x0_20,
x0_21,
                        x0 22, x0 23, x0 24, x0 25, x0 26, x0 27, x0 28, x0 29, x0 30,
x0_31,
                        x0 32, x0 33, x0 34, x0 35, x0 36, x0 37, x0 38, x0 39, x0 40,
x0 41,
                        x0_42, x0_43, x0_44, x0_45, x0_46, x0_47, x0_48, x0_49, x0_50,
x0 51,
                        x0 52, x0 53, x0 54, x0 55, x0 56, x0 57, x0 58, x0 59, x0 60,
x0 61,
                        x0 62, x0 63, x0 64, x0 65, x0 66, x0 67, x0 68, x0 69, x0 70,
x0_{71},
                        x0_72, x0_73, x0_74, x0_75, x0_76, x0_77, x0_78, x0_79, x0_80,
x0 81,
                        x0 82, x0 83, x0 84, x0 85, x0 86, x0 87, x0 88, x0 89, x0 90,
```

```
x0_91,
                     x0 92, x0 93, x0 94, x0 95, x0 96, x0 97, x0 98, x0 99, x0 100,
x0 101,
                     x0 102, x0 103, x0 104, x0 105, x0 106, x0 107, x0 108, x0 109,
x0 110,
                     x0_111, x0_112, x0_113, x0_114, x0_115, x0_116, x0_117, x0_118,
x0 119,
                     x0_120, x0_121, x0_122, x0_123, x0_124, x0_125, x0_126, x0_127,
x0_{128},
                     x0 129, x0 130, x0 131, x0 132, x0 133, x0 134, x0 135, x0 136,
x0_137,
                     x0_138, x0_139, x0_140, x0_141, x0_142, x0_143, x0_144, x0_145,
x0 146,
                     x0 147, x0 148, x0 149, x0 150, x0 151, x0 152, x0 153, x0 154,
x0_{155},
                      x0 156, x0 157, x0 158, x0 159, x0 160, x0 161, x0 162, x0 163,
x0_164,
                     x0_165, x0_166, x0_167, x0_168, x0_169, x0_170, x0_171, x0_172,
x0 173,
                     x0 174, x0 175, x0 176, x0 177, x0 178, x0 179, x0 180, x0 181,
x0 182,
                     x0 183, x0 184, x0 185, x0 186, x0 187, x0 188, x0 189, x0 190,
x0_191,
                     x0_192, x0_193, x0_194, x0_195, x0_196, x0_197, x0_198, x0_199,
x0 200,
                     x0 201, x0 202, x0 203, x0 204, x0 205, x0 206, x0 207, x0 208,
x0 209,
                     x0_210, x0_211, x0_212, x0_213, x0_214, x0_215, x0_216, x0_217,
x0_218,
                     x0 219, x0 220, x0 221, x0 222, x0 223, x0 224, x0 225, x0 226,
x0 227,
                     x0 228, x0 229, x0 230, x0 231, x0 232, x0 233, x0 234, x0 235,
x0_236,
                     x0 237, x0 238, x0 239, x0 240, x0 241, x0 242, x0 243, x0 244,
x0_245,
                     x0_246, x0_247, x0_248, x0_249, x0_250, x0_251, x0_252, x0_253,
x0 254,
                     x0_255, x1_0, x1_1, x1_2, x1_3, x1_4, x1_5, x1_6, x1_7, x1_8,
x1_9, x1_10,
                     x1 11, x1 12, x1 13, x1 14, x1 15, x1 16, x1 17, x1 18, x1 19,
x1 20, x1 21,
                     x1_22, x1_23, x1_24, x1_25, x1_26, x1_27, x1_28, x1_29, x1_30,
x1 31, x1 32,
                     x1 33, x1 34, x1 35, x1 36, x1 37, x1 38, x1 39, x1 40, x1 41,
x1_42, x1_43,
                     x1 44, x1 45, x1 46, x1 47, x1 48, x1 49, x1 50, x1 51, x1 52,
x1_53, x1_54,
                     x1 55, x1 56, x1 57, x1 58, x1 59, x1 60, x1 61, x1 62, x1 63,
x1 64, x1 65,
                      x1_66, x1_67, x1_68, x1_69, x1_70, x1_71, x1_72, x1_73, x1_74,
x1_75, x1_76,
                      x1_77, x1_78, x1_79, x1_80, x1_81, x1_82, x1_83, x1_84, x1_85,
x1 86, x1 87,
                      x1 88, x1 89, x1 90, x1 91, x1 92, x1 93, x1 94, x1 95, x1 96,
x1 97, x1 98,
                     x1_99, x1_100, x1_101, x1_102, x1_103, x1_104, x1_105, x1_106,
x1 107, x1 108,
                     x1 109, x1 110, x1 111, x1 112, x1 113, x1 114, x1 115, x1 116,
x1 117, x1 118,
                     x1 119, x1 120, x1 121, x1 122, x1 123, x1 124, x1 125, x1 126,
x1 127, x1 128,
                     x1_129, x1_130, x1_131, x1_132, x1_133, x1_134, x1_135, x1_136,
x1 137, x1 138,
                      x1 139, x1 140, x1 141, x1 142, x1 143, x1 144, x1 145, x1 146,
```

```
x1 147, x1 148,
                        x1 149, x1 150, x1 151, x1 152, x1 153, x1 154, x1 155, x1 156,
x1 157, x1 158,
                        x1 159, x1 160, x1 161, x1 162, x1 163, x1 164, x1 165, x1 166,
x1 167, x1 168,
                        x1 169, x1 170, x1 171, x1 172, x1 173, x1 174, x1 175, x1 176,
x1 177, x1 178,
                        x1 179, x1 180, x1 181, x1 182, x1 183, x1 184, x1 185, x1 186,
x1 187, x1 188,
                        x1 189, x1 190, x1 191, x1 192, x1 193, x1 194, x1 195, x1 196,
x1_197, x1_198,
                        x1_199, x1_200, x1_201, x1_202, x1_203, x1_204, x1_205, x1_206,
x1 207, x1 208,
                        x1 209, x1 210, x1 211, x1 212, x1 213, x1 214, x1 215, x1 216,
x1 217, x1 218,
                        x1 219, x1 220, x1 221, x1 222, x1 223, x1 224, x1 225, x1 226,
x1_227, x1_228,
                        x1_229, x1_230, x1_231, x1_232, x1_233, x1_234, x1_235, x1_236,
x1 237, x1 238,
                        x1 239, x1 240, x1 241, x1 242, x1 243, x1 244, x1 245, x1 246,
x1 247, x1 248,
                        x1 249, x1 250, x1 251, x1 252, x1 253, x1 254, x1 255 :
std_logic_vector(8 downto 0);
        begin
i0 0: lut h1
        port map(
        address \Rightarrow xin_0, result \Rightarrow x0_0
i0 1: lut h2
        port map (
        address \Rightarrow xin 1, result \Rightarrow x0 1
);
i0 2: lut h3
        address \Rightarrow xin 2, result \Rightarrow x0 2
i0 3: lut h4
        port map (
        address \Rightarrow xin 3, result \Rightarrow x0 3
yl_0 \le x0_0 + x0_1 + x0_2 + x0_3;
i0 4: lut h1
        port map (
        address \Rightarrow xin 2, result \Rightarrow x0 4
i0 5: lut h2
        port map(
        address => xin_3, result => x0 5
);
i0 6: lut h3
        port map (
        address \Rightarrow xin 4, result \Rightarrow x0 6
);
i0 7: lut h4
        port map (
        address \Rightarrow xin 5, result \Rightarrow x0 7
y1 1 \le x0 4 + x0 5 + x0 6 + x0 7;
i0 8: lut h1
        port map (
        address \Rightarrow xin 4, result \Rightarrow x0 8
```

```
i0 9: lut_h2
       port map(
       address \Rightarrow xin 5, result \Rightarrow x0 9
i0 10: lut h3
       port map(
       address => xin_6, result => x0_10
);
i0 11: lut h4
       port map(
        address => xin_7, result => x0_11
);
y1_2 \le x0_8 + x0_9 + x0_{10} + x0_{11};
i0 12: lut h1
       port map(
       address => xin_6, result => x0_12
i0 13: lut h2
       port map(
        address \Rightarrow xin 7, result \Rightarrow x0 13
i0_14: lut_h3
       port map(
        address \Rightarrow xin 8, result \Rightarrow x0 14
i0 15: lut h4
       port map(
        address \Rightarrow xin 9, result \Rightarrow x0 15
y1 3 \le x0 12 + x0 13 + x0 14 + x0 15;
i0_16: lut_h1
       port map(
       address => xin_8, result => x0_16
i0 17: lut h2
       port map(
       address \Rightarrow xin 9, result \Rightarrow x0 17
i0_18: lut_h3
       port map(
        address => xin_10, result => x0_18
);
i0 19: lut_h4
       port map(
       address => xin 11, result => x0 19
yl_4 \le x0_{16} + x0_{17} + x0_{18} + x0_{19};
i0_20: lut_h1
       port map(
       address => xin 10, result => x0 20
);
i0_21: lut_h2
       port map(
       address => xin 11, result => x0 21
i0 22: lut_h3
       port map(
        address => xin_12, result => x0_22
i0 23: lut h4
```

```
port map(
        address \Rightarrow xin 13, result \Rightarrow x0 23
yl 5 <= x0 20 + x0 21 + x0 22 + x0 23;
i0_24: lut_h1
        port map(
        address => xin_12, result => x0_24
);
i0 25: lut h2
        port map(
        address => xin_13, result => x0_25
);
i0_26: lut_h3
        port map (
        address => xin 14, result => x0 26
i0 27: lut h4
        port map(
        address \Rightarrow xin 15, result \Rightarrow x0 27
y1 6 \le x0 24 + x0 25 + x0 26 + x0 27;
i0_28: lut_h1
        port map(
        address => xin 14, result => x0 28
i0 29: lut h2
        port map(
        address => xin 15, result => x0 29
i0 30: lut h3
        port map(
        address \Rightarrow xin 16, result \Rightarrow x0 30
i0 31: lut h4
        port map(
        address => xin_17, result => x0_31
y1 7 \le x0 28 + x0 29 + x0 30 + x0 31;
i0_32: lut_h1
        port map(
        address => xin_16, result => x0_32
i0_33: lut_h2
        port map(
        address \Rightarrow xin 17, result \Rightarrow x0 33
i0 34: lut_h3
        port map(
        address \Rightarrow xin 18, result \Rightarrow x0 34
i0 35: lut_h4
        port map(
        address => xin_19, result => x0_35
y1 8 \le x0 32 + x0 33 + x0 34 + x0 35;
i0 36: lut h1
        port map(
        address \Rightarrow xin 18, result \Rightarrow x0 36
i0 37: lut h2
```

```
port map(
        address \Rightarrow xin 19, result \Rightarrow x0 37
);
i0 38: lut h3
        port map(
        address => xin 20, result => x0 38
i0 39: lut_h4
        port map(
        address \Rightarrow xin 21, result \Rightarrow x0 39
yl_9 \le x0_36 + x0_37 + x0_38 + x0_39;
i0_40: lut_h1
        port map (
        address \Rightarrow xin 20, result \Rightarrow x0 40
i0 41: lut h2
        port map(
        address \Rightarrow xin 21, result \Rightarrow x0 41
i0 42: lut h3
        port map(
        address \Rightarrow xin 22, result \Rightarrow x0 42
i0 43: lut_h4
        port map(
        address => xin_23, result => x0_43
y1 10 \le x0 40 + x0 41 + x0 42 + x0 43;
i0_44: lut_h1
        port map(
        address \Rightarrow xin 22, result \Rightarrow x0 44
i0 45: lut h2
        port map(
        address \Rightarrow xin 23, result \Rightarrow x0 45
i0 46: lut h3
        port map(
        address => xin 24, result => x0 46
);
i0_47: lut_h4
        port map(
        address \Rightarrow xin 25, result \Rightarrow x0 47
y1 11 \le x0 44 + x0 45 + x0 46 + x0 47;
i0_48: lut_h1
        port map(
        address \Rightarrow xin 24, result \Rightarrow x0 48
);
i0 49: lut_h2
        port map (
        address => xin_25, result => x0_49
i0 50: lut h3
        port map (
        address => xin 26, result => x0 50
i0_51: lut_h4
        port map(
        address \Rightarrow xin 27, result \Rightarrow x0 51
```

```
y1 12 \le x0 48 + x0 49 + x0 50 + x0 51;
i0 52: lut h1
       port map(
        address => xin 26, result => x0 52
i0 53: lut_h2
       port map (
       address \Rightarrow xin 27, result \Rightarrow x0 53
i0 54: lut h3
       port map(
        address \Rightarrow xin 28, result \Rightarrow x0 54
);
i0 55: lut h4
        port map(
       address => xin_29, result => x0_55
yl 13 <= x0 52 + x0 53 + x0 54 + x0 55;
i0 56: lut h1
       port map(
        address => xin 28, result => x0 56
i0 57: lut_h2
       port map(
        address => xin_29, result => x0_57
i0 58: lut_h3
       port map(
        address \Rightarrow xin 30, result \Rightarrow x0 58
);
i0 59: lut h4
        port map(
       address => xin_31, result => x0_59
yl 14 <= x0 56 + x0 57 + x0 58 + x0 59;
i0 60: lut h1
       port map(
       address => xin 30, result => x0 60
);
i0_61: lut_h2
       port map(
       address => xin_31, result => x0_61
);
i0 62: lut h3
       port map(
       address => xin_32, result => x0_62
);
i0_63: lut_h4
        port map (
        address => xin 33, result => x0 63
yl_15 \le x0_60 + x0_61 + x0_62 + x0_63;
i0 64: lut h1
       port map (
        address => xin 32, result => x0 64
i0 65: lut h2
        port map(
        address \Rightarrow xin 33, result \Rightarrow x0 65
```

```
i0 66: lut_h3
        port map(
        address \Rightarrow xin 34, result \Rightarrow x0 66
i0 67: lut_h4
        port map(
        address \Rightarrow xin_35, result \Rightarrow x0_67
);
yl 16 <= x0 64 + x0 65 + x0 66 + x0 67;
i0_68: lut_h1
        port map(
        address \Rightarrow xin 34, result \Rightarrow x0 68
);
i0 69: lut h2
        port map(
        address => xin_35, result => x0_69
i0 70: lut h3
        port map (
        address \Rightarrow xin 36, result \Rightarrow x0 70
i0_71: lut_h4
        port map(
        address \Rightarrow xin 37, result \Rightarrow x0 71
yl_17 \le x0_68 + x0_69 + x0_70 + x0_71;
i0 72: lut h1
        port map (
        address \Rightarrow xin 36, result \Rightarrow x0 72
);
i0 73: lut h2
        port map(
        address => xin_37, result => x0_73
i0 74: lut h3
        port map(
        address \Rightarrow xin 38, result \Rightarrow x0 74
i0 75: lut_h4
        port map(
        address \Rightarrow xin 39, result \Rightarrow x0 75
yl_18 \le x0_72 + x0_73 + x0_74 + x0_75;
i0 76: lut h1
        port map(
        address => xin_38, result => x0_76
);
i0_77: lut_h2
        port map (
        address => xin 39, result => x0 77
);
i0_78: lut_h3
        port map(
        address \Rightarrow xin 40, result \Rightarrow x0 78
i0 79: lut_h4
        port map(
        address => xin_41, result => x0_79
yl 19 <= x0 76 + x0 77 + x0 78 + x0 79;
```

```
i0 80: lut h1
        port map(
        address => xin 40, result => x0 80
i0 81: lut h2
        port map(
        address => xin_41, result => x0_81
);
i0 82: lut h3
        port map(
        address => xin_42, result => x0_82
);
i0 83: lut_h4
        port map (
        address \Rightarrow xin 43, result \Rightarrow x0 83
yl_20 \le x0_80 + x0_81 + x0_82 + x0_83;
i0 84: lut h1
        port map (
        address \Rightarrow xin 42, result \Rightarrow x0 84
i0_85: lut_h2
        port map(
        address => xin 43, result => x0 85
i0 86: lut h3
        port map(
        address => xin 44, result => x0 86
i0 87: lut h4
        port map(
        address \Rightarrow xin 45, result \Rightarrow x0 87
yl_21 \le x0_84 + x0_85 + x0_86 + x0_87;
i0_88: lut h1
        port map(
        address \Rightarrow xin 44, result \Rightarrow x0 88
i0_89: lut_h2
        port map(
        address => xin_45, result => x0_89
);
i0 90: lut_h3
        port map(
        address => xin 46, result => x0 90
i0 91: lut_h4
        port map(
        address \Rightarrow xin 47, result \Rightarrow x0 91
y1_22 \le x0_88 + x0_89 + x0_90 + x0_91;
i0_92: lut_h1
        port map(
        address \Rightarrow xin 46, result \Rightarrow x0 92
i0 93: lut_h2
        port map(
        address \Rightarrow xin_47, result \Rightarrow x0_93
i0 94: lut h3
```

```
port map (
        address => xin 48, result => x0 94
);
i0 95: lut h4
        port map(
        address => xin 49, result => x0 95
y1_23 \le x0_92 + x0_93 + x0_94 + x0_95;
i0 96: lut h1
        port map(
        address => xin_48, result => x0_96
);
i0 97: lut_h2
        port map (
        address \Rightarrow xin 49, result \Rightarrow x0 97
i0 98: lut h3
        port map(
        address => xin 50, result => x0 98
i0 99: lut_h4
        port map(
        address \Rightarrow xin_51, result \Rightarrow x0_99
y1 24 \le x0 96 + x0 97 + x0 98 + x0 99;
i0_100: lut_h1
        port map(
        address \Rightarrow xin 50, result \Rightarrow x0 100
);
i0 101: lut h2
        port map(
        address \Rightarrow xin 51, result \Rightarrow x0 101
i0 102: lut h3
        port map (
        address \Rightarrow xin 52, result \Rightarrow x0 102
i0 103: lut h4
        port map(
        address => xin 53, result => x0 103
yl_25 <= x0_100 + x0_101 + x0_102 + x0_103;
i0_104: lut_h1
        port map(
        address => xin 52, result => x0 104
i0 105: lut_h2
        port map (
        address \Rightarrow xin 53, result \Rightarrow x0 105
);
i0 106: lut_h3
        port map(
        address => xin_54, result => x0_106
i0 107: lut h4
        port map (
        address => xin 55, result => x0 107
yl_26 <= x0_104 + x0_105 + x0_106 + x0_107;
i0 108: lut h1
```

```
port map (
        address \Rightarrow xin 54, result \Rightarrow x0 108
);
i0 109: lut h2
        port map(
        address => xin 55, result => x0 109
i0 110: lut h3
       port map (
        address \Rightarrow xin 56, result \Rightarrow x0 110
i0 111: lut h4
        port map(
        address => xin_57, result => x0_111
);
yl 27 <= x0 108 + x0 109 + x0 110 + x0 111;
i0 112: lut h1
        port map(
        address \Rightarrow xin 56, result \Rightarrow x0 112
i0 113: lut h2
        port map(
        address \Rightarrow xin 57, result \Rightarrow x0 113
i0 114: lut h3
        port map (
        address => xin_58, result => x0_114
);
i0 115: lut h4
        port map(
        address \Rightarrow xin 59, result \Rightarrow x0 115
);
yl 28 <= x0 112 + x0 113 + x0 114 + x0 115;
i0 116: lut h1
        port map (
        address => xin 58, result => x0 116
i0 117: lut h2
        port map(
        address => xin 59, result => x0 117
);
i0_118: lut_h3
        port map(
        address \Rightarrow xin 60, result \Rightarrow x0 118
);
i0 119: lut h4
        port map(
        address => xin_61, result => x0_119
);
yl_29 <= x0_116 + x0_117 + x0_118 + x0_119;
i0 120: lut_h1
        port map(
        address => xin_60, result => x0_120
i0 121: lut h2
        port map (
        address => xin 61, result => x0 121
i0 122: lut_h3
        port map(
        address \Rightarrow xin 62, result \Rightarrow x0 122
```

```
i0 123: lut h4
        port map(
        address \Rightarrow xin 63, result \Rightarrow x0 123
yl_30 <= x0_120 + x0_121 + x0_122 + x0_123;
i0 124: lut_h1
        port map (
        address \Rightarrow xin 62, result \Rightarrow x0 124
i0 125: lut h2
        port map(
        address \Rightarrow xin 63, result \Rightarrow x0 125
);
i0 126: lut h3
        port map(
        address => xin_64, result => x0_126
i0 127: lut h4
        port map (
        address \Rightarrow xin 65, result \Rightarrow x0 127
yl_31 \le x0_{124} + x0_{125} + x0_{126} + x0_{127};
i0 128: lut h1
        port map (
        address \Rightarrow xin_64, result \Rightarrow x0_128
i0 129: lut h2
        port map (
        address \Rightarrow xin 65, result \Rightarrow x0 129
);
i0 130: lut h3
        port map(
        address => xin_66, result => x0_130
i0 131: lut h4
        port map (
        address \Rightarrow xin 67, result \Rightarrow x0 131
yl_32 <= x0_128 + x0_129 + x0_130 + x0_131;
i0_132: lut_h1
        port map (
        address \Rightarrow xin 66, result \Rightarrow x0 132
);
i0 133: lut h2
        port map(
        address \Rightarrow xin_67, result \Rightarrow x0_133
);
i0_134: lut_h3
        port map (
        address => xin 68, result => x0 134
i0_135: lut_h4
        port map (
        address \Rightarrow xin 69, result \Rightarrow x0 135
yl 33 <= x0 132 + x0 133 + x0 134 + x0 135;
i0 136: lut_h1
        port map (
        address => xin 68, result => x0 136
```

```
i0 137: lut h2
        port map(
        address \Rightarrow xin 69, result \Rightarrow x0 137
i0 138: lut_h3
        port map(
        address \Rightarrow xin_70, result \Rightarrow x0_138
);
i0 139: lut h4
        port map(
        address => xin_71, result => x0_139
);
yl_34 <= x0_136 + x0_137 + x0_138 + x0_139;
i0 140: lut h1
        port map(
        address => xin_70, result => x0_140
i0 141: lut h2
        port map (
        address => xin 71, result => x0 141
i0_142: lut_h3
        port map(
        address \Rightarrow xin 72, result \Rightarrow x0 142
i0_143: lut_h4
        port map(
        address \Rightarrow xin 73, result \Rightarrow x0 143
yl 35 <= x0 140 + x0 141 + x0 142 + x0 143;
i0_144: lut_h1
        port map(
        address => xin_72, result => x0_144
i0 145: lut h2
        port map (
        address \Rightarrow xin 73, result \Rightarrow x0 145
i0_146: lut_h3
        port map(
        address \Rightarrow xin_74, result \Rightarrow x0_146
);
i0 147: lut_h4
        port map(
        address \Rightarrow xin 75, result \Rightarrow x0 147
yl_36 \le x0_144 + x0_145 + x0_146 + x0_147;
i0_148: lut_h1
        port map (
        address => xin 74, result => x0 148
i0_149: lut_h2
        port map (
        address \Rightarrow xin 75, result \Rightarrow x0 149
i0 150: lut_h3
        port map(
        address \Rightarrow xin_76, result \Rightarrow x0_150
i0 151: lut h4
```

```
port map (
        address \Rightarrow xin 77, result \Rightarrow x0 151
yl 37 <= x0 148 + x0 149 + x0 150 + x0 151;
i0_152: lut_h1
        port map(
        address \Rightarrow xin_76, result \Rightarrow x0_152
);
i0 153: lut h2
        port map(
        address => xin_77, result => x0_153
);
i0_154: lut_h3
        port map (
        address \Rightarrow xin 78, result \Rightarrow x0 154
i0 155: lut h4
        port map(
        address \Rightarrow xin 79, result \Rightarrow x0 155
yl 38 <= x0 152 + x0 153 + x0 154 + x0 155;
i0_156: lut_h1
        port map(
        address \Rightarrow xin 78, result \Rightarrow x0 156
i0 157: lut h2
        port map(
        address \Rightarrow xin 79, result \Rightarrow x0 157
);
i0 158: lut h3
        port map (
        address \Rightarrow xin 80, result \Rightarrow x0 158
i0 159: lut h4
        port map (
        address \Rightarrow xin 81, result \Rightarrow x0 159
yl 39 <= x0 156 + x0 157 + x0 158 + x0 159;
i0_160: lut_h1
        port map(
        address => xin_80, result => x0_160
);
i0_161: lut_h2
        port map(
        address => xin 81, result => x0 161
);
i0 162: lut_h3
        port map (
        address => xin 82, result => x0 162
);
i0 163: lut h4
        port map(
        address => xin_83, result => x0_163
yl 40 <= x0 160 + x0 161 + x0 162 + x0 163;
i0 164: lut h1
        port map(
        address => xin_82, result => x0_164
i0 165: lut h2
```

```
port map (
        address \Rightarrow xin 83, result \Rightarrow x0 165
);
i0 166: lut h3
        port map(
        address => xin 84, result => x0 166
i0 167: lut h4
        port map (
        address \Rightarrow xin 85, result \Rightarrow x0 167
yl_41 \le x0_164 + x0_165 + x0_166 + x0_167;
i0_168: lut_h1
        port map (
        address => xin 84, result => x0 168
i0 169: lut h2
        port map(
        address \Rightarrow xin 85, result \Rightarrow x0 169
i0 170: lut h3
        port map(
        address \Rightarrow xin 86, result \Rightarrow x0 170
i0 171: lut h4
        port map (
        address \Rightarrow xin_87, result \Rightarrow x0_171
yl 42 <= x0 168 + x0 169 + x0 170 + x0 171;
i0 172: lut h1
        port map(
        address \Rightarrow xin 86, result \Rightarrow x0 172
i0 173: lut h2
        port map (
        address \Rightarrow xin 87, result \Rightarrow x0 173
i0 174: lut h3
        port map(
        address => xin 88, result => x0 174
);
i0_175: lut_h4
        port map (
        address \Rightarrow xin 89, result \Rightarrow x0 175
yl 43 <= x0 172 + x0 173 + x0 174 + x0 175;
i0_176: lut_h1
        port map (
        address => xin 88, result => x0 176
);
i0 177: lut_h2
        port map(
        address => xin_89, result => x0_177
i0 178: lut h3
        port map (
        address => xin 90, result => x0 178
i0 179: lut_h4
        port map (
        address => xin 91, result => x0 179
```

```
yl 44 <= x0 176 + x0 177 + x0 178 + x0 179;
i0 180: lut h1
       port map(
       address => xin 90, result => x0 180
i0 181: lut h2
       port map (
       address => xin 91, result => x0 181
i0 182: lut h3
       port map(
       address \Rightarrow xin 92, result \Rightarrow x0 182
);
i0 183: lut h4
       port map(
       address => xin_93, result => x0_183
yl 45 <= x0 180 + x0 181 + x0 182 + x0 183;
i0 184: lut h1
       port map(
       address \Rightarrow xin 92, result \Rightarrow x0 184
i0 185: lut h2
       port map (
       address => xin_93, result => x0_185
i0 186: lut h3
       port map(
       address => xin 94, result => x0 186
);
i0 187: lut h4
       port map(
       address => xin_95, result => x0_187
yl 46 <= x0 184 + x0 185 + x0 186 + x0 187;
i0 188: lut h1
       port map(
       address => xin 94, result => x0 188
);
i0_189: lut_h2
       port map (
       address => xin 95, result => x0 189
);
i0 190: lut h3
       port map(
       address => xin_96, result => x0_190
);
i0 191: lut_h4
       port map (
       address => xin 97, result => x0 191
yl_47 <= x0_188 + x0_189 + x0_190 + x0_191;
i0 192: lut h1
       port map(
       address => xin 96, result => x0 192
i0_193: lut_h2
       port map (
       address \Rightarrow xin 97, result \Rightarrow x0 193
```

```
i0 194: lut h3
       port map(
       address => xin 98, result => x0 194
i0 195: lut_h4
       port map(
       address => xin_99, result => x0_195
);
yl 48 <= x0 192 + x0 193 + x0 194 + x0 195;
i0_196: lut_h1
       port map(
       address => xin 98, result => x0 196
);
i0 197: lut h2
       port map(
       address => xin_99, result => x0_197
i0 198: lut h3
       port map (
       address => xin 100, result => x0 198
i0_199: lut_h4
       port map (
       address => xin 101, result => x0 199
yl_49 <= x0_196 + x0_197 + x0_198 + x0_199;
i0 200: lut h1
       port map (
       address => xin 100, result => x0 200
);
i0 201: lut h2
       port map(
       address => xin 101, result => x0 201
i0 202: lut h3
       port map (
       address \Rightarrow xin 102, result \Rightarrow x0 202
i0_203: lut_h4
       port map (
       address => xin_103, result => x0 203
y1_50 \le x0_200 + x0_201 + x0_202 + x0_203;
i0 204: lut h1
       port map(
       address \Rightarrow xin_102, result \Rightarrow x0_204
);
i0_205: lut_h2
       port map (
       address => xin 103, result => x0 205
i0 206: lut h3
       port map (
       address => xin 104, result => x0 206
i0 207: lut_h4
       port map(
       address \Rightarrow xin 105, result \Rightarrow x0 207
yl 51 <= x0 204 + x0 205 + x0 206 + x0 207;
```

```
i0 208: lut h1
       port map(
        address \Rightarrow xin 104, result \Rightarrow x0 208
i0 209: lut h2
        port map(
        address => xin 105, result => x0 209
);
i0 210: lut h3
        port map(
        address => xin 106, result => x0 210
);
i0 211: lut_h4
        port map (
        address \Rightarrow xin 107, result \Rightarrow x0 211
yl_52 <= x0_208 + x0_209 + x0_210 + x0_211;
i0 212: lut h1
        port map (
        address \Rightarrow xin 106, result \Rightarrow x0 212
i0 213: lut h2
        port map(
        address \Rightarrow xin 107, result \Rightarrow x0 213
i0 214: lut h3
        port map(
        address => xin 108, result => x0 214
);
i0 215: lut h4
        port map (
        address \Rightarrow xin 109, result \Rightarrow x0 215
yl 53 <= x0 212 + x0 213 + x0 214 + x0 215;
i0_216: lut h1
        port map (
        address \Rightarrow xin 108, result \Rightarrow x0 216
i0_217: lut_h2
        port map (
        address => xin 109, result => x0 217
);
i0_218: lut_h3
        port map(
        address => xin 110, result => x0 218
i0 219: lut_h4
        port map (
        address => xin 111, result => x0 219
yl 54 <= x0 216 + x0 217 + x0 218 + x0 219;
i0 220: lut h1
        port map (
        address => xin 110, result => x0 220
i0 221: lut_h2
        port map (
        address => xin 111, result => x0 221
i0 222: lut h3
```

```
port map (
        address => xin 112, result => x0 222
);
i0 223: lut h4
       port map(
        address => xin 113, result => x0 223
yl_55 <= x0_220 + x0_221 + x0_222 + x0_223;
i0 224: lut h1
       port map(
        address => xin_112, result => x0_224
);
i0 225: lut_h2
       port map (
        address \Rightarrow xin 113, result \Rightarrow x0 225
i0 226: lut_h3
       port map (
       address => xin 114, result => x0 226
i0 227: lut h4
       port map(
        address => xin 115, result => x0 227
yl 56 <= x0 224 + x0 225 + x0 226 + x0 227;
i0_228: lut_h1
       port map(
        address => xin 114, result => x0 228
i0 229: lut_h2
       port map(
        address \Rightarrow xin 115, result \Rightarrow x0 229
i0 230: lut h3
       port map (
       address => xin 116, result => x0 230
i0 231: lut h4
       port map(
        address => xin 117, result => x0 231
y1_57 <= x0_228 + x0_229 + x0_230 + x0 231;
i0_232: lut_h1
       port map(
       address \Rightarrow xin 116, result \Rightarrow x0 232
i0 233: lut_h2
       port map (
       address \Rightarrow xin 117, result \Rightarrow x0 233
i0 234: lut_h3
        port map(
       address \Rightarrow xin_118, result \Rightarrow x0_234
i0 235: lut h4
        port map (
        address => xin 119, result => x0 235
yl_58 <= x0_232 + x0_233 + x0_234 + x0_235;
i0 236: lut h1
```

```
port map (
        address => xin 118, result => x0 236
);
i0 237: lut h2
       port map(
        address => xin 119, result => x0 237
i0 238: lut_h3
       port map (
       address \Rightarrow xin 120, result \Rightarrow x0 238
i0 239: lut h4
       port map(
        address => xin 121, result => x0 239
yl 59 <= x0 236 + x0 237 + x0 238 + x0 239;
i0 240: lut h1
       port map(
       address => xin 120, result => x0 240
i0 241: lut h2
       port map(
        address \Rightarrow xin 121, result \Rightarrow x0 241
i0 242: lut_h3
       port map (
       address => xin_122, result => x0_242
i0 243: lut h4
       port map(
        address => xin 123, result => x0 243
yl 60 <= x0 240 + x0 241 + x0 242 + x0 243;
i0 244: lut h1
       port map (
       address => xin 122, result => x0 244
i0 245: lut h2
       port map(
        address => xin 123, result => x0 245
);
i0_246: lut_h3
       port map(
       address \Rightarrow xin 124, result \Rightarrow x0 246
);
i0 247: lut h4
       port map(
        address => xin_125, result => x0_247
);
yl_61 \le x0_244 + x0_245 + x0_246 + x0_247;
i0 248: lut_h1
       port map(
       address \Rightarrow xin_124, result \Rightarrow x0_248
i0 249: lut h2
       port map (
        address => xin 125, result => x0 249
i0_250: lut_h3
       port map (
        address \Rightarrow xin 126, result \Rightarrow x0 250
```

```
i0 251: lut_h4
        port map(
        address \Rightarrow xin 127, result \Rightarrow x0 251
yl_62 <= x0_248 + x0_249 + x0_250 + x0_251;
i0 252: lut_h1
        port map (
        address \Rightarrow xin 126, result \Rightarrow x0 252
i0 253: lut h2
        port map(
        address \Rightarrow xin 127, result \Rightarrow x0 253
);
i0 254: lut h3
        port map(
        address => xin_0, result => x0_254
i0 255: lut h4
        port map (
        address \Rightarrow xin 1, result \Rightarrow x0 255
yl 63 <= x0_252 + x0_253 + x0_254 + x0_255;
i1 0: lut h4
        port map(
        address => xin_0, result => x1_0
i1 1: lut h3
        port map(
        address \Rightarrow xin 1, result \Rightarrow x1 1
);
i1 2: lut h2
        address => xin 2, result => x1 2
i1 3: lut h1
        port map (
        address \Rightarrow xin 3, result \Rightarrow x1 3
yh_0 \le x1_2 + x1_1 + x1_0 + x1_3;
i1_4: lut_h4
        port map(
        address \Rightarrow xin 2, result \Rightarrow x1 4
i1 5: lut h3
        port map(
        address => xin_3, result => x1_5
);
i1 6: lut h2
        port map (
        address => xin 4, result => x1 6
i1_7: lut_h1
        port map(
        address \Rightarrow xin 5, result \Rightarrow x1 7
yh 1 \le x1 6 + x1 5 + x1 4 + x1 7;
i1 8: lut h4
        port map (
        address => xin 4, result => x1 8
```

```
i1 9: lut h3
       port map (
       address \Rightarrow xin 5, result \Rightarrow x1 9
i1 10: lut h2
       port map(
       address => xin_6, result => x1_10
);
i1 11: lut h1
       port map(
       address => xin_7, result => x1_11
);
yh_2 \le x1_10 + x1_9 + x1_8 + x1_11;
i1 12: lut h4
       port map(
       address => xin_6, result => x1_12
i1 13: lut h3
       port map (
       address \Rightarrow xin 7, result \Rightarrow x1 13
i1_14: lut_h2
       port map(
       address => xin 8, result => x1 14
i1 15: lut h1
       port map(
       address \Rightarrow xin 9, result \Rightarrow x1 15
yh_3 \le x1_14 + x1_13 + x1_12 + x1_15;
i1_16: lut_h4
       port map(
       address => xin_8, result => x1_16
i1 17: lut h3
       port map(
       address => xin 9, result => x1 17
i1_18: lut_h2
       port map(
       address => xin_10, result => x1_18
);
i1_19: lut_h1
       port map(
       address => xin 11, result => x1 19
yh_4 \le x1_18 + x1_17 + x1_16 + x1_19;
i1_20: lut_h4
       port map(
       address => xin 10, result => x1 20
);
i1_21: lut_h3
       port map(
       address => xin 11, result => x1 21
i1 22: lut_h2
       port map(
       address => xin 12, result => x1 22
i1 23: lut h1
```

```
port map(
       address => xin 13, result => x1 23
yh 5 <= x1 22 + x1 21 + x1 20 + x1 23;
i1_24: lut_h4
       port map(
       address => xin_12, result => x1 24
);
i1 25: lut h3
       port map(
       address => xin_13, result => x1_25
);
i1_26: lut_h2
       port map (
       address => xin 14, result => x1 26
i1 27: lut h1
       port map(
       address => xin 15, result => x1 27
yh 6 \le x1 26 + x1 25 + x1 24 + x1 27;
i1_28: lut_h4
       port map(
       address => xin 14, result => x1 28
i1 29: lut h3
       port map(
       address => xin 15, result => x1 29
);
i1 30: lut h2
       port map(
       address \Rightarrow xin 16, result \Rightarrow x1 30
i1 31: lut h1
       port map(
       address => xin_17, result => x1_31
yh 7 \le x1 30 + x1 29 + x1 28 + x1 31;
i1_32: lut_h4
       port map(
       address => xin_16, result => x1_32
i1_33: lut_h3
       port map(
       address => xin 17, result => x1 33
i1 34: lut_h2
       port map(
       address => xin 18, result => x1 34
i1 35: lut_h1
       port map(
       address => xin_19, result => x1_35
yh 8 \le x1 34 + x1 33 + x1 32 + x1 35;
i1 36: lut h4
       port map(
       address => xin 18, result => x1 36
i1 37: lut h3
```

```
port map(
        address => xin 19, result => x1 37
);
i1 38: lut h2
        port map(
        address => xin 20, result => x1 38
i1 39: lut_h1
        port map(
        address \Rightarrow xin 21, result \Rightarrow x1 39
yh_9 \le x1_38 + x1_37 + x1_36 + x1_39;
i1_40: lut_h4
        port map(
        address => xin 20, result => x1 40
i1 41: lut h3
        port map(
        address => xin 21, result => x1 41
i1 42: lut_h2
        port map(
        address => xin 22, result => x1 42
i1 43: lut h1
        port map(
        address \Rightarrow xin_23, result \Rightarrow x1_43
yh 10 \le x1 42 + x1 41 + x1 40 + x1 43;
i1_44: lut_h4
        port map(
        address => xin 22, result => x1 44
i1 45: lut h3
        port map(
        address \Rightarrow xin 23, result \Rightarrow x1 45
i1 46: lut h2
        port map(
        address => xin 24, result => x1 46
);
i1 47: lut h1
        port map(
        address \Rightarrow xin_25, result \Rightarrow x1_47
yh_11 \le x1_46 + x1_45 + x1_44 + x1_47;
i1_48: lut_h4
        port map(
        address \Rightarrow xin 24, result \Rightarrow x1 48
);
i1 49: lut h3
        port map(
        address => xin_25, result => x1_49
i1 50: lut h2
        port map (
        address => xin 26, result => x1 50
);
i1_51: lut_h1
        port map(
        address \Rightarrow xin 27, result \Rightarrow x1 51
```

```
yh 12 \le x1 50 + x1 49 + x1 48 + x1 51;
i1 52: lut h4
       port map(
       address => xin 26, result => x1 52
i1 53: lut_h3
       port map(
       address => xin 27, result => x1 53
i1 54: lut h2
       port map(
       address => xin 28, result => x1 54
);
i1 55: lut h1
       port map(
       address => xin_29, result => x1_55
yh 13 \le x1 54 + x1 53 + x1 52 + x1 55;
i1 56: lut h4
       port map(
       address => xin 28, result => x1 56
i1 57: lut_h3
       port map(
       address => xin_29, result => x1_57
i1 58: lut_h2
       port map(
       address => xin 30, result => x1 58
);
i1 59: lut_h1
       address => xin_31, result => x1_59
yh 14 <= x1 58 + x1 57 + x1 56 + x1 59;
i1 60: lut h4
       port map(
       address => xin 30, result => x1 60
);
i1_61: lut_h3
       port map(
       address => xin_31, result => x1_61
i1 62: lut h2
       port map(
       address => xin_32, result => x1_62
);
i1_63: lut_h1
       port map (
       address => xin 33, result => x1 63
yh_15 <= x1_62 + x1_61 + x1_60 + x1_63;
i1 64: lut h4
       port map (
       address => xin 32, result => x1 64
i1_65: lut_h3
       port map(
       address \Rightarrow xin 33, result \Rightarrow x1 65
```

```
i1 66: lut h2
        port map(
        address \Rightarrow xin 34, result \Rightarrow x1 66
i1 67: lut_h1
        port map(
        address \Rightarrow xin_35, result \Rightarrow x1_67
);
yh 16 <= x1 66 + x1 65 + x1 64 + x1 67;
i1_68: lut_h4
        port map(
        address => xin 34, result => x1 68
);
i1 69: lut h3
        port map(
        address => xin_35, result => x1_69
i1 70: lut h2
        port map (
        address \Rightarrow xin 36, result \Rightarrow x1 70
i1_71: lut_h1
        port map(
        address => xin 37, result => x1 71
yh_17 \le x1_70 + x1_69 + x1_68 + x1_71;
i1 72: lut h4
        port map (
        address \Rightarrow xin 36, result \Rightarrow x1 72
);
i1 73: lut_h3
        port map(
        address => xin_37, result => x1_73
i1 74: lut h2
        port map(
        address \Rightarrow xin 38, result \Rightarrow x1 74
i1_75: lut_h1
        port map(
        address \Rightarrow xin_39, result \Rightarrow x1_75
yh_18 \le x1_74 + x1_73 + x1_72 + x1_75;
i1 76: lut h4
        port map(
        address => xin_38, result => x1_76
);
i1_77: lut_h3
        port map (
        address => xin 39, result => x1 77
i1_78: lut_h2
        port map(
        address \Rightarrow xin 40, result \Rightarrow x1 78
i1 79: lut_h1
        port map(
        address => xin_41, result => x1_79
yh 19 <= x1 78 + x1 77 + x1 76 + x1 79;
```

```
i1 80: lut h4
       port map(
       address \Rightarrow xin 40, result \Rightarrow x1 80
i1 81: lut_h3
       port map(
       address => xin_41, result => x1_81
);
i1 82: lut h2
       port map(
       address => xin_42, result => x1_82
);
i1_83: lut_h1
       port map (
       address => xin_43, result => x1 83
yh_20 <= x1_82 + x1_81 + x1_80 + x1_83;
i1 84: lut h4
       port map (
       address => xin 42, result => x1 84
i1_85: lut_h3
       port map(
       address => xin 43, result => x1 85
i1 86: lut h2
       port map(
       address => xin 44, result => x1 86
i1 87: lut h1
       port map(
       address \Rightarrow xin 45, result \Rightarrow x1 87
yh_21 \le x1_86 + x1_85 + x1_84 + x1_87;
i1 88: lut h4
       port map(
       address => xin 44, result => x1 88
i1_89: lut_h3
       port map (
       address => xin_45, result => x1_89
i1 90: lut_h2
       port map(
       address => xin 46, result => x1 90
i1 91: lut_h1
       port map(
       address \Rightarrow xin 47, result \Rightarrow x1 91
yh_22 <= x1_90 + x1_89 + x1_88 + x1_91;
i1_92: lut_h4
       port map(
       address => xin 46, result => x1 92
i1 93: lut_h3
       port map(
       address => xin_47, result => x1_93
i1 94: lut h2
```

```
port map(
       address => xin 48, result => x1 94
);
i1 95: lut h1
       port map(
       address => xin 49, result => x1 95
yh_23 \le x1_94 + x1_93 + x1_92 + x1_95;
i1 96: lut h4
       port map(
       address => xin_48, result => x1_96
);
i1 97: lut_h3
       port map (
       address => xin 49, result => x1 97
i1 98: lut h2
       port map(
       address => xin 50, result => x1 98
i1 99: lut_h1
       port map(
       address => xin_51, result => x1_99
yh 24 \le x1 98 + x1 97 + x1 96 + x1 99;
i1_100: lut_h4
       port map(
       address \Rightarrow xin 50, result \Rightarrow x1 100
);
i1 101: lut h3
       port map(
       address => xin 51, result => x1 101
i1 102: lut h2
       port map (
       address => xin_52, result => x1_102
i1 103: lut h1
       port map(
       address => xin 53, result => x1 103
yh_25 <= x1_102 + x1_101 + x1_100 + x1_103;
i1_104: lut_h4
       port map(
       address => xin 52, result => x1 104
i1 105: lut_h3
       port map (
       address \Rightarrow xin 53, result \Rightarrow x1 105
);
i1 106: lut_h2
       port map(
       address => xin_54, result => x1_106
i1 107: lut h1
       port map (
       address => xin 55, result => x1 107
yh_26 <= x1_106 + x1_105 + x1_104 + x1_107;</pre>
i1 108: lut h4
```

```
port map (
       address \Rightarrow xin 54, result \Rightarrow x1 108
);
i1 109: lut h3
       port map(
       address => xin 55, result => x1 109
i1 110: lut h2
       port map (
       address => xin 56, result => x1 110
i1 111: lut_h1
       port map(
       address => xin_57, result => x1_111
);
yh 27 <= x1 110 + x1 109 + x1 108 + x1 111;
i1_112: lut_h4
       port map(
       address => xin 56, result => x1 112
i1 113: lut h3
       port map(
       address \Rightarrow xin 57, result \Rightarrow x1 113
i1 114: lut h2
       port map (
       address => xin_58, result => x1_114
);
i1 115: lut h1
       port map(
       address \Rightarrow xin 59, result \Rightarrow x1 115
);
yh 28 <= x1 114 + x1 113 + x1 112 + x1 115;
i1 116: lut_h4
       port map (
       address => xin_58, result => x1_116
i1 117: lut h3
       port map(
       address => xin 59, result => x1 117
);
i1_118: lut_h2
       port map(
       address => xin_60, result => x1_118
);
i1 119: lut h1
       port map(
       address => xin_61, result => x1_119
);
yh 29 <= x1 118 + x1 117 + x1 116 + x1 119;
i1 120: lut h4
       port map(
       address => xin_60, result => x1_120
i1 121: lut h3
       port map(
       address => xin 61, result => x1 121
);
i1_122: lut_h2
       port map(
       address => xin 62, result => x1 122
```

```
i1 123: lut h1
        port map(
        address \Rightarrow xin 63, result \Rightarrow x1 123
yh_30 <= x1_122 + x1_121 + x1_120 + x1_123;</pre>
i1 124: lut_h4
        port map (
        address \Rightarrow xin 62, result \Rightarrow x1 124
i1 125: lut h3
        port map(
        address => xin_63, result => x1_125
);
i1 126: lut h2
        port map(
        address => xin_64, result => x1_126
i1 127: lut h1
        port map (
        address => xin_65, result => x1_127
yh_31 <= x1_126 + x1_125 + x1_124 + x1_127;
i1 128: lut h4
        port map (
        address => xin_64, result => x1_128
i1 129: lut h3
        port map (
        address \Rightarrow xin 65, result \Rightarrow x1 129
);
i1_130: lut_h2
        port map(
        address => xin_66, result => x1_130
i1 131: lut_h1
        port map (
        address => xin 67, result => x1 131
yh_32 <= x1_130 + x1_129 + x1_128 + x1 131;
i1_132: lut_h4
        port map(
        address \Rightarrow xin 66, result \Rightarrow x1 132
i1 133: lut h3
        port map(
        address => xin_67, result => x1_133
);
i1_134: lut_h2
        port map (
        address \Rightarrow xin 68, result \Rightarrow x1 134
i1_135: lut_h1
        port map (
        address \Rightarrow xin 69, result \Rightarrow x1 135
yh 33 <= x1 134 + x1 133 + x1 132 + x1 135;
i1_136: lut_h4
        port map (
        address => xin 68, result => x1 136
```

```
i1 137: lut h3
        port map(
        address \Rightarrow xin 69, result \Rightarrow x1 137
i1_138: lut_h2
        port map(
        address => xin_70, result => x1_138
);
i1 139: lut h1
        port map(
        address => xin_71, result => x1 139
);
yh_34 <= x1_138 + x1_137 + x1_136 + x1_139;
i1 140: lut h4
        port map(
        address => xin_70, result => x1_140
i1 141: lut h3
        port map (
        address => xin 71, result => x1 141
i1_142: lut_h2
        port map(
        address \Rightarrow xin 72, result \Rightarrow x1 142
i1 143: lut_h1
        port map(
        address => xin 73, result => x1 143
yh 35 <= x1 142 + x1 141 + x1 140 + x1 143;
i1_144: lut_h4
        address => xin_72, result => x1_144
i1 145: lut h3
        port map (
        address \Rightarrow xin 73, result \Rightarrow x1 145
i1_146: lut_h2
        port map(
        address \Rightarrow xin 74, result \Rightarrow x1 146
);
i1 147: lut_h1
        port map(
        address \Rightarrow xin 75, result \Rightarrow x1 147
yh_36 <= x1_146 + x1_145 + x1_144 + x1_147;</pre>
i1_148: lut_h4
        port map (
        address => xin 74, result => x1 148
i1_149: lut_h3
        port map (
        address \Rightarrow xin 75, result \Rightarrow x1 149
i1 150: lut_h2
        port map (
        address => xin_76, result => x1_150
i1 151: lut h1
```

```
port map (
        address => xin 77, result => x1 151
yh 37 <= x1 150 + x1 149 + x1 148 + x1 151;
i1_152: lut_h4
       port map(
       address => xin_76, result => x1_152
);
i1 153: lut h3
       port map(
       address => xin_77, result => x1_153
);
i1_154: lut_h2
       port map (
       address \Rightarrow xin 78, result \Rightarrow x1 154
i1_155: lut_h1
       port map(
       address \Rightarrow xin 79, result \Rightarrow x1 155
yh 38 <= x1 154 + x1 153 + x1 152 + x1 155;
i1 156: lut_h4
       port map(
       address \Rightarrow xin 78, result \Rightarrow x1 156
i1 157: lut h3
       port map(
       address \Rightarrow xin 79, result \Rightarrow x1 157
);
i1 158: lut_h2
       port map(
       address => xin 80, result => x1 158
i1 159: lut_h1
       port map (
       address => xin_81, result => x1_159
yh 39 <= x1 158 + x1 157 + x1 156 + x1 159;
i1_160: lut_h4
       port map(
       address => xin_80, result => x1_160
i1 161: lut_h3
       port map(
       address => xin 81, result => x1 161
i1 162: lut_h2
       port map (
       address => xin 82, result => x1 162
i1 163: lut h1
       port map(
       address => xin_83, result => x1_163
yh 40 <= x1 162 + x1 161 + x1 160 + x1 163;
i1 164: lut h4
       port map(
       address => xin_82, result => x1_164
i1 165: lut h3
```

```
port map (
        address \Rightarrow xin 83, result \Rightarrow x1 165
);
i1 166: lut h2
       port map(
        address => xin 84, result => x1 166
i1 167: lut h1
       port map (
       address \Rightarrow xin 85, result \Rightarrow x1 167
yh_41 <= x1_166 + x1_165 + x1_164 + x1_167;</pre>
i1_168: lut_h4
       port map (
       address => xin 84, result => x1 168
i1 169: lut h3
       port map(
       address => xin 85, result => x1 169
i1 170: lut h2
       port map(
        address \Rightarrow xin 86, result \Rightarrow x1 170
il 171: lut h1
       port map (
       address \Rightarrow xin_87, result \Rightarrow x1_171
yh 42 <= x1 170 + x1 169 + x1 168 + x1 171;
i1_172: lut_h4
       port map(
        address => xin 86, result => x1 172
i1 173: lut h3
       port map (
       address => xin_87, result => x1_173
i1 174: lut h2
       port map(
       address => xin 88, result => x1 174
);
i1_175: lut_h1
        port map(
       address \Rightarrow xin_89, result \Rightarrow x1_175
yh 43 <= x1 174 + x1 173 + x1 172 + x1 175;
i1_176: lut_h4
       port map (
       address => xin 88, result => x1 176
);
i1 177: lut h3
        port map(
       address => xin_89, result => x1_177
i1 178: lut h2
       port map(
        address => xin 90, result => x1 178
);
i1_179: lut_h1
       port map (
        address => xin 91, result => x1 179
```

```
yh 44 <= x1 178 + x1 177 + x1 176 + x1 179;
i1 180: lut h4
       port map(
       address => xin 90, result => x1 180
i1 181: lut h3
       port map (
       address => xin 91, result => x1 181
i1 182: lut h2
       port map(
       address => xin 92, result => x1 182
);
i1 183: lut_h1
       port map(
       address => xin_93, result => x1_183
yh 45 <= x1 182 + x1 181 + x1 180 + x1 183;
i1_184: lut_h4
       port map(
       address => xin_92, result => x1_184
i1 185: lut h3
       port map (
       address \Rightarrow xin_93, result \Rightarrow x1_185
i1 186: lut h2
       port map (
       address => xin 94, result => x1 186
);
i1 187: lut_h1
       port map(
       address => xin_95, result => x1_187
yh 46 <= x1 186 + x1 185 + x1 184 + x1 187;
i1 188: lut h4
       port map(
       address => xin 94, result => x1 188
);
i1_189: lut_h3
       port map(
       address => xin 95, result => x1 189
);
i1 190: lut h2
       port map(
       address => xin_96, result => x1_190
);
i1_191: lut_h1
       port map (
       address => xin 97, result => x1 191
yh_47 <= x1_190 + x1_189 + x1_188 + x1_191;
i1 192: lut h4
       port map(
       address => xin 96, result => x1 192
);
i1 193: lut_h3
       port map (
       address => xin 97, result => x1 193
```

```
i1 194: lut h2
       port map(
       address => xin 98, result => x1 194
i1_195: lut_h1
       port map(
       address => xin_99, result => x1_195
);
yh 48 <= x1 194 + x1 193 + x1 192 + x1 195;
i1_196: lut_h4
       port map(
       address => xin 98, result => x1 196
);
i1 197: lut h3
       port map (
       address => xin_99, result => x1_197
i1 198: lut h2
       port map (
       address => xin 100, result => x1 198
i1 199: lut_h1
       port map (
       address => xin 101, result => x1 199
yh_49 <= x1_198 + x1_197 + x1_196 + x1_199;
i1 200: lut h4
       address => xin 100, result => x1 200
);
i1 201: lut h3
       port map(
       address => xin_101, result => x1_201
i1 202: lut h2
       port map (
       address => xin 102, result => x1 202
i1_203: lut_h1
       port map(
       address \Rightarrow xin_103, result \Rightarrow x1_203
yh_50 \le x1_202 + x1_201 + x1_200 + x1_203;
i1 204: lut h4
       port map(
       address \Rightarrow xin_102, result \Rightarrow x1_204
);
i1_205: lut_h3
       port map (
       address => xin 103, result => x1 205
i1_206: lut_h2
       port map (
       address => xin 104, result => x1 206
i1 207: lut_h1
       port map(
       address => xin 105, result => x1 207
yh 51 <= x1 206 + x1 205 + x1 204 + x1 207;
```

```
i1 208: lut h4
       port map(
       address => xin 104, result => x1 208
i1 209: lut_h3
       port map(
       address => xin_105, result => x1 209
);
i1 210: lut h2
       port map(
       address => xin_106, result => x1_210
);
i1_211: lut_h1
       port map (
       address => xin 107, result => x1 211
yh_52 <= x1_210 + x1_209 + x1_208 + x1_211;
i1 212: lut h4
       port map (
       address => xin_106, result => x1 212
i1_213: lut_h3
       port map(
       address => xin 107, result => x1 213
i1 214: lut h2
       port map(
       address => xin 108, result => x1 214
);
i1 215: lut h1
       port map(
       address => xin 109, result => x1 215
yh 53 <= x1 214 + x1 213 + x1 212 + x1 215;
i1_216: lut h4
       port map (
       address => xin 108, result => x1 216
i1_217: lut_h3
       port map(
       address => xin_109, result => x1_217
);
i1_218: lut_h2
       port map(
       address => xin 110, result => x1 218
i1 219: lut_h1
       port map (
       address => xin 111, result => x1 219
yh 54 <= x1 218 + x1 217 + x1 216 + x1 219;
i1_220: lut_h4
       port map (
       address => xin 110, result => x1 220
i1 221: lut_h3
       port map(
       address => xin 111, result => x1 221
i1 222: lut h2
```

```
port map (
       address => xin 112, result => x1 222
);
i1 223: lut h1
       port map(
       address => xin 113, result => x1 223
yh_55 <= x1_222 + x1_221 + x1_220 + x1_223;</pre>
i1 224: lut h4
       port map(
       address => xin_112, result => x1_224
);
i1_225: lut_h3
       port map (
       address => xin 113, result => x1 225
i1 226: lut h2
       port map(
       address => xin 114, result => x1 226
i1 227: lut h1
       port map(
       address => xin 115, result => x1 227
yh 56 <= x1 226 + x1 225 + x1 224 + x1 227;
i1_228: lut_h4
       port map(
       address => xin 114, result => x1 228
);
i1 229: lut_h3
       port map(
       address => xin 115, result => x1 229
i1 230: lut h2
       port map (
       address => xin 116, result => x1 230
i1 231: lut h1
       port map(
       address => xin 117, result => x1 231
yh_57 <= x1_230 + x1_229 + x1_228 + x1_231;
i1_232: lut_h4
       port map(
       address => xin 116, result => x1 232
i1 233: lut_h3
       port map (
       address => xin 117, result => x1 233
i1 234: lut_h2
       port map(
       address => xin_118, result => x1_234
i1 235: lut h1
       port map(
       address => xin 119, result => x1 235
yh_58 <= x1_234 + x1_233 + x1_232 + x1_235;
i1 236: lut h4
```

```
port map (
       address => xin 118, result => x1 236
);
i1 237: lut h3
       port map(
       address => xin 119, result => x1 237
i1 238: lut_h2
       port map (
       address => xin 120, result => x1 238
i1 239: lut h1
       port map(
       address => xin 121, result => x1 239
yh 59 <= x1 238 + x1 237 + x1 236 + x1 239;
i1 240: lut h4
       port map(
       address => xin 120, result => x1 240
i1 241: lut h3
       port map(
       address => xin 121, result => x1 241
i1 242: lut_h2
       port map (
       address \Rightarrow xin_122, result \Rightarrow x1_242
i1 243: lut h1
       port map(
       address => xin 123, result => x1 243
);
yh 60 <= x1 242 + x1 241 + x1 240 + x1 243;
i1 244: lut h4
       port map (
       address => xin 122, result => x1 244
i1 245: lut h3
       port map(
       address => xin 123, result => x1 245
);
i1_246: lut_h2
       port map(
       address \Rightarrow xin 124, result \Rightarrow x1 246
i1 247: lut h1
       port map(
       address \Rightarrow xin_125, result \Rightarrow x1_247
);
yh 61 <= x1 246 + x1 245 + x1 244 + x1 247;
i1 248: lut_h4
       port map(
       address => xin_124, result => x1_248
i1 249: lut h3
       port map(
       address => xin 125, result => x1 249
);
i1 250: lut_h2
       port map (
       address => xin 126, result => x1 250
```

```
i1 251: lut h1
       port map (
       address \Rightarrow xin 127, result \Rightarrow x1 251
yh 62 <= x1 250 + x1 249 + x1 248 + x1 251;
i1 252: lut h4
       port map (
       address => xin 126, result => x1 252
i1 253: lut h3
       port map(
       address \Rightarrow xin 127, result \Rightarrow x1 253
);
i1 254: lut h2
       port map(
       address => xin_0, result => x1_254
i1 255: lut h1
       port map (
       address \Rightarrow xin 1, result \Rightarrow x1 255
yh 63 <= x1 254 + x1 253 + x1 252 + x1 255;
end architecture;
--Look up table for H1 coefficient calculations
-- This LUT is used to get the results of a bitwise multiplication of a number and the
-- hl, which is the first coefficient of the DWT Daubechies wavelet transform.
-- h1 has the value of 0.483. This is encoded by using 0.483 * 256, which will give a
-- which is rounded off so that it will give an integer. This integer is the 8 bias
number for 0.483.
library ieee;
use ieee.std logic 1164.all;
use ieee.std logic arith.all;
use ieee.std_logic_unsigned.all;
entity LUT h1 is
       port (
               address : in std logic vector(7 downto 0);
               result : out std logic vector(8 downto 0)
end entity;
architecture behavioral of LUT hl is
type LUT is array(0 to 255) of std_logic_vector(8 downto 0);
constant lut_h1calc : LUT := (
"000000000",
"00000000",
"00000000",
"000000001",
"000000001",
"000000010",
"000000010",
"000000011",
"000000011",
"000000100",
"00000100",
"000000101",
```

```
"000000101",
"000000110",
"000000110",
"000000111",
"000000111",
"000001000",
"000001000",
"000001001",
"000001001",
"000001010",
"000001010",
"000001011",
"000001011",
"000001100",
"000001100",
"000001101",
"000001101",
"000001110",
"000001110",
"000001111",
"000001111",
"000001111",
"000010000",
"000010000",
"000010001",
"000010001",
"000010010",
"000010010",
"000010011",
"000010011",
"000010100",
"000010100",
"000010101",
"000010101",
"000010110",
"000010110",
"000010111",
"000010111",
"000011000",
"000011000",
"000011001",
"000011001",
"000011010",
"000011010",
"000011011",
"000011011",
"000011100",
"000011100",
"000011101",
"000011101",
"000011110",
"000011110",
"000011111",
"000011111",
"000011111",
"000100000",
"000100000",
"000100001",
"000100001",
"000100010",
"000100010",
"000100011",
"000100011",
"000100100",
```

```
"000100100",
"000100101",
"000100101",
"000100110",
"000100110",
"000100111",
"000100111",
"000101000",
"000101000",
"000101001",
"000101001",
"000101010",
"000101010",
"000101011",
"000101011",
"000101100",
"000101100",
"000101101",
"000101101",
"000101110",
"000101110",
"000101110",
"000101111",
"000101111",
"000110000",
"000110000",
"000110001",
"000110001",
"000110010",
"000110010",
"000110011",
"000110011",
"000110100",
"000110100",
"000110101",
"000110101",
"000110110",
"000110110",
"000110111",
"000110111",
"000111000",
"000111000",
"000111001",
"000111001",
"000111010",
"000111010",
"000111011",
"000111011",
"000111100",
"000111100",
"000111101",
"000111101",
"000111110",
"000111110",
"000111110",
"000111111",
"000111111",
"001000000",
"001000000",
"001000001",
"001000001",
"001000010",
"001000010",
"001000011",
```

```
"001000011",
"001000100",
"001000100",
"001000101",
"001000101",
"001000110",
"001000110",
"001000111",
"001000111",
"001001000",
"001001000",
"001001001",
"001001001",
"001001010",
"001001010",
"001001011",
"001001011",
"001001100",
"001001100",
"001001101",
"001001101",
"001001101",
"001001110",
"001001110",
"001001111",
"001001111",
"001010000",
"001010000",
"001010001",
"001010001",
"001010010",
"001010010",
"001010011",
"001010011",
"001010100",
"001010100",
"001010101",
"001010101",
"001010110",
"001010110",
"001010111",
"001010111",
"001011000",
"001011000",
"001011001",
"001011001",
"001011010",
"001011010",
"001011011",
"001011011",
"001011100",
"001011100",
"001011101",
"001011101",
"001011101",
"001011110",
"001011110",
"001011111",
"001011111",
"001100000",
"001100000",
"001100001",
"001100001",
"001100010",
```

```
"001100010",
"001100011",
"001100011",
"001100100",
"001100100",
"001100101",
"001100101",
"001100110",
"001100110",
"001100111",
"001100111",
"001101000",
"001101000",
"001101001",
"001101001",
"001101010",
"001101010",
"001101011",
"001101011",
"001101100",
"001101100",
"001101100",
"001101101",
"001101101",
"001101110",
"001101110",
"001101111",
"001101111",
"001110000",
"001110000",
"001110001",
"001110001",
"001110010",
"001110010",
"001110011",
"001110011",
"001110100",
"001110100",
"001110101",
"001110101",
"001110110",
"001110110",
"001110111",
"001110111",
"001111000",
"001111000",
"001111001",
"001111001",
"001111010",
"001111010",
"001111011",
"001111011");
--signal address int : std logic vector(7 downto 0);
begin
       process (address)
       variable address_int : std_logic_vector (7 downto 0);
       begin
               address int := address;
               result <= lut h1calc(conv integer(address int));</pre>
       end process;
end architecture;
configuration config lut h1 of lut h1 is
       for behavioral
```

```
end for;
end configuration;
--Look up table for H1 coefficient calculations(idwt)
-- This LUT is used to get the results of a bitwise multiplication of a number and the
coefficient
-- hl, which is the first coefficient of the DWT Daubechies wavelet transform.
-- h1 has the value of 0.483
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;
entity lut h1 idwt is
       port (
              address : in std_logic_vector(8 downto 0);
              result : out std logic vector(8 downto 0)
end entity;
architecture behavioral of LUT h1 idwt is
type lut is array(0 to 511) of std logic vector(8 downto 0);
constant lut h1calc : lut := (
"000000000",
"000000000",
"000000000",
"000000001",
"000000001",
"000000010",
"000000010",
"000000011",
"000000011",
"000000100",
"00000100",
"000000101",
"000000101",
"000000110",
"000000110",
"000000111",
"000000111",
"000001000",
"000001000",
"000001001",
"000001001",
"000001010",
"000001010",
"000001011",
"000001011",
"000001100",
"000001100",
"000001101",
"000001101",
"000001110",
"000001110",
"000001110",
"000001111",
"000001111",
"000010000",
"000010000",
"000010001",
"000010001",
```

```
"000010010",
"000010010",
"000010011",
"000010011",
"000010100",
"000010100",
"000010101",
"000010101",
"000010110",
"000010110",
"000010111",
"000010111",
"000011000",
"000011000",
"000011001",
"000011001",
"000011010",
"000011010",
"000011011",
"000011011",
"000011100",
"000011100",
"000011100",
"000011101",
"000011101",
"000011110",
"000011110",
"000011111",
"000011111",
"000100000",
"000100000",
"000100001",
"000100001",
"000100010",
"000100010",
"000100011",
"000100011",
"000100100",
"000100100",
"000100101",
"000100101",
"000100110",
"000100110",
"000100111",
"000100111",
"000101000",
"000101000",
"000101001",
"000101001",
"000101010",
"000101010",
"000101010",
"000101011",
"000101011",
"000101100",
"000101100",
"000101101",
"000101101",
"000101110",
"000101110",
"000101111",
"000101111",
"000110000",
"000110000",
```

```
"000110001",
"000110001",
"000110010",
"000110010",
"000110011",
"000110011",
"000110100",
"000110100",
"000110101",
"000110101",
"000110110",
"000110110",
"000110111",
"000110111",
"000111000",
"000111000",
"000111000",
"000111001",
"000111001",
"000111010",
"000111010",
"000111011",
"000111011",
"000111100",
"000111100",
"000111101",
"000111101",
"000111110",
"000111110",
"000111111",
"000111111",
"001000000",
"001000000",
"001000001",
"001000001",
"001000010",
"001000010",
"001000011",
"001000011",
"001000100",
"001000100",
"001000101",
"001000101",
"001000110",
"001000110",
"001000111",
"001000111",
"001000111",
"001001000",
"001001000",
"001001001",
"001001001",
"001001010",
"001001010",
"001001011",
"001001011",
"001001100",
"001001100",
"001001101",
"001001101",
"001001110",
"001001110",
"001001111",
"001001111",
```

```
"001010000",
"001010000",
"001010001",
"001010001",
"001010010",
"001010010",
"001010011",
"001010011",
"001010100",
"001010100",
"001010101",
"001010101",
"001010101",
"001010110",
"001010110",
"001010111",
"001010111",
"001011000",
"001011000",
"001011001",
"001011001",
"001011010",
"001011010",
"001011011",
"001011011",
"001011100",
"001011100",
"001011101",
"001011101",
"001011110",
"001011110",
"001011111",
"001011111",
"001100000",
"001100000",
"001100001",
"001100001",
"001100010",
"001100010",
"001100011",
"001100011",
"001100011",
"001100100",
"001100100",
"001100101",
"001100101",
"001100110",
"001100110",
"001100111",
"001100111",
"001101000",
"001101000",
"001101001",
"001101001",
"001101010",
"001101010",
"001101011",
"001101011",
"001101100",
"001101100",
"001101101",
"001101101",
"001101110",
"001101110",
```

```
"001101111",
"001101111",
"001110000",
"001110000",
"001110001",
"001110001",
"001110001",
"001110010",
"001110010",
"001110011",
"001110011",
"001110100",
"001110100",
"001110101",
"001110101",
"001110110",
"001110110",
"001110111",
"001110111",
"001111000",
"001111000",
"001111001",
"001111001",
"001111010",
"001111010",
"001111011",--
"000000000",
"110000100",
"110000101",
"110000101",
"110000110",
"110000110",
"110000111",
"110000111",
"110001000",
"110001000",
"110001001",
"110001001",
"110001010",
"110001010",
"110001011",
"110001011",
"110001100",
"110001100",
"110001101",
"110001101",
"110001110",
"110001110",
"110001110",
"110001111",
"110001111",
"110010000",
"110010000",
"110010001",
"110010001",
"110010010",
"110010010",
"110010011",
"110010011",
"110010100",
"110010100",
"110010101",
"110010101",
"110010110",
```

```
"110010110",
"110010111",
"110010111",
"110011000",
"110011000",
"110011001",
"110011001",
"110011010",
"110011010",
"110011011",
"110011011",
"110011100",
"110011100",
"110011100",
"110011101",
"110011101",
"110011110",
"110011110",
"110011111",
"110011111",
"110100000",
"110100000",
"110100001",
"110100001",
"110100010",
"110100010",
"110100011",
"110100011",
"110100100",
"110100100",
"110100101",
"110100101",
"110100110",
"110100110",
"110100111",
"110100111",
"110101000",
"110101000",
"110101001",
"110101001",
"110101010",
"110101010",
"110101010",
"110101011",
"110101011",
"110101100",
"110101100",
"110101101",
"110101101",
"110101110",
"110101110",
"110101111",
"110101111",
"110110000",
"110110000",
"110110001",
"110110001",
"110110010",
"110110010",
"110110011",
"110110011",
"110110100",
"110110100",
"110110101",
```

```
"110110101",
"110110110",
"110110110",
"110110111",
"110110111",
"110111000",
"110111000",
"110111000",
"110111001",
"110111001",
"110111010",
"110111010",
"110111011",
"110111011",
"110111100",
"110111100",
"110111101",
"110111101",
"1101111110",
"1101111110",
"110111111",
"110111111",
"111000000",
"111000000",
"111000001",
"111000001",
"111000010",
"111000010",
"111000011",
"111000011",
"111000100",
"111000100",
"111000101",
"111000101",
"111000110",
"111000110",
"111000111",
"111000111",
"111000111",
"111001000",
"111001000",
"111001001",
"111001001",
"111001010",
"111001010",
"111001011",
"111001011",
"111001100",
"111001100",
"111001101",
"111001101",
"111001110",
"111001110",
"111001111",
"111001111",
"111010000",
"111010000",
"111010001",
"111010001",
"111010010",
"111010010",
"111010011",
"111010011",
"111010100",
```

```
"111010100",
"111010101",
"111010101",
"111010101",
"111010110",
"111010110",
"111010111",
"111010111",
"111011000",
"111011000",
"111011001",
"111011001",
"111011010",
"111011010",
"111011011",
"111011011",
"111011100",
"111011100",
"111011101",
"111011101",
"1110111110",
"1110111110",
"111011111",
"111011111",
"111100000",
"111100000",
"111100001",
"111100001",
"111100010",
"111100010",
"111100011",
"111100011",
"111100011",
"111100100",
"111100100",
"111100101",
"111100101",
"111100110",
"111100110",
"111100111",
"111100111",
"111101000",
"111101000",
"111101001",
"111101001",
"111101010",
"111101010",
"111101011",
"111101011",
"111101100",
"111101100",
"111101101",
"111101101",
"111101110",
"111101110",
"111101111",
"111101111",
"111110000",
"111110000",
"111110001",
"111110001",
"111110001",
"111110010",
"111110010",
```

```
"111110011",
"111110011",
"111110100",
"111110100",
"111110101",
"111110101",
"111110110",
"111110110",
"111110111",
"111110111",
"111111000",
"111111000",
"111111001",
"111111001",
"111111010",
"111111010",
"111111011",
"111111011",
"111111100",
"111111100",
"111111101",
"111111101",
"111111110",
"111111110",
"111111111",
"111111111");
--signal address int : std logic vector(7 downto 0);
begin
       process (address)
       variable address int : std logic vector (8 downto 0);
       begin
               address int := address;
               if (conv integer(address int) > 256) then
                       result <= lut h1calc(conv integer(address int)) + "000000001";
                       result <= lut h1calc(conv integer(address int));</pre>
               end if;
       end process;
end architecture;
configuration config_lut_h1 of lut_h1_idwt is
       for behavioral
       end for;
end configuration;
--threshold estimator using LUT design
-- has an implied threshold of 1.6
library ieee;
use ieee.std logic 1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_signed.all;
entity threshold estimator is
       port (
               x0_in : in std_logic_vector(8 downto 0);
               x1_in : in std_logic_vector(8 downto 0);
               x2 in : in std logic vector(8 downto 0);
               x3 in : in std logic vector(8 downto 0);
               x4 in : in std logic vector(8 downto 0);
               x5_in : in std_logic_vector(8 downto 0);
               x6_in : in std_logic_vector(8 downto 0);
               x7_in : in std_logic_vector(8 downto 0);
x8_in : in std_logic_vector(8 downto 0);
               x9 in : in std logic vector(8 downto 0);
```

```
x11 in : in std logic vector(8 downto 0);
        x12_in : in std_logic_vector(8 downto 0);
        x13_in : in std_logic_vector(8 downto 0);
        x14_in : in std_logic_vector(8 downto 0);
x15_in : in std_logic_vector(8 downto 0);
        x16 in : in std logic vector(8 downto 0);
        x17 in : in std logic vector(8 downto 0);
        x18 in : in std logic vector(8 downto 0);
        x19 in : in std logic vector(8 downto 0);
        x20 in : in std logic vector(8 downto 0);
        x21_in : in std_logic_vector(8 downto 0);
        x22_in : in std_logic_vector(8 downto 0);
        x23_in : in std_logic_vector(8 downto 0);
x24_in : in std_logic_vector(8 downto 0);
x25_in : in std_logic_vector(8 downto 0);
        x26_in : in std_logic_vector(8 downto 0);
        x27_in : in std_logic_vector(8 downto 0);
        x28_in : in std_logic_vector(8 downto 0);
        x29 in : in std logic vector(8 downto 0);
        x30 in : in std logic vector(8 downto 0);
        x31_in : in std_logic_vector(8 downto 0);
        x32_in : in std_logic_vector(8 downto 0);
        x33_in : in std_logic_vector(8 downto 0);
x34_in : in std_logic_vector(8 downto 0);
        x35 in : in std logic vector(8 downto 0);
        x36 in : in std logic vector(8 downto 0);
        x37 in : in std logic vector(8 downto 0);
        x38 in : in std logic vector(8 downto 0);
        x39 in : in std logic vector(8 downto 0);
        x40 in : in std logic vector(8 downto 0);
        x41_in : in std_logic_vector(8 downto 0);
        x42_in : in std_logic_vector(8 downto 0);
x43_in : in std_logic_vector(8 downto 0);
        x44_in : in std_logic_vector(8 downto 0);
x45_in : in std_logic_vector(8 downto 0);
        x46 in : in std logic vector(8 downto 0);
        x47 in : in std logic vector(8 downto 0);
        x48 in : in std logic vector(8 downto 0);
        x49 in : in std logic vector(8 downto 0);
        x50_in : in std_logic_vector(8 downto 0);
        x51_in : in std_logic_vector(8 downto 0);
        x52_in : in std_logic_vector(8 downto 0);
        x53_in : in std_logic_vector(8 downto 0);
x54_in : in std_logic_vector(8 downto 0);
        x55 in : in std logic vector(8 downto 0);
        x56 in : in std logic vector(8 downto 0);
        x57 in : in std logic vector(8 downto 0);
        x58 in : in std logic vector(8 downto 0);
        x59_in : in std_logic_vector(8 downto 0);
        x60_in : in std_logic_vector(8 downto 0);
        x61_in : in std_logic_vector(8 downto 0);
        x62_in : in std_logic_vector(8 downto 0);
x63_in : in std_logic_vector(8 downto 0);
        thld est : out std logic vector(8 downto 0)
        );
end entity;
architecture behavioral of threshold estimator is
component lut_threshold
        port (
                 address: in std logic vector(7 downto 0);
                result : out std logic vector(8 downto 0)
```

x10 in : in std logic vector(8 downto 0);

```
);
        end component;
        signal x_median : std_logic_vector(7 downto 0);
        type xd_array is array (0 to 63) of integer;
        begin
        process (
                 x0 in, x1 in, x2 in, x3 in, x4 in, x5 in, x6 in, x7 in,
                 x8 in, x9 in, x10 in, x11 in, x12 in, x13 in, x14 in,
                 x\overline{15} in, x\overline{16} in, x\overline{17} in, x\overline{18} in, x\overline{19} in, x\overline{20} in, x\overline{21} in,
                 x22 in, x23 in, x24 in, x25 in, x26 in, x27 in, x28 in,
                 x29_in, x30_in, x31_in, x32_in, x33_in, x34_in, x35_in,
                 x36_in, x37_in, x38_in, x39_in, x40_in, x41_in, x42_in,
                 x43_in, x44_in, x45_in, x46_in, x47_in, x48_in, x49_in,
                 x50_in, x51_in, x52_in, x53_in, x54_in, x55_in, x56_in, x57_in, x58_in, x59_in, x60_in, x61_in, x62_in, x63_in
variable temp: integer;
variable xd : xd array;
begin
        xd(0) := abs(conv integer(x0 in));
        xd(1) := abs(conv integer(x1 in));
        xd(2) := abs(conv integer(x2 in));
        xd(3) := abs(conv_integer(x3_in));
        xd(4) := abs(conv_integer(x4_in));
        xd(5) := abs(conv_integer(x5_in));
xd(6) := abs(conv_integer(x6_in));
        xd(7) := abs(convinteger(x7 in));
        xd(8) := abs(conv integer(x8 in));
        xd(9) := abs(conv integer(x9 in));
        xd(10) := abs(conv integer(x10 in));
        xd(11) := abs(conv integer(x11 in));
        xd(12) := abs(conv_integer(x12_in));
        xd(13) := abs(conv_integer(x13_in));
        xd(14) := abs(conv_integer(x14_in));
        xd(15) := abs(conv_integer(x15_in));
xd(16) := abs(conv_integer(x16_in));
        xd(17) := abs(convinteger(x17 in));
        xd(18) := abs(conv integer(x18 in));
        xd(19) := abs(conv integer(x19 in));
        xd(20) := abs(conv integer(x20 in));
        xd(21) := abs(conv_integer(x21_in));
        xd(22) := abs(conv_integer(x22_in));
        xd(23) := abs(conv_integer(x23_in));
        xd(24) := abs(conv_integer(x24_in));
xd(25) := abs(conv_integer(x25_in));
        xd(26) := abs(convinteger(x26 in));
        xd(27) := abs(convinteger(x27 in));
        xd(28) := abs(conv integer(x28 in));
        xd(29) := abs(conv integer(x29 in));
        xd(30) := abs(conv_integer(x30_in));
        xd(31) := abs(conv_integer(x31_in));
        xd(32) := abs(conv_integer(x32_in));
        xd(33) := abs(conv_integer(x33_in));
xd(34) := abs(conv_integer(x34_in));
xd(35) := abs(conv_integer(x35_in));
        xd(36) := abs(convinteger(x36 in));
        xd(37) := abs(conv integer(x37 in));
        xd(38) := abs(conv integer(x38 in));
        xd(39) := abs(conv integer(x39 in));
        xd(40) := abs(conv_integer(x40_in));
        xd(41) := abs(conv_integer(x41_in));
        xd(42) := abs(conv_integer(x42_in));
xd(43) := abs(conv_integer(x43_in));
xd(44) := abs(conv_integer(x44_in));
```

```
xd(45) := abs(conv integer(x45 in));
        xd(46) := abs(conv integer(x46 in));
        xd(47) := abs(conv_integer(x47_in));
        xd(48) := abs(conv_integer(x48_in));
        xd(49) := abs(conv_integer(x49_in));
xd(50) := abs(conv_integer(x50_in));
xd(51) := abs(conv_integer(x51_in));
xd(52) := abs(conv_integer(x52_in));
        xd(53) := abs(convinteger(x53in));
        xd(54) := abs(conv integer(x54 in));
        xd(55) := abs(conv integer(x55 in));
        xd(56) := abs(conv_integer(x56_in));
        xd(57) := abs(conv_integer(x57_in));
        xd(58) := abs(conv_integer(x58_in));
        xd(59) := abs(conv_integer(x59_in));
xd(60) := abs(conv_integer(x60_in));
xd(61) := abs(conv_integer(x61_in));
        xd(62) := abs(conv_integer(x62_in));
        xd(63) := abs(conv integer(x63 in));
        -- Sort the array
        for i in 63 downto 0 loop
                for j in 1 to i loop
                         if xd(j-1) > xd(j) then
                                 temp := xd(j-1);
                                 xd(j-1) := xd(j);
                                 xd(j) := temp;
                         else
                                 -- for eliminating other hardware.
                         end if;
                end loop;
        end loop;
        x_median <= conv_std_logic_vector(xd(32),8);</pre>
        end process;
        instance threshold: lut threshold
                port map (
                        address => x median, result => thld est
end architecture;
--Daubechies Inverse Discrete Wavelet Transform
-- Code is generated using C.
-- This design is based on the Look up tables for multiplication.
library ieee;
use ieee.std logic 1164.all;
use ieee.std logic arith.all;
use ieee.std logic signed.all;
entity idwt is
        port (
                xout_0 : out std_logic_vector(8 downto 0);
                xout_1 : out std_logic_vector(8 downto 0);
xout_2 : out std_logic_vector(8 downto 0);
                xout 3 : out std logic vector(8 downto 0);
                xout 4 : out std_logic_vector(8 downto 0);
                xout 5 : out std logic vector(8 downto 0);
                xout 6 : out std logic vector(8 downto 0);
                xout 7 : out std logic vector(8 downto 0);
                xout_8 : out std_logic_vector(8 downto 0);
                xout_9 : out std_logic_vector(8 downto 0);
                xout_10 : out std_logic_vector(8 downto 0);
                xout_11 : out std_logic_vector(8 downto 0);
                xout 12 : out std logic vector(8 downto 0);
```

```
xout 13 : out std logic vector(8 downto 0);
xout 14 : out std logic vector(8 downto 0);
xout 15 : out std logic vector(8 downto 0);
xout_16 : out std_logic_vector(8 downto 0);
xout_17 : out std_logic_vector(8 downto 0);
xout_18 : out std_logic_vector(8 downto 0);
xout 19 : out std logic vector(8 downto 0);
xout 20 : out std logic vector(8 downto 0);
xout 21 : out std logic vector(8 downto 0);
xout 22 : out std logic vector(8 downto 0);
xout 23 : out std logic vector(8 downto 0);
xout_24 : out std_logic_vector(8 downto 0);
xout_25 : out std_logic_vector(8 downto 0);
xout_26 : out std_logic_vector(8 downto 0);
xout_27 : out std_logic_vector(8 downto 0);
xout_28 : out std_logic_vector(8 downto 0);
xout 29 : out std logic_vector(8 downto 0);
xout_30 : out std_logic_vector(8 downto 0);
xout 31 : out std logic vector(8 downto 0);
xout 32 : out std logic vector(8 downto 0);
xout 33 : out std logic vector(8 downto 0);
xout 34 : out std logic vector(8 downto 0);
xout_35 : out std_logic_vector(8 downto 0);
xout_36 : out std_logic_vector(8 downto 0);
xout_37 : out std_logic_vector(8 downto 0);
xout 38 : out std logic vector(8 downto 0);
xout 39 : out std logic vector(8 downto 0);
xout_40 : out std_logic_vector(8 downto 0);
xout_41 : out std logic vector(8 downto 0);
xout 42 : out std logic vector(8 downto 0);
xout 43 : out std logic vector(8 downto 0);
xout_44 : out std_logic_vector(8 downto 0);
xout_45 : out std_logic_vector(8 downto 0);
xout_46 : out std_logic_vector(8 downto 0);
xout 47 : out std logic vector(8 downto 0);
xout 48 : out std logic vector(8 downto 0);
xout 49 : out std logic vector(8 downto 0);
xout 50 : out std logic vector(8 downto 0);
xout 51 : out std logic vector(8 downto 0);
xout 52 : out std logic vector(8 downto 0);
xout_53 : out std_logic_vector(8 downto 0);
xout_54 : out std_logic_vector(8 downto 0);
xout_55 : out std_logic_vector(8 downto 0);
xout_56 : out std_logic_vector(8 downto 0);
xout 57 : out std_logic_vector(8 downto 0);
xout 58 : out std logic vector(8 downto 0);
xout 59 : out std logic vector(8 downto 0);
xout 60 : out std logic vector(8 downto 0);
xout 61 : out std logic vector(8 downto 0);
xout_62 : out std_logic_vector(8 downto 0);
xout_63 : out std_logic_vector(8 downto 0);
xout_64 : out std_logic_vector(8 downto 0);
xout_65 : out std_logic_vector(8 downto 0);
xout_66 : out std_logic_vector(8 downto 0);
xout 67 : out std logic vector(8 downto 0);
xout_68 : out std_logic_vector(8 downto 0);
xout_69 : out std logic vector(8 downto 0);
xout 70 : out std logic vector(8 downto 0);
xout 71 : out std logic vector(8 downto 0);
xout_72 : out std_logic_vector(8 downto 0);
xout_73 : out std_logic_vector(8 downto 0);
xout_74 : out std_logic_vector(8 downto 0);
xout_75 : out std_logic_vector(8 downto 0);
xout 76 : out std logic vector(8 downto 0);
```

```
xout 77 : out std logic vector(8 downto 0);
xout 78 : out std logic vector(8 downto 0);
xout 79 : out std logic vector(8 downto 0);
xout_80 : out std_logic_vector(8 downto 0);
xout_81 : out std_logic_vector(8 downto 0);
xout_82 : out std_logic_vector(8 downto 0);
xout 83 : out std logic vector(8 downto 0);
xout 84 : out std logic vector(8 downto 0);
xout 85 : out std logic vector(8 downto 0);
xout 86 : out std logic vector(8 downto 0);
xout 87 : out std logic vector(8 downto 0);
xout_88 : out std_logic_vector(8 downto 0);
xout_89 : out std_logic_vector(8 downto 0);
xout_90 : out std_logic_vector(8 downto 0);
xout_91 : out std_logic_vector(8 downto 0);
xout_92 : out std_logic_vector(8 downto 0);
xout 93 : out std logic vector(8 downto 0);
xout_94 : out std_logic_vector(8 downto 0);
xout 95 : out std logic vector(8 downto 0);
xout 96 : out std logic vector(8 downto 0);
xout 97 : out std_logic_vector(8 downto 0);
xout 98 : out std logic vector(8 downto 0);
xout_99 : out std_logic_vector(8 downto 0);
xout_100 : out std_logic_vector(8 downto 0);
xout_101 : out std_logic_vector(8 downto 0);
xout 102 : out std logic vector(8 downto 0);
xout 103 : out std logic vector(8 downto 0);
xout_104 : out std_logic_vector(8 downto 0);
xout 105 : out std logic vector(8 downto 0);
xout 106 : out std logic vector(8 downto 0);
xout 107 : out std logic vector(8 downto 0);
xout_108 : out std_logic_vector(8 downto 0);
xout_109 : out std_logic_vector(8 downto 0);
xout_110 : out std_logic_vector(8 downto 0);
xout_111 : out std_logic_vector(8 downto 0);
xout 112 : out std logic vector(8 downto 0);
xout 113 : out std logic vector(8 downto 0);
xout 114 : out std logic vector(8 downto 0);
xout 115 : out std logic vector(8 downto 0);
xout 116 : out std logic vector(8 downto 0);
xout_117 : out std_logic_vector(8 downto 0);
xout_118 : out std_logic_vector(8 downto 0);
xout_119 : out std_logic_vector(8 downto 0);
xout_120 : out std_logic_vector(8 downto 0);
xout_121 : out std_logic_vector(8 downto 0);
xout 122 : out std logic vector(8 downto 0);
xout 123 : out std logic vector(8 downto 0);
xout 124 : out std logic vector(8 downto 0);
xout 125 : out std logic vector(8 downto 0);
xout_126 : out std_logic_vector(8 downto 0);
xout_127 : out std_logic_vector(8 downto 0);
yl 0 : in std logic vector(8 downto 0);
yl_1 : in std_logic_vector(8 downto 0);
yl_2 : in std_logic_vector(8 downto 0);
yl 3 : in std logic vector(8 downto 0);
yl 4 : in std logic vector(8 downto 0);
yl 5 : in std logic vector(8 downto 0);
yl 6 : in std logic vector(8 downto 0);
yl_7 : in std_logic vector(8 downto 0);
yl_8 : in std_logic_vector(8 downto 0);
yl_9 : in std_logic_vector(8 downto 0);
yl_10 : in std_logic_vector(8 downto 0);
yl_11 : in std_logic vector(8 downto 0);
yl 12 : in std logic vector(8 downto 0);
```

```
yl 13 : in std logic vector(8 downto 0);
yl 14 : in std logic vector(8 downto 0);
yl 15 : in std logic vector(8 downto 0);
yl_16 : in std_logic_vector(8 downto 0);
yl_17 : in std_logic_vector(8 downto 0);
yl_18 : in std_logic_vector(8 downto 0);
yl 19 : in std logic vector(8 downto 0);
yl 20 : in std logic vector(8 downto 0);
yl 21 : in std logic vector(8 downto 0);
yl 22 : in std logic vector(8 downto 0);
yl 23 : in std logic vector(8 downto 0);
yl_24 : in std_logic_vector(8 downto 0);
yl_25 : in std_logic_vector(8 downto 0);
yl_26 : in std_logic_vector(8 downto 0);
yl 27 : in std logic vector(8 downto 0);
yl 28 : in std logic vector(8 downto 0);
yl 29 : in std logic vector(8 downto 0);
yl 30 : in std logic vector(8 downto 0);
yl 31 : in std logic vector(8 downto 0);
yl 32 : in std logic vector(8 downto 0);
yl 33 : in std logic vector(8 downto 0);
yl_34 : in std_logic_vector(8 downto 0);
yl_35 : in std_logic_vector(8 downto 0);
yl_36 : in std_logic_vector(8 downto 0);
y1_37 : in std_logic_vector(8 downto 0);
yl 38 : in std logic vector(8 downto 0);
yl 39 : in std logic vector(8 downto 0);
yl 40 : in std logic vector(8 downto 0);
yl 41 : in std logic vector(8 downto 0);
yl 42 : in std logic vector(8 downto 0);
yl 43 : in std logic vector(8 downto 0);
yl 44 : in std logic vector(8 downto 0);
yl_45 : in std_logic_vector(8 downto 0);
yl_46 : in std_logic_vector(8 downto 0);
yl 47 : in std logic vector(8 downto 0);
yl 48 : in std logic vector(8 downto 0);
yl 49 : in std logic vector(8 downto 0);
yl 50 : in std logic vector(8 downto 0);
yl 51 : in std logic vector(8 downto 0);
yl 52 : in std logic vector(8 downto 0);
yl_53 : in std_logic_vector(8 downto 0);
yl_54 : in std_logic_vector(8 downto 0);
yl 55 : in std logic vector(8 downto 0);
yl 56 : in std logic vector(8 downto 0);
yl 57 : in std logic vector(8 downto 0);
yl 58 : in std logic vector(8 downto 0);
yl 59 : in std logic vector(8 downto 0);
yl 60 : in std logic vector(8 downto 0);
yl 61 : in std logic vector(8 downto 0);
yl_62 : in std_logic_vector(8 downto 0);
yl_63 : in std_logic_vector(8 downto 0);
yh 0 : in std logic vector(8 downto 0);
yh_1 : in std_logic_vector(8 downto 0);
yh_2 : in std_logic_vector(8 downto 0);
yh 3 : in std logic vector(8 downto 0);
yh 4 : in std logic vector(8 downto 0);
yh_5 : in std_logic vector(8 downto 0);
yh 6 : in std logic vector(8 downto 0);
yh_7 : in std_logic vector(8 downto 0);
yh 8 : in std logic vector(8 downto 0);
yh_9 : in std_logic_vector(8 downto 0);
yh_10 : in std_logic_vector(8 downto 0);
yh 11 : in std logic vector(8 downto 0);
yh 12 : in std logic vector(8 downto 0);
```

```
yh 14 : in std logic vector(8 downto 0);
               yh 15 : in std logic vector(8 downto 0);
               yh_16 : in std_logic_vector(8 downto 0);
               yh_17 : in std_logic_vector(8 downto 0);
yh_18 : in std_logic_vector(8 downto 0);
               yh 19 : in std logic vector(8 downto 0);
               yh 20 : in std logic vector(8 downto 0);
               yh 21 : in std logic vector(8 downto 0);
               yh 22 : in std logic vector(8 downto 0);
               yh 23 : in std logic vector(8 downto 0);
               yh_24 : in std_logic_vector(8 downto 0);
               yh_25 : in std_logic_vector(8 downto 0);
               yh_26 : in std_logic_vector(8 downto 0);
yh_27 : in std_logic_vector(8 downto 0);
               yh 28 : in std logic vector(8 downto 0);
               yh 29 : in std logic vector(8 downto 0);
               yh 30 : in std logic vector(8 downto 0);
               yh 31 : in std logic vector(8 downto 0);
               yh 32 : in std logic vector(8 downto 0);
               yh 33 : in std logic vector(8 downto 0);
               yh_34 : in std_logic_vector(8 downto 0);
               yh_35 : in std_logic_vector(8 downto 0);
               yh_36 : in std_logic_vector(8 downto 0);
               yh 37 : in std logic vector(8 downto 0);
               yh 38 : in std logic vector(8 downto 0);
               yh 39 : in std logic vector(8 downto 0);
               yh 40 : in std logic vector(8 downto 0);
               yh 41 : in std logic vector(8 downto 0);
               yh 42 : in std logic vector(8 downto 0);
               yh_43 : in std_logic_vector(8 downto 0);
               yh_44 : in std_logic_vector(8 downto 0);
               yh_45 : in std_logic_vector(8 downto 0);
               yh_46 : in std_logic_vector(8 downto 0);
               yh 47 : in std_logic_vector(8 downto 0);
               yh 48 : in std logic vector(8 downto 0);
               yh 49 : in std logic vector (8 downto 0);
               yh 50 : in std logic vector(8 downto 0);
               yh 51 : in std logic vector(8 downto 0);
               yh 52 : in std logic vector(8 downto 0);
               yh_53 : in std_logic_vector(8 downto 0);
               yh_54 : in std_logic_vector(8 downto 0);
               yh_55 : in std_logic_vector(8 downto 0);
               yh 56 : in std logic vector(8 downto 0);
               yh 57 : in std_logic_vector(8 downto 0);
               yh 58 : in std logic vector(8 downto 0);
               yh 59 : in std logic vector(8 downto 0);
               yh 60 : in std logic vector(8 downto 0);
               yh 61 : in std logic vector(8 downto 0);
               yh_62 : in std_logic_vector(8 downto 0);
               yh_63 : in std_logic_vector(8 downto 0)
               );
end entity;
architecture behavioral of idwt is
       component lut h1 idwt
               port (
                      address: in std logic vector(8 downto 0);
                      result : out std logic vector(8 downto 0)
              );
       end component;
       component lut h2 idwt
```

yh 13 : in std logic vector(8 downto 0);

```
port (
                      address: in std logic vector(8 downto 0);
                      result : out std logic vector(8 downto 0)
              );
       end component;
       component lut h3 idwt
              port (
                      address: in std logic vector(8 downto 0);
                      result : out std logic vector(8 downto 0)
              );
       end component;
       component lut h4 idwt
              port (
                      address : in std logic vector(8 downto 0);
                      result : out std_logic_vector(8 downto 0)
              );
       end component;
       component lut_h1_idwt neg
              port (
                      address : in std_logic_vector(8 downto 0);
                      result : out std logic vector(8 downto 0)
       end component;
       component lut h3 idwt neg
              port (
                      address: in std logic vector(8 downto 0);
                      result : out std logic vector(8 downto 0)
       end component;
       signal x0 0, x0 1, x0 2, x0 3, x0 4, x0 5, x0 6, x0 7, x0 8, x0 9, x0 10,
x0 11,
                      x0 12, x0 13, x0 14, x0 15, x0 16, x0 17, x0 18, x0 19, x0 20,
x0 21,
                      x0 22, x0 23, x0 24, x0 25, x0 26, x0 27, x0 28, x0 29, x0 30,
x0 31,
                      x0 32, x0 33, x0 34, x0 35, x0 36, x0 37, x0 38, x0 39, x0 40,
x0 41,
                      x0 42, x0 43, x0 44, x0 45, x0 46, x0 47, x0 48, x0 49, x0 50,
x0 51,
                      x0_52, x0_53, x0_54, x0_55, x0_56, x0_57, x0_58, x0_59, x0_60,
x0 61,
                      x0 62, x0 63, x0 64, x0 65, x0 66, x0 67, x0 68, x0 69, x0 70,
x0_{71},
                      x0 72, x0 73, x0 74, x0 75, x0 76, x0 77, x0 78, x0 79, x0 80,
x0 81,
                      x0_82, x0_83, x0_84, x0_85, x0_86, x0_87, x0_88, x0_89, x0_90,
x0_91,
                      x0 92, x0 93, x0 94, x0 95, x0 96, x0 97, x0 98, x0 99, x0 100,
x0 101,
                      x0 102, x0 103, x0 104, x0 105, x0 106, x0 107, x0 108, x0 109,
x0 110,
                      x0_111, x0_112, x0_113, x0_114, x0_115, x0_116, x0_117, x0_118,
x0 119,
                      x0 120, x0 121, x0 122, x0 123, x0 124, x0 125, x0 126, x0 127,
x0 128,
                      x0 129, x0 130, x0 131, x0 132, x0 133, x0 134, x0 135, x0 136,
x0 137,
                      x0 138, x0 139, x0 140, x0 141, x0 142, x0 143, x0 144, x0 145,
x0 146,
                      x0 147, x0 148, x0 149, x0 150, x0 151, x0 152, x0 153, x0 154,
```

x0 155, x0 156, x0 157, x0 158, x0 159, x0 160, x0 161, x0 162, x0 163, x0 164, x0 165, x0 166, x0 167, x0 168, x0 169, x0 170, x0 171, x0 172, x0 173,x0\_174, x0\_175, x0\_176, x0\_177, x0\_178, x0\_179, x0\_180, x0\_181, x0 182, x0\_183, x0\_184, x0\_185, x0\_186, x0\_187, x0\_188, x0\_189, x0\_190, x0\_191, x0 192, x0 193, x0 194, x0 195, x0 196, x0 197, x0 198, x0 199, x0\_200, x0\_201, x0\_202, x0\_203, x0\_204, x0\_205, x0\_206, x0\_207, x0\_208, x0 209, x0\_210, x0\_211, x0\_212, x0\_213, x0\_214, x0\_215, x0\_216, x0\_217,  $x0_218,$ x0 219, x0 220, x0 221, x0 222, x0 223, x0 224, x0 225, x0 226,  $x0_227,$ x0\_228, x0\_229, x0\_230, x0\_231, x0\_232, x0\_233, x0\_234, x0\_235, x0 236, x0 237, x0 238, x0 239, x0 240, x0 241, x0 242, x0 243, x0 244, x0 245, x0 246, x0 247, x0 248, x0 249, x0 250, x0 251, x0 252, x0 253, x0\_254, x0\_255, x1\_0, x1\_1, x1\_2, x1\_3, x1\_4, x1\_5, x1\_6, x1\_7, x1\_8, x1 9, x1 10, x1 11, x1 12, x1 13, x1 14, x1 15, x1 16, x1 17, x1 18, x1 19, x1 20, x1 21, x1\_22, x1\_23, x1\_24, x1\_25, x1\_26, x1\_27, x1\_28, x1\_29, x1\_30, x1\_31, x1\_32, x1\_33, x1\_34, x1\_35, x1\_36, x1\_37, x1\_38, x1\_39, x1\_40, x1\_41, x1 42, x1 43, x1\_44, x1\_45, x1\_46, x1\_47, x1\_48, x1\_49, x1\_50, x1\_51, x1\_52, x1\_53, x1\_54, x1 55, x1 56, x1 57, x1 58, x1 59, x1 60, x1 61, x1 62, x1 63, x1\_64, x1\_65, x1\_66, x1\_67, x1\_68, x1\_69, x1\_70, x1\_71, x1\_72, x1\_73, x1\_74, x1 75, x1 76, x1 77, x1 78, x1 79, x1 80, x1 81, x1 82, x1 83, x1 84, x1 85, x1\_86, x1\_87, x1 88, x1 89, x1 90, x1 91, x1 92, x1 93, x1 94, x1 95, x1 96, x1 97, x1 98, x1 99, x1 100, x1 101, x1 102, x1 103, x1 104, x1 105, x1 106, x1 107, x1 108, x1\_109, x1\_110, x1\_111, x1\_112, x1\_113, x1\_114, x1\_115, x1\_116, x1\_117, x1\_118, x1 119, x1 120, x1 121, x1 122, x1 123, x1 124, x1 125, x1 126, x1 127, x1 128, x1 129, x1\_130, x1\_131, x1\_132, x1\_133, x1\_134, x1\_135, x1\_136, x1 137, x1 138, x1\_139, x1\_140, x1\_141, x1\_142, x1\_143, x1\_144, x1\_145, x1\_146, x1\_147, x1\_148, x1 149, x1 150, x1 151, x1 152, x1 153, x1 154, x1 155, x1 156, x1 157, x1 158, x1\_159, x1\_160, x1\_161, x1\_162, x1\_163, x1\_164, x1\_165, x1\_166, x1 167, x1\_168, x1\_169, x1\_170, x1\_171, x1\_172, x1\_173, x1\_174, x1\_175, x1\_176, x1\_177, x1\_178, x1 179, x1 180, x1 181, x1 182, x1 183, x1 184, x1 185, x1 186, x1 187, x1 188, x1 189, x1 190, x1 191, x1 192, x1 193, x1 194, x1 195, x1 196, x1 197, x1 198, x1\_199, x1\_200, x1\_201, x1\_202, x1\_203, x1\_204, x1\_205, x1\_206, x1 207, x1 208, x1 209, x1 210, x1 211, x1 212, x1 213, x1 214, x1 215, x1 216,

```
x1_217, x1_218,
                         x1 219, x1 220, x1 221, x1 222, x1 223, x1 224, x1 225, x1 226,
x1 227, x1 228,
                         x1 229, x1 230, x1 231, x1 232, x1 233, x1 234, x1 235, x1 236,
x1_237, x1_238,
                          x1 239, x1 240, x1 241, x1 242, x1 243, x1 244, x1 245, x1 246,
x1 247, x1 248,
                         x1_249, x1_250, x1_251, x1_252, x1_253, x1_254, x1_255 :
std_logic_vector(8 downto 0);
                         begin
                          -- even signal
         i0 0: lut h3 idwt
                 port map(
                          address \Rightarrow yl 0, result \Rightarrow x0 0
        );
         i0 1: lut h2 idwt
                 port map(
                          address => yh_0, result => x0_1
        i0 2: lut h1 idwt
                 port map(
                          address \Rightarrow yl 1, result \Rightarrow x0 2
        i0_3: lut_h4_idwt
                 port map(
                          address \Rightarrow yh 1, result \Rightarrow x0 3
        xout_0 \le x0_0 + x0_1 + x0_2 + x0_3;
        i0 4: lut h3 idwt
                 port map(
                          address \Rightarrow yl 1, result \Rightarrow x0 4
        );
         i0_5: lut_h2_idwt
                 port map(
                          address \Rightarrow yh 1, result \Rightarrow x0 5
        i0 6: lut h1 idwt
                 port map(
                          address \Rightarrow yl 2, result \Rightarrow x0 6
        i0 7: lut h4 idwt
                 port map (
                         address \Rightarrow yh 2, result \Rightarrow x0 7
                 );
        xout_2 \le x0_4 + x0_5 + x0_6 + x0_7;
        i0 8: lut h3 idwt
                 port map(
                         address \Rightarrow yl 2, result \Rightarrow x0 8
         i0 9: lut h2 idwt
                 port map(
                          address \Rightarrow yh 2, result \Rightarrow x0 9
        );
         i0 10: lut h1 idwt
                 port map(
                          address \Rightarrow yl_3, result \Rightarrow x0_10
         i0 11: lut h4 idwt
                 port map (
                         address \Rightarrow yh 3, result \Rightarrow x0 11
                 );
        xout_4 \le x0_8 + x0_9 + x0_{10} + x0_{11};
         i0 1\overline{2}: lut h\overline{3} idwt
                 port map (
```

```
address \Rightarrow yl 3, result \Rightarrow x0 12
i0 13: lut h2 idwt
         port map(
                 address \Rightarrow yh_3, result \Rightarrow x0_13
i0 14: lut h1 idwt
         port map(
                 address => yl 4, result => x0 14
i0 15: lut h4 idwt
         port map(
                 address \Rightarrow yh 4, result \Rightarrow x0 15
         );
xout 6 <= x0 12 + x0 13 + x0 14 + x0 15;
i0 16: lut h3 idwt
         port map(
                 address => yl_4, result => x0_16
i0 17: lut h2 idwt
         port map (
                 address \Rightarrow yh 4, result \Rightarrow x0 17
i0_18: lut_h1_idwt
         port map(
                 address \Rightarrow yl 5, result \Rightarrow x0 18
i0_19: lut_h4_idwt
         port map(
                 address \Rightarrow yh 5, result \Rightarrow x0 19
xout 8 <= x0 16 + x0 17 + x0 18 + x0 19;
i0_{20}: lut_h3_idwt
        port map(
                 address \Rightarrow yl 5, result \Rightarrow x0 20
i0 21: lut h2 idwt
         port map(
                  address \Rightarrow yh 5, result \Rightarrow x0 21
i0 22: lut h1 idwt
         port map (
                 address \Rightarrow yl 6, result \Rightarrow x0 22
i0_23: lut_h4_idwt
         port map (
                 address \Rightarrow yh 6, result \Rightarrow x0 23
xout 10 <= x0 20 + x0 21 + x0 22 + x0 23;
i0_24: lut_h3_idwt
        port map(
                 address \Rightarrow yl 6, result \Rightarrow x0 24
);
i0 25: lut_h2_idwt
         port map(
                 address \Rightarrow yh_6, result \Rightarrow x0_25
i0 26: lut h1 idwt
         port map(
                 address \Rightarrow yl 7, result \Rightarrow x0 26
i0_27: lut_h4_idwt
         port map(
                 address \Rightarrow yh 7, result \Rightarrow x0 27
```

```
);
xout 12 \le x0 24 + x0 25 + x0 26 + x0 27;
i0 28: lut h3 idwt
        port map(
                  address \Rightarrow yl 7, result \Rightarrow x0 28
i0 29: lut h2 idwt
         port map(
                 address \Rightarrow yh 7, result \Rightarrow x0 29
i0 30: lut h1 idwt
         port map(
                  address \Rightarrow yl 8, result \Rightarrow x0 30
i0 31: lut h4 idwt
         port map(
                  address \Rightarrow yh_8, result \Rightarrow x0_31
         );
xout 14 <= x0 28 + x0 29 + x0 30 + x0 31;
i0 32: lut h3 idwt
         port map (
                  address \Rightarrow yl 8, result \Rightarrow x0 32
i0_33: lut_h2_idwt
         port map(
                  address \Rightarrow yh 8, result \Rightarrow x0 33
i0_34: lut_h1_idwt
         port map(
                  address \Rightarrow yl 9, result \Rightarrow x0 34
i0 35: lut h4 idwt
         port map (
                  address \Rightarrow yh 9, result \Rightarrow x0 35
xout_16 <= x0_32 + x0_33 + x0_34 + x0_35;</pre>
i0 36: lut h3 idwt
        port map(
                  address \Rightarrow yl 9, result \Rightarrow x0 36
i0 37: lut h2 idwt
         port map (
                  address \Rightarrow yh 9, result \Rightarrow x0 37
i0_38: lut_h1_idwt
         port map(
                  address \Rightarrow yl 10, result \Rightarrow x0 38
i0 39: lut h4 idwt
         port map(
                  address \Rightarrow yh_10, result \Rightarrow x0_39
         );
xout_18 <= x0_36 + x0_37 + x0_38 + x0_39;</pre>
i0 4\overline{0}: lut h3 idwt
        port map(
                  address \Rightarrow yl_10, result \Rightarrow x0_40
i0 41: lut h2 idwt
         port map(
                  address \Rightarrow yh 10, result \Rightarrow x0 41
);
i0_42: lut_h1_idwt
         port map(
                  address \Rightarrow yl 11, result \Rightarrow x0 42
```

```
i0 43: lut h4 idwt
        port map(
                 address \Rightarrow yh 11, result \Rightarrow x0 43
        );
xout 20 \le x0 40 + x0 41 + x0 42 + x0 43;
i0 44: lut h3 idwt
        port map(
                 address => yl 11, result => x0 44
i0 45: lut h2 idwt
        port map(
                 address \Rightarrow yh 11, result \Rightarrow x0 45
i0 46: lut h1 idwt
        port map(
                 address \Rightarrow yl_12, result \Rightarrow x0_46
i0 47: lut h4 idwt
        port map(
                 address \Rightarrow yh 12, result \Rightarrow x0 47
        );
xout_22 \le x0_44 + x0_45 + x0_46 + x0_47;
i0_48: lut_h3_idwt
        port map(
                 address \Rightarrow yl 12, result \Rightarrow x0 48
i0_49: lut_h2_idwt
        port map(
                 address \Rightarrow yh 12, result \Rightarrow x0 49
i0 50: lut h1 idwt
        port map (
                 address \Rightarrow yl 13, result \Rightarrow x0 50
i0 51: lut h4 idwt
        port map(
                 address \Rightarrow yh 13, result \Rightarrow x0 51
xout 24 <= x0 48 + x0 49 + x0 50 + x0 51;
i0 52: lut h3 idwt
        port map(
                 address \Rightarrow yl 13, result \Rightarrow x0 52
i0 53: lut_h2_idwt
        port map(
                 address \Rightarrow yh 13, result \Rightarrow x0 53
i0 54: lut h1 idwt
        port map(
                 address \Rightarrow yl_14, result \Rightarrow x0_54
i0 55: lut h4 idwt
        port map(
                 address => yh_14, result => x0_55
xout 26 <= x0 52 + x0 53 + x0 54 + x0 55;
i0 56: lut h3 idwt
        port map (
                 address => yl 14, result => x0 56
i0_57: lut_h2_idwt
        port map(
                 address \Rightarrow yh 14, result \Rightarrow x0 57
```

```
i0 58: lut h1 idwt
        port map(
                 address \Rightarrow yl 15, result \Rightarrow x0 58
i0 59: lut h4 idwt
        port map(
                  address \Rightarrow yh_15, result \Rightarrow x0_59
         );
xout 28 <= x0 56 + x0 57 + x0 58 + x0 59;
i0 60: lut h3 idwt
         port map(
                 address \Rightarrow yl 15, result \Rightarrow x0 60
i0 61: lut h2 idwt
        port map(
                 address \Rightarrow yh_15, result \Rightarrow x0_61
i0 62: lut h1 idwt
        port map(
                 address => yl 16, result => x0 62
i0_63: lut_h4_idwt
        port map (
                 address \Rightarrow yh 16, result \Rightarrow x0 63
xout 30 \le x0 60 + x0 61 + x0 62 + x0 63;
i0_64: lut_h3_idwt
        port map(
                  address \Rightarrow yl 16, result \Rightarrow x0 64
i0 65: lut h2 idwt
         port map(
                 address \Rightarrow yh 16, result \Rightarrow x0 65
i0 66: lut h1 idwt
         port map(
                 address => yl 17, result => x0 66
i0 67: lut h4 idwt
         port map (
                 address \Rightarrow yh 17, result \Rightarrow x0 67
        );
xout 32 \le x0_64 + x0_65 + x0_66 + x0_67;
i0_68: lut_h3_idwt
        port map(
                  address \Rightarrow yl 17, result \Rightarrow x0 68
i0 69: lut h2 idwt
                 address \Rightarrow yh_17, result \Rightarrow x0_69
i0 70: lut h1 idwt
        port map(
                 address \Rightarrow yl_18, result \Rightarrow x0_70
i0 71: lut h4 idwt
         port map(
                 address \Rightarrow yh 18, result \Rightarrow x0 71
        );
xout_34 \le x0_68 + x0_69 + x0_70 + x0_71;
i0_72: lut_h3_idwt
        port map (
                  address \Rightarrow yl 18, result \Rightarrow x0 72
```

```
i0 73: lut h2 idwt
        port map(
                  address \Rightarrow yh 18, result \Rightarrow x0 73
i0 74: lut h1 idwt
         port map(
                  address \Rightarrow yl 19, result \Rightarrow x0 74
);
i0 75: lut h4 idwt
        port map(
                 address \Rightarrow yh_19, result \Rightarrow x0 75
         );
xout_36 \le x0_72 + x0_73 + x0_74 + x0_75;
i0_76: lut_h3_idwt
         port map(
                 address \Rightarrow yl_19, result \Rightarrow x0_76
i0 77: lut h2 idwt
        port map(
                 address \Rightarrow yh 19, result \Rightarrow x0 77
i0_78: lut_h1_idwt
        port map (
                  address \Rightarrow yl 20, result \Rightarrow x0 78
i0 79: lut h4 idwt
        port map(
                 address \Rightarrow yh 20, result \Rightarrow x0 79
xout 38 <= x0 76 + x0_77 + x0_78 + x0_79;</pre>
i0 80: lut h3 idwt
         port map(
                  address \Rightarrow yl 20, result \Rightarrow x0 80
i0 81: lut h2 idwt
         port map(
                 address \Rightarrow yh 20, result \Rightarrow x0 81
i0 82: lut h1 idwt
         port map(
                 address => yl 21, result => x0 82
);
i0_83: lut_h4_idwt
         port map (
                 address \Rightarrow yh 21, result \Rightarrow x0 83
        );
xout 40 <= x0 80 + x0 81 + x0_82 + x0_83;</pre>
i0 84: lut h3 idwt
        port map(
                 address => yl_21, result => x0_84
);
i0 85: lut h2 idwt
        port map(
                 address \Rightarrow yh_21, result \Rightarrow x0_85
i0 86: lut h1 idwt
         port map(
                 address => yl 22, result => x0 86
i0_87: lut_h4_idwt
        port map(
                 address \Rightarrow yh 22, result \Rightarrow x0 87
```

```
xout 42 <= x0 84 + x0 85 + x0 86 + x0 87;
i0 88: lut h3 idwt
        port map (
                 address \Rightarrow yl 22, result \Rightarrow x0 88
);
i0 89: lut h2 idwt
        port map(
                 address \Rightarrow yh 22, result \Rightarrow x0 89
);
i0 90: lut h1 idwt
        port map(
                 address \Rightarrow yl_23, result \Rightarrow x0_90
);
i0_91: lut_h4_idwt
        port map(
                 address \Rightarrow yh 23, result \Rightarrow x0 91
xout_44 \le x0_88 + x0_89 + x0_90 + x0_91;
i0 9\overline{2}: lut h3 idwt
        port map(
                 address \Rightarrow yl 23, result \Rightarrow x0 92
i0_93: lut_h2_idwt
        port map (
                 address \Rightarrow yh 23, result \Rightarrow x0 93
i0 94: lut h1 idwt
        port map(
                 address \Rightarrow yl 24, result \Rightarrow x0 94
i0 95: lut h4 idwt
        port map(
                 address => yh_24, result => x0_95
        );
xout 46 <= x0 92 + x0 93 + x0 94 + x0 95;
i0_96: lut_h3_idwt
        port map(
                 address => yl 24, result => x0 96
i0 97: lut h2 idwt
        port map (
                 address => yh 24, result => x0 97
);
i0 98: lut h1 idwt
        port map(
                 address \Rightarrow yl 25, result \Rightarrow x0 98
i0 99: lut h4 idwt
        port map(
                 address \Rightarrow yh_25, result \Rightarrow x0_99
        );
xout_48 \le x0_96 + x0_97 + x0_98 + x0_99;
i0 100: lut h3 idwt
        port map(
                 address => yl_25, result => x0 100
i0 101: lut h2 idwt
        port map (
                 address \Rightarrow yh 25, result \Rightarrow x0 101
i0_102: lut_h1_idwt
        port map(
                 address \Rightarrow yl 26, result \Rightarrow x0 102
);
```

```
i0 103: lut h4 idwt
         port map(
                  address \Rightarrow yh 26, result \Rightarrow x0 103
         );
xout_50 \le x0_{100} + x0_{101} + x0_{102} + x0_{103};
i0 1\overline{0}4: lut h\overline{3} idwt
        port map(
                  address \Rightarrow yl 26, result \Rightarrow x0 104
);
i0 105: lut h2 idwt
         port map (
                  address => yh 26, result => x0 105
);
i0_106: lut_h1_idwt
         port map (
                  address \Rightarrow yl 27, result \Rightarrow x0 106
i0_107: lut_h4_idwt
         port map(
                  address \Rightarrow yh 27, result \Rightarrow x0 107
xout_52 \le x0_104 + x0_105 + x0_106 + x0_107;
i0_108: lut_h3_idwt
        port map(
                  address \Rightarrow yl 27, result \Rightarrow x0 108
i0 109: lut h2 idwt
         port map(
                  address \Rightarrow yh 27, result \Rightarrow x0 109
i0 110: lut h1 idwt
         port map(
                  address => yl 28, result => x0 110
);
i0 111: lut h4 idwt
         port map (
                  address \Rightarrow yh 28, result \Rightarrow x0 111
xout 54 <= x0 108 + x0 109 + x0 110 + x0 111;
i0 1\overline{12}: lut h\overline{3} idwt
        port map(
                  address => yl 28, result => x0 112
);
i0 113: lut h2 idwt
         port map(
                  address \Rightarrow yh 28, result \Rightarrow x0 113
);
i0 114: lut h1 idwt
         port map(
                  address \Rightarrow yl_29, result \Rightarrow x0_114
);
i0_115: lut_h4_idwt
         port map(
                  address \Rightarrow yh 29, result \Rightarrow x0 115
xout 56 <= x0_112 + x0_113 + x0_114 + x0_115;</pre>
i0 1\overline{16}: lut h\overline{3} idwt
         port map(
                  address \Rightarrow yl 29, result \Rightarrow x0 116
i0_117: lut_h2_idwt
         port map(
                  address \Rightarrow yh 29, result \Rightarrow x0 117
);
```

```
i0 118: lut h1 idwt
         port map(
                 address \Rightarrow yl 30, result \Rightarrow x0 118
i0_119: lut_h4_idwt
        port map (
                 address \Rightarrow yh 30, result \Rightarrow x0 119
xout 58 <= x0 116 + x0 117 + x0 118 + x0 119;
i0 1\overline{20}: lut h\overline{3} idwt
        port map(
                 address => y1_30, result => x0_120
);
i0_121: lut_h2_idwt
         port map (
                 address \Rightarrow yh 30, result \Rightarrow x0 121
i0_122: lut_h1_idwt
        port map(
                 address \Rightarrow yl 31, result \Rightarrow x0 122
i0 123: lut_h4_idwt
        port map(
                 address \Rightarrow yh 31, result \Rightarrow x0 123
xout 60 <= x0 120 + x0 121 + x0 122 + x0 123;
i0 1\overline{2}4: lut h\overline{3} idwt
       port map(
                 address => yl 31, result => x0 124
);
i0 125: lut_h2_idwt
        port map(
                 address \Rightarrow yh 31, result \Rightarrow x0 125
);
i0 126: lut h1 idwt
         port map(
                 address => yl 32, result => x0 126
i0 127: lut h4 idwt
        port map (
                 address \Rightarrow yh_32, result \Rightarrow x0 127
        );
xout_62 \le x0_{124} + x0_{125} + x0_{126} + x0_{127};
i0 1\overline{28}: lut h\overline{3} idwt
        port map (
                 address \Rightarrow yl 32, result \Rightarrow x0 128
);
i0 129: lut h2 idwt
        port map(
                 address \Rightarrow yh_32, result \Rightarrow x0_129
);
i0_130: lut_h1_idwt
         port map(
                 address => yl 33, result => x0 130
i0_131: lut_h4_idwt
         port map (
                 address => yh 33, result => x0 131
xout 64 <= x0 128 + x0 129 + x0 130 + x0 131;
i0_132: lut_h3_idwt
        port map(
                 address \Rightarrow yl 33, result \Rightarrow x0 132
);
```

```
i0 133: lut h2 idwt
        port map(
                 address \Rightarrow yh 33, result \Rightarrow x0 133
i0_134: lut_h1_idwt
        port map (
                 address => yl 34, result => x0 134
i0_135: lut_h4_idwt
        port map (
                 address \Rightarrow yh 34, result \Rightarrow x0 135
        );
xout 66 <= x0 132 + x0 133 + x0 134 + x0 135;
i0_136: lut_h3_idwt
        port map(
                 address \Rightarrow yl 34, result \Rightarrow x0 136
i0_137: lut_h2_idwt
        port map(
                 address \Rightarrow yh 34, result \Rightarrow x0 137
i0_138: lut_h1_idwt
        port map(
                 address \Rightarrow yl 35, result \Rightarrow x0 138
i0 139: lut h4 idwt
        port map(
                 address \Rightarrow yh_35, result \Rightarrow x0_139
xout 68 <= x0 136 + x0 137 + x0 138 + x0 139;
i0 140: lut h3 idwt
       port map(
                 address => yl 35, result => x0 140
);
i0 141: lut h2 idwt
        port map (
                 address \Rightarrow yh 35, result \Rightarrow x0 141
i0 142: lut h1 idwt
        port map (
                 address \Rightarrow yl 36, result \Rightarrow x0 142
);
i0 143: lut h4 idwt
        port map(
                 address => yh_36, result => x0 143
xout 70 <= x0 140 + x0 141 + x0 142 + x0 143;
i0 1\overline{44}: lut h\overline{3} idwt
        port map(
                 address \Rightarrow yl_36, result \Rightarrow x0_144
);
i0_145: lut_h2_idwt
        port map (
                 address \Rightarrow yh 36, result \Rightarrow x0 145
i0_146: lut_h1_idwt
        port map (
                 address \Rightarrow yl 37, result \Rightarrow x0 146
i0 147: lut h4_idwt
        port map(
                 address \Rightarrow yh_37, result \Rightarrow x0_147
xout 72 <= x0 144 + x0 145 + x0 146 + x0 147;
```

```
i0 148: lut h3 idwt
        port map(
                 address \Rightarrow yl 37, result \Rightarrow x0 148
i0_149: lut_h2_idwt
        port map (
                address \Rightarrow yh 37, result \Rightarrow x0 149
i0 150: lut h1 idwt
        port map(
                 address => yl 38, result => x0 150
i0 151: lut h4 idwt
        port map(
                 address \Rightarrow yh 38, result \Rightarrow x0 151
xout_74 \le x0_148 + x0_149 + x0_150 + x0_151;
i0_{152}: lut_h\overline{3}_idwt
       port map(
                 address \Rightarrow yl 38, result \Rightarrow x0 152
i0 153: lut_h2_idwt
       port map(
                 address \Rightarrow yh 38, result \Rightarrow x0 153
i0 154: lut h1 idwt
       port map(
                address => yl 39, result => x0 154
i0 155: lut h4 idwt
        port map (
                 address \Rightarrow yh 39, result \Rightarrow x0 155
        );
xout 76 <= x0 152 + x0 153 + x0 154 + x0 155;
i0 156: lut h3 idwt
       port map(
                 address => yl 39, result => x0 156
i0 157: lut h2 idwt
       port map(
                 address \Rightarrow yh 39, result \Rightarrow x0 157
);
i0 158: lut h1 idwt
       port map(
                address => yl_40, result => x0 158
i0 159: lut h4 idwt
        port map(
                 address \Rightarrow yh 40, result \Rightarrow x0 159
xout_78 <= x0_156 + x0_157 + x0_158 + x0_159;</pre>
i0 1\overline{60}: lut h\overline{3} idwt
        port map(
                 address \Rightarrow yl 40, result \Rightarrow x0 160
i0_161: lut_h2_idwt
        port map (
                 address \Rightarrow yh 40, result \Rightarrow x0 161
i0 162: lut h1 idwt
        port map(
                 address \Rightarrow yl_41, result \Rightarrow x0_162
i0 163: lut h4 idwt
```

```
port map(
                 address \Rightarrow yh 41, result \Rightarrow x0 163
        );
xout 80 <= x0 160 + x0 161 + x0 162 + x0 163;
i0 1\overline{6}4: lut h\overline{3} idwt
        port map (
                 address => yl 41, result => x0 164
i0 165: lut h2 idwt
        port map(
                 address \Rightarrow yh 41, result \Rightarrow x0 165
i0_166: lut_h1_idwt
        port map(
                 address => yl 42, result => x0 166
i0_167: lut_h4_idwt
        port map(
                 address \Rightarrow yh 42, result \Rightarrow x0 167
xout 82 <= x0 164 + x0 165 + x0 166 + x0 167;</pre>
i0 168: lut h3 idwt
       port map(
                 address \Rightarrow yl 42, result \Rightarrow x0 168
i0 169: lut h2 idwt
       port map(
                 address \Rightarrow yh_42, result \Rightarrow x0_169
i0 170: lut h1 idwt
        port map (
                 address \Rightarrow yl 43, result \Rightarrow x0 170
);
i0_171: lut_h4_idwt
         port map(
                 address => yh 43, result => x0 171
xout 84 <= x0 168 + x0 169 + x0 170 + x0 171;
i0 1\overline{7}2: lut h\overline{3} idwt
        port map(
                 address \Rightarrow yl_43, result \Rightarrow x0_172
);
i0 173: lut h2 idwt
        port map(
                 address \Rightarrow yh_43, result \Rightarrow x0_173
i0 174: lut h1 idwt
        port map(
                 address => yl 44, result => x0 174
i0_175: lut_h4_idwt
         port map(
                 address \Rightarrow yh 44, result \Rightarrow x0 175
xout 86 <= x0 172 + x0 173 + x0 174 + x0 175;
i0_{176}: lut_h3_idwt
        port map (
                 address \Rightarrow yl 44, result \Rightarrow x0 176
i0 177: lut h2_idwt
        port map(
                 address \Rightarrow yh_44, result \Rightarrow x0_177
i0 178: lut h1 idwt
```

```
port map(
                 address \Rightarrow yl 45, result \Rightarrow x0 178
);
i0 179: lut h4 idwt
        port map(
                 address => yh 45, result => x0 179
xout 88 <= x0 176 + x0 177 + x0 178 + x0 179;
i0 1\overline{8}0: lut h\overline{3} idwt
        port map (
                 address \Rightarrow yl 45, result \Rightarrow x0 180
i0_181: lut_h2_idwt
        port map(
                 address \Rightarrow yh 45, result \Rightarrow x0 181
i0_182: lut_h1_idwt
        port map(
                 address => yl 46, result => x0 182
i0 183: lut h4 idwt
        port map(
                 address \Rightarrow yh_46, result \Rightarrow x0_183
        );
xout_90 <= x0_180 + x0_181 + x0_182 + x0_183;</pre>
i0 1\overline{8}4: lut h\overline{3} idwt
        port map (
                 address => yl 46, result => x0 184
i0 185: lut h2 idwt
        port map (
                 address \Rightarrow yh 46, result \Rightarrow x0 185
);
i0_186: lut_h1_idwt
        port map(
                 address => yl 47, result => x0 186
i0_187: lut h4 idwt
        port map (
                 address \Rightarrow yh 47, result \Rightarrow x0 187
        );
xout 92 <= x0 184 + x0 185 + x0 186 + x0 187;
i0 188: lut h3 idwt
        port map(
                 address => yl_47, result => x0_188
i0 189: lut h2 idwt
        port map(
                 address \Rightarrow yh 47, result \Rightarrow x0 189
i0_190: lut_h1_idwt
        port map (
                 address \Rightarrow yl 48, result \Rightarrow x0 190
i0 191: lut h4 idwt
        port map(
                 address => yh 48, result => x0 191
xout 94 <= x0 188 + x0 189 + x0 190 + x0 191;
i0 1\overline{9}2: lut h\overline{3} idwt
        port map (
                 address \Rightarrow yl_48, result \Rightarrow x0_192
i0 193: lut h2 idwt
```

```
port map(
                 address \Rightarrow yh 48, result \Rightarrow x0 193
);
i0 194: lut h1 idwt
        port map(
                 address => yl 49, result => x0 194
i0 195: lut h4 idwt
        port map (
                 address \Rightarrow yh 49, result \Rightarrow x0 195
xout 96 <= x0_192 + x0_193 + x0_194 + x0_195;</pre>
i0_196: lut_h3_idwt
        port map(
                 address \Rightarrow yl 49, result \Rightarrow x0 196
i0_197: lut_h2_idwt
        port map(
                 address \Rightarrow yh 49, result \Rightarrow x0 197
i0 198: lut h1 idwt
        port map(
                 address \Rightarrow yl_50, result \Rightarrow x0_198
);
i0 199: lut h4 idwt
        port map (
                 address => yh 50, result => x0 199
xout 98 <= x0 196 + x0 197 + x0 198 + x0 199;
i0 200: lut h3 idwt
        port map (
                 address \Rightarrow yl 50, result \Rightarrow x0 200
);
i0_201: lut_h2_idwt
        port map(
                 address \Rightarrow yh 50, result \Rightarrow x0 201
i0 202: lut h1 idwt
        port map (
                 address \Rightarrow yl 51, result \Rightarrow x0 202
i0_203: lut_h4_idwt
        port map(
                 address \Rightarrow yh 51, result \Rightarrow x0 203
xout 100 <= x0 200 + x0 201 + x0 202 + x0 203;
i0 204: lut h3 idwt
        port map (
                 address \Rightarrow yl 51, result \Rightarrow x0 204
i0_205: lut_h2_idwt
        port map (
                 address \Rightarrow yh 51, result \Rightarrow x0 205
i0 206: lut h1 idwt
        port map(
                 address \Rightarrow yl 52, result \Rightarrow x0 206
i0 207: lut h4 idwt
        port map(
                 address => yh 52, result => x0 207
xout 102 <= x0 204 + x0 205 + x0 206 + x0 207;
i0 208: lut h3 idwt
```

```
port map(
                 address \Rightarrow yl 52, result \Rightarrow x0 208
);
i0 209: lut h2 idwt
        port map(
                 address \Rightarrow yh 52, result \Rightarrow x0 209
i0 210: lut h1 idwt
        port map (
                 address \Rightarrow yl 53, result \Rightarrow x0 210
i0_211: lut_h4_idwt
         port map (
                 address \Rightarrow yh_53, result \Rightarrow x0 211
         );
xout 104 <= x0 208 + x0 209 + x0 210 + x0 211;
i0_212: lut_h3_idwt
        port map (
                 address \Rightarrow yl 53, result \Rightarrow x0 212
i0 213: lut h2 idwt
        port map(
                 address \Rightarrow yh_53, result \Rightarrow x0_213
);
i0 214: lut h1 idwt
        port map(
                 address => yl 54, result => x0 214
);
i0 215: lut h4 idwt
        port map (
                 address \Rightarrow yh 54, result \Rightarrow x0 215
         );
xout_106 <= x0_212 + x0_213 + x0_214 + x0_215;</pre>
i0_216: lut_h3_idwt
        port map(
                 address => yl 54, result => x0 216
i0_217: lut h2 idwt
         port map (
                 address \Rightarrow yh 54, result \Rightarrow x0 217
i0_218: lut_h1_idwt
        port map(
                 address \Rightarrow yl 55, result \Rightarrow x0 218
i0 219: lut h4 idwt
        port map(
                 address \Rightarrow yh 55, result \Rightarrow x0 219
xout 108 \le x0_216 + x0_217 + x0_218 + x0_219;
i0_220: lut_h3_idwt
        port map(
                 address \Rightarrow yl 55, result \Rightarrow x0 220
i0 221: lut h2 idwt
         port map(
                 address \Rightarrow yh 55, result \Rightarrow x0 221
i0 222: lut h1 idwt
        port map(
                 address => yl 56, result => x0 222
i0 223: lut h4 idwt
        port map(
```

```
address \Rightarrow yh 56, result \Rightarrow x0 223
         );
xout 110 <= x0 220 + x0 221 + x0 222 + x0 223;
i0 224: lut h3 idwt
        port map(
                 address => yl 56, result => x0 224
i0 225: lut h2 idwt
        port map (
                 address \Rightarrow yh 56, result \Rightarrow x0 225
i0 226: lut h1 idwt
         port map (
                 address \Rightarrow yl 57, result \Rightarrow x0 226
);
i0 227: lut h4 idwt
        port map(
                 address \Rightarrow yh_57, result \Rightarrow x0_227
xout 112 <= x0 224 + x0 225 + x0 226 + x0 227;
i0 228: lut h3 idwt
        port map(
                 address \Rightarrow yl_57, result \Rightarrow x0_228
);
i0 229: lut h2 idwt
        port map (
                 address \Rightarrow yh 57, result \Rightarrow x0 229
);
i0 230: lut h1 idwt
         port map (
                 address \Rightarrow yl 58, result \Rightarrow x0 230
i0_231: lut_h4_idwt
         port map (
                 address \Rightarrow yh 58, result \Rightarrow x0 231
xout 114 <= x0 228 + x0 229 + x0 230 + x0 231;
i0 232: lut h3 idwt
        port map (
                 address \Rightarrow yl 58, result \Rightarrow x0 232
i0_233: lut_h2_idwt
        port map (
                 address \Rightarrow yh 58, result \Rightarrow x0 233
i0 234: lut h1 idwt
        port map(
                 address \Rightarrow yl 59, result \Rightarrow x0 234
i0 235: lut_h4_idwt
         port map (
                 address \Rightarrow yh 59, result \Rightarrow x0 235
         );
xout 116 <= x0 232 + x0 233 + x0 234 + x0 235;
i0_236: lut_h3_idwt
        port map(
                 address \Rightarrow yl 59, result \Rightarrow x0 236
i0 237: lut h2 idwt
        port map(
                 address => yh_59, result => x0_237
i0 238: lut h1 idwt
         port map(
```

```
address \Rightarrow yl 60, result \Rightarrow x0 238
i0 239: lut h4 idwt
        port map (
                 address \Rightarrow yh 60, result \Rightarrow x0 239
xout 118 <= x0 236 + x0 237 + x0 238 + x0 239;
i0 240: lut h3 idwt
        port map (
                 address \Rightarrow yl 60, result \Rightarrow x0 240
i0 241: lut h2 idwt
        port map (
                 address \Rightarrow yh 60, result \Rightarrow x0 241
);
i0 242: lut h1 idwt
        port map(
                 address \Rightarrow yl_61, result \Rightarrow x0_242
i0 243: lut h4 idwt
        port map (
                 address \Rightarrow yh_61, result \Rightarrow x0 243
        );
xout 120 <= x0 240 + x0 241 + x0 242 + x0 243;
i0 244: lut h3 idwt
        port map(
                 address => yl 61, result => x0 244
);
i0 245: lut h2 idwt
        port map (
                 address \Rightarrow yh 61, result \Rightarrow x0 245
);
i0_246: lut_h1_idwt
        port map (
                 address \Rightarrow yl 62, result \Rightarrow x0 246
i0 247: lut h4 idwt
        port map(
                 address \Rightarrow yh 62, result \Rightarrow x0 247
xout_122 \le x0_244 + x0_245 + x0_246 + x0_247;
i0_248: lut_h3_idwt
        port map (
                 address \Rightarrow yl 62, result \Rightarrow x0 248
);
i0 249: lut h2 idwt
        port map(
                 address \Rightarrow yh 62, result \Rightarrow x0 249
i0 250: lut_h1_idwt
        port map (
                 address => yl 63, result => x0 250
i0 251: lut_h4_idwt
        port map (
                 address \Rightarrow yh_63, result \Rightarrow x0_251
xout 124 <= x0 248 + x0 249 + x0 250 + x0 251;
i0 252: lut h3 idwt
        port map(
                 address => yl 63, result => x0 252
i0 253: lut h2 idwt
        port map(
```

```
address \Rightarrow yh 63, result \Rightarrow x0 253
        i0 254: lut h1 idwt
                 port map(
                          address \Rightarrow yl 0, result \Rightarrow x0 254
        i0 255: lut h4 idwt
                 port map(
                         address \Rightarrow yh 0, result \Rightarrow x0 255
        xout_126 <= x0_252 + x0_253 + x0_254 + x0_255;</pre>
--odd signal
        i1_0: lut_h2_idwt
                 port map (
                          address \Rightarrow yl 1, result \Rightarrow x1 0
        i1_1: lut_h4_idwt
                 port map(
                          address \Rightarrow yl 0, result \Rightarrow x1 1
        i1 2: lut h1 idwt neg
                 port map(
                          address \Rightarrow yh 0, result \Rightarrow x1 2
        i1 3: lut h3 idwt neg
                 port map(
                         address \Rightarrow yh 1, result \Rightarrow x1 3
                 );
        xout 1 \le x1 0 + x1 1 + x1 2 + x1 3;
        i1 4: lut h2 idwt
                 port map(
                          address \Rightarrow yl 2, result \Rightarrow x1 4
        );
        i1 5: lut h4 idwt
                 port map(
                          address \Rightarrow yl 1, result \Rightarrow x1 5
        il 6: lut h1 idwt neg
                 port map(
                          address \Rightarrow yh 1, result \Rightarrow x1 6
        );
        i1_7: lut_h3_idwt_neg
                 port map(
                         address => yh_2, result => x1 7
        xout_3 <= x1_4 + x1_5 + x1_6 + x1_7;</pre>
        i1 8: lut h2 idwt
                 port map(
                         address \Rightarrow yl_3, result \Rightarrow x1_8
        );
        i1_9: lut_h4_idwt
                 port map(
                          address => yl 2, result => x1 9
        i1_10: lut_h1_idwt_neg
                 port map (
                          address \Rightarrow yh 2, result \Rightarrow x1 10
        il 11: lut h3 idwt neg
                 port map(
                          address => yh_3, result => x1_11
        xout 5 <= x1 8 + x1 9 + x1 10 + x1 11;
```

```
i1 12: lut h2 idwt
        port map(
                 address \Rightarrow yl 4, result \Rightarrow x1 12
i1_13: lut_h4_idwt
        port map (
                 address => yl 3, result => x1 13
il 14: lut h1 idwt neg
        port map(
                 address \Rightarrow yh 3, result \Rightarrow x1 14
i1_15: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 4, result \Rightarrow x1 15
xout 7 <= x1_12 + x1_13 + x1_14 + x1_15;</pre>
i1_{\overline{16}}: lut_{\overline{12}}idwt
        port map(
                 address \Rightarrow yl 5, result \Rightarrow x1 16
i1_17: lut_h4_idwt
        port map(
                 address \Rightarrow yl 4, result \Rightarrow x1 17
i1 18: lut h1 idwt neg
        port map(
                 address => yh_4, result => x1_18
i1 19: lut h3 idwt neg
        port map(
                 address \Rightarrow yh 5, result \Rightarrow x1 19
        );
xout_9 <= x1_16 + x1_17 + x1_18 + x1_19;</pre>
i1 20: lut h2 idwt
        port map(
                 address => yl 6, result => x1 20
i1 21: lut h4 idwt
        port map(
                 address \Rightarrow yl 5, result \Rightarrow x1 21
i1 22: lut h1 idwt neg
        port map(
                 address => yh_5, result => x1_22
i1_23: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 6, result \Rightarrow x1 23
xout_11 <= x1_20 + x1_21 + x1_22 + x1_23;
i1_24: lut_h2_idwt
        port map(
                 address => yl 7, result => x1 24
i1_25: lut_h4_idwt
        port map (
                 address \Rightarrow yl 6, result \Rightarrow x1 25
i1 26: lut h1 idwt neg
        port map (
                 address \Rightarrow yh 6, result \Rightarrow x1 26
i1 27: lut h3 idwt neg
```

```
port map(
                 address \Rightarrow yh 7, result \Rightarrow x1 27
        );
xout_13 <= x1_24 + x1_25 + x1_26 + x1_27;</pre>
i1_28: lut_h2_idwt
        port map (
                 address => yl 8, result => x1 28
i1 29: lut h4 idwt
        port map(
                 address \Rightarrow yl 7, result \Rightarrow x1 29
i1_30: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 7, result \Rightarrow x1 30
i1_31: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 8, result \Rightarrow x1 31
xout 15 <= x1 28 + x1 29 + x1 30 + x1 31;
i1 32: lut_h2_idwt
        port map(
                 address \Rightarrow yl 9, result \Rightarrow x1 32
i1 33: lut h4 idwt
        port map(
                 address \Rightarrow yl_8, result \Rightarrow x1_33
il 34: lut h1 idwt neg
        port map(
                 address \Rightarrow yh 8, result \Rightarrow x1 34
);
i1_35: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 9, result \Rightarrow x1 35
xout 17 <= x1 32 + x1 33 + x1 34 + x1 35;
i1 36: lut h2 idwt
        port map(
                 address \Rightarrow yl_10, result \Rightarrow x1_36
);
i1 37: lut h4 idwt
        port map(
                 address => yl_9, result => x1_37
i1_38: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 9, result \Rightarrow x1 38
i1_39: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 10, result \Rightarrow x1 39
xout 19 <= x1 36 + x1 37 + x1 38 + x1 39;
i1_40: lut_h2_idwt
        port map(
                 address => yl 11, result => x1 40
i1 41: lut h4 idwt
        port map(
                 address \Rightarrow yl 10, result \Rightarrow x1 41
i1 42: lut h1 idwt neg
```

```
port map(
                address \Rightarrow yh 10, result \Rightarrow x1 42
);
i1 43: lut h3 idwt neg
        port map(
                address => yh 11, result => x1 43
xout_21 <= x1_40 + x1_41 + x1_42 + x1_43;</pre>
i1_44: lut_h2_idwt
        port map(
                address => yl 12, result => x1 44
i1 45: lut h4 idwt
        port map(
                address => yl 11, result => x1 45
i1_46: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 11, result \Rightarrow x1 46
il 47: lut h3 idwt neg
        port map(
                address \Rightarrow yh_12, result \Rightarrow x1_47
        );
xout_23 \le x1_44 + x1_45 + x1_46 + x1_47;
i1 48: lut h2 idwt
        port map (
                address \Rightarrow yl 13, result \Rightarrow x1 48
i1 49: lut h4 idwt
        port map (
                address => yl 12, result => x1 49
);
i1_50: lut_h1_idwt_neg
        port map(
                address => yh 12, result => x1 50
il 51: lut h3 idwt neg
        port map(
                address \Rightarrow yh 13, result \Rightarrow x1 51
xout_25 <= x1_48 + x1_49 + x1_50 + x1_51;
i1 5\overline{2}: lut h2 idwt
        port map(
                address => yl_14, result => x1_52
i1 53: lut h4 idwt
        port map(
                address => yl 13, result => x1 53
i1_54: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 13, result \Rightarrow x1 54
i1 55: lut h3 idwt neg
        port map(
                address => yh 14, result => x1 55
xout 27 <= x1 52 + x1 53 + x1 54 + x1 55;
i1 \overline{56}: lut h2 idwt
        port map(
                address \Rightarrow yl_15, result \Rightarrow x1_56
i1 57: lut h4 idwt
```

```
port map(
                address \Rightarrow yl 14, result \Rightarrow x1 57
);
i1 58: lut h1 idwt neg
        port map(
                address => yh 14, result => x1 58
i1 59: lut h3 idwt neg
        port map(
                address \Rightarrow yh 15, result \Rightarrow x1 59
        );
xout_29 <= x1_56 + x1_57 + x1_58 + x1_59;
i1_60: lut_h2_idwt
        port map(
                address => yl 16, result => x1 60
i1_61: lut_h4_idwt
        port map(
                address => yl 15, result => x1 61
i1 62: lut h1 idwt neg
        port map(
                address \Rightarrow yh_15, result \Rightarrow x1_62
);
i1 63: lut h3 idwt neg
        port map(
                address => yh 16, result => x1 63
        );
xout_31 <= x1_60 + x1_61 + x1_62 + x1_63;</pre>
i1 6\overline{4}: lut h2 idwt
        port map (
                address \Rightarrow yl 17, result \Rightarrow x1 64
);
i1_65: lut_h4_idwt
        port map(
                address => yl 16, result => x1 65
il 66: lut h1 idwt neg
        port map(
                address => yh 16, result => x1 66
i1_67: lut_h3_idwt_neg
        port map(
                address \Rightarrow yh_17, result \Rightarrow x1_67
        );
xout 33 <= x1 64 + x1 65 + x1 66 + x1 67;
i1 68: lut h2 idwt
        port map(
                address => yl 18, result => x1 68
i1_69: lut_h4_idwt
        port map(
                address => yl 17, result => x1 69
i1_70: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 17, result \Rightarrow x1 70
il 71: lut h3 idwt neg
        port map(
                address => yh 18, result => x1 71
        );
xout 35 <= x1 68 + x1 69 + x1 70 + x1 71;
i1 72: lut h2 idwt
```

```
port map(
                address => yl 19, result => x1 72
);
i1 73: lut h4 idwt
        port map(
                address => yl 18, result => x1 73
il 74: lut h1 idwt neg
        port map (
                address \Rightarrow yh 18, result \Rightarrow x1 74
i1 75: lut_h3_idwt_neg
        port map(
                address \Rightarrow yh_19, result \Rightarrow x1_75
        );
xout 37 <= x1 72 + x1 73 + x1 74 + x1 75;
i1_76: lut_h2_idwt
        port map(
                address \Rightarrow yl 20, result \Rightarrow x1 76
i1 77: lut h4 idwt
        port map(
                address \Rightarrow yl_19, result \Rightarrow x1_77
);
il 78: lut h1 idwt neg
        port map(
                address => yh 19, result => x1 78
);
i1 79: lut h3 idwt neg
        port map(
                address \Rightarrow yh 20, result \Rightarrow x1 79
        );
xout_39 \le x1_76 + x1_77 + x1_78 + x1_79;
i1_80: lut_h2_idwt
        port map(
                address => yl_21, result => x1_80
il 81: lut h4 idwt
        port map (
                address \Rightarrow yl 20, result \Rightarrow x1 81
i1_82: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 20, result \Rightarrow x1 82
i1 83: lut h3 idwt neg
        port map(
                address => yh 21, result => x1 83
xout 41 <= x1_80 + x1_81 + x1_82 + x1_83;</pre>
i1_84: lut_h2_idwt
        port map(
                address => yl 22, result => x1 84
i1 85: lut h4 idwt
        port map(
                address => yl 21, result => x1 85
il 86: lut h1 idwt neg
        port map(
                address => yh 21, result => x1 86
il 87: lut h3 idwt neg
        port map(
```

```
address \Rightarrow yh 22, result \Rightarrow x1 87
        );
xout 43 <= x1 84 + x1 85 + x1 86 + x1 87;
i1 88: lut h2 idwt
        port map(
                address => yl 23, result => x1 88
i1 89: lut h4 idwt
        port map(
                address => yl 22, result => x1 89
i1 90: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 22, result \Rightarrow x1 90
);
il 91: lut h3 idwt neg
        port map(
                address => yh_23, result => x1_91
xout 45 <= x1 88 + x1 89 + x1 90 + x1 91;
i1 92: lut h2 idwt
        port map(
                address \Rightarrow yl_24, result \Rightarrow x1_92
);
i1 93: lut h4 idwt
        port map (
                address => yl 23, result => x1 93
);
il 94: lut h1 idwt neg
        port map(
                address \Rightarrow yh 23, result \Rightarrow x1 94
i1_95: lut_h3_idwt_neg
        port map(
                address \Rightarrow yh 24, result \Rightarrow x1 95
xout 47 <= x1 92 + x1 93 + x1 94 + x1 95;
i1 96: lut h2 idwt
        port map (
                address => yl 25, result => x1 96
i1_97: lut_h4_idwt
        port map(
                address => yl 24, result => x1 97
il 98: lut h1 idwt neg
        port map(
                address => yh 24, result => x1 98
i1 99: lut_h3_idwt_neg
        port map(
                address \Rightarrow yh 25, result \Rightarrow x1 99
        );
xout 49 <= x1 96 + x1 97 + x1 98 + x1 99;
i1 1\overline{0}0: lut h\overline{2} idwt
        port map(
                address => yl 26, result => x1 100
i1 101: lut h4 idwt
        port map(
                address => y1_25, result => x1_101
il 102: lut h1 idwt neg
        port map(
```

```
address \Rightarrow yh 25, result \Rightarrow x1 102
il 103: lut h3 idwt neg
        port map(
                 address \Rightarrow yh 26, result \Rightarrow x1 103
xout 51 <= x1 100 + x1 101 + x1 102 + x1 103;
il 1\overline{0}4: lut h\overline{2} idwt
       port map (
                 address \Rightarrow yl 27, result \Rightarrow x1 104
i1 105: lut h4 idwt
        port map (
                 address => yl 26, result => x1 105
);
il 106: lut h1 idwt neg
        port map(
                 address => yh_26, result => x1_106
il 107: lut h3 idwt neg
        port map(
                address => yh_27, result => x1 107
        );
xout_53 \le x1_104 + x1_105 + x1_106 + x1_107;
i1 108: lut h2 idwt
        port map(
                 address => yl 28, result => x1 108
);
il 109: lut h4 idwt
        port map(
                 address \Rightarrow yl_27, result \Rightarrow x1 109
);
i1 110: lut_h1_idwt_neg
        port map (
                 address \Rightarrow yh 27, result \Rightarrow x1 110
il 111: lut h3 idwt neg
        port map(
                 address => yh 28, result => x1 111
xout_55 <= x1_108 + x1_109 + x1_110 + x1_111;</pre>
i1_{112}: lut_h\overline{2}_idwt
        port map(
                 address \Rightarrow yl 29, result \Rightarrow x1 112
);
i1 113: lut h4 idwt
        port map(
                 address => yl 28, result => x1 113
i1_114: lut_h1_idwt_neg
        port map (
                 address \Rightarrow yh 28, result \Rightarrow x1 114
i1 115: lut h3 idwt neg
        port map (
                 address => yh_29, result => x1_115
xout 57 <= x1 112 + x1 113 + x1 114 + x1 115;
il 1\overline{16}: lut h\overline{2} idwt
        port map(
                 address => y1_30, result => x1_116
i1 117: lut h4 idwt
        port map(
```

```
address \Rightarrow yl 29, result \Rightarrow x1 117
i1_118: lut_h1_idwt_neg
        port map(
                 address => yh_29, result => x1_118
il 119: lut h3 idwt neg
        port map(
                 address => yh 30, result => x1 119
xout 59 <= x1 116 + x1 117 + x1 118 + x1 119;
i1_1\overline{20}: lut_h\overline{2}_idwt
        port map(
                 address => yl_31, result => x1_120
);
i1 121: lut h4 idwt
        port map(
                 address => y1_30, result => x1_121
i1 122: lut h1 idwt neg
        port map(
                 address \Rightarrow yh 30, result \Rightarrow x1 122
i1_123: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 31, result \Rightarrow x1 123
xout_61 <= x1_120 + x1_121 + x1_122 + x1_123;</pre>
i1 1\overline{2}4: lut h\overline{2} idwt
        port map (
                 address \Rightarrow yl 32, result \Rightarrow x1 124
);
i1_125: lut_h4_idwt
         port map (
                  address \Rightarrow yl 31, result \Rightarrow x1 125
i1 126: lut h1 idwt neg
        port map(
                 address \Rightarrow yh 31, result \Rightarrow x1 126
i1_127: lut_h3_idwt_neg
        port map (
                 address \Rightarrow yh 32, result \Rightarrow x1 127
xout_63 <= x1_124 + x1_125 + x1_126 + x1_127;</pre>
i1 1\overline{28}: lut h\overline{2} idwt
        port map(
                 address => yl 33, result => x1 128
i1 129: lut_h4_idwt
        port map(
                  address \Rightarrow yl 32, result \Rightarrow x1 129
);
i1 130: lut h1 idwt neg
        port map(
                 address \Rightarrow yh_32, result \Rightarrow x1_130
i1 131: lut h3 idwt neg
         port map(
                 address => yh 33, result => x1 131
        );
xout_65 \le x1_128 + x1_129 + x1_130 + x1_131;
i1_132: lut_h2_idwt
        port map(
```

```
address \Rightarrow yl 34, result \Rightarrow x1 132
i1 133: lut h4 idwt
        port map(
                 address => yl 33, result => x1 133
il 134: lut hl idwt neg
        port map(
                address => yh 33, result => x1 134
il 135: lut h3 idwt neg
        port map(
                 address \Rightarrow yh 34, result \Rightarrow x1 135
        );
xout 67 <= x1 132 + x1 133 + x1 134 + x1 135;
il 1\overline{3}6: lut h\overline{2} idwt
        port map(
                 address => yl_35, result => x1_136
i1 137: lut h4 idwt
        port map(
                 address => yl 34, result => x1 137
i1_138: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 34, result \Rightarrow x1 138
i1_139: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 35, result \Rightarrow x1 139
xout 69 <= x1 136 + x1 137 + x1 138 + x1 139;
i1_{\overline{40}}: lut_{\overline{2}}idwt
        port map(
                 address => yl 36, result => x1 140
il 141: lut h4 idwt
        port map(
                 address \Rightarrow yl 35, result \Rightarrow x1 141
i1 142: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 35, result \Rightarrow x1 142
i1 143: lut_h3_idwt_neg
        port map(
                 address \Rightarrow yh 36, result \Rightarrow x1 143
xout 71 <= x1 140 + x1 141 + x1 142 + x1 143;
i1_144: lut_h2_idwt
       port map(
                 address \Rightarrow yl 37, result \Rightarrow x1 144
);
i1 145: lut h4 idwt
        port map (
                 address \Rightarrow yl_36, result \Rightarrow x1_145
il 146: lut h1 idwt neg
        port map(
                 address => yh 36, result => x1 146
i1_147: lut_h3_idwt_neg
        port map (
                 address \Rightarrow yh 37, result \Rightarrow x1 147
```

```
);
xout 73 <= x1 144 + x1 145 + x1 146 + x1 147;
il 1\overline{48}: lut h\overline{2} idwt
        port map(
                 address => yl 38, result => x1 148
i1 149: lut h4 idwt
        port map(
                address => yl 37, result => x1 149
il 150: lut h1 idwt neg
        port map (
                address \Rightarrow yh 37, result \Rightarrow x1 150
il 151: lut h3 idwt neg
        port map(
                 address \Rightarrow yh_38, result \Rightarrow x1_151
xout 75 <= x1 148 + x1 149 + x1 150 + x1 151;
i1 152: lut h2 idwt
        port map(
                address => yl 39, result => x1 152
i1_153: lut_h4_idwt
        port map(
                address => yl 38, result => x1 153
i1_154: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 38, result \Rightarrow x1 154
i1_155: lut_h3_idwt_neg
        port map (
                 address \Rightarrow yh 39, result \Rightarrow x1 155
xout 77 <= x1 152 + x1 153 + x1 154 + x1 155;
il 1\overline{5}6: lut h\overline{2} idwt
        port map(
                 address \Rightarrow yl 40, result \Rightarrow x1 156
i1_157: lut_h4_idwt
       port map (
                address \Rightarrow yl 39, result \Rightarrow x1 157
i1 158: lut_h1_idwt_neg
       port map(
                address \Rightarrow yh 39, result \Rightarrow x1 158
il 159: lut h3 idwt neg
                address => yh 40, result => x1 159
        );
xout 79 <= x1 156 + x1 157 + x1 158 + x1 159;
il 1\overline{60}: lut h\overline{2} idwt
       port map(
                address => yl_41, result => x1_160
i1 161: lut h4 idwt
        port map(
                address => yl 40, result => x1 161
);
i1_162: lut_h1_idwt_neg
        port map(
                address \Rightarrow yh 40, result \Rightarrow x1 162
```

```
il 163: lut h3 idwt neg
        port map (
                address \Rightarrow yh 41, result \Rightarrow x1 163
        );
xout 81 <= x1 160 + x1 161 + x1 162 + x1 163;
il 1\overline{64}: lut h\overline{2} idwt
       port map(
                address => yl 42, result => x1 164
i1 165: lut h4 idwt
                address => yl 41, result => x1 165
il 166: lut h1 idwt neg
        port map(
                address => yh_41, result => x1_166
il 167: lut h3 idwt neg
        port map(
                address => yh 42, result => x1 167
       );
xout_83 <= x1_164 + x1_165 + x1_166 + x1_167;</pre>
i1_{\overline{168}}: lut_h\overline{2}_idwt
       port map(
                address => yl 43, result => x1 168
i1_169: lut_h4_idwt
        port map (
                address => yl 42, result => x1 169
i1_170: lut_h1_idwt_neg
        port map (
                address \Rightarrow yh 42, result \Rightarrow x1 170
i1_171: lut_h3_idwt_neg
        port map(
                address \Rightarrow yh_43, result \Rightarrow x1_171
xout 85 <= x1 168 + x1 169 + x1 170 + x1 171;
i1 172: lut h2 idwt
       port map(
                address \Rightarrow yl 44, result \Rightarrow x1 172
i1 173: lut_h4_idwt
       port map(
                address => yl 43, result => x1 173
il 174: lut h1 idwt neg
                address => yh_43, result => x1_174
il 175: lut h3 idwt neg
        port map(
                address => yh 44, result => x1 175
xout_87 <= x1_172 + x1_173 + x1_174 + x1_175;</pre>
i1 176: lut h2 idwt
        port map (
                address => yl 45, result => x1 176
i1_177: lut_h4_idwt
        port map(
                address => yl 44, result => x1 177
```

```
il 178: lut h1 idwt neg
        port map(
                address \Rightarrow yh 44, result \Rightarrow x1 178
);
il 179: lut h3 idwt neg
        port map(
                 address \Rightarrow yh_45, result \Rightarrow x1_179
xout 89 <= x1 176 + x1 177 + x1 178 + x1 179;
i1 180: lut h2 idwt
        port map(
                address \Rightarrow yl 46, result \Rightarrow x1 180
);
il 181: lut h4 idwt
        port map(
                address \Rightarrow yl_45, result \Rightarrow x1_181
il 182: lut h1 idwt neg
        port map(
                address \Rightarrow yh 45, result \Rightarrow x1 182
i1_183: lut_h3_idwt_neg
        port map(
                address \Rightarrow yh 46, result \Rightarrow x1 183
xout 91 <= x1 180 + x1 181 + x1 182 + x1 183;
i1_184: lut_h2_idwt
        port map(
                address => yl 47, result => x1 184
i1 185: lut h4 idwt
        port map (
                address \Rightarrow yl 46, result \Rightarrow x1 185
i1_186: lut_h1_idwt_neg
        port map(
                address => yh 46, result => x1 186
il 187: lut h3 idwt neg
        port map(
                address => yh 47, result => x1 187
        );
xout 93 <= x1_184 + x1_185 + x1_186 + x1_187;</pre>
i1_{\overline{188}}: lut_{\overline{12}}idwt
        port map(
                address => yl 48, result => x1 188
il 189: lut h4 idwt
                address => yl_47, result => x1_189
);
il 190: lut h1 idwt neg
        port map(
                address => yh 47, result => x1 190
il 191: lut h3 idwt neg
        port map (
                address => yh 48, result => x1 191
        );
xout_95 <= x1_188 + x1_189 + x1_190 + x1_191;</pre>
i1_192: lut_h2_idwt
        port map (
                 address \Rightarrow yl 49, result \Rightarrow x1 192
```

```
i1 193: lut h4 idwt
         port map(
                  address \Rightarrow yl 48, result \Rightarrow x1 193
);
i1_194: lut_h1_idwt_neg
         port map(
                  address \Rightarrow yh 48, result \Rightarrow x1 194
);
i1 195: lut_h3_idwt_neg
         port map (
                  address => yh_49, result => x1_195
         );
xout_97 <= x1_192 + x1_193 + x1_194 + x1_195;</pre>
il 1\overline{9}6: lut h\overline{2} idwt
         port map(
                  address => yl_50, result => x1_196
il 197: lut h4 idwt
         port map(
                  address \Rightarrow yl 49, result \Rightarrow x1 197
i1_198: lut_h1_idwt_neg
         port map(
                  address \Rightarrow yh 49, result \Rightarrow x1 198
il 199: lut h3 idwt neg
         port map (
                  address \Rightarrow yh 50, result \Rightarrow x1 199
xout 99 <= x1 196 + x1_197 + x1_198 + x1_199;</pre>
i1_2\overline{00}: lut_h\overline{2}_idwt
         port map (
                  address \Rightarrow yl 51, result \Rightarrow x1 200
i1 201: lut h4 idwt
         port map(
                  address \Rightarrow yl 50, result \Rightarrow x1 201
i1 202: lut h1 idwt neg
         port map(
                  address \Rightarrow yh 50, result \Rightarrow x1 202
i1_203: lut_h3_idwt_neg
         port map (
                  address \Rightarrow yh 51, result \Rightarrow x1 203
xout 101 <= x1 200 + x1 201 + x1 202 + x1 203;
i1 204: lut h2 idwt
                  address => y1_52, result => x1_204
);
i1 205: lut h4 idwt
         port map(
                  address => yl 51, result => x1 205
il 206: lut hl idwt neg
         port map (
                 address \Rightarrow yh 51, result \Rightarrow x1 206
i1_207: lut_h3_idwt_neg
         port map (
                  address \Rightarrow yh 52, result \Rightarrow x1 207
```

```
xout 103 <= x1 204 + x1 205 + x1 206 + x1 207;
i1 208: lut h2 idwt
        port map (
                 address \Rightarrow yl 53, result \Rightarrow x1 208
);
i1 209: lut h4 idwt
        port map(
                 address \Rightarrow yl 52, result \Rightarrow x1 209
);
i1 210: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 52, result \Rightarrow x1 210
);
i1_211: lut_h3_idwt_neg
        port map (
                 address \Rightarrow yh 53, result \Rightarrow x1 211
xout_105 <= x1_208 + x1_209 + x1_210 + x1_211;
i1 212: lut h2 idwt
        port map(
                 address => yl 54, result => x1 212
);
i1_213: lut_h4_idwt
        port map (
                 address \Rightarrow yl 53, result \Rightarrow x1 213
il 214: lut h1 idwt neg
        port map (
                 address \Rightarrow yh 53, result \Rightarrow x1 214
i1 215: lut h3 idwt neg
        port map(
                 address => yh_54, result => x1_215
        );
xout 107 <= x1 212 + x1 213 + x1 214 + x1 215;
i1_216: lut_h2_idwt
        port map(
                 address \Rightarrow yl 55, result \Rightarrow x1 216
i1 217: lut h4 idwt
        port map(
                 address => yl 54, result => x1 217
);
i1_218: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 54, result \Rightarrow x1 218
i1 219: lut h3 idwt neg
        port map(
                 address \Rightarrow yh_55, result \Rightarrow x1_219
        );
xout_109 <= x1_216 + x1_217 + x1_218 + x1_219;
i1_220: lut_h2_idwt
        port map(
                 address => yl 56, result => x1 220
i1 221: lut h4 idwt
        port map (
                 address \Rightarrow yl 55, result \Rightarrow x1 221
i1_222: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 55, result \Rightarrow x1 222
);
```

```
i1 223: lut h3 idwt neg
         port map(
                  address \Rightarrow yh 56, result \Rightarrow x1 223
        );
xout_111 <= x1_220 + x1_221 + x1_222 + x1_223;
i1_224: lut_h2_idwt</pre>
        port map(
                  address \Rightarrow yl 57, result \Rightarrow x1 224
);
i1 225: lut h4 idwt
        port map (
                  address => yl 56, result => x1 225
);
i1_226: lut_h1_idwt_neg
        port map (
                  address \Rightarrow yh 56, result \Rightarrow x1 226
i1_227: lut_h3_idwt_neg
         port map(
                 address \Rightarrow yh 57, result \Rightarrow x1 227
xout 113 <= x1 224 + x1 225 + x1 226 + x1 227;
i1_228: lut_h2_idwt
        port map (
                  address \Rightarrow yl 58, result \Rightarrow x1 228
i1 229: lut h4 idwt
        port map (
                 address \Rightarrow yl 57, result \Rightarrow x1 229
il 230: lut h1 idwt neg
         port map(
                  address \Rightarrow yh_57, result \Rightarrow x1_230
);
i1 231: lut_h3_idwt_neg
         port map(
                  address \Rightarrow yh 58, result \Rightarrow x1 231
xout 115 <= x1 228 + x1 229 + x1 230 + x1 231;
i1 232: lut h2 idwt
        port map(
                 address => yl 59, result => x1 232
);
i1 233: lut h4 idwt
        port map (
                  address \Rightarrow yl 58, result \Rightarrow x1 233
i1 234: lut h1 idwt neg
        port map(
                 address \Rightarrow yh_58, result \Rightarrow x1_234
);
i1_235: lut_h3_idwt_neg
         port map(
                  address \Rightarrow yh 59, result \Rightarrow x1 235
xout_117 <= x1_232 + x1_233 + x1_234 + x1_235;
i1 236: lut h2 idwt
        port map (
                 address \Rightarrow yl 60, result \Rightarrow x1 236
);
i1_237: lut_h4_idwt
        port map(
                 address \Rightarrow yl 59, result \Rightarrow x1 237
);
```

```
il 238: lut h1 idwt neg
        port map(
                 address \Rightarrow yh 59, result \Rightarrow x1 238
i1_239: lut_h3_idwt_neg
        port map (
                 address \Rightarrow yh 60, result \Rightarrow x1 239
xout 119 <= x1 236 + x1 237 + x1 238 + x1 239;
i1 240: lut h2 idwt
        port map (
                 address => yl_61, result => x1_240
);
i1_241: lut_h4_idwt
        port map (
                 address \Rightarrow yl 60, result \Rightarrow x1 241
i1_242: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 60, result \Rightarrow x1 242
il 243: lut h3 idwt neg
        port map(
                 address \Rightarrow yh 61, result \Rightarrow x1 243
xout 121 <= x1 240 + x1 241 + x1 242 + x1 243;
i1 244: lut h2 idwt
        port map (
                 address \Rightarrow yl 62, result \Rightarrow x1 244
);
i1 245: lut_h4_idwt
        port map(
                 address => yl 61, result => x1 245
);
i1 246: lut h1 idwt neg
        port map(
                 address \Rightarrow yh 61, result \Rightarrow x1 246
i1 247: lut h3 idwt neg
        port map(
                 address \Rightarrow yh 62, result \Rightarrow x1 247
        );
xout_123 \le x1_244 + x1_245 + x1_246 + x1_247;
i1 248: lut h2 idwt
        port map(
                 address \Rightarrow yl 63, result \Rightarrow x1 248
);
i1 249: lut h4 idwt
        port map(
                 address \Rightarrow yl_62, result \Rightarrow x1_249
);
i1_250: lut_h1_idwt_neg
        port map(
                 address \Rightarrow yh 62, result \Rightarrow x1 250
i1_251: lut_h3_idwt_neg
        port map (
                 address \Rightarrow yh 63, result \Rightarrow x1 251
xout 125 <= x1 248 + x1 249 + x1 250 + x1 251;
i1_252: lut_h2_idwt
        port map(
                 address \Rightarrow yl 0, result \Rightarrow x1 252
);
```

## **Appendix C:**

```
C Code to generate LUT Values
#include <iostream>
#include <stdio.h>
#include <math.h>
short decimal2binary(unsigned long decimal_value, char
binary_value[32])
{
    short index,significant_digits=0;
    unsigned long temp_value;
    for(index=31;index>=0;index--)
        // temp_value=decimal_value/pow(2,index)
        temp_value=decimal_value/(1<<index);</pre>
        if(temp_value>0)
        {
            binary_value[index]=(char)('0'+temp_value);
            // decimal_value=decimal_value%pow(2,index)
            decimal_value=decimal_value%(1<<index);</pre>
            if(!significant_digits)
                significant_digits=index;
        }
        else
        {
            binary_value[index]='0';
        }
    return significant_digits;
}
int main (int argc, char * const argv□) {
    FILE *fp;
    //char *mode = "w";
    char outputFilename[] = "out.txt";
    int i,j;
    short significant_digits,index;
    char binary_value[32];
    fp = fopen(outputFilename, "w");
    for (i = 0; i \le 255; i++){
        j = int(round(0.2241*256*i));
        significant_digits=decimal2binary(j,binary_value);
        fprintf(fp,"'");
        /*if (significant_digits >= 8)
        {*/
                for ( index = 16; index >= (8); index--)
```

```
fprintf(fp,"%c",binary_value[index]);
        /*}
        else
        {
                for(index = 7; index \rightarrow 0; index--)
                    fprintf(fp, "%c", binary_value[index]);
        }*/
        fprintf(fp,"',\n");
    fclose(fp);
}
C Code to Generate VHDL Code for IDWT (highpass)
#include <iostream>
#include <stdio.h>
#include <math.h>
int main (int argc, char * const argv[]) {
    FILE *fp;
    char outputFilename[] = "out.txt";
    int i, k;
    int counter_in, counter_out;
    int counterh;
    fp = fopen(outputFilename, "w");
    counterh = 4;
    counter_in = 0;
    k = 0;
    for (i = 0; i \le 255; i++)
        fprintf(fp,"i1_");
        fprintf(fp,"%u",i);
        fprintf(fp,": lut_h");
        fprintf(fp,"%u",counterh);
        counterh = counterh - 1;
        fprintf(fp,"\n");
        fprintf(fp,"\t");
        fprintf(fp,"port map(");
        fprintf(fp,"\n");
        fprintf(fp,"\t");
        fprintf(fp, "address => xin_");
        fprintf(fp, "%u", counter_in);
        counter_in = counter_in + 1;
        fprintf(fp,", result => x1_");
        fprintf(fp,"%u",i);
        fprintf(fp,"\n");
        fprintf(fp,");");
        fprintf(fp,"\n");
        if (counterh == 0)
```

```
{
            counterh = 4;
            fprintf(fp,"yh_");
            fprintf(fp, "%u", counter_out);
            counter_out = counter_out + 1;
            fprintf(fp," \ll x1_");
            fprintf(fp,"%u",i-1);
            fprintf(fp," + x1_");
            fprintf(fp,"%u",i-2);
            fprintf(fp," + x1_");
            fprintf(fp,"%u",i-3);
            fprintf(fp," + x1_");
            fprintf(fp,"%u",i);
            fprintf(fp,";\n");
            fprintf(fp,"\n");
            k = k + 2;
            counter_in = k;
        }
    }
    fclose(fp);
}
C Code to Generate Thresholding VHDL code
#include <iostream>
#include <stdio.h>
#include <math.h>
int main (int argc, char * const argv[]) {
    FILE *fp;
    char outputFilename[] = "out.txt";
    fp = fopen(outputFilename, "w");
    for (int i = 0; i <= 63; i++)
        fprintf(fp,"if yh_");
        fprintf(fp,"%u",i);
        fprintf(fp," <= thld then");</pre>
        fprintf(fp,"\n");
        fprintf(fp,"\t");
        fprintf(fp,"yhout_");
        fprintf(fp,"%u",i);
        /*fprintf(fp," <= yl_");</pre>
        fprintf(fp,"%u",i);
        fprintf(fp," - thld;");*/
        fprintf(fp," <= '000000000';");</pre>
        fprintf(fp,"\n");
        fprintf(fp, "else\n");
        fprintf(fp,"\t");
        fprintf(fp, "yhout_");
```

```
fprintf(fp,"%u",i);
    fprintf(fp," <= yh_");
    fprintf(fp,"%u",i);
    fprintf(fp,";\n");
    fprintf(fp,"end if;\n");
    fprintf(fp,"\n");
}
fclose(fp);
}</pre>
```