



## Carátula para entrega de prácticas

Facultad de Ingeniería

Laboratorios de docencia

# Laboratorio

*Profesor:* ING. JULIO CESAR CRUZ ESTRADA

*Asignatura:* LABORATORIO DE ORGANIZACIÓN Y ARQUITECTURA DE COMPUTADORAS

*Grupo:* 07

*No de Práctica:* 3

*Integrante(s):* Jiménez Treviño Emilio Cristóbal  
Martínez Pérez Brian Erik

*No. de Equipo de cómputo empleado:* s/n

*Semestre:* 2026-1

*Fecha de entrega:* 19/09/2025

*Observaciones:* \_\_\_\_\_  
\_\_\_\_\_

**CALIFICACIÓN:** \_\_\_\_\_

## **Práctica 3. Construcción de Máquinas de estados Usando Memorias Direccionamiento por Trayectoria**

### **Objetivo**

Familiarizar al alumno en el conocimiento de construcción de máquinas de estados usando direccionamiento de memorias con el método de direccionamiento por trayectoria.

### **Introducción**

En esta práctica se abordará la construcción de máquinas de estados usando memorias direccionamiento por trayectoria. Este enfoque permite organizar el diseño en etapas bien definidas: la elaboración de la carta ASM, la obtención de la tabla de verdad y la codificación de los distintos bloques en VHDL, como el registro, concatenador, memoria ROM, divisor de datos y divisor de frecuencia. Se detallarán los pasos para la creación de un proyecto en Quartus y la asignación de pines para su posterior simulación y carga en un dispositivo FPGA que en nuestro caso fue la DE10-LITE debido a su capacidad y accesibilidad

## Desarrollo

Para comenzar primero se propuso una carta ASM con 5 estados, 3 entradas y 4 salidas. las restricciones eran, tener al menos un estado con más de una condición, al menos dos salidas en lógica negada, al menos un estado con salidas condicionales.



**Figura 1.** Carta ASM propuesta.

Después de obtener la carta ASM, obtenemos la tabla de verdad, donde debemos de tomar en cuenta que utilizamos el método de direccionamiento por trayectoria. debemos tener en la cabecera el estado presente, las entradas, estado siguiente y las salidas.

|      | edop | x | y | z | edos | s1 | s0 | ~u1 | ~u0 |
|------|------|---|---|---|------|----|----|-----|-----|
| EST0 | 000  | 0 | * | * | 001  | 1  | 1  | 1   | 1   |
|      | 000  | 1 | 0 | * | 010  | 0  | 1  | 1   | 1   |
|      | 000  | 1 | 1 | * | 011  | 0  | 1  | 1   | 1   |
| EST1 | 001  | * | * | 0 | 000  | 0  | 0  | 1   | 0   |
|      | 001  | * | * | 1 | 100  | 0  | 0  | 1   | 0   |
| EST2 | 010  | * | * | * | 100  | 1  | 0  | 1   | 1   |
| EST3 | 011  | * | * | * | 000  | 0  | 0  | 1   | 0   |
| EST4 | 100  | * | * | * | 000  | 1  | 0  | 1   | 1   |

**Figura 2.** Tabla de verdad, obtenida por el método de direccionamiento por trayectoria.

Cuando ya tenemos la tabla de verdad, podemos implementar el direccionamiento por trayectoria utilizando el software de desarrollo Quartus y escribir el contenido de memoria obtenido.

Lo primero que debemos hacer es crear un proyecto en Quartus, seleccionamos la pestaña FILE -> New Project Wizard. En el asistente de creación de nuevos proyectos, en la Fig. 3 podemos observar seleccionado la familia del dispositivo en nuestro caso la MAX 10 y dentro de esta vendría a hacer la 10M50DAF484C7G dentro de esta familia.



**Figura 3.** Device

Una vez creado nuestro proyecto, creamos un archivo de tipo .bdf dando click en la opción de Block Diagram/Schematic File como se muestra en la Fig. 4.



**Figura 4.** New File

Para implementar el circuito de direccionamiento por trayectoria, debemos tener en cuenta que tenemos un bloque llamado “registro”, el cual tiene como entradas la liga “estado siguiente”, el reloj, y las entradas de nuestra carta ASM. y otro bloque donde contenemos la memoria con las combinaciones de la tabla de verdad, la liga y las salidas de cada estado.



**Figura 5.** Diagrama circuito direccionamiento por trayectoria.

El primer código generado fue “registró”, Su función es almacenar el valor de una señal de entrada (edos) y mantenerlo en una señal de salida (edop). El registro se actualiza en cada flanco de subida de la señal de reloj (reloj), a menos que la señal de reinicio (reset) esté activa, en cuyo caso se inicializa a "000".

```

1  library IEEE;
2  use IEEE.STD_LOGIC_1164.ALL;
3  use IEEE.STD_LOGIC_UNSIGNED.ALL;
4  use IEEE.STD_LOGIC_ARITH.ALL;
5
6  entity registro is
7      Port (
8          reloj : in std_logic;
9          reset : in std_logic;
10         edos : in std_logic_vector (2 downto 0);
11         edop : out std_logic_vector (2 downto 0)
12     );
13 end registro;
14
15 architecture Behavioral of registro is
16
17     signal internal_value: std_logic_vector (2 downto 0) := B"000";
18 begin
19     process(reloj, reset, edos)
20     begin
21
22         if reset = '0' then
23             internal_value <= B"000";
24         elsif rising_edge(reloj) then
25             internal_value <= edos;
26         end if;
27     end process;
28
29     process(internal_value)
30     begin
31         edop <= internal_value;
32     end process;
33
34 end Behavioral;
35

```

**Figura 6.** Código VHDL, para generar el bloque “registro”.



**Figura 7.** Bloque “registro”.

El segundo código fue “concatenador”, Su única función es unir dos vectores de bits de entrada (edop y entradas) para formar un único vector de salida (salida). En este caso, une dos vectores de 3 bits cada uno para crear una salida de 6 bits.

```

1  library IEEE;
2  use IEEE.STD_LOGIC_1164.ALL;
3  use IEEE.STD_LOGIC_ARITH.ALL;
4  use IEEE.STD_LOGIC_UNSIGNED.ALL;
5
6  entity concatenador is
7    Port ( entradas : in std_logic_vector (2 downto 0);
8           edop : in std_logic_vector (2 downto 0);
9           salida : out std_logic_vector (5 downto 0)
10      );
11 end concatenador;
12
13 architecture Behavioral of concatenador is
14 begin
15
16   process(edop, entradas)
17   begin
18     salida <= edop & entradas;
19
20   end process;
21
22 end Behavioral;
23
24

```

**Figura 8.** Código VHDL, para generar el bloque “concatenador”.



**Figura 9.** Bloque “concatenador”.

El tercer código fue “rom”, Almacena una serie de valores predefinidos en un arreglo interno (internal\_mem). Cuando se le proporciona una dirección de 6 bits (direccion), el circuito devuelve el valor de 7 bits almacenado en esa posición de la memoria, actuando como una tabla de consulta.

```

1  Library IEEE;
2  use IEEE.STD_LOGIC_1164.ALL;
3  use IEEE.STD_LOGIC_ARITH.ALL;
4  use IEEE.STD_LOGIC_UNSIGNED.ALL;
5
6  entity rom is
7      Port ( direccion : in std_logic_vector (5 downto 0);
8             data : out std_logic_vector (6 downto 0)
9         );
10 end rom;
11
12 architecture Behavioral of rom is
13
14     type mem is array (0 to 63) of std_logic_vector (6 downto 0);
15     signal internal_mem: mem;
16
17     --estado 6
18     internal_mem(48) <= "000" & "0011";
19     internal_mem(49) <= "000" & "0011";
20     internal_mem(50) <= "000" & "0011";
21     internal_mem(51) <= "000" & "0011";
22     internal_mem(52) <= "000" & "0011";
23     internal_mem(53) <= "000" & "0011";
24     internal_mem(54) <= "000" & "0011";
25     internal_mem(55) <= "000" & "0011";
26
27     --estado 7
28     internal_mem(56) <= "000" & "0011";
29     internal_mem(57) <= "000" & "0011";
30     internal_mem(58) <= "000" & "0011";
31     internal_mem(59) <= "000" & "0011";
32     internal_mem(60) <= "000" & "0011";
33     internal_mem(61) <= "000" & "0011";
34     internal_mem(62) <= "000" & "0011";
35     internal_mem(63) <= "000" & "0011";
36
37     begin
38         internal_mem(8) <= "0000010"; --
39         internal_mem(9) <= "0000010"; --
40         internal_mem(10) <= "0000010"; --
41         internal_mem(11) <= "0000010"; --
42         internal_mem(12) <= "0000010"; --
43         internal_mem(13) <= "0000010"; --
44         internal_mem(14) <= "0000010"; --
45         internal_mem(15) <= "0000010"; --
46         internal_mem(16) <= "1001011"; --
47         internal_mem(17) <= "1001011"; --
48         internal_mem(18) <= "1001011"; --
49         internal_mem(19) <= "1001011"; --
50         internal_mem(20) <= "1001011"; --
51         internal_mem(21) <= "1001011"; --
52         internal_mem(22) <= "1001011"; --
53         internal_mem(23) <= "1001011"; --
54         internal_mem(24) <= "0000010"; --
55         internal_mem(25) <= "0000010"; --
56         internal_mem(26) <= "0000010"; --
57         internal_mem(27) <= "0000010"; --
58         internal_mem(28) <= "0000010"; --
59         internal_mem(29) <= "0000010"; --
60         internal_mem(30) <= "0000010"; --
61         internal_mem(31) <= "0000010"; --
62
63     end begin
64
65     --estado 4
66     internal_mem(32) <= "0001011";
67     internal_mem(33) <= "0001011";
68     internal_mem(34) <= "0001011";
69     internal_mem(35) <= "0001011";
70     internal_mem(36) <= "0001011";
71     internal_mem(37) <= "0001011";
72     internal_mem(38) <= "0001011";
73     internal_mem(39) <= "0001011";
74
75     --estado 5
76     internal_mem(40) <= "000" & "0011";
77     internal_mem(41) <= "000" & "0011";
78     internal_mem(42) <= "000" & "0011";
79     internal_mem(43) <= "000" & "0011";
80     internal_mem(44) <= "000" & "0011";
81     internal_mem(45) <= "000" & "0011";
82     internal_mem(46) <= "000" & "0011";
83     internal_mem(47) <= "000" & "0011";

```

Figura 10. Código VHDL, para generar el bloque “rom”.



Figura 11. Bloque “rom”.

El cuarto código fue “div\_datos”, Toma un vector de bits de entrada (data) de 7 bits y lo divide en dos vectores de salida más pequeños. El primer vector de salida (liga) toma los 3 bits más significativos (del 6 al 4) y el segundo vector (salidas) toma los 4 bits menos significativos (del 3 al 0).

```

1  library IEEE;
2  use IEEE.STD_LOGIC_1164.ALL;
3  use IEEE.STD_LOGIC_UNSIGNED.ALL;
4
5
6  entity div_datos is
7    Port ( data : in std_logic_vector (6 downto 0);
8           liga : out std_logic_vector (2 downto 0);
9           salidas : out std_logic_vector (3 downto 0)
10      );
11 end div_datos;
12
13 architecture Behavioral of div_datos is
14 begin
15
16   process(data)
17   begin
18     liga <= data(6 downto 4);
19     salidas <= data (3 downto 0);
20
21   end process;
22
23 end Behavioral;

```

**Figura 12.** Código VHDL, para generar el bloque “div\_datos”.



**Figura 13.** Bloque “div\_datos”.

Por último creamos el código de “div\_frec”, toma una señal de reloj de entrada (reloj) y genera una señal de salida (div\_clk) con una frecuencia mucho menor. Esto nos ayuda a observar ,los efectos de los leds en la salida.

```

1  library IEEE;
2  use IEEE.STD_LOGIC_1164.ALL;
3  use IEEE.STD_LOGIC_ARITH.ALL;
4  use IEEE.STD_LOGIC_UNSIGNED.ALL;
5
6  entity div_frec is
7    Port (reloj : in std_logic;
8          div_clk : out std_logic);
9  end div_frec;
10
11 architecture Behavioral of div_frec is
12 begin
13   process (reloj)
14     variable cuenta: std_logic_vector (27 downto 0):=x"0000000";
15   begin
16     if rising_edge (reloj) then
17       if cuenta = x"17D7840" then --25M pulsos
18         cuenta:= x"0000000";
19       else
20         cuenta:= cuenta+1;
21       end if;
22     end if;
23     div_clk <= cuenta(24);
24   end process;
25 end Behavioral;
26

```

**Figura 14.** Código VHDL, para generar el bloque “div\_frec”.



**Figura 15.** Bloque “div\_frec”.

En el archivo esquemático, tenemos todos los bloques generados a partir del código vhdl, en este tenemos 5 entradas, “Reset”, “entrada[0]”, “entrada[1]”, “entrada[2]” y “CLK”. Además tenemos 5 salidas que serán asignadas a los leds de la tarjeta. “salida[0]”, “salida[1]”, “salida[2]”, “salida[3]”, “edop[0]”, “edop[1]”, “edop[2]”.



**Figura 16.** Diagrama de conexiones

Procedemos con nuestro asignación de pines, para esto ocuparemos nuestro data sheet de nuestra FPGA DE-10 Lite, para hacer esto daremos click al icono que dice pin planner o presionando "ctrl+shift+n" los pines se colocan en el apartado de Location en la Fig. 17 podremos ver cuales se asignaron para este caso, recordemos que deben asignarse desde el más significativo al menos, para una correcta secuencia.

| Node Name      | Direction | Location |
|----------------|-----------|----------|
| in CLK         | Input     | PIN_P11  |
| out edop[2]    | Output    | PIN_E14  |
| out edop[1]    | Output    | PIN_C13  |
| out edop[0]    | Output    | PIN_D13  |
| in entradas[2] | Input     | PIN_C12  |
| in entradas[1] | Input     | PIN_D12  |
| in entradas[0] | Input     | PIN_C11  |
| in Reset       | Input     | PIN_C10  |
| out salidas[3] | Output    | PIN_B10  |
| out salidas[2] | Output    | PIN_A10  |
| out salidas[1] | Output    | PIN_A9   |
| out salidas[0] | Output    | PIN_A8   |

**Figura 17.** Asignación de pines

## Resultados

|      | edop | x | y | z | edos | s1 | s0 | $\neg u_1$ | $\neg u_0$ |
|------|------|---|---|---|------|----|----|------------|------------|
| EST0 | 000  | 0 | * | * | 001  | 1  | 1  | 1          | 1          |
|      | 000  | 1 | 0 | * | 010  | 0  | 1  | 1          | 1          |
|      | 000  | 1 | 1 | * | 011  | 0  | 1  | 1          | 1          |
| EST1 | 001  | * | * | 0 | 000  | 0  | 0  | 1          | 0          |
|      | 001  | * | * | 1 | 100  | 0  | 0  | 1          | 0          |
| EST2 | 010  | * | * | * | 100  | 1  | 0  | 1          | 1          |
| EST3 | 011  | * | * | * | 000  | 0  | 0  | 1          | 0          |
| EST4 | 100  | * | * | * | 000  | 1  | 0  | 1          | 1          |

|                                                                                           |                                                                                      |
|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| <p>Estado 0 con X=0, y salidas S1, S0, <math>\neg U_1</math> y <math>\neg U_2</math>.</p> |    |
| <p>Estado 0 con X=1 Y=0, y salidas S0, <math>\neg U_1</math> y <math>\neg U_2</math>.</p> |   |
| <p>Estado 0 con X=1 Y=1, y salidas S0, <math>\neg U_1</math> y <math>\neg U_2</math>.</p> |  |
| <p>Estado 1 Z=0, y salidas <math>\neg U_1</math></p>                                      |  |

Estado 1 Z=1, y salidas  $\neg U_1$



Estado 2, salidas S0,  $\neg U_1$  y  $\neg U_2$ .



Estado 3, salidas  $\neg U_1$



Estado 4. salidas S0,  $\neg U_1$  y  $\neg U_2$ .



## Simulación

Estado 0 con X=0, y salidas S1, S0,  $\neg U_1$  y  $\neg U_2$ .



Estado 0 con X=1 Y=0, y salidas S0,  $\neg U_1$  y  $\neg U_2$ .



Estado 0 con X=1 Y=1, y salidas S0,  $\neg U_1$  y  $\neg U_2$ .



Estado 1 Z=0, y salidas  $\neg U_1$ .



Estado 1  $Z=1$ , y salidas  $\neg U_1$ .



Estado 2, salidas S0,  $\neg U_1$  y  $\neg U_2$ .



Estado 3, salidas  $\neg U_1$ .



Estado 4. salidas S0,  $\neg U_1$  y  $\neg U_2$ .



## **Conclusiones**

### **Jiménez Treviño Emilio Cristóbal**

En esta práctica se logró diseñar y simular una máquina de estados mediante el método de direccionamiento por trayectoria, confirmando su correcto funcionamiento en Quartus por medio de la simulación de modelsim y la FPGA DE10-Lite. Se observó que el uso de memorias facilita la implementación de lógica secuencial y se aprendió a traducir una carta ASM a bloques en VHDL y el correcto llenado de la memoria ROM que fue lo mas complicado, así mismo las dificultades fueron la asignación de pines y la frecuencia del reloj, las cuales se solucionaron preguntando al profesor como se hacía y ya masomenos nos orientó y con eso pudimos hacer un correcto llenado de esta debido a que estabamos poniendo datos que no tenían que ver.

### **Martinez Perez Brian Erik**

En esta práctica, hemos logrado construir y simular una máquina de estados utilizando el método de direccionamiento por trayectoria con memorias. A través del desarrollo de las actividades, se aplicaron los fundamentos teóricos para representar la carta ASM en una tabla de contenido de memoria. Este enfoque demostró ser un método sistemático y eficaz para la implementación de lógica secuencial, ya que el estado siguiente y las salidas se codifican directamente en la memoria. La fase de simulación en el software Quartus permitió validar el funcionamiento del diseño, confirmando que la máquina de estados se comporta de manera predecible y transiciona correctamente entre los estados según las entradas y las ligas de memoria.

## **Bibliografía**

Laboratorio de Organización y Arquitectura de Computadoras. (2020, octubre 11). *Práctica No. 3 Construcción de Máquinas de estados Usando Memorias Direccionamiento por Trayectoria*.