Nivel: Avanzado — Construye y analiza un oscilador en anillo de 5 etapas para calcular el retardo de propagación de los componentes.
Objetivo y caso de uso
En este caso, construirás un oscilador en anillo conectando en cascada un número impar (5) de puertas NOT (inversores) en un bucle de retroalimentación cerrado utilizando un CI 74HC04. Medirás la frecuencia de oscilación resultante para calcular el retardo de propagación intrínseco de las puertas lógicas.
Por qué es útil:
* Caracterización de procesos: Utilizado en la fabricación de semiconductores para probar la velocidad y calidad de las obleas de silicio.
* Generación de reloj: Topología fundamental para generar relojes internos en ASICs y FPGAs.
* Generación de Números Aleatorios: El jitter inherente en los osciladores en anillo es una fuente de entropía para Generadores de Números Aleatorios Verdaderos (TRNG).
* Convertidores de Tiempo a Digital (TDC): Utilizados para medir intervalos de tiempo con alta precisión.
Resultado esperado:
* Una salida de onda cuadrada estable oscilando en el rango de MHz (típicamente 20 MHz–50 MHz para lógica 74HC en una protoboard).
* Medición de la frecuencia de oscilación (fosc).
* Cálculo del retardo de propagación promedio (tpd) por puerta.
* Observación visual de los tiempos de subida (tr) y bajada (tf) debido a la carga capacitiva.
Público objetivo y nivel:
Estudiantes avanzados de electrónica; Estudiantes de ingeniería.
Materiales
- U1: CI 74HC04 Hex Inverter, función: puertas lógicas para el anillo
- C1: Condensador cerámico de 100 nF, función: desacoplo de la fuente de alimentación (crítico para la estabilidad)
- C2: Condensador de 10 pF, función: carga simulada (opcional, representa la capacitancia de la sonda)
- V1: Fuente de alimentación de 5 V DC
- W1-W5: Cables puente (jumpers), función: conexiones entre etapas
Pin-out del CI utilizado
Chip seleccionado: 74HC04 (Hex Inverter)
| Pin | Nombre | Función lógica | Conexión en este caso |
|---|---|---|---|
| 1 | 1 A | Entrada 1 | Desde Salida 5 (Nodo N5) |
| 2 | 1Y | Salida 1 | A Entrada 2 (Nodo N1) |
| 3 | 2 A | Entrada 2 | Desde Salida 1 (Nodo N1) |
| 4 | 2Y | Salida 2 | A Entrada 3 (Nodo N2) |
| 5 | 3 A | Entrada 3 | Desde Salida 2 (Nodo N2) |
| 6 | 3Y | Salida 3 | A Entrada 4 (Nodo N3) |
| 7 | GND | Tierra (Ground) | Conectar a Nodo 0 |
| 8 | 4Y | Salida 4 | A Entrada 5 (Nodo N4) |
| 9 | 4 A | Entrada 4 | Desde Salida 3 (Nodo N3) |
| 10 | 5Y | Salida 5 | A Entrada 1 (Nodo N5 – Retroalimentación) |
| 11 | 5 A | Entrada 5 | Desde Salida 4 (Nodo N4) |
| 14 | VCC | Alimentación | Conectar a Nodo VCC (+5 V) |
Nota: Los pines 12 (6Y) y 13 (6 A) no se utilizan y deben dejarse abiertos o conectados a GND/VCC dependiendo de los requisitos específicos de ruido, aunque para esta prueba dejarlos abiertos es aceptable.
Guía de conexionado
Este circuito depende de una longitud de pista mínima para mantener la oscilación de alta frecuencia.
- V1 se conecta entre el nodo
VCCy el nodo0(GND). - C1 se conecta entre el nodo
VCCy el nodo0(colocar físicamente cerca de U1). - U1 (Pin 14) se conecta al nodo
VCC. - U1 (Pin 7) se conecta al nodo
0. - U1 (Pin 1 – Entrada 1) se conecta al nodo
N5(Cierre del bucle de retroalimentación). - U1 (Pin 2 – Salida 1) se conecta al nodo
N1. - U1 (Pin 3 – Entrada 2) se conecta al nodo
N1. - U1 (Pin 4 – Salida 2) se conecta al nodo
N2. - U1 (Pin 5 – Entrada 3) se conecta al nodo
N2. - U1 (Pin 6 – Salida 3) se conecta al nodo
N3. - U1 (Pin 9 – Entrada 4) se conecta al nodo
N3. - U1 (Pin 8 – Salida 4) se conecta al nodo
N4. - U1 (Pin 11 – Entrada 5) se conecta al nodo
N4. - U1 (Pin 10 – Salida 5) se conecta al nodo
N5. - C2 (Carga opcional) se conecta entre el nodo
N5y el nodo0para simular la capacitancia de la sonda.
Diagrama de bloques conceptual

Esquemático
POWER SUPPLY & DECOUPLING:
VCC (5 V) --> [ Node VCC ] --(Pin 14)--> [ U1: 74HC04 Power ]
|
[ C1: 100nF ]
|
GND (0 V) --> [ Node 0 ] --(Pin 7)---> [ U1: 74HC04 GND ]
SIGNAL FLOW (RING OSCILLATOR):
(Logic flows Left to Right, wrapping around at the end)
[ Feedback N5 ] --> [ U1: Gate 1 ] --(Node N1)--> [ U1: Gate 2 ] --(Node N2)--> [ U1: Gate 3 ] --(Node N3)--> \
(Input Pin 1) (In:1 / Out:2) (In:3 / Out:4) (In:5 / Out:6) |
|
/-------------------------------------------------------------------------------------------------------------/
|
\--> [ U1: Gate 4 ] --(Node N4)--> [ U1: Gate 5 ] --(Node N5)--> [ C2: 10pF ] --> GND
(In:9 / Out:8) (In:11 / Out:10) |
|
(Loop back to Start)
Tabla de verdad (Puerta NOT simple)
| Entrada (A) | Salida (Y) |
|---|---|
| L | H |
| H | L |
En una configuración de anillo con un número impar de etapas, la lógica nunca se estabiliza, causando una oscilación perpetua.
Mediciones y pruebas
- Configuración: Asegura que el cableado sea corto y ordenado. Los cables largos añaden inductancia y capacitancia parásitas que reducirán significativamente la frecuencia.
- Visualización: Conecta una sonda de osciloscopio (se recomienda atenuación x10 para reducir la carga) al Nodo
N5(o cualquier nodoN1aN4). - Medición de frecuencia: Mide la frecuencia de la oscilación (fosc). Para una serie 74HC a 5 V, espera aprox. 20MHz – 40MHz dependiendo de la capacitancia parásita.
- Cálculo del retardo de propagación: Calcula el retardo de propagación promedio por puerta (tpd) usando la fórmula:
$tpd = (1 / (2 × N × fosc))$
Donde $N = 5$ (número de etapas).
Ejemplo: Si $f_{osc} = 25 MHz$, entonces $T = 40 ns$. $t_{pd} = 40 ns / 10 = 4 ns$. - Análisis de forma de onda: Haz zoom en los flancos. Observa que la onda no es un cuadrado perfecto; el tiempo de subida ($t_{r}$) y el tiempo de bajada ($t_{f}$) son visibles debido a la carga capacitiva de la entrada de la siguiente puerta.
Netlist SPICE y simulación
Netlist SPICE de referencia (ngspice) — extractoNetlist SPICE completo (ngspice)
* Practical case: Ring Oscillator and Delay
.width out=256
* Ngspice Netlist
* --- Power Supply ---
* V1: 5 V DC supply connecting VCC to GND (0)
V1 VCC 0 DC 5
* --- Decoupling Capacitor ---
* C1: 100 nF ceramic capacitor, power supply decoupling
C1 VCC 0 100n
* --- Integrated Circuit U1: 74HC04 Hex Inverter ---
* Modeled as a subcircuit to strictly follow physical pinout and wiring guide.
* Pin Mapping (Standard DIP-14):
* 1:1A 2:1Y 3:2A 4:2Y 5:3A 6:3Y 7:GND
* 8:4Y 9:4A 10:5Y 11:5A 12:6Y 13:6A 14:VCC
*
* Wiring Connections based on Guide:
* Pin 1 (In1) -> N5
* ... (truncated in public view) ...Copia este contenido en un archivo .cir y ejecútalo con ngspice.
* Practical case: Ring Oscillator and Delay
.width out=256
* Ngspice Netlist
* --- Power Supply ---
* V1: 5 V DC supply connecting VCC to GND (0)
V1 VCC 0 DC 5
* --- Decoupling Capacitor ---
* C1: 100 nF ceramic capacitor, power supply decoupling
C1 VCC 0 100n
* --- Integrated Circuit U1: 74HC04 Hex Inverter ---
* Modeled as a subcircuit to strictly follow physical pinout and wiring guide.
* Pin Mapping (Standard DIP-14):
* 1:1A 2:1Y 3:2A 4:2Y 5:3A 6:3Y 7:GND
* 8:4Y 9:4A 10:5Y 11:5A 12:6Y 13:6A 14:VCC
*
* Wiring Connections based on Guide:
* Pin 1 (In1) -> N5
* Pin 2 (Out1) -> N1
* Pin 3 (In2) -> N1
* Pin 4 (Out2) -> N2
* Pin 5 (In3) -> N2
* Pin 6 (Out3) -> N3
* Pin 7 (GND) -> 0
* Pin 8 (Out4) -> N4
* Pin 9 (In4) -> N3
* Pin 10 (Out5)-> N5
* Pin 11 (In5) -> N4
* Pin 12 (Out6)-> NC_OUT (Unused)
* Pin 13 (In6) -> NC_IN (Unused)
* Pin 14 (VCC) -> VCC
XU1 N5 N1 N1 N2 N2 N3 0 N4 N3 N5 N4 NC_OUT NC_IN VCC 74HC04
* --- Load Capacitor ---
* C2: 10 pF capacitor, simulated load on Output Node N5
C2 N5 0 10p
* --- Unused Pin Termination ---
* High resistance to ground to prevent floating node errors
R_NC1 NC_OUT 0 1G
R_NC2 NC_IN 0 1G
* --- Subcircuit Definitions ---
.subckt 74HC04 1 2 3 4 5 6 7 8 9 10 11 12 13 14
* Local Power: 14=VCC, 7=GND
* Gate 1
X1 1 2 14 7 inv_gate
* Gate 2
X2 3 4 14 7 inv_gate
* Gate 3
X3 5 6 14 7 inv_gate
* Gate 4 (Note: Pin 9 is Input, Pin 8 is Output)
X4 9 8 14 7 inv_gate
* Gate 5 (Note: Pin 11 is Input, Pin 10 is Output)
X5 11 10 14 7 inv_gate
* Gate 6 (Unused)
X6 13 12 14 7 inv_gate
.ends
.subckt inv_gate in out vcc gnd
* Internal RC Delay Stage
* Essential for Ring Oscillator simulation to function (creates phase shift)
* R=1k, C=10p yields approx 10ns delay per stage
R_delay in int 1k
C_delay int gnd 10p
* Behavioral Voltage Source (Sigmoid Inverter)
* Uses continuous function for convergence: Vout = Vcc / (1 + exp(k*(Vin - Vcc/2)))
* Gain factor k=10
B_logic out gnd V=V(vcc) / (1 + exp(10 * (V(int) - V(vcc)/2)))
.ends
* --- Simulation Directives ---
* Initial Condition:
* Force node N1 to 0V at t=0 to prevent metastable state (kickstart oscillation)
.ic V(N1)=0
* Transient Analysis:
* Run for 2 microseconds, step size 1 nanosecond
* 'uic' (Use Initial Conditions) is required for .ic to take effect
.tran 1n 2u uic
* Operating Point (for check)
.op
* Output Printing:
* V(N5) is the primary OSC_OUT node
.print tran V(N5) V(N1) V(N2) V(N3) V(N4)
.end
* --- GPT review (BOM/Wiring/SPICE) ---
* circuit_ok=true
* simulation_summary: The transient analysis shows sustained oscillation on nodes N1 through N5. The voltages swing between ~0V and ~5V. The frequency can be inferred from the timestamps (e.g., N5 rising edges around 1.43us and subsequent cycles), confirming the ring oscillator behavior.
* bom_vs_spice equivalences ignored:
* - U1 (74HC04 Hex Inverter) is modeled as a subcircuit using behavioral voltage sources and RC delay stages to simulate propagation delay and logic inversion.
* overall_comment: The circuit is well-modeled for a didactic example. The inclusion of internal RC delay stages inside the inverter subcircuit is crucial for a ring oscillator simulation, as ideal SPICE inverters often fail to oscillate or converge without explicit time-dependent behavior. The initial condition (.ic V(N1)=0) correctly kickstarts the oscillation. The connectivity matches the wiring guide perfectly.
* --------------------------------------Resultados de Simulación (Transitorio)
Show raw data table (2039 rows)
Index time v(n5) v(n1) v(n2) v(n3) v(n4) 0 1.000000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 1 1.028000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 2 1.084000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 3 1.196000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 4 1.420000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5 1.868000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 6 2.764000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 7 4.556000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 8 8.140000e-11 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 9 1.530800e-10 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 10 2.964400e-10 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 11 5.831600e-10 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 12 1.000000e-09 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 13 1.057344e-09 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 14 1.172032e-09 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 15 1.401408e-09 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 16 1.860160e-09 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 5.000000e+00 17 2.777664e-09 4.999998e+00 4.999998e+00 4.999998e+00 4.999998e+00 4.999998e+00 18 3.777664e-09 4.999526e+00 4.999526e+00 4.999526e+00 4.999526e+00 4.999526e+00 19 4.777664e-09 4.987728e+00 4.987728e+00 4.987728e+00 4.987728e+00 4.987728e+00 20 5.777664e-09 4.795985e+00 4.795985e+00 4.795985e+00 4.795985e+00 4.795985e+00 21 6.777664e-09 3.794650e+00 3.794650e+00 3.794650e+00 3.794650e+00 3.794650e+00 22 7.777664e-09 2.828762e+00 2.828762e+00 2.828762e+00 2.828762e+00 2.828762e+00 23 8.777664e-09 2.564867e+00 2.564867e+00 2.564867e+00 2.564867e+00 2.564867e+00 ... (2015 more rows) ...
Errores comunes y cómo evitarlos
- Usar un número par de puertas: Si usas 4 o 6 puertas, la lógica se asentará en un estado estable (enclavamiento) en lugar de oscilar. Usa siempre un número impar (3, 5, 7…).
- Capacitancia de la protoboard: Las protoboards estándar tienen una alta capacitancia parásita entre filas (aprox. 2-5pF). Esto hará que el oscilador funcione más lento de lo que implican las especificaciones de la hoja de datos. Evita bucles largos de cables.
- Falta del condensador de desacoplo: Sin C1 cerca del chip, la corriente de conmutación de alta frecuencia causará caídas en VCC, resultando en una frecuencia errática o ausencia de oscilación.
Solución de problemas
- La salida está atascada en Alto o Bajo: Comprueba que tienes un número impar de inversores en el bucle. Verifica que el cable de retroalimentación conecta la última salida a la primera entrada.
- La frecuencia es inestable (jitter): Probablemente ruido en la fuente de alimentación. Asegúrate de que C1 (100nF) esté instalado extremadamente cerca de los pines 14 y 7.
- El osciloscopio muestra una onda sinusoidal en lugar de cuadrada: A frecuencias muy altas (acercándose al límite de ancho de banda del osciloscopio o sonda), las ondas cuadradas parecen ondas sinusoidales debido a la atenuación de los armónicos superiores. Asegúrate de que el ancho de banda de tu osciloscopio sea de al menos 100 MHz.
- El circuito se calienta: Busca cortocircuitos entre salidas. Nunca conectes dos salidas juntas.
Posibles mejoras y extensiones
- Control de habilitación: Reemplaza el primer inversor con una puerta NAND (por ejemplo, usando 74HC00). Usa una entrada para el bucle de retroalimentación y la otra como señal de control de Habilitar/Deshabilitar.
- Salida con buffer: Usa el sexto inversor no utilizado en el paquete 74HC04 como un buffer conectado a uno de los nodos del anillo. Conecta tu sonda/carga a esta salida del buffer. Esto aísla el oscilador en anillo de la capacitancia de carga, proporcionando una medición de frecuencia más precisa.
Más Casos Prácticos en Prometeo.blog
Encuentra este producto y/o libros sobre este tema en Amazon
Como afiliado de Amazon, gano con las compras que cumplan los requisitos. Si compras a través de este enlace, ayudas a mantener este proyecto.




