



Figura 1: Banco de medición

## 1. Mediciones

### 1.1. Banco de medición

En la figura 1 puede observarse un diagrama del banco de medición. Consiste de los siguientes bloques:

- Placa FPGA: genera un pulso cuadrado unipolar, de frecuencia y ciclo de trabajo configurables. Con la frecuencia se controla la *PRF* de los pulsos de salida, y con el ciclo de trabajo los valores de tensión del pulso de salida del *driver*.
- Fuente de alimentación: provee la alimentación  $V_{dd}$  para el driver. El valor de esta tensión determina la amplitud pico a pico del pulso de salida del *driver*.
- *Driver*: cumplía la función de *buffer* para la *FPGA*, presentando una alta impedancia a la salida de la misma. Convierte el pulso unipolar de 3,3 V en uno bipolar, con amplitud pico a pico igual a  $V_{dd}$  (5 V o 7 V).
- *Pulser*: el *DUT*, genera pulsos ultra cortos en base a la salida del driver.
- Osciloscopio: instrumento de medición del experimento. Actúa como carga con su impedancia de entrada de  $50\ \Omega$ .

#### 1.1.1. Fuente de alimentación

Para la fuente de alimentación se utilizó una *Marconi Instruments TF2154*, en la figura 2 puede observarse la misma.

Presentaba limitación de corriente regulable e indicadores para la amplitud y la corriente suministrada, lo que permitía trabajar de manera segura, dentro de los límites de consumo obtenidos en las simulaciones anteriores **REEMPLAZAR ESTA REF ??**.

Como fuese explicado en la sección **REEMPLAZAR ESTA REF ??**, la corriente máxima esperada en las condiciones de trabajo era menor a 200 mA, por lo que se monitoreó durante todo el experimento que la corriente entregada por la fuente no supere este máximo teórico.

#### 1.1.2. FPGA

La *FPGA* generaba el pulso unipolar cuadrado de entrada, que controla la *PRF* y el ciclo de trabajo del pulso del driver. La placa utilizada fue *Nexys-4 DDR* de Digilent [1], con un chip *Artix-7* de Xilinx. En la figura 3 puede observarse la misma.



Figura 2: Fuente de alimentación *Marconi Instruments TF2154*.



Figura 3: Placa de desarrollo *Nexys-4 DDR*.

Se utilizó una *FPGA* para poder validar la utilidad del prototipo en el contexto de un sistema UWB como el descripto en ??, en el que se dispone de señales de control digitales. Este componente del sistema es fácilmente reemplazable por otra *FPGA* o sistema embebido.

Las variables de ajuste del pulso unipolar de la *FPGA* eran las siguientes

- Frecuencia: la frecuencia de la señal cuadrada de entrada es igual a la frecuencia de repetición de pulsos (*PRF*) del sistema, ya que controla la frecuencia con la que el *SRD* se prende y se apaga y, por lo tanto, la frecuencia de generación de pulsos.
- Ciclo de trabajo: el ciclo de trabajo de la señal cuadrada unipolar determina los extremos de tensión de la señal cuadrada bipolar de salida del driver. A mayor ciclo de trabajo, valores más negativos. Este control se da a través del control del valor medio de la señal, que luego es restado por el capacitor serie del *driver*.

#### 1.1.2.1 Diseño implementado

El diseño implementado en la *FPGA* consistía en un generador de cuadrada con ciclo de trabajo y frecuencia variables. La interfaz del sistema consistió en

- Los botones *BTNL* y *BTNR* controlaban el ciclo de trabajo en pasos de a 1 % en incrementos y decrementos respectivamente.



Figura 4: Osciloscopio *Tektronix MSO 70404C*

- Los botones *BTND* y *BTNU* controlaban el ciclo de trabajo en pasos de a 10% en incrementos y decrementos respectivamente.
- Con los *switches SW0* a *SW1* se controlaba la frecuencia del pulso unipolar.
  - Con *SW0* seleccionado, la frecuencia era de 1 MHz.
  - Con *SW1* seleccionado, la frecuencia era de 5 MHz.
  - Con *SW2* seleccionado, la frecuencia era de 10 MHz.

En el anexo A se encuentra el *HDL* del diseño implementado.

### 1.1.3. Osciloscopio

El osciloscopio fue utilizado para realizar la medición en el dominio del tiempo del pulso generado. Para una medición exitosa, era indispensable que este instrumento cuente con los requerimientos de ancho de banda del pulso. Como fuese explicado en REEMPLAZAR ESTA REF ??, el ancho de banda esperado para el pulso era de 3,6 GHz.

El osciloscopio utilizado fue *Tektronix MSO 70404C*, en la figura 4 puede observarse el mismo. El instrumento posee 4 GHz de ancho de banda analógico, y una tasa de muestreo de 25 GS/s, con la posibilidad de realizar muestreo en tiempo equivalente [2]. Estas prestaciones eran suficientes para medir el pulso de salida.

El instrumento posee configuraciones de impedancia de entrada seleccionables entre  $50\Omega$  y  $500\text{ M}\Omega$  [2]. Para la medición del prototipo, se seleccionó la entrada de  $50\Omega$ , actuando esta impedancia como carga del generador de pulsos.

#### 1.1.3.1 Seguridad del instrumento

Debido a las prestaciones del osciloscopio, era fundamental garantizar la integridad del mismo en la medición del prototipo. Dado que actuaba como carga del *DUT*, se debía garantizar que bajo todas las condiciones de trabajo, la potencia entregada por el generador de pulsos se encuentre dentro de los límites determinados por el fabricante del equipo para evitar posibles daños.

La máxima tensión de entrada se especifica en  $5\text{ V}_{RMS}$  para una resolución  $\geq 100\text{ mV/div}$  y  $1\text{ V}_{RMS}$  para una resolución  $< 100\text{ mV/div}$ . Para garantizar la seguridad del equipo en cualquier caso, se toma como límite el valor de peor caso,  $1\text{ V}_{RMS}$  (correspondiente a una resolución  $\geq 100\text{ mV/div}$ , para resoluciones menores a esta el límite es mayor).

En condiciones normales de funcionamiento, la potencia disipada por la carga es mínima, ya que es la potencia que disipa el tren de pulsos en un carga de  $50\Omega$ . Como fuese desarrollado en REEMPLAZAR ESTA REF ??, esta potencia está acotada por  $9999\text{ mW}$ , que en  $50\Omega$  resultan en  $9999\text{ V}_{rms}$ , que se encuentran muy por debajo de los  $1\text{ V}_{RMS}$  especificados por el fabricante.

No solo es necesario analizar la disipación de potencia en condiciones normales de funcionamiento, sino también para el caso de una falla, ya que el principal objetivo es garantizar la integridad del instrumento en cualquier condición.

En caso de ocurrir alguna falla con algún componente del circuito, el *stub* de salida provee una función de protección. Este componente, para señales con una variación temporal mucho mayor al largo del mismo, actúa como una puesta a tierra.

Entonces, la componente de continua a la salida del generador de pulsos tiene un valor esperado de 0 V, tanto para condiciones normales de funcionamiento como en presencia de fallas.

En cuanto a la componente alterna de la salida, su valor esperado es extremadamente bajo, ya que únicamente señales de gran ancho de banda pueden ser filtradas y permanecer con una amplitud considerable a la salida del *stub*.

## 1.2. Mediciones realizadas

Las mediciones consistieron en mediciones en el dominio del tiempo del pulso de salida. Utilizando funciones provistas por el osciloscopio, se midieron tiempo de crecimiento, tiempo de decaimiento, amplitud máxima, y ancho a medio máximo (*FWHM* del inglés *Full Width at Half Maximum*).

Se realizaron distintas mediciones para distintas condiciones de trabajo del circuito. Se barrió para el pulso digital de entrada, el ciclo de trabajo, y para la fuente de alimentación distintos valores de tensión.

- Para la amplitud de la fuente, se utilizaron valores de 5 V y 7 V.
  - 5 V por ser un valor fácilmente obtenible en los sistemas *UWB* de referencia.
  - 7 V por ser la máxima amplitud tolerable por el circuito. Tensiones de alimentación mayores a estas resultan en corrientes de polarización mayores a las máximas admisibles dado los dimensionamientos de las pistas de los *PCBs*.
- El ciclo de trabajo se barrió entre 50 % y 70 %.
  - Se tomó 50 % como límite inferior por ser un valor fácilmente obtenible como división de un reloj digital.
  - Se tomó 70 % como límite superior ya que se observó que valores superiores a este resultaban en un pulso bipolar con amplitudes negativas decrecientes, y por lo tanto, amplitudes de pulso decrecientes.
  - La teoría no indicaba un límite superior para el ciclo de trabajo. Sin embargo, este se observó en la práctica debido a no idealidades en el pulso de salida del driver, que no era perfectamente cuadrado.

En la figura 5 puede observarse el *pulser* junto con el *driver* y la *FPGA*.

### 1.2.1. Mediciones preliminares

Previo a las mediciones principales, se realizó una medición de la salida del driver, con el objetivo de validar el pulso bipolar generado.

El motivo de esta medición previa, fue la limitada disponibilidad del osciloscopio de gran ancho de banda utilizado para la medición final del pulso. Esta pre-medición del pulso bipolar se realizó con un osciloscopio de bajo ancho de banda, ya que el objetivo era validar los niveles de tensión del pulso, y su correcta variación con la variación del ciclo de trabajo del pulso unipolar.

En la figura 6 puede observarse el banco de medición. Los resultados fueron los esperados y, por lo tanto, no se requirió ninguna iteración sobre la implementación del driver.



Figura 5: *FPGA, driver y pulser.*



Figura 6: Banco de mediciones previas a la medición final del pulso.



Figura 7: Salida @  $V_{cc}$  5 V, D 50 %



Figura 8: Salida @  $V_{cc}$  5 V, D 70 %

### 1.3. Resultados

En las figuras 7, 8, 9, 10, 11 pueden observarse los resultados en diversas capturas de pantalla tomadas del osciloscopio.

Se observó en las mediciones una amplitud de pulso creciente con mayor ciclo de trabajo y mayor amplitud de pulso, como era esperado. La menor amplitud de pulso obtenida fue de 380 mV para un  $V_{cc}$  de 5 V y un D de 50 %, y la mayor fue de 1,12 V para un  $V_{cc}$  de 7 V y un D de 70 %

En cuanto al ancho de pulso, se mantuvo aproximadamente constante en 160 ps, al igual que los tiempos de crecimiento y decrecimiento, que se mantuvieron constantes en 90 ps. Este resultado es el esperado para un *pulser* basado en un *stub*, ya que el ancho de pulso está determinado por el largo del *stub*.

En la tabla 1 pueden observarse los resultados obtenidos. Para el ancho de banda, se utiliza el obtenido a partir de la *PSD* del pulso medido. En la sección 1.3.1 se detalla cómo fue obtenido este valor.



Figura 9: Salida @  $V_{cc}$  7 V, D 50 %



Figura 10: Salida @  $V_{cc}$  7 V, D 60 %

| $V_{cc}$ [V] | D [%] | A [V] | FWHM [ps] | 3 dB B [GHz] | $t_r$ [ps] | $t_f$ [ps] |
|--------------|-------|-------|-----------|--------------|------------|------------|
| 5            | 50    | 0.380 | 159       | 7.5          | 93         | 88         |
| 5            | 70    | 0.625 | 161       | 3.6          | 93         | 91         |
| 7            | 50    | 0.702 | 162       | 4            | 93         | 93         |
| 7            | 60    | 0.909 | 164       | 4            | 94         | 95         |
| 7            | 70    | 1.120 | 165       | 2.8          | 95         | 96         |

Cuadro 1: Resultados de mediciones.



Figura 11: Salida @  $V_{cc}$  7 V, D 70 %

### 1.3.1. Comparación con simulación

En las figuras 12 a 21 pueden observarse los resultados de las mediciones obtenidas superpuestos con los resultados de simulación para las mismas condiciones de trabajo (amplitud de alimentación y ciclo de trabajo).

Para las simulaciones, se toman dos resultados:

- Una simulación “ideal”, indicada como “esquemático ideal” en las leyendas, que se corresponde a una simulación sin contemplar parásitos de ningún tipo.
- Una simulación “real”, en las leyendas “Layout”, una simulación en la que se extrajeron previamente los efectos parásitos del *PCB* mediante una simulación electromagnética y se incorporaron en la simulación del pulso.

Se realizan las comparaciones en el dominio del tiempo y de la frecuencia. Las comparaciones en el dominio del tiempo consisten en la superposición del pulso medido con los simulados. Para las comparaciones en el dominio de la frecuencia, se calculó el espectro de cada una de las formas de onda del dominio del tiempo. Para reducir el *leakage* espectral, se utilizó una ventana de *Hanning* [3].

En el dominio del tiempo, se observa una buena coincidencia entre la amplitud de los pulsos y el ancho. Se observa una diferencia en el *ringing* de ambos. Las simulaciones prácticamente no presentan oscilaciones alrededor del pulso, mientras que las mediciones las presentan tanto previa como posteriormente. También se observa un segundo pulso de menor amplitud siguiendo al primero.

Como causa de estas discrepancias, se descarta un efecto del *PCB* no modelado, ya que los parásitos de esta estructura fueron extraídos por una simulación electromagnética, y sus efectos contemplados en las simulaciones del *layout*.

Estas discrepancias sugieren una limitación en el modelado de alguno de los dispositivos, tanto el SRD como el Schottky. Las simulaciones predijeron correctamente la amplitud y el ancho de los pulsos resultantes, pero fallaron en predecir el *ringing* y el pulso secundario.

### 1.3.2. Comparación con resultados de la literatura

En la tabla 2 se resumen resultados reportados para generadores de pulsos *UWB* en la literatura. En la figura 22 se observan los valores de amplitud y duración reportados en un gráfico de dispersión.

$V_{cc}$ : 5V, duty: 50%



Figura 12: Pulso @  $V_{cc}$  5 V, D 50 %

PSD,  $V_{cc}$ : 5V, duty: 50%



Figura 13: PSD @  $V_{cc}$  5 V, D 50 %

$V_{cc}$ : 5V, duty: 70%



Figura 14: Pulso @  $V_{cc}$  5 V, D 70 %

PSD, Vcc: 5V, duty: 70%



Figura 15: PSD @  $V_{cc}$  5 V, D 70 %

Vcc: 7V, duty: 50%



Figura 16: Pulso @  $V_{cc}$  7 V, D 50 %

PSD, Vcc: 7V, duty: 50%



Figura 17: PSD @  $V_{cc}$  7 V, D 50 %

$V_{cc}$ : 7V, duty: 60%



Figura 18: Pulso @  $V_{cc}$  7 V, D 60 %

PSD,  $V_{cc}$ : 7V, duty: 60%



Figura 19: PSD @  $V_{cc}$  7 V, D 60 %

$V_{cc}$ : 7V, duty: 70%



Figura 20: Pulso @  $V_{cc}$  7V, D 70 %

PSD, Vcc: 7V, duty: 70%



Figura 21: PSD @  $V_{cc}$  7V, D 70 %

Cuadro 2: Resultados reportados en la literatura

| Referencia          | $A$ [V]                           | $FWHM$ [ps] | Bal <sup>a</sup> | Bias | Dispositivos | $V_{cc}$ [V] | $V_{in}$ [V]    | $PRF$ [MHz] |
|---------------------|-----------------------------------|-------------|------------------|------|--------------|--------------|-----------------|-------------|
| [4]                 | $\pm 0,896, \pm 1,6$ <sup>b</sup> | 335, 511    | Sí               | Int  | SRD          | 5            | TTL             | 50          |
| [5]                 | -7,5                              | 110         | No               | Ext  | SRD+3TBJ+SD  | 12           | TTL             | 5           |
| [6]                 | 0,8                               | 170         | No               | Int  | SRD          | 4            | 4               | 10          |
| [7]                 | 0,2                               | 300         | No               | Ext  | SRD+2SD      | ?            | ?               | 10          |
| [8]                 | -6, -4                            | 150         | No               | Int  | SRD+L        | ?            | 5               | 12          |
| [9]                 | 1,27 <sup>c</sup>                 | 286         | No               | Int  | 2SRD+L       | 10           | 10 <sup>d</sup> | ?           |
| <b>Este trabajo</b> | 1,12                              | 165         | No               | Int  | SRD+SD       | 7            | CMOS            | 10          |

<sup>a</sup> Balanceado.

<sup>b</sup> la publicación presenta dos resultados, correspondientes a circuitos con componentes concentrados y distribuidos.

<sup>c</sup> la publicación presenta múltiples resultados, se muestran los mejores.

<sup>d</sup> la señal de entrada es senoidal.



Figura 22: Diagrama de dispersión de resultados reportados.

En cuanto a los resultados reportados en este trabajo, se obtuvo uno de los anchos de pulso más bajos, existiendo otros trabajos que reportan el mismo o menor ancho de pulso con mayor amplitud, pero también mayor complejidad. Otra característica a destacar es la simplicidad del diseño implementado, tanto en cantidad de componentes activos, como en requisitos de fuente de alimentación y pulso de entrada.

En [4] se presenta un diseño compuesto de un solo SRD en el que se desarrolla un pulso balanceado a la salida. Se presentan dos diseños, uno con componentes distribuidos y otro con componentes concentrados. En ambos casos se obtienen amplitudes pico a pico de pulso mayores a las de este trabajo. Es destacable que se obtienen mayores amplitudes usando una fuente de alimentación menor, de 5 V. En cuanto al ancho de pulso, ambos pulsos presentan duraciones mayores que las de nuestro trabajo. En cuanto a la complejidad, el *pulser* está implementado solamente con 1 SRD y componentes distribuidos o concentrados, dependiendo de la versión, por lo que es más simple que nuestro trabajo. El *driver* presenta la misma complejidad en ambos casos, ya que está implementado con un solo circuito integrado. Nuestro trabajo presenta más versatilidad, ya que la amplitud de la fuente de alimentación puede variarse entre 0 V y 30 V, mientras que el integrado utilizado en el driver de [4] trabaja con 5 V fijos.

En [5] se reporta un resultado de gran amplitud y duración de pulso menor a la de este trabajo. La complejidad del diseño implementado es mucho mayor: necesita una alimentación de 12 V y una corriente de *bias* externa, y la etapa *driver* está implementada con 3 TBJs, frente a 1 solo *gate driver* en nuestro trabajo.

En [6] el pulso reportado es de características muy similares a las de nuestro trabajo. La duración del pulso es prácticamente la misma, mientras que en amplitud nuestro trabajo logró una mayor en un 40 %. Nuestro trabajo logró para el *pulser* una complejidad menor a la reportada en [6], ya que en nuestro caso omitimos la red RC y el atenuador. En cuanto a etapa *driver*, [6] no presenta ninguna, en los resultados se reporta haber utilizado como entrada al *pulser* un pulso bipolar.

En [7] el generador presentado desarrolla pulsos monociclo, que son la primera derivada de un pulso gaussiano. Nuestro trabajo logró una amplitud de pulso mayor y también una duración de pulso menor. No se especifica el valor de amplitud de señal de entrada utilizado. La entrada al circuito es bipolar, y no se incluye un *driver* de adaptación de pulso. La complejidad del generador descripto es mayor que la de este trabajo, utilizando bias externo, un diodo SRD, dos Schottky y una red RC. Sin embargo, el generador de [7] implementa un monociclo que es una derivada de un pulso gaussiano como el desarrollado en nuestro trabajo, por lo que es natural que la complejidad sea mayor.

El resultado reportado en [8] consiste en pulsos de mayor amplitud y menor duración a los de nuestro trabajo. En ambos casos, el pulser se encuentra acoplado por *AC*, lo que vuelve más complejo el diseño. Se presentan dos generadores, uno con línea de transmisión, y otro con un inductor, que utiliza al SRD en paralelo. El diseño con inductor es más complejo, ya que este se encuentra en el camino del pulso por lo que debe ser seleccionado con cuidado. En ambos casos se utiliza una red RC paralelo, mientras que en nuestro trabajo no.

El resultado de [9] consiste en un pulso de mayor amplitud y mayor ancho al de nuestro trabajo. La complejidad del diseño es mayor, ya que utiliza dos SRD y un inductor que se encuentra en el camino de alta frecuencia, por lo que es costoso de seleccionar. La señal de entrada es una senoidal, que para el contexto en el que desarrollamos nuestro generador, es más costosa de conseguir, ya que requiere algún DAC, frente a la excitación de nuestro generador que es una señal cuadrada, fácilmente obtenible como salida digital de una FPGA o microcontrolador.

## Referencias

- [1] Digilent, “Nexys 4 DDR.” Página Oficial, 2023. Disponible online en <https://digilent.com/reference/programmable-logic/nexys-4-ddr/start>.

- [2] Tektronix, Inc., “Osciloscopio MSO 70404C.” Datasheet, 2023. Disponible online en <https://download.tek.com/datasheet/DPO-DSA-MSO70000-DataSheet-EN-11Apr23.pdf>.
- [3] A. V. Oppenheim, R. W. Schafer, and J. R. Buck, *Discrete-Time Signal Processing*. Upper Saddle River, NJ: Prentice Hall, 2nd ed., 1999.
- [4] P. Rulikowski and J. Barrett, “Truly balanced step recovery diode pulse generator with single power supply,” in *Proceedings. 2004 IEEE Radio and Wireless Conference (IEEE Cat. No.04TH8746)*, pp. 347–350, 2004.
- [5] P. Protiva, J. Mrkvica, and J. Macháč, “A compact step recovery diode subnanosecond pulse generator,” *Microwave and Optical Technology Letters*, vol. 52, no. 2, pp. 438–440, 2010.
- [6] A. Kamal, A. Bhattacharya, M. Tamrakar, and C. Roy, “Low-ringing and reduced-cost step recovery diode based uwb pulse generators for gpr applications,” *Microwave and Optical Technology Letters*, vol. 56, no. 10, pp. 2289–2294, 2014.
- [7] J. Han and C. Nguyen, “A new ultra-wideband, ultra-short monocycle pulse generator with reduced ringing,” *IEEE Microwave and Wireless Components Letters*, vol. 12, no. 6, pp. 206–208, 2002.
- [8] J. Han and C. Nguyen, “Coupled-slotline-hybrid sampling mixer integrated with step-recovery-diode pulse generator for uwb applications,” *IEEE Transactions on Microwave Theory and Techniques*, vol. 53, no. 6, pp. 1875–1882, 2005.
- [9] D. Oloumi and E. Fear, “A picosecond pulse generator using srd diodes: Design, analysis, and measurements,” in *2018 USNC-URSI Radio Science Meeting (Joint with AP-S Symposium)*, pp. 159–160, 2018.

## A. Código Fuente Verilog

```

'timescale 1ns / 1ps

module top(
    input clk,
    input btnU, btnD,
    input btnL, btnR,
    input [1:0] sw,
    output [1:0] led,
    output [0:0] JA
);

    wire duty_inc_coarse, duty_inc_fine, duty_dec_coarse, duty_dec_fine;

    localparam W = 8;
    reg [W-1:0] div_value = 'd10;
    reg [1:0] sw_old = 'd0;
    reg initialized = 'b0;
    reg [3:0] init_counter = 'b0;
    reg srst = 'b0;

    localparam real DUTY_CYCLE NOMINAL = 0.5;
    localparam real DUTY_CYCLE COARSE = 0.1;
    localparam real DUTY_CYCLE FINE = 0.01;

    localparam integer DIV_VALUE_10MHZ = 10;

```

```

localparam integer COUNTS_DUTY_NOMINAL_10MHZ      = DUTY_CYCLE_NOMINAL*
    DIV_VALUE_10MHZ;
localparam integer COUNTS_DUTY_COARSE_10MHZ        = DUTY_CYCLE_COARSE *
    DIV_VALUE_10MHZ;
localparam integer COUNTS_DUTY_FINE_10MHZ          = DUTY_CYCLE_FINE   *
    DIV_VALUE_10MHZ;

localparam integer DIV_VALUE_5MHZ = 20;             = DUTY_CYCLE_NOMINAL*
localparam integer COUNTS_DUTY_NOMINAL_5MHZ        = DUTY_CYCLE_NOMINAL*
    DIV_VALUE_5MHZ;
localparam integer COUNTS_DUTY_COARSE_5MHZ         = DUTY_CYCLE_COARSE *
    DIV_VALUE_5MHZ;
localparam integer COUNTS_DUTY_FINE_5MHZ           = 'd1;

localparam integer DIV_VALUE_1MHZ = 100;            = DUTY_CYCLE_NOMINAL*
localparam integer COUNTS_DUTY_NOMINAL_1MHZ        = DUTY_CYCLE_NOMINAL*
    DIV_VALUE_1MHZ;
localparam integer COUNTS_DUTY_COARSE_1MHZ         = DUTY_CYCLE_COARSE *
    DIV_VALUE_1MHZ;
localparam integer COUNTS_DUTY_FINE_1MHZ           = DUTY_CYCLE_FINE   *
    DIV_VALUE_1MHZ;

reg [W-1:0] div_value_curr,
           counts_duty_nominal_curr,
           counts_duty_coarse_curr,
           counts_duty_fine_curr;

always @(posedge clk) begin
    if (sw[1]) begin
        div_value_curr           <= DIV_VALUE_1MHZ;
        counts_duty_nominal_curr <= COUNTS_DUTY_NOMINAL_1MHZ;
        counts_duty_coarse_curr <= COUNTS_DUTY_COARSE_1MHZ;
        counts_duty_fine_curr   <= COUNTS_DUTY_FINE_1MHZ;
    end
    else if (sw[0]) begin
        div_value_curr           <= DIV_VALUE_5MHZ;
        counts_duty_nominal_curr <= COUNTS_DUTY_NOMINAL_5MHZ;
        counts_duty_coarse_curr <= COUNTS_DUTY_COARSE_5MHZ;
        counts_duty_fine_curr   <= COUNTS_DUTY_FINE_5MHZ;
    end
    else begin
        div_value_curr           <= DIV_VALUE_10MHZ;
        counts_duty_nominal_curr <= COUNTS_DUTY_NOMINAL_10MHZ;
        counts_duty_coarse_curr <= COUNTS_DUTY_COARSE_10MHZ;
        counts_duty_fine_curr   <= COUNTS_DUTY_FINE_10MHZ;
    end
    sw_old <= sw;
end

always @(posedge clk) begin
    if (initialized == 'b0) begin
        if (init_counter < 'd14) begin
            init_counter <= init_counter+1;
        end
        else begin
            initialized <= 'b1;
            srst <= 'b1;
        end
    end

```

```

        end
    else begin
        if (sw_old != sw) srst <= 'b1;
    end
    if (srst) srst <= 'b0;
end

// debounce of buttons
debounce u_debounce_inc_coarse(clk,btnU,duty_inc_coarse);
debounce u_debounce_dec_coarse(clk,btnD,duty_dec_coarse);
debounce u_debounce_inc_fine(clk,btnR,duty_inc_fine);
debounce u_debounce_dec_fine(clk,btnL,duty_dec_fine);

// PWM generator
adhoc_generator#.WIDTH(W)u_generator(
    .clk(clk),
    .srst(srst),
    .duty_coarse(counts_duty_coarse_curr),
    .duty_fine(counts_duty_fine_curr),
    .duty_nominal(counts_duty_nominal_curr),
    .div_value(div_value_curr),
    .duty_inc_coarse(duty_inc_coarse),
    .duty_inc_fine(duty_inc_fine),
    .duty_dec_coarse(duty_dec_coarse),
    .duty_dec_fine(duty_dec_fine),
    .PWM(JA[0])
);
assign led = sw;

endmodule

module debounce(
    input clk,
    input data_in,
    output data_out
);
localparam DEBOUNCE_BITS = 23;

reg [DEBOUNCE_BITS-1:0] debounce_counter;
wire debounce_enable;
wire tmp_1, tmp_2;

// debounce enable generation, has period T_clk/2**DEBOUNCE_BITS
always @(posedge clk) debounce_counter = debounce_counter + 'b1;
assign debounce_enable = debounce_counter == 2**DEBOUNCE_BITS-1 ? 'b1
: 'b0;

// debounce of buttons
DFF u_DFF_inc_coarse(clk,debounce_enable,data_in,tmp_1);
DFF u_DFF_dec_coarse(clk,debounce_enable,tmp_1,tmp_2);

assign data_out = tmp_1 & (~tmp_2) & debounce_enable;

endmodule

module DFF(

```

```

    input  clk,
    input  en,
    input  D,
    output reg  Q
);
  always @ (posedge clk) begin
    if (en) Q <= D;
  end
endmodule

'timescale 1ns / 1ps

module adhoc_generator#(
  parameter WIDTH = 8
) (
  input  clk, srst,
  input  duty_inc_coarse, duty_inc_fine,
  input  duty_dec_coarse, duty_dec_fine,
  input [WIDTH-1:0] duty_coarse, duty_fine, duty_nominal, div_value,
  output reg  PWM
);

reg [WIDTH-1:0] counter      = 'd0;
reg [WIDTH-1:0] duty_cycle  = 'd0;
wire n_PWM;

assign n_PWM = counter < duty_cycle ? 'b1 : 'b0;

always @ (posedge clk) begin
  if (srst) begin
    duty_cycle  <= duty_nominal;
    counter     <= 'd0;
    PWM         <= 'd1;
  end
  else begin
    counter           <= counter >= div_value-1
      ? 'd0 : counter + 1;
    PWM             <= n_PWM;
    if (duty_inc_coarse) duty_cycle <= duty_cycle +
      duty_coarse;
    else if (duty_inc_fine) duty_cycle <= duty_cycle + duty_fine
      ;
    else if (duty_dec_coarse) duty_cycle <= duty_cycle -
      duty_coarse;
    else if (duty_dec_fine) duty_cycle <= duty_cycle - duty_fine
      ;
  end
end
end

endmodule

```