

# EASTERN MEDITERRANEAN UNIVERSITY COMPUTER ENGINEERING DEPARTMENT

# CMPE 324 - Computer Architecture and Organization

### Lab 5: Introduction to Circuit Synthesis Using ALTERA QUARTUS

### 1. Objective:

To get familiar with the VHDL development and simulation tools by generating a full adder circuit entry using the graphical capture. Within the framework of EDA (Electronic Design Automation), in this Lab we will learn the use of "Quartus" software to design and test logic circuits. The Quartus program is very popular and it is used in the construction of many modern devices.

## **1. Introduction**

VHDL is an abbreviation for the VHSIC Hardware Description Language, where VHSIC is acronym for the Very High-Speed Integrated Circuits. It is originated from the standardization efforts of US. Department of Defence to provide a convenient and precise form of communication for the defence contracts. Today, the digital circuits are mostly implemented with digital programmable logic devices namely SPLDs CPLDs and FPGAs.

# **2. Experimental Practice**

#### Part 1: about Quartus and first simple experiment

Step 1. Create a Project: Every new design you make in the Quartus program must be under a project name. After opening the program, to create a project, click on: [File] -> [New Project Wizard]

| 🕥 Q      | uartus Prime Lite Edition |                 |                                        |
|----------|---------------------------|-----------------|----------------------------------------|
| File     | Edit View Project         | Assignments Pro | cessing Tools Window He                |
|          | New                       | Ctrl+N          | • <u>-</u>                             |
| ~        | Open                      | Ctrl+O          | `````````````````````````````````````` |
|          | Close                     | Ctrl+F4         |                                        |
| A        | New Project Wizard        |                 |                                        |
| <b>K</b> | Open Project              | Ctrl+J          |                                        |
|          | Save Project              |                 |                                        |
|          | Close Project             |                 |                                        |
| Ξ        | Save                      | Ctrl+S          |                                        |
|          | Save As                   |                 | Compare Editions                       |
| é9       | Save All                  | Ctrl+Shift+S    |                                        |
|          | File Properties           |                 | What's New                             |
|          | Consta / Undata           | •               |                                        |

After this stage you will see the following project builder screen.

| Introd          | uction                                                                                                                          |  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------|--|
| The New         | Project Wizard helps you create a new project and preliminary project settings, including the following:                        |  |
| •               | Project name and directory                                                                                                      |  |
| •               | Name of the top-level design entity                                                                                             |  |
|                 | Project files and libraries                                                                                                     |  |
| •               | Target device family and device                                                                                                 |  |
|                 | EDA tool settings                                                                                                               |  |
| ou can          | change the settings for an existing project and specify additional project-wide settings with the Settings command (Assignments |  |
| nenu). Y        | ou can use the various pages of the Settings dialog box to add functionality to the project.                                    |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
|                 |                                                                                                                                 |  |
| Don't           | show me this introduction again                                                                                                 |  |
| _ <u>D</u> on't | show me this introduction again                                                                                                 |  |
| ] <u>D</u> on't | show me this introduction again                                                                                                 |  |

This screen is the home screen of the project builder. Here you will see which stages of your project are formed and what you can organize.

Here, press [Next >] button to continue.

On the new screen, you will see the input sections that ask us to enter the directory and the name of the related project. Please fill in the appropriate information here. (Project names for the Quartus program is very important.)

| V New Project Wizard                                                                                                                                     |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Directory, Name, Top-Level Entity                                                                                                                        |  |  |  |  |  |  |  |
| What is the <u>w</u> orking directory for this project?                                                                                                  |  |  |  |  |  |  |  |
| C:/Q_Projects/Project_1                                                                                                                                  |  |  |  |  |  |  |  |
| What is the name of this project?                                                                                                                        |  |  |  |  |  |  |  |
| Project_1                                                                                                                                                |  |  |  |  |  |  |  |
| What is the name of the top-level design entity for this project? This name is case sensitive and must exactly match the entity name in the design file. |  |  |  |  |  |  |  |
| Project_1                                                                                                                                                |  |  |  |  |  |  |  |
| Use Existing Project Settings                                                                                                                            |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
|                                                                                                                                                          |  |  |  |  |  |  |  |
| < <u>B</u> ack <u>N</u> ext > <u>F</u> inish Cancel <u>H</u> elp                                                                                         |  |  |  |  |  |  |  |

The project type display gives you additional setting options for what hardware the project will be compiled and implemented. Since, we'll simulate our projects on the program and we won't run on any real hardware, we'll choose the [Empty Project] option here, and then click the [Finish] button to create our project.

| New Project Wizard                                                            |                                     |                     |                   |                    |                     |      |
|-------------------------------------------------------------------------------|-------------------------------------|---------------------|-------------------|--------------------|---------------------|------|
| Project Type                                                                  |                                     |                     |                   |                    |                     |      |
| Select the type of project to create.                                         |                                     |                     |                   |                    |                     |      |
| Empty project                                                                 |                                     |                     |                   |                    |                     |      |
| Create new project by specifying projec                                       | files and libraries, t              | arget device family | and device, and I | EDA tool settings  |                     |      |
| O Project <u>t</u> emplate                                                    |                                     |                     |                   |                    |                     |      |
| Create a project from an existing desigr download design templates from the D | template. You can o<br>esign Store. | choose from design  | templates insta   | lled with the Quar | tus Prime software, | , oi |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |
|                                                                               |                                     |                     |                   |                    |                     |      |

Once your project is created, you will see a screen like this:



Step 2. Simple schematic design:

Once you have successfully created your project, we can make a simple design and simulation process. At this stage, we will use the design below as an example.



The next step is to create an empty Block Diagram. To do so, click [File] -> [New] to select Block Diagram / Schematic File on the pop-up menu and click [OK]. At this stage, an empty design window will be opened.

When you double-click on the empty worksheet that opens, you will see a screen showing the libraries that are built in the Quartus program. On this screen you will see Logic gates libraries under the Primitives libraries. Once you have chosen this, you will come across logical gates that you can use in your designs.

Here, we will include 1 nand2, 1 nor2, 1 and2, 4 inputs and finally 1 output components as shown in our sample circuit.

Connecting the elements together:

We will place the elements added to the Quartus schematic page by dragging them with the mouse or selecting the element and moving them with the arrow keys on our keyboard. After this step, to connect the circuit elements together as required, place the mouse cursor on the input or output pins of the circuit elements so that it will inform us that it is ready to make a connection by turning into a symbol related to the connection. Press the left mouse button and pull the connecting cable / wire to the other part to be connected. To indicate that the connection to the input is made correctly, a small square between the wire and the port will appear where the mouse cursor is located. You can leave the mouse button after this square appears.

Note: If your connection is faulty, there will be a sign similar to "x" at the end of the cable that you connect. This sign shows that the connection has not been made correctly. In this case, you must right-click on the cable you connect and click "delete" to delete and reconnect the cable again.

After connecting our circuit without problems, double-click on the "PIN\_NAME" pin posts on the input and output pins to name them as in the example.

After all the steps are finished, we can save our project with the combination of [ctrl + s] keys or [File] -> [Save] option.



Step 3. Compiling the Project:

We do the compilation of the project with the [Processing -> [Start Compilation] menu.

If there are no errors in your project, a pop-up menu with "Full compilation was successful" will appear.

Close the Compiler display.

Step 4. Simulating the Project:

A circuit can be simulated in two ways. The simplest way is to assume that the logical elements and the interconnecting wires are perfect, so it does not cause delays in the propagation of the signals throughout the circulation. This is called functional simulation. A more complex alternative leads to timing simulation, taking into account all propagation delays. Typically, the functional simulation is used to confirm the functional accuracy of a circuit as designed. This takes much less time

because the simulation can be performed using logical expressions that define a simple circuit. In this course we will use only functional simulation.

Select [File] -> [New] -> [Verification / Debugging Files] -> [University Program VWF] and press the "OK" button.

Select [Edit] -> [Insert Node or Bus] from the pop-up window.

Click on the "Node Finder" button.

In the list of the pins, press the Import all button ">>" and click "Start".

You can change the order of the pins you see on your screen.

Enter [Edit] -> [End Time] menu to set "set end time" to 160 and change the time type section "ns" -> "us".

Click the "Overwrite clock" <sup>™</sup> button to set the time intervals of our pins to A: 20, B: 40, C: 80, D: 160.

| ulation Wa<br>Edit Vie | aveform Editor - C:<br>w Simulation | /Q_Projects/Proje<br>Help | ect_2/Project_2 - Project | 2 - [Waveform.vwf]* |                 |         |             |          | Search alt | era.com |
|------------------------|-------------------------------------|---------------------------|---------------------------|---------------------|-----------------|---------|-------------|----------|------------|---------|
| . 🔉 ا                  | Ů Å ≝ Xī X                          | E ₩ XC X X                | 2 )8 💐 👯 🐴 🖥              | <b>≝</b> 號          |                 |         |             |          | Julia      | cra.com |
| er Time Bar            | 0 ps                                |                           |                           | r. 426 ps           | Interval: 426 p | 5       | Start: 0 ps | E        | ind: 0 ps  |         |
| Name                   | Value at<br>0 ps                    | 0 ps<br>0 ps              | 20.0 ns                   | 40.0 ns             | 60.0 ns         | 80.0 ns | 100.0 ns    | 120,0 ns | 140.0 ns   | 160.0   |
| Α                      | BO                                  |                           |                           |                     |                 |         |             |          |            |         |
| в                      | во                                  |                           |                           |                     |                 |         |             |          |            |         |
| c                      | B 0                                 |                           |                           |                     |                 |         |             |          |            |         |
| D                      | BO                                  |                           |                           |                     |                 |         |             |          |            |         |
|                        |                                     |                           |                           |                     |                 |         |             |          |            |         |
|                        |                                     |                           |                           |                     |                 |         |             |          |            |         |
|                        | 2                                   | <                         |                           |                     |                 |         |             |          |            |         |

Under [Simulation] -> "Run Simulation Functional Settings"

Save your simulation model by pressing [File] -> [Save]. Simulate your project by pressing [Processing] -> [Start Simulation].

#### Part 2: single-bit full adder

In this section, we will implement a full adder, an 8-bit adder, and compare the multiplication algorithms by simulation. First of all, build a single-bit full adder circuit entry Building a single-bit full adder circuit entry.

he full-adder extends the concept of the half-adder by providing an additional carryin (Cin) input, as shown in Figure 5.21. This is a design with three inputs (A, B, and Cin) and two outputs (Sum and Cout). This cell adds the three binary input numbers to produce sum and carry-out terms



| Α | В | Cin | Sum | Cout |
|---|---|-----|-----|------|
| 0 | 0 | 0   | 0   | 0    |
| 0 | 0 | 1   | 1   | 0    |
| 0 | 1 | 0   | 1   | 0    |
| 0 | 1 | 1   | 0   | 1    |
| 1 | 0 | 0   | 1   | 0    |
| 1 | 0 | 1   | 0   | 1    |
| 1 | 1 | 0   | 0   | 1    |
| 1 | 1 | 1   | 1   | 1    |

From viewing the truth table, the Sum output is only a logic 1 when *one or three* (but not two) of the inputs is logic 1. The Boolean expression for this is (in reduced form):

 $Sum=Cin \oplus (A \oplus B)$ 

From viewing the truth table, the Cout output is only a logic 1 when *two or three* of the inputs is logic 1. The Boolean expression for this is (in reduced form):

 $Cout=(A.B)+(Cin.(A \oplus B))$ 

This can be drawn as a circuit schematic as shown in Figure bellow:



Follow the on steps part 1 in order to design this circuit:



- Draw the "Schematic / Block Diagram" of the above functions using the Quartus software program.
- Simulate the project showing the WaveForm in the Quartus program "University program VWF" and show it to the lab assistant.
- Compare the truth table that you wrote in your notebook with the result of the simulation that Quartus gives you.

Note: be careful about connections.

#### Part 3: 8-Bit Adder

Binary adders are digital circuits often used in computers for basic arithmetic operations. Using the digital library in the standard Modelica library, we have constructed an 8-bit adder that takes two 8-bit integers and calculates their sum.



The circuit created is an 8-bit adder. The 8-bit adder adds two 8-bit binary inputs and the result is produced in the output. In order to create a Full 8-bit adder, I could use eight Full 1-bit adders and connect them. This way, the least significant bit on the far right will be produced by adding the first two bits, then it will carry out (if any) a bit to the next two bits to add. This will continue seven more times until it is done. In the end, the last carry out will be output.

To create this adder, I implemented eight full adders and connected them together to create an 8- bit adder. I created a symbol and sub-Design for the full adder I created for the mini-project we did earlier in the semester:



Note: There is no exp53 (1-bit full adder) in list of objects, we must create it from our last section. in order to create exp53 follow these steps:

- 1. Select BDF file
- 2. File $\rightarrow$ Create/Update $\rightarrow$ create symbol file for current files
- 3. Then you can search it in list like other gate or inputs

Note: be careful about the connections.

- Draw the "Schematic / Block Diagram" of the above functions using the Quartus software program.
- Simulate the project showing the WaveForm in the Quartus program "University program VWF" and show it to the lab assistant.
- Compare the truth table that you wrote in your notebook with the result of the simulation that Quartus gives you.

0 ps 40.0 ns 80.0 ns 120.0 ns 160.0 ns Value at Name 0 ps 0 ps in\_ A0 В 0 A1 B 0 in\_ A2 В 0 in\_ A3 B 0 B0 в 0 in B1 В 0 in\_ B2 B 0 in B3 В 0 in\_ Cin B 0 out во Cout out Sum0 B 0 out Sum1 В 0 out Sum2 B 0 Sum3 В 0

Note: The waveform will be like this after simulation (set inputs 10,20,30, ....90):

# **3. Reporting**

Before the Lab-time is over, show the simulation result to your lab assistant, in order to grading.

### 4. Homework: build a 4-bit full adder

Any number of half- and full-adder cells can be connected together to form an n-bit addition. The Figure shows the connections for a four-bit binary adder. In this design, there is no Cin input. Inputs A and B are four bits wide, and bit 0 (A(0) and B(0)) are the LSBs.

- Draw the "Schematic / Block Diagram" of the above functions using the Quartus software program.
- Simulate the project showing the WaveForm in the Quartus program "University program VWF" and show it to the lab assistant.
- Compare the truth table that you wrote in your notebook with the result of the simulation that Quartus gives you.

Grading: Lab Performance: Asst. Observations: