

Group #:

**G 12**

## Design Project 2

ENSC 350 1257

Project Submitted in Partial Fulfillment of the  
Requirements for Ensc 350  
Towards a Bachelor Degree in Engineering Science.

Last Name:

Saghafi

SID:

3 0 1 4 5

5 8 1 4

Last Name:

Schaufele

SID:

3 0 1 4 5

4 2 5 5

Last Name:

Singh

SID:

3 0 1 3 9

4 6 7 1

# ***Table of Contents***

|                                         |           |
|-----------------------------------------|-----------|
| <b>Table of Contents.....</b>           | <b>0</b>  |
| <b>1 - Introduction.....</b>            | <b>1</b>  |
| <b>2 - Experimental Procedures.....</b> | <b>1</b>  |
| <b>3 - Design Candidates.....</b>       | <b>2</b>  |
| Design Topologies.....                  | 2         |
| Ripple-Carry Adder.....                 | 2         |
| Conditional-Sum Adder.....              | 2         |
| Look Ahead Tree Adder.....              | 2         |
| Brent-Kung Adder.....                   | 3         |
| Ladner-Fischer Adder.....               | 3         |
| Design Implementations.....             | 3         |
| Candidate Estimations.....              | 4         |
| Cost.....                               | 4         |
| Timing.....                             | 4         |
| Post-Fitting Analysis.....              | 5         |
| <b>4 - Testbenches.....</b>             | <b>6</b>  |
| <b>5 - Cost Analysis.....</b>           | <b>7</b>  |
| <b>6 - Timing Analysis.....</b>         | <b>9</b>  |
| <b>7 - Results Analysis.....</b>        | <b>10</b> |
| <b>8 - Appendix.....</b>                | <b>11</b> |
| A.1 Directory Structure.....            | 11        |
| A.2 References.....                     | 13        |

# ***1 - Introduction***

Outline the purpose of the project and introduce topics used

```
entity EN_Adder is
  generic (N: natural := 64);
  port (
    A, B : in std_logic_vector (N-1 downto 0);
    S : out std_logic_vector (N-1 downto 0);
    Cin : in std_logic;
    Cout, Ovfl : out std_logic
  );
end EN_Adder;
```

*Figure 1:* Adder Entity Definition within EN\_Adder.vhd

# ***2 - Experimental Procedures***

Flowchart for the flow of the procedure

## ***3 - Design Candidates***

### **Design Topologies**

#### ***Ripple-Carry Adder***

Brief description of topology purpose and implementation

Image of the topology for a smaller case  
(Ripple-carry Adder)

#### ***Conditional-Sum Adder***

Brief description of topology purpose and implementation

Image of the topology for a smaller case  
(Conditional-Sum Adder)

#### ***Look Ahead Tree Adder***

Brief description of topology purpose and implementation

Image of the topology for a smaller case  
(Look Ahead Tree Adder)

## ***Brent-Kung Adder***

Brief description of topology purpose and implementation

Image of the topology for a smaller case  
(Brent-Kung Adder)

## ***Ladner-Fischer Adder***

Brief description of topology purpose and implementation

Image of the topology for a smaller case  
(Ladner-Fischer Adder)

## **Design Implementations**

Brief discussion of the devices used and their primitive elements

## Candidate Estimations

### *Cost*

State assumptions, formulas, and method for each topology

### *Timing*

State assumptions, formulas, and method for each topology

Estimation Calculations examples for each topology

Estimation Calculations examples for each topology

## Post-Fitting Analysis

Annotated Post fitting images

Brief discussion of what's interesting about these post fittings

## *4 - Testbenches*

Brief description of test vectors and tvs file format

Flowchart for the flow of the testing

Sample Annotated Wave Output

## 5 - Cost Analysis

The costs for the design candidates were calculated using this formula:

$$\text{Cost per LE/ALM} = \text{Device price} \div \text{Total Device LEs/ALMs}$$

This method of calculating the cost factors accounts for the total resources available to the board and the fraction of those resources used by the circuit. Resource data was obtained from the Quartus synthesis reports. LEs were selected as the unit of cost, and all ALMs were converted to LEs using a conversion factor. The normalized cost is obtained by dividing each candidate cost by the baseline cost. The boards used to synthesize the architectures are currently obsolete. This inflates the price and makes cost calculations inaccurate. To account for these inaccuracies, the Cyclone IV Nano and the ARRIA 10 GX 480 were considered. These are comparable to the devices used in synthesis, but they have more accurate pricing because they are currently active on DigiKey, indicating they are still widely used and in production. The following calculations assume that the LEs and ALMs on the available devices cost the same as the original board's elements.

| Device          | Total Device LEs/ALMs | Device Price (CAD) | Cost per LE/ALM (CAD) | Normalized Cost in terms of LEs |
|-----------------|-----------------------|--------------------|-----------------------|---------------------------------|
| Cyclone IV Nano | 22320                 | 169.49[3]          | \$0.00759184          | 1                               |
| Arria 10 GX 480 | 181790                | 3937.25[4]         | \$0.02165823          | 2.85                            |

Discussion of the effect of topology

Discussion of the effect of implementation

Comparison of Cost between all candidates

| <b>Design Candidate</b> | <b>Target Device</b> | <b>Resource Usage Predictions (LEs/ALMs)</b> | <b>Resources Used (LEs/ALMs)</b> | <b>Predicted Cost (CAD)</b> | <b>Candidate Cost (CAD)</b> | <b>Cost (LEs)</b> | <b>Normalized Cost (W.R.T. Baseline LEs)</b> |
|-------------------------|----------------------|----------------------------------------------|----------------------------------|-----------------------------|-----------------------------|-------------------|----------------------------------------------|
| 1<br>(Baseline)         | Cyclone IV           | 130                                          | 161                              | \$0.99                      | \$1.22                      | 161               | 1                                            |
| 2<br>(RCA)              | ARRIA II             | 66                                           | 147                              | \$1.43                      | \$3.18                      | 418.95            | 2.60                                         |
| 3<br>(CSA)              | Cyclone IV           | 960                                          | 271                              | \$7.29                      | \$2.06                      | 271               | 1.68                                         |
| 4<br>(CSA)              | ARRIA II             | 667                                          | 188                              | \$14.45                     | \$4.07                      | 535.8             | 3.33                                         |
| 5<br>(LATA)             | Cyclone IV           |                                              |                                  |                             |                             |                   |                                              |
| 6<br>(LATA)             | ARRIA II             |                                              |                                  |                             |                             |                   |                                              |
| 7<br>(BKA)              | Cyclone IV           |                                              |                                  |                             |                             |                   |                                              |
| 8<br>(BKA)              | ARRIA II             |                                              |                                  |                             |                             |                   |                                              |
| 9<br>(LDA)              | Cyclone IV           |                                              |                                  |                             |                             |                   |                                              |
| 10<br>(LDA)             | ARRIA II             |                                              |                                  |                             |                             |                   |                                              |

*Figure 9:* Cost Calculations of Design Candidates

The conversion factor from LEs to ALMs was 2.85, slightly more than double.

Comparison of Cost estimation and analysis

## **6 - Timing Analysis**

Brief description of tools used for timing analysis

| <b>Design Candidate</b> | <b>Target Device</b> | <b>Estimation</b> | <b>Simulation Results</b> | <b>Normalized Time (W.R.T. Baseline Simulation)</b> |
|-------------------------|----------------------|-------------------|---------------------------|-----------------------------------------------------|
| 1<br>(Baseline)         | Cyclone IV           | 130               | 161                       | 1                                                   |
| 2<br>(RCA)              | ARRIA II             | 66                | 147                       | 2.60                                                |
| 3<br>(CSA)              | Cyclone IV           | 960               | 271                       | 1.68                                                |
| 4<br>(CSA)              | ARRIA II             | 667               | 188                       | 3.33                                                |
| 5<br>(LATA)             | Cyclone IV           |                   |                           |                                                     |
| 6<br>(LATA)             | ARRIA II             |                   |                           |                                                     |
| 7<br>(BKA)              | Cyclone IV           |                   |                           |                                                     |
| 8<br>(BKA)              | ARRIA II             |                   |                           |                                                     |
| 9<br>(LDA)              | Cyclone IV           |                   |                           |                                                     |
| 10<br>(LDA)             | ARRIA II             |                   |                           |                                                     |

Comparison of time estimation and analysis

## *7 - Results Analysis*

Conclusion from time and cost analysis

# **8 - Appendix**

## A.1 Directory Structure

### **(folder) Documentation**

- (folder) ActivityLogs
  - a folder including each group member's activity log worksheets
- (folder) Images
  - a folder containing all the images used in the report
- (folder) OutputFiles
  - (file) Quartus-Summaries.text
    - Includes summary reports from the synthesis of each design candidate
  - (file) Sim-Transcript-CSA.text
    - Includes the transcript from the conditional sum adder testbench, displays the test vector index, as well as the test vectors, and the status of each tested test vector
  - (file) Sim-Transcript-Ripple.text
    - Includes the transcript from the ripple-carry adder testbench, displays the test vector index, as well as the test vectors, and the status of each tested test vector
- (file) VHDLsrc\_EN\_Adder.pdf
  - A PDF listing of the VHDL code for the Adder Entity and Architectures
- (file) VHDLsrc\_TB\_Adder\_CSA.pdf
  - A PDF listing of the VHDL code for the testbench written for the conditional sum adder topology
- (file) VHDLsrc\_TB\_Adder\_RIP.pdf
  - A PDF listing of the VHDL code for the testbench written for the ripple adder topology
- (file) DP2-Report-G12-350-1257.pdf
  - Project Report, including cost and efficiency analysis (this document)
- (file) DP2-Summary-G12-350-1257.pdf
  - A summary of tasks completed in this project, as well as a brief overview of the cost and efficiency analysis

## (folder) Simulation

- (folder) questa
  - folder created by modelsim, includes pre-compiled netlists
- (folder) TestVectors
  - Adder00.tvs
    - File including all the test vectors used by the testbenches
  - gen\_testVec.py
    - a python script to append randomly generated test vectors to the Adder00.tvs file
- (files) DP1.cr.mti / DP1.mpf
  - Modelsim project files for simulation and testing
- (file) run\_CSA.do
  - Script to compile, add waves, run simulation and create a simulation transcript for the conditional-sum adder topology testbench
- (file) run\_ripple.do
  - Script to compile, add waves, run simulation and create a simulation transcript for the ripple-carry adder topology testbench
- (file) TB\_Adder\_CSA.vhd
  - Conditional-sum adder testbench written in VHDL
- (file) TB\_Adder\_RIP.vhd
  - Ripple-Carry adder testbench written in VHDL

## (folder) SourceCode

- (file) EN\_Adder.vhd
  - Defines the adder entity as well as a ripple adder, fast ripple adder, and conditional sum adder architectures in VHDL

## (file) DP2.qpf / DP2.qsf

- Quartus project files for synthesis and analysis of the digital circuits

## A.2 References

- [1] "DigiKey," 2 November 2009. [Online]. Available:  
<https://www.digikey.ca/en/products/detail/altera/EP4CE115F29C7/2260452>. [Accessed 12 October 2025].
- [2] "DigiKey," 2 February 2009. [Online]. Available:  
<https://www.digikey.ca/en/products/detail/altera/EP2AGX45DF29C6/2349475>. [Accessed 12 October 2025].
- [3] "DigiKey," 28 October 2014. [Online]. Available:  
<https://www.digikey.ca/en/products/detail/terasic-inc/P0082/2625112>. [Accessed 25 October 2025].
- [4] "DigiKey," 29 September 2023. [Online]. Available:  
<https://www.digikey.ca/en/products/detail/iwave-global/IW-G24D-CU0F-4D004G-S008G-NCI/15780313>.  
[Accessed 25 October 2025].