# Índice

| Co | ontenidos                                                                                                                 | 1               |
|----|---------------------------------------------------------------------------------------------------------------------------|-----------------|
| 1. | Introducción 1.1. Descripción de los módulos VHDL                                                                         | 2               |
| 2. | Diseño de banco de filtros  2.1. Implementación de los filtros en VHDL                                                    | 7               |
| 3. | Diseño de módulo de reverberación                                                                                         | 9               |
| 4. | Diseño de vúmetro 4.1. Mantenimiento del nivel                                                                            | 9<br>10         |
| 5. | Mejoras  5.1. Sumador Ripple Carry  5.2. Sumador Carry Bypass  5.3. Multiplicador en array  5.4. Multiplicador carry save | 13              |
| 6. | Pruebas y resultados 6.1. Comprobación del funcionamiento de los filtros                                                  | 17              |
| Aŗ | péndices                                                                                                                  | 20              |
| Α. | Gráficas de evaluación de filtros  A.1. Sin aplicar atenuación                                                            | 20<br>20<br>27  |
| В. | Gráficas de evaluación de reverb                                                                                          | 34              |
| C. | Gráficas de evaluación de ajuste de ganancia                                                                              | 35              |
| D. | Gráficas de prueba de mejoras  D.1. Sumadores                                                                             | <b>36</b> 36 36 |

### 1. Introducción

En esta memoria vamos a tratar un proyecto realizado para la asignatura Diseño de Circuitos y Sistemas Electrónicos impartida en la ETSI de Telecomunicación de la Universidad Politécnica de Madrid.

El proyecto se propone como trabajo adicional a la asignatura, para tratar los temas de diseño de circuitos digitales de una forma más práctica y obtener conocimientos mucho más amplios sobre tecnologías relacionadas con estos campos.

En concreto, la propuesta consiste en el diseño y simulación de un sistema utilizando VHDL. El sistema propuesto consiste en un ecualizador de audio, del cual se implementarán algunos subsistemas de procesado digital en VHDL. Esta práctica se apoya sobre el trabajo realizado en el año anterior en el *Laboratorio de Sistemas Electrónicos Digitales*, donde se realizó este sistema utilizando un microcontrolador.

El esquema de dicho sistema puede verse en la figura 1. El proyecto que nos ocupa se centrará en la realización del subsistema de procesado digital de audio, cuyo esquema puede verse en la figura 2.

Para la realización del proyecto se ha utilizado la herramienta ModelSim. De forma auxiliar, se utilizará la herramienta MATLAB para el tratamiento de las señales obtenidas de forma sencilla y eficiente, para poder así evaluar el funcionamiento del sistema.

## 1.1. Descripción de los módulos VHDL

El subsistema digital representado en la figura 2 se va a dividir en los siguientes módulos principales VHDL:

Banco de filtros Este módulo incluye los 7 filtros digitales que separarán la señal de entrada en sus diferentes bandas de frecuencia. Incluye 7 submódulos correspondientes a los 7 filtros digitales. Además, este módulo ofrece la funcionalidad de selección de ganancia, como se explicará posteriormente.

Módulo de reverberación Este módulo sirve para retardar y atenuar una señal. Se utilizará para realimentar en el banco de filtros la salida retardada hasta la entrada, para generar un efecto de reverberación. El subsistema de retardo se ha implementado independientemente como un submódulo.

Vúmetro Proporciona información sobre el nivel de señal de cada una de las bandas de audio. Consiste en 7 elementos vúmetro individuales que se agrupan para obtener el vúmetro de 7 bandas.



Figura 1: Descripcción del sistema completo

Todo ello se ha agrupado en un único módulo *ecualizador*, para facilitar la simulación y la ejecución de pruebas. La relación de módulos y señales puede verse en la figura 3.

Por último, se han implementado sumadores y multiplicadores con las estructuras estudiadas en clase. Como mejora, se han sustituido las operaciones de suma y multiplicación de señales en el sistema mediante funciones VHDL (operadores + y \*) por sumas y productos obtenidos mediante sumadores y multiplicadores más realistas.



Figura 2: Descripcción del subsistema de procesado digital



Figura 3: Relación de módulos VHDL

| Banda | $f_0$ | $f_{c1}$ | $f_{c2}$ |  |  |
|-------|-------|----------|----------|--|--|
| 0     | 31.25 | 22.10    | 44.19    |  |  |
| 1     | 62.5  | 44.19    | 88.39    |  |  |
| 2     | 125   | 88.39    | 176.78   |  |  |
| 3     | 250   | 176.78   | 353.55   |  |  |
| 4     | 500   | 323.55   | 704.11   |  |  |
| 5     | 1000  | 707.11   | 1414.21  |  |  |
| 6     | 2000  | 1414.21  | 2828.43  |  |  |

Cuadro 1: Descripción de las distintas bandas y sus filtros asociados

#### 2. Diseño de banco de filtros

El sistema propuesto se trata de un ecualizador de audio, por lo que las señales de entrada que tendremos estarán comprendidas en el rango de frecuencias audibles por el hombre. En concreto, la especificación del sistema propuesto propone señales cuya frecuencia estará comprendida aproximadamente entre los 22 Hz y los 2.8 KHz.

Este rango de frecuencias se dividirá en 7 bandas, para lo cual utilizaremos filtros IIR de segundo orden. Las bandas de frecuencias se detallan en la tabla 2, y los coeficientes para la realización de los filtros IIR en la tabla 2.

# 2.1. Implementación de los filtros en VHDL

Para una implementación más sencilla de los filtros, utilizaremos la *Forma directa II*. El detalle de esta implementación se puede ver en la figura 4.

A la hora de implementar estos filtros digitales, tenemos que tener en cuenta una limitación muy importante. Debemos definir un ancho de palabra fijo para la representación de las señales de entrada y de salida. En nuestro caso, hemos escogido un ancho de palabra de 16 bits, correspondientes a 6 bits enteros y 10 bits fraccionarios. Esto es especialmente conveniente a la hora de representar los coeficientes de los filtros, ya que para todos ellos tenemos que  $a_0 = 1024$ . Normalizar los coeficientes realizando una división por 1024 equivale a desplazar los bits 10 lugares a la derecha (o lo que es lo mismo, la coma decimal 10 lugares a la izquierda). De esta forma, cuando representemos los coeficientes enteros como palabras binarias de 16 bits, bastará como tomar los 10 bits menos significativos

| Filtro | Ganancia | $a_0$ | $a_1$ | $a_2$ | $b_0$ | $b_1$ | $b_2$ |
|--------|----------|-------|-------|-------|-------|-------|-------|
| 0      | 8        | 1024  | -2029 | 1006  | 1024  | 0     | -1024 |
| 1      | 17       | 1024  | -2011 | 988   | 1024  | 0     | -1024 |
| 2      | 34       | 1024  | -1970 | 955   | 1024  | 0     | -1024 |
| 3      | 66       | 1024  | -1878 | 890   | 1024  | 0     | -1024 |
| 4      | 125      | 1024  | -1660 | 772   | 1024  | 0     | -1024 |
| 5      | 227      | 1024  | -1115 | 569   | 1024  | 0     | -1024 |
| 6      | 392      | 1024  | 141   | 239   | 1024  | 0     | -1024 |

Cuadro 2: Descripción de los coeficientes de los filtros IIR

como fraccionarios para tener el coeficiente normalizado a 1024.

#### 2.2. Ruido de cuantificación

El haber elegido un ancho de palabra de 16 bits con 6 bits enteros y 10 fraccionarios nos impone una limitación considerable en cuanto a la resolución de nuestro sistema a la hora de representar señales. Sobretodo en señales de amplitud baja, tendremos un ruido de cuantificación que puede llegar a influir en el correcto funcionamiento de nuestro sistema.

Para intentar minimizar el ruido de cuantificación, se puede intentar ajustar más el numero de bits enteros, ya que las señales con las que trabajaremos estan normalizadas a 1, y a priori debería bastarnos con un bit entero y 15 fraccionarios. Este enfoque se ha intentado realizar sin éxito en la implementación, ya que aunque las señales de entrada esten normalizadas a 1, en puntos intermedios de los filtros algunas señales pueden tomar valores más altos, produciendo desbordamiento. Por ello, se ha decidido tomar una postura más conservadora y mantener la representación con 10 bits fraccionarios, que aunque no es óptima en sentido del ruido de cuantificación, nos ofrece mayor seguridad frente a desbordamiento.

Otra forma de abordar este problema sería utilizar palabras de 32 bits en lugar de 16. Esto nos ofrecería una resolución enormemente mayor, mejorando sensiblemente la calidad del sistema. No obstante, trabajar con palabras de 32 bits supone una complejidad mucho mayor a la hora de implementar los sumadores y multiplicadores vistos en clase. Debido a que el objetivo del proyecto es mayormente didáctico y no obtener una calidad de audio excepcional, se ha decidido mantener



Figura 4: Diagrama de bloques de un filtro IIR de segundo orden

las palabras de 16 bits y asumir los efectos del ruido de cuantificación.

### 2.3. Ajuste de ganancias

Además de separar la señal en 7 bandas de frecuencias, el banco de filtros de nuestro sistema debe aplicar a cada uno una ganancia ajustable y disponer a la salida de la señal global sumada.

La selección de ganancia para cada banda se realiza mediante 3 entradas adicionales:

Entrada f\_sel Entrada de 3 bits mediante la cual seleccionamos el filtro (de 0 a 6) cuya ganancia queremos ajustar.

Entrada g\_sel Entrada de 4 bits mediante la cual seleccionamos la ganancia que queremos aplicar al filtro seleccionado. Estas ganancias se encuentran definidas en el propio sistema en forma de tabla, de forma que a cada uno de los valores 0 a 15 le corresponde un valor de ganancia predefinido.

Entrada g\_en Señal de *enable* del sistema de selección de ganancia. Cuando se detecta un flanco de subida se aplica la ganancia seleccionada al filtro seleccionado.

Para evitar desbordamiento en la señal al aplicar la ganancia, trabajaremos con posibles valores de ganancia menores que 1 (atenuaremos la señal). De esta forma, la ganancia numero 0 corresponde a una ganancia de 0dB, y de ahí se irá bajando a medida que aumente el índice de la ganancia seleccionada.

#### 3. Diseño de módulo de reverberación

El subsistema de reverberación consiste en un módulo que ofrece a la salida la señal que obtiene a la entrada con un retraso de N posiciones y aplicandole una atenuación determinada.

Para la implementación de este módulo se ha utilizado como base una cola FIFO, en la cual se va introduciendo la señal que posteriormente se va obteniendo por la salida tras N ciclos de reloj. Para ello es importante inicializar la cola para que esté llena de palabras a cero, ya que si no la primera muestra de la señal de entrada ocuparía la primera posición y sería la que se ofrecería a la salida en el siguiente ciclo de reloj.

En nuestro sistema, el numero de palabras en la cola será siempre fijo e igual al número de muestras que queramos retrasar la señal. La implementación de una cola FIFO tiene cierta complejidad derivada del hecho de que el numero de palabras en la cola es variable y puede ser impredecible, conllevando posibles problemas de desbordamiento o cola vacía. Sin embargo, puesto que el funcionamiento de nuestro retardador es mucho más predecible (llegará una muestra por cada ciclo de reloj y sacaremos una muestra por cada ciclo de reloj, resultando en un tamaño constante) podemos simplificar considerablemente este diseño.

Se ha implementado para ello el subsistema delay, que consiste en una memoria de N posiciones (tamaño configurable mediante genéricos) con un puntero señalando a una de esas posiciones. En cada ciclo de reloj, se sacará la señal de la posición indicada por el puntero y se añadirá en su lugar la señal que llegue a la entrada. El valor del puntero se va aumentando de forma cíclica, de forma que la señal que acabamos de introducir no se sacará hasta que el puntero vuelva a apuntar a esa misma posición, es decir, tras N ciclos de reloj.

Posteriormente, la señal se atenúa mediante un valor de ganancia también configurable mediante genéricos, y se realimenta a la entrada del banco de filtros.

#### 4. Diseño de vúmetro

El vúmetro ofrece información sobre el nivel de señal disponible en cada una de las bandas de señal. Para abordar la implementación de este módulo, se ha implementado un subsistema vúmetro con úna única entrada que ofrece el nivel de la señal que tenga a la entrada. Estos vúmetros individuales se agrupan en un módulo vúmetro de 7 entradas, que conectaremos a la salida de cada uno de los filtros del banco de filtros.

Cada uno de los vúmetros individuales generan a la salida una señal de 8 bits, simulando los leds que tradicionalmente se utilizan en estos sistemas. El número de bits que se pongan a 1 en la señal (leds que se iluminan) indicará el nivel de la

señal en esa banda.

Para detectar el nivel de la señal, observaremos la palabra a nivel binario. Una palabra de la señal está representada de la siguiente forma:

$$X_{15}X_{14}X_{13}X_{12}X_{11}X_{10}X_{9}X_{8}X_{7}X_{6}X_{5}X_{4}X_{3}X_{2}X_{1}X_{0}$$

Definiremos cada uno de los 8 niveles de señal dividiendo los 16 bits en conjuntos de dos. Así, el nivel 0 corresponderá a todos los bits a 0, el nivel 1 se alcanzará cuando sólo los bits  $X_1$  o  $X_0$  estén a nivel alto, el nivel 2 si los bits  $X_4$  o  $X_3$  están a 1, y así sucesivamente. cada uno de estos niveles *encenderá* a la salida el led correspondiente a su nivel además de todos los de los niveles anteriores.

Para tener en cuenta las posibles palabras negativas en complemento a dos, es importante tener en cuenta que debemos observar siempre el valor absoluto de las señales, ya que si no siempre obtendríamos el nivel más alto para cualquier entrada negativa.

#### 4.1. Mantenimiento del nivel

Debido a las posibles variaciones rápidas de la señal, es importante que los picos a la salida del vúmetro se mantengan un mínimo tiempo para su correcta visualización.

Para implementar este comportamiento, se ha definido el siguiente procedimiento:

- 1. Se toma una muestra a la entrada y se mantiene en memoria
- 2. Se inicia un contador (configurable mediante genéricos) que indica el tiempo mínimo que se han de mantener los niveles a la salida
- 3. Si a la entrada llega alguna muestra mayor a la que tenemos en memoria, se sustituye y se reinicia el contador, comenzando el proceso desde el principio.
- 4. Si el contador llega a cero, se elimina la señal de memoria, permitiendo que otras señales más bajas tomen el lugar de la muestra. En este punto el pico anterior deja de mantenerse y el nivel del vúmetro puede bajar
- 5. La siguiente muestra entra en memoria y se reinicia el proceso

Esto nos permite mantener de forma sencilla los niveles un mínimo de tiempo en pantalla sin perder información de posibles picos que puedan aparecer mientras estamos manteniendo la señal.

# 5. Mejoras

Para la aplicación de los conocimientos obtenidos en la asignatura *Diseño de Circuitos y Sistemas Electrónicos*, se ha propuesto la realización de varias modificaciones que se corresponden con lo estudiado en la parte digital de la asignatura.

En concreto, se ha propuesto la implementación de sumadores y multiplicadores binarios, correspondiendose con las configuraciones estudiadas en clase. Estas implementaciones se han de realizar a bajo nivel, mediante la conexión y configuración de *Full Adders*, ilustrando además los efectos de retardo en cada una de las distintas configuraciones.

En concreto, se han implementado las siguientes configuraciones:

- Sumador ripple carry
- Sumador carry bypass
- Multiplicador en array
- Multiplicador carry save

Se ha supuesto para ello un retardo en los *Full Adder* fijo de 1 ns, tanto en la generación de la señal de suma como en la señal de carry. Esto nos permite observar el efecto de los distintos caminos críticos en el retardo en la generación de las señales.

## 5.1. Sumador Ripple Carry

Este sumador es el más sencillo en términos de implementación. Simplemente se han conectado 16 full adders de forma secuencial de forma que el acarreo se propague de uno a otro.

En la figura 5 se muestra un esquema simplificado (4 bits) de este sumador.

# 5.2. Sumador Carry Bypass

El sumador Carry Bypass (o Carry Skip) permite reducir el tiempo de retardo del camino crítico sensiblemente. En la figura ?? puede verse un esquema de este tipo de sumador.

Para la implementación de este tipo de sumadores, se divide la operación en varios bloques. En el esquema de la figura ?? estos bloques son de 4 bits, aunque se puede variar el tamaño de los mismos para optimizar aún más el retardo de este sumador.

En la figura 6 puede verse un detalle de los bloques carry bypass.



Figura 5: Sumador Ripple Carry de 4 bits



Figura 6: Bloque carry bypass

En nuestro diseño, se ha optado por un tamaño de bloque de 4 bits, lo que resulta en un total de 4 bloques carry bypass para obtener el sumador completo. Para trabajar con las señales P y G que se han explicado en teoría, se ha implementado una versión modificada del full adder que trabaja con las señales P y G en lugar de los sumandos originales.

## 5.3. Multiplicador en array

El multiplicador en array corresponde a la implementación más directa de una multiplicación binaria. Para ello, simplemente se generan los productos parciales y se van sumando en distintas filas de sumadores. Esto conlleva un retardo considerablemente alto, que como podremos ver, se puede reducir mediante otras configuraciones de multiplicadores.

En la figura 7 se puede ver un esquema general de un multiplicador en array. Para un multiplicador de 16 x 16 bits como el que necesitamos en nuestro sistema, tendríamos que utilizar un total de 256 full adders. Debido a que esta cantidad es inmanejable a la hora de realizar conexiones de señales en VHDL, se ha optado por dividir la estructura del multiplicador en filas de 16 full adders, de forma que solo tengamos que diseñar una fila y después tratar con 16 filas. El diseño de estas filas (bloques de multiplicador en array) puede verse en la figura 8. Es importante destacar que esta agrupación en filas no conlleva ninguna modificación en el funcionamiento del multiplicador, y que equivale exactamente a haber conectado entre si los 256 full adders en un único módulo.

Para realizar multiplicaciones con signo, se calcula previamente el signo del resultado mediante un XOR de los MSB de los factores. Posteriormente se realiza la multiplicación del valor absoluto de los factores, invirtiendose posteriormente el signo del resultado si se espera un resultado negativo.



Figura 7: Multiplicador en array



Figura 8: Bloque de multiplicador en array

#### 5.4. Multiplicador carry save

El multiplicador carry save es una estrucutra de multiplicador modificada que permite reducir el tiempo de retardo en la generación del producto. Para ello, los acarreos de una fila de full adders no son propagados dentro de una misma fila, sino que se propagan a la fila siguiente como un sumando adicional.

El esquema de este tipo de multiplicador puede verse en la figura 9.



Figura 9: Multiplicador carry save

De forma análoga a lo que sucede con el multiplicador en array, realizar un multiplicador carry save de 16x16 bits conlleva la utilización de un número inmanejable de full adders. Para evitar este problema, se ha optado por una solución similar a la tomada para la implementación del multiplicador en array: dividir el sistema en bloques para cada fila de full adders.

El diseño elegido para estos bloques puede verse en la figura 10

Para realizar multiplicaciones con signo, se calcula previamente el signo del resultado mediante un XOR de los MSB de los factores. Posteriormente se realiza la multiplicación del valor absoluto de los factores, invirtiendose posteriormente el signo del resultado si se espera un resultado negativo.



Figura 10: Bloque del multiplicador carry save

# 6. Pruebas y resultados

En esta sección se van a describir los procedimientos utilizados para evaluar el funcionamiento de los sistemas implementados

#### 6.1. Comprobación del funcionamiento de los filtros

Para comprobar el correcto funcionamiento de los filtros, se ha comparado la respuesta al impulso obtenida en la simulación del sistema VHDL con la respuesta al impulso teórica que debería tener un filtro IIR con los coeficientes indicados en las especificaciones.

Es importante tener en cuenta que al aplicar la atenuación a la salida de los filtros (para que todas las bandas presenten una ganancia de 0dB) se aumenta considerablemente el ruido de cuantificación de la señal de salida. Para evitar este efecto a la hora de comprobar la correcta realización del filtro, se van a comparar las respuestas al impulso sin aplicar la atenuación en primer lugar, y posteriormente aplicándola.

Las gráficas detalladas con los resultados de esta prueba se encuentran en el apéndice A.

Observando los resultados, se puede ver que las respuestas al impulso que se observa sin atenuar la salida de los filtros corresponde bastante bien con la respuesta teórica esperada (calculada con MATLAB). No obstante, si observamos las respuestas al impulso con la salida atenuada, vemos que el ruido de cuantificación es considerablemente alto, especialmente en los filtros de frecuencias bajas.

Debido a que esta atenuación se aplica a la entrada (para evitar saturación en puntos intermedios) este ruido nos afecta también a los valores de realimentación dentro de la estructura del filtro, lo que nos modifica la forma de la respuesta al impulso en los filtros 0 y 1.

El diseño de los filtros es correcto, como se observa en las respuestas al impulso sin atenuar. El funcionamiento pobre de los filtros 0 y 1 se debe por tanto únicamente al error de cuantificación, y por tanto para mejorar el funcionamiento en este aspecto debería trabajarse con un mayor tamaño de palabra.

#### 6.2. Prueba de la función de reverb

Para comprobar el funcionamiento de la función de reverb se ha realizado una prueba sencilla. Se ha generado un estímulo de entrada de corta duración (un periodo de una señal sinusoidal) y se ha ajustado el número de muestras del retardo de reverberación para que el eco se produzca justo después de finalizar la señal original, pudiendo así apreciarse mejor.

Se ha comparado la señal obtenida con la función de reverb activada con la obtenida con la función de reverb desactivada. Mientras que en la señal filtrada sin reverb se pueden apreciar únicamente pequeñas oscilaciones derivadas de la respuesta de los filtros tras el ciclo sinusoidal de la señal original, en la señal con reverb se pueden apreciar claramente réplicas atenuadas de este ciclo a lo largo del tiempo.

Las gráficas que muestran este resultado pueden verse en el apéndice B.

#### 6.3. Prueba de ajuste de ganancia

Para comprobar el funcionamiento de la función de ajuste de ganancia se ha observado la evolución de la señal de salida mientras se va modificando la ganancia. Para ilustrar este funcionamiento, se ha tomado una señal sinusoidal centrada en la frecuencia del filtro 3, y se ha ido aumentando la atenuación progresivamente en las bandas 2, 3 y 4. En la salida puede verse claramente como la señal va atenuandose a medida que vamos variando la ganancia.

Observar de forma gráfica la evaluación temporal de la señal es la forma más adecuada de comprobar este funcionamiento. Las gráficas que muestran este resultado pueden verse en el apéndice C.

#### 6.4. Prueba de mejoras

Para comprobar el funcionamiento de los sumadores y multiplicadores se han realizado varias operaciones y se ha comparado el resultado que ofrecían nuestros sumadores y multiplicadores con el que resultaría de utilizar las funciones + y \* de VHDL. Se pretende así comprobar que el uso de nuestros bloques operacionales corresponde exactamente al uso de las funciones VHDL. Para ello se ha elegido un conjunto de señales de prueba a sumar, teniendo cuidado en comprobar las operaciones con señales negativas.

Los resultados son satisfactorios y se obtienen en todo caso los valores esperados.

En las gráficas incluidas en el apéndice D puede observarse la comparación de estas señales.

#### Observación sobre retardos

Como es de esperar, al utilizar nuestros sumadores y multiplicadores implementados con Full Adders con retardo, observamos los efectos de la propagación de las señales de suma y de acarreo. Esto se traduce en una oscilación en los valores del resultado que ofrecen nuestros bloques, que tarda unos nanosegundos en estabilizarse y ofrecer el valor correcto.

Este efecto se elimina del resto del sistema mediante el uso de una señal de reloj. Utilizando un periodo de reloj mayor que el necesario para la generación de las sumas y multiplicaciones evitamos estas oscilaciones. En la simulación se ha establecido un periodo de reloj de 100ns, suficientemente alto ya que el retardo de los full adders es de 1 ns.

En las gráficas incluidas en el apéndice D puede además verse la diferencia en el retardo de las diferentes configuraciones. Así, observamos como el sumador ripple carry en muchas ocasiones tarda sensiblemente más en estabilizar su resultado que el sumador carry bypass. También se observa esta diferencia en los multiplicadores. El multiplicador carry save tiene un retardo sensiblemente mejor que el del multiplicador en array. Esto corresponde con lo estudiado en teoría en clase.

# **Apéndices**

# A. Gráficas de evaluación de filtros

Estas gráficas corresponden a los resultados de los procedimientos descritos en la sección  $6.1\,$ 

# A.1. Sin aplicar atenuación



Figura 11: Comprobación del filtro 0



Figura 12: Comprobación del filtro 1



Figura 13: Comprobación del filtro 2



Figura 14: Comprobación del filtro 3



Figura 15: Comprobación del filtro 4



Figura 16: Comprobación del filtro 5



Figura 17: Comprobación del filtro 6

# A.2. Aplicando atenuación



Figura 18: Comprobación del filtro 0 (con atenuación)



Figura 19: Comprobación del filtro 1 (con atenuación)



Figura 20: Comprobación del filtro 2 (con atenuación)



Figura 21: Comprobación del filtro 3 (con atenuación)



Figura 22: Comprobación del filtro 4 (con atenuación)



Figura 23: Comprobación del filtro 5 (con atenuación)



Figura 24: Comprobación del filtro 6 (con atenuación)

# B. Gráficas de evaluación de reverb



Figura 25: Comprobación de la función reverb

# C. Gráficas de evaluación de ajuste de ganancia



Figura 26: Comprobación del ajuste de ganancia

# D. Gráficas de prueba de mejoras

#### D.1. Sumadores

En la gráfica que se presenta a continuación se pueden observar las siguientes señales:

Valid\_rc Esta señal se pone a nivel alto cuando el resultado del sumador ripple carry es válido.

Valid\_cb Esta señal se pone a nivel alto cuando el resultado del sumador carry bypass es válido.

sig1 Término 1 de la suma.

sig2 Término 2 de la suma.

sout\_rc Resultado del sumador ripple carry.

sout\_cb Resultado del sumador carry bypass.

sout\_ts Resultado de la función + VHDL

En las señales valid\_rc y valid\_cb se observa la diferencia entre los tiempos de retardo de ambos sumadores.



Figura 27: Comprobación de sumadores

# D.2. Multiplicadores

En la gráfica que se presenta a continuación se pueden observar las siguientes señales:

Valid\_ar Esta señal se pone a nivel alto cuando el resultado del multiplicador en array es válido.

Valid\_cs Esta señal se pone a nivel alto cuando el resultado del multiplicador carry save es válido.

signal1 Factor de la multiplicación.

signal2 Factor de la multiplicación.

mult\_cs Resultado del multiplicador carry save.

mult\_ar Resultado del multiplicador en array.

mult\_test Resultado de la función \* VHDL

En las señales valid\_ar y valid\_cs se observa la diferencia entre los tiempos de retardo de ambos multiplicadores.



Figura 28: Comprobación de multiplicadores