

UNIVERSIDAD DE LAS AMÉRICAS PUEBLA

ESCUELA DE CIENCIAS

DEPARTAMENTO DE ACTUARÍA, FÍSICA Y  
MATEMÁTICAS



## Documento Evaluación Final

**Cálculo II MAT2012-13**

Anabel Hernandez Ramirez

**Equipo: Malcolm in The Middle**

183339 Juan Pablo Lopez Moreno LMT

185406 Amy Marianee Ramírez Sánchez LMT

183887 Malcolm Arriaga Galván LBM

182733 Fátima Lucía Carmona Lagarda LQI

186295 Mayela Martin Meneses LQI

182884 Yahel Reyes Noguez LBM

27 de Noviembre de 2025, San Andrés Cholula, Puebla

## 1. Abstract

This report will present the results obtained from the forth laboratory practice of the Digital Design course. The main objective of this practice was to begin the development of FPGAs, continuing the use of VHDL as a programming language. The practice focused on the implementation and simulation of combinational logic circuits using both schematic diagrams and Boolean functions.

## 2. Introduction

With the evolution of technologies, digital systems have increasingly incorporated more complex logic behind their functionality, for these reasons, technologies have to evolve and improve to suit these needs. For this reason, FPGAs (Field Programmable Gate Arrays) have become a popular choice for implementing digital logic circuits due to their flexibility and reconfigurability. FPGAs allow designers to program custom logic functions directly onto the hardware, enabling rapid prototyping and development of complex digital systems. In order to understand the functioning of the Gate Arrays used, a couple of combinational logic gates will be explored in the lab practice, these gates are as follows:

- Half-subtractor, performs the binary subtraction of two single-bit binary numbers. It has two inputs, A and B, and two outputs, Difference and Borrow.
- Multiplexer, combinational circuit that has many data inputs and a single output, depending on control or select inputs.
- Demultiplexer, data distributor combinational circuit. It works in a reverse way of the Multiplexer.
- Magnitud Comparator, combinational circuit that compares two digital or binary numbers in order to find out whether one binary number is equal, less than, or greater than the other binary number.

[?] It's critical to comprehend not only how these combinational circuits operate but also the various ways in which they can be connected within a program or FPGA. Additionally, we can investigate the plethora of possibilities in the field of digital logic by experimenting with various configurations.

## 3. Objectives

The objectives of this lab are:

- Program and simulate basic combinational logic circuits VHDL.
- Implement basic combination circuits on the Basys 3 board.

For the purpose of this lab, we must understand the following concepts:

- Combinational Logic Circuits

- VHDL Programming
- FPGA Implementation

Of which, we must begin explaining combinational logic circuits, which are very well-known components in digital electronics, which can provide an output instantly based on the current input. Unlike sequential circuits, a combinational circuit listens for input signals and generates output regardless of the past input or state, as it has no feedback or memory component.<sup>[?]</sup> VHDL, which has been used in previous labs, is a hardware description language that allows designers to describe the behavior and structure of digital systems. VHDL is widely used for designing FPGAs and ASICs (Application-Specific Integrated Circuits) due to its ability to model complex digital systems at various levels of abstraction.<sup>[1]</sup> Finally, field programmable gate array (FPGA) is a versatile type of integrated circuit, which, unlike traditional logic devices such as application-specific integrated circuits (ASICs), is designed to be programmable (and often reprogrammable) to suit different purposes, notably high-performance computing (HPC) and prototyping.<sup>[?]</sup> FPGA implementation involves programming the FPGA device with the designed VHDL code to realize the desired combinational logic circuit. This process includes synthesis, mapping, placement, and routing of the design onto the FPGA fabric.

## 4. Methodology

The methodology applied in this laboratory practice was structured into three main phases: physical implementation in the laboratory, simulation in Multisim, and programming in EDA Playground.

### 4.1. Physical Laboratory Phase

During the laboratory work, the following activities were carried out:

- The Boolean function and the truth table corresponding to the schematic shown in Figure 1 were obtained through logical analysis of its structure.
- The schematic and truth table of the Boolean function provided in the practice were determined:

$$F(A, B, C, D) = (B' \cdot D) \cdot (A \oplus B) + (C \cdot A)$$

- The consistency between the derived truth tables and the constructed schematics was verified, ensuring the correct representation of the logical expressions.

### 4.2. Multisim Simulation Phase

In the Multisim simulation environment, the following procedures were performed:

- Both circuits were virtually constructed using the logic components available in the software.
- Simulations were executed to validate the expected behavior of each circuit.
- The obtained results were compared with the analytically derived truth tables to confirm the correctness of the designs.

### 4.3. EDA Playground Programming Phase

Finally, in the EDA Playground platform, the following actions were conducted:

- Both Boolean functions were programmed using the VHDL language, following proper coding conventions.
- Testbenches were created and applied to verify the correct functionality of the circuits under all possible input combinations.
- The simulation results were validated against those obtained in the previous phases.

## 5. Results

## 6. Conclusions

The development of this practice allowed the fulfillment of the laboratory objectives, as Boolean functions were obtained from schematics, and schematics were interpreted from Boolean functions. Additionally, the Boolean functions were programmed and simulated using VHDL, confirming their correct logical behavior. The detailed identification of gates, analysis of partial outputs, and the creation of truth tables and canonical forms allowed algebraic validation of the results. Simulations performed in Multisim and EDA Playground corroborated the consistency between theory and practice, demonstrating the usefulness of digital simulation tools for predicting and verifying circuit operation. In this way, the practice not only enabled experimental validation of theoretical principles but also reinforced the understanding of programming and simulation of Boolean functions in digital environments.

## Referencias

- [1] Intel Corporation, “Vhdl definition,” [https://www.intel.com/content/www/us/en/programmable/quartushelp/17.0/reference/glossary/def\\_vhdl.htm](https://www.intel.com/content/www/us/en/programmable/quartushelp/17.0/reference/glossary/def_vhdl.htm), 2017, accessed: 2024-10-27.