

**Facultad de ingeniería**

**Materia:** Laboratorio de Organización y  
Arquitectura de Computadoras

**Título:** Practica 1 Introducción a las  
herramientas de desarrollo de los FPGAs

**Alumno:** Martínez Pérez Brian Erik

**Profesor:** M. C. I. Julio Cesar Cruz Estrada

**Grupo:** 7

**Semestre:** 2026-1



## Desarrollo

Creamos un nuevo proyecto en “FILE - New Project Wizard”, con la siguiente configuración:



Una vez que tenemos creado el nuevo proyecto, creamos un nuevo archivo de tipo “Block diagram / Schematic file”.



Agregamos el componente en la sección de “Symbol Tool”, ingresamos el numero “74193”, para encontrar el componente, posteriormente le damos en OK.



Agregamos las entradas y salidas del componente en la sección de “Pin Tool”, debemos de colocar 2 entradas y 4 salidas. Conectamos cada una de las entradas y de las salidas



Por último, compilamos y guardamos el programa, si tenemos errores el compilador nos lo mostrara en la sección inferior, de lo contrario la compilación llegara al 100%.



## Divisor de frecuencia.

Para poder observar el encendido y apagados de los leds debemos crear un divisor de frecuencia, ya que el ciclo de reloj del CLK es muy rápido para la percepción del ojo humano.

Para poder implementar el divisor de frecuencia debemos obtener el valor del factor n para poder conseguir un cambio entre los leds de un segundo. El valor obtenido fue  $n=2,500,000$ .

$$F = 50 \text{ MHz}$$

$$1 s = 7 * 2 * 20^{-8}$$

$$n = 1 / (2 * 10^{-8})$$

$$n = 2,500,000$$

Ahora procederemos a crear un archivo nuevo de “VHDL File”



Obtenemos este código para el divisor de frecuencia solicitado.

Después compilamos el código y si NO marca errores significa que podemos usar el código en nuestro contador.



Creamos el componente del bloque para poder usarlo en el contador



Ahora lo agregamos desde la sección de “Symbol Tool” y colocamos la entrada “CLK” a la entrada “reloj” del divisor de frecuencia y la salida “div\_clk” a la entrada del contador “UP”.



Debemos compilar para saber que conectamos correctamente los bloques.



Ahora solo quedaría asignar pines y subir el archivo a la tarjeta FPGA que utilizaremos para poder ver el contador funcionando.

## Simulaciones

### Simulación con Waveform Editor

Creamos un nuevo archivo de tipo “University Program VWF”. Le damos en Ok.



Agregamos todas nuestras variables en la barra de herramientas para que se muestren las señales de cada una de ella.



Damos una señal cuadrada al CLK y señal en “cero lógico” a RESET.



Corremos la simulación para ver como se comportan las salidas, respecto a las entradas que le dimos al contador.



Podemos observar que realmente tenemos un contador de 4 bits, por lo que se mostrara la sucesión de numero binarios del 0 al 15.



Simulación externa con ModelSim – Altera

Pasamos el diagrama de bloque al simulador modelsim, una vez que la tenemos en la sección de objetos podemos asignar valores a nuestras entradas.



El valor de RESET lo forzamos a "0", y a CLK le ponemos el valor de clock.



Una vez que asignamos valores a las entradas podemos iniciar la simulación:



Podemos observar que, en el simulador externo, obtenemos los mismos resultados que en el simulador propio de Quartus. El contador realiza la sucesión de binaria del 0 al 15.



## **Conclusión**

La práctica introdujo el uso de Quartus Prime y ModelSim-Altera para FPGAs. Se configuró el entorno y se vinculó ambas herramientas correctamente. Se implementó un contador mediante diagramas esquemáticos. Se aprendió a simular con ModelSim y el editor de waveforms de Quartus. Se comprobó el funcionamiento del contador con reset y reloj. Adquirí habilidades esenciales en compilación y detección de errores. El proyecto quedó listo para programarse en la tarjeta FPGA. Los objetivos de familiarización con las herramientas se cumplieron exitosamente.