

Tecnológico de Costa Rica  
Escuela de Ingeniería Electrónica



**Unidad de linealización y normalización para un estimador de  
parámetros de uso en un sistema de optimización de energía en  
paneles fotovoltaicos**

Informe de Proyecto de Graduación para optar por el título de  
Ingeniero en Electrónica con el grado académico de Licenciatura

Adrián Ignacio Cervantes Segura

Borrador de 29 de mayo de 2016



Declaro que el presente Proyecto de Graduación ha sido realizado enteramente por mi persona, utilizando y aplicando literatura referente al tema e introduciendo conocimientos propios.

En los casos en que he utilizado bibliografía he procedido a indicar las fuentes mediante las respectivas citas bibliográficas. En consecuencia, asumo la responsabilidad total por el trabajo de graduación realizado y por el contenido del correspondiente informe final.

Adrián Ignacio Cervantes Segura

Cartago, 29 de mayo de 2016

Céd: 1-1508-0317



Instituto Tecnológico de Costa Rica  
Escuela de Ingeniería Electrónica  
Proyecto de Graduación  
Tribunal Evaluador

Proyecto de Graduación defendido ante el presente Tribunal Evaluador como requisito para optar por el título de Ingeniero en Electrónica con el grado académico de Licenciatura, del Instituto Tecnológico de Costa Rica.

Miembros del Tribunal

---

M.Sc. Leonardo Rivas Arce  
Profesora Lector

---

Ing. Leonardo Sandoval  
Profesor Lector

---

Dr. Alfonso Chacón Rodríguez  
Profesor Asesor

Los miembros de este Tribunal dan fe de que el presente trabajo de graduación ha sido aprobado y cumple con las normas establecidas por la Escuela de Ingeniería Electrónica.

Cartago, 25 de marzo de 2016



Instituto Tecnológico de Costa Rica  
Escuela de Ingeniería Electrónica  
Proyecto de Graduación  
Tribunal Evaluador  
Acta de Evaluación

Proyecto de Graduación defendido ante el presente Tribunal Evaluador como requisito para optar por el título de Ingeniero en Electrónica con el grado académico de Licenciatura, del Instituto Tecnológico de Costa Rica.

Estudiante: Adrián Ignacio Cervantes Segura

Nombre del Proyecto: *Unidad de linealización y normalización para un estimador de parámetros de uso en un sistema de optimización de energía en paneles fotovoltaicos*

Miembros del Tribunal

---

M.Sc. Leonardo Rivas Arce  
Profesora Lector

---

Ing. Leonardo Sandoval  
Profesor Lector

---

Dr. Alfonso Chacón Rodríguez  
Profesor Asesor

Los miembros de este Tribunal dan fe de que el presente trabajo de graduación ha sido aprobado y cumple con las normas establecidas por la Escuela de Ingeniería Electrónica.

Nota final del Proyecto de Graduación: \_\_\_\_\_

Cartago, 25 de marzo de 2016



# Resumen

En esta tesis se presenta el diseño de un linealizador de corriente descrito en lenguaje VHDL, basado en el estándar para aritmética de coma flotante de IEEE 754 para microprocesadores, para el cual se utiliza el formato binario de precisión simple de 32 bits, utilizando el algoritmo de CORDIC para realizar la operación logaritmo natural. Por otro lado se realiza un convertidor de formato IEEE 754 coma flotante a coma fija, ambos en 32 bits, por último se normaliza el dato en coma fija, esta normalización se aplica tanto en corriente como en tensión. Estos circuitos serán utilizados en un sistema de aumento de eficiencia para suministros de paneles fotovoltaicos. Este linealizador cuenta con la capacidad para realizar operaciones aritméticas en coma flotante, lo cual es fundamental para una mejor precisión y desempeño del sistema en el procesamiento de los datos, ha sido diseñado considerando los parámetros de velocidad, área utilizada dentro de la FPGA y consumo de potencia estimada, además el circuito ha sido sintetizado y simulado sobre la FPGA Virtex® 7 de la familia Xilinx®. El circuito se interconectó en un diagrama esquemático principal para mayor facilidad de incorporación de los bloques de control, entradas y salidas.

**Palabras clave:** Aritmética Binaria, Formato IEEE 754, coma fija, FPGA, VHDL.



# Abstract

This thesis presents the design of a current linearizer described in VHDL language based on the standard for Arithmetic floating Point IEEE-754 for microprocessors and the binary format used is single-precision 32-bit, using CORDIC algorithm to perform the operation. On the other hand a converter IEEE 754 floating point to fixed point, both in 32 bits, finally the data is normalized in fixed point, this normalization is applied to both current and voltage. These circuits will be used in a system for increased efficiency of supplies photovoltaic panels. This linearizer has the ability to perform arithmetic floating point operations, which is critical for better accuracy and performance of the system in data processing, it has been designed considering the parameters of speed, area used within the FPGA and consumption estimated power addition the circuit has been synthesized and simulated on FPGA Xilinx® Virtex® 7 family. The circuit has been interconnected in a main schematic diagram for easy incorporation of control blocks, inputs, outputs.

**Keywords:** Binary arithmetic, IEEE 754 Format, Fixed point, FPGA, VHDL.

*a mis queridos padres*

# Agradecimientos

En primer lugar a Dios, quién me ha dado sabiduría y ha sido un pilar importante a lo largo de esta carrera.

Al Ing. Alfonso Chacón Rodríguez, quién ha sido un gran apoyo en el desarrollo del proyecto y en cursos a lo largo de la carrera, por los consejos, paciencia, conocimiento compartido y su nivel de profesionalismo.

A mi familia, por apoyarme a lo largo de toda mi educación, por la ayuda y por los grandes sacrificios que ha hecho para poder llegar donde estoy hoy, por los valores y por toda la ayuda que me han dado en todos estos años.

Finalmente, agradezco a las personas que de una u otra forma me han apoyado a lo largo del proceso.

Adrián Ignacio Cervantes Segura

Cartago, 29 de mayo de 2016



# Índice general

|                                                                                                                              |           |
|------------------------------------------------------------------------------------------------------------------------------|-----------|
| Índice de figuras                                                                                                            | iii       |
| Índice de tablas                                                                                                             | vii       |
| <b>1 Introducción</b>                                                                                                        | <b>1</b>  |
| 1.1 Entorno del proyecto . . . . .                                                                                           | 1         |
| 1.2 Descripción del problema y justificación . . . . .                                                                       | 2         |
| 1.3 Síntesis del problema . . . . .                                                                                          | 2         |
| 1.4 Enfoque de la solución . . . . .                                                                                         | 2         |
| 1.5 Meta . . . . .                                                                                                           | 4         |
| 1.6 Objetivos y estructura . . . . .                                                                                         | 5         |
| 1.6.1 Objetivo general . . . . .                                                                                             | 5         |
| 1.6.2 Objetivos específicos . . . . .                                                                                        | 5         |
| 1.6.3 Estructura . . . . .                                                                                                   | 5         |
| <b>2 Marco teórico</b>                                                                                                       | <b>7</b>  |
| 2.1 Descripción . . . . .                                                                                                    | 7         |
| 2.2 Panel Fotovoltaico . . . . .                                                                                             | 7         |
| 2.2.1 Curvas Corriente-Tensión(I-V) para un PV . . . . .                                                                     | 8         |
| 2.2.2 Modelos del panel fotovoltaico . . . . .                                                                               | 8         |
| 2.3 Algoritmo de CORDIC . . . . .                                                                                            | 11        |
| 2.3.1 Sistema de coordenadas hiperbólico . . . . .                                                                           | 12        |
| 2.3.2 Logaritmo natural utilizando el algoritmo hiperbólico de CORDIC .                                                      | 12        |
| 2.3.3 Exponencial utilizando el algoritmo hiperbólico de CORDIC . . .                                                        | 13        |
| 2.4 Coma flotante . . . . .                                                                                                  | 14        |
| 2.5 Coma fija . . . . .                                                                                                      | 14        |
| <b>3 Sistema de linealización</b>                                                                                            | <b>17</b> |
| 3.1 Algoritmo de CORDIC hiperbólico implementado en software . . . . .                                                       | 17        |
| 3.2 Sistema de linealización implementado en hardware (CORDIC) . . . . .                                                     | 19        |
| 3.3 Diseño e implementación del coprocesador de linealización por medio del<br>algoritmo de CORDIC . . . . .                 | 20        |
| 3.4 Sistema de control para la unidad de coprocesamiento CORDIC por medio<br>de un máquina de estados finita (FSM) . . . . . | 25        |

|                                                                                                                                                             |           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| 3.5 Algoritmo de CORDIC implementado en verilog para una placa de desarrollo nexys-4 . . . . .                                                              | 26        |
| 3.6 Simulación del circuito linealizador con algoritmo de CORDIC . . . . .                                                                                  | 27        |
| 3.6.1 Resultados de la simulación del rango de convergencia del circuito linealizador CORDIC . . . . .                                                      | 27        |
| <b>4 Sistema de conversión coma flotante a coma fija y normalización</b>                                                                                    | <b>33</b> |
| 4.1 Diseño del sistema de conversión, normalización y control . . . . .                                                                                     | 33        |
| 4.2 Convertidor coma flotante - coma fija y normalizador . . . . .                                                                                          | 35        |
| 4.3 Control para el convertidor coma flotante - coma fija y normalizador . . . . .                                                                          | 38        |
| 4.4 Sistema de conversión-normalización implementado en verilog para una placa de desarrollo nexys-4 . . . . .                                              | 39        |
| 4.5 Resultados de la simulación post-síntesis del sistema de conversión-normalización                                                                       | 39        |
| <b>5 Sistema de linealización, conversión coma flotante a coma fija y normalización</b>                                                                     | <b>45</b> |
| 5.1 Sistema para realizar las pruebas en una placa de desarrollo Nexys-4 . . . . .                                                                          | 47        |
| 5.2 Simulación del sistema de linealización, conversión coma flotante a coma fija y normalización, implementado en hardware mediante verilog . . . . .      | 49        |
| 5.3 Resultados del sistema de linealización, conversión coma flotante a coma fija y normalización implementado en una placa de desarrollo nexys-4 . . . . . | 50        |
| 5.4 Recursos utilizados . . . . .                                                                                                                           | 56        |
| 5.5 Reporte de tiempos . . . . .                                                                                                                            | 56        |
| 5.6 Consumo de potencia . . . . .                                                                                                                           | 56        |
| <b>6 Conclusiones y recomendaciones</b>                                                                                                                     | <b>59</b> |
| 6.1 Conclusiones . . . . .                                                                                                                                  | 59        |
| 6.2 Recomendaciones . . . . .                                                                                                                               | 59        |
| <b>7 bibliográficas</b>                                                                                                                                     | <b>61</b> |

# Índice de figuras

|     |                                                                                                                                                                                                         |    |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 1.1 | Diagrama de solución para el sistema completo para aumentar la eficiencia de los paneles fotovoltaicos por medio de un linealizador, estimador de parámetros, deslinealizador. . . . .                  | 3  |
| 1.2 | Diagrama de solución para el sistema de linealización y normalización, con entradas de corriente y tensión del panel fotovoltaico y salidas de corriente y tensión linealizadas y normalizadas. . . . . | 4  |
| 2.1 | Curva característica de corriente(A)-tensión(V) para un panel fotovoltaico . . . . .                                                                                                                    | 8  |
| 2.2 | Modelo simple ideal para un panel fotovoltaico, compuesto por un diodo y una fuente de corriente . . . . .                                                                                              | 9  |
| 2.3 | Modelo para un panel fotovoltaico, compuesto por un diodo, una fuente de corriente, perdidas resistivas por cada celda . . . . .                                                                        | 9  |
| 2.4 | Formato IEEE 754 coma flotante para 32 bits . . . . .                                                                                                                                                   | 14 |
| 2.5 | Formato para un número en coma fija . . . . .                                                                                                                                                           | 15 |
| 3.1 | Algoritmo de CORDIC en Python . . . . .                                                                                                                                                                 | 18 |
| 3.2 | Bloque principal de linealización: Entradas y salidas para la unidad logaritmo natural basada en el algoritmo de CORDIC e implementado en hardware . . . . .                                            | 19 |
| 3.3 | Sistema de linealización: Coprocesador coma flotante de 32bits basado en el algoritmo de CORDIC y una máquina de estados finita como control . . . . .                                                  | 19 |
| 3.4 | Coprocesador segmentado para el cálculo de una función logarítmica con el algoritmo de CORDIC en hardware . . . . .                                                                                     | 21 |
| 3.5 | Circuito de comparación de signo actual $\delta$ , para las variables $X_{i+1}$ , $Y_{i+1}$ y $Z_{i+1}$ de la iteración siguiente, utilizando la tabla 3.1 . . . . .                                    | 23 |
| 3.6 | Máquina de estados finitos para la unidad de coprocesamiento CORDIC . . . . .                                                                                                                           | 25 |
| 3.7 | Simulación del linealizador implementado en Verilog, ingresando en la entrada un archivo de texto, con 1000 valores del intervalo de convergencia para el argumento del logaritmo natural . . . . .     | 26 |
| 3.8 | Datos de salida para la simulación post-sintesis del linealizador, mediante mil valores de entrada dentro del rango de convergencia utilizando 8 iteraciones en el algoritmo de CORDIC . . . . .        | 28 |

|      |                                                                                                                                                                                                                                |    |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 3.9  | Porcentaje de error para los datos de la simulación post-síntesis del linealizador, tomando mil valores de entrada dentro del rango de convergencia y 8 iteraciones para el algoritmo de CORDIC . . . . .                      | 29 |
| 3.10 | Datos de salida para la simulación post-síntesis del linealizador, mediante mil valores de entrada dentro del rango de convergencia utilizando 12 iteraciones en el algoritmo de CORDIC . . . . .                              | 30 |
| 3.11 | Porcentaje de error para los datos de la simulación post-síntesis del linealizador, tomando mil valores de entrada dentro del rango de convergencia y 12 iteraciones para el algoritmo de CORDIC . . . . .                     | 30 |
| 3.12 | Datos de salida para la simulación post-síntesis del linealizador, mediante mil valores de entrada dentro del rango de convergencia utilizando 15 iteraciones en el algoritmo de CORDIC . . . . .                              | 31 |
| 3.13 | Porcentaje de error para los datos de la simulación post-síntesis del linealizador, tomando mil valores de entrada dentro del rango de convergencia y 8 iteraciones para el algoritmo de CORDIC . . . . .                      | 32 |
| 4.1  | Diagrama general de entradas y salidas para el convertidor coma flotante a coma fija y normalizador . . . . .                                                                                                                  | 33 |
| 4.2  | Sistema de conversión, normalización y control utilizando una máquina de estados. Señales de entrada, salida, datos y control. . . . .                                                                                         | 34 |
| 4.3  | Diagrama general del sistema de conversión de coma flotante a coma fija y normalización corriente-tensión . . . . .                                                                                                            | 35 |
| 4.4  | Circuito de conversión coma flotante a coma fija y normalización de corriente y tensión, con un dato de entrada en coma flotante y una salida en coma fija normalizada . . . . .                                               | 36 |
| 4.5  | Sistema de control para el convertidor-normalizador, diseñado mediante una máquina de estados finita . . . . .                                                                                                                 | 38 |
| 4.6  | Simulación del circuito de conversión y normalización, ingresando en la entrada un archivo de texto, con 1000 valores de corriente lineal . . . . .                                                                            | 39 |
| 4.7  | Comparación entre la conversión-normalización de corriente $i_{pv}$ teórica y la simulación post-síntesis del circuito . . . . .                                                                                               | 40 |
| 4.8  | Porcentaje de error entre la conversión-normalización de corriente $i_{pv}$ teórica y experimental del circuito . . . . .                                                                                                      | 41 |
| 4.9  | Comparación entre la conversión-normalización de tensión $V_{pv}$ teórica y la simulación post-síntesis del circuito . . . . .                                                                                                 | 42 |
| 4.10 | Porcentaje de error entre la conversión-normalización de tensión $V_{pv}$ teórica y del circuito . . . . .                                                                                                                     | 42 |
| 5.1  | Diseño general de entradas y salidas para el sistema de linealización, conversión y normalización de corriente y tensión para un panel fotovoltaico .                                                                          | 45 |
| 5.2  | Sistema de linealización, conversión y normalización de corriente y tensión para un panel fotovoltaico, con entradas: corriente $i_{pv}$ y tensión $V_{pv}$ y salidas de corriente y tensión lineales y normalizadas . . . . . | 46 |

|      |                                                                                                                                                                                                                                                                                                                    |    |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 5.3  | Diagrama de flujo general para el ambiente de verificación utilizado en el procesamiento de datos del circuito de linealización, ingresando los datos de entrada por medio de una memoria ROM y enviando los datos de salida por medio de transmisión serial (UART) desde la nexys-4 hacia un computador . . . . . | 47 |
| 5.4  | Sistema de verificación para el linealizador, ingresando los datos de entrada por medio de una memoria ROM y enviando los datos de salida por medio de transmisión serial (UART) desde la nexys-4 hacia un computador . . . . .                                                                                    | 48 |
| 5.5  | Simulación del sistema de linealización-conversión-normalización de corriente y sistema de conversión- normalización de tensión para un panel fotovoltaico . . . . .                                                                                                                                               | 49 |
| 5.6  | Comparación entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 8 iteraciones en el algoritmo de CORDIC del linealizador . . . . .                                                                                                                  | 51 |
| 5.7  | Porcentaje de error entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 8 iteraciones en el algoritmo de CORDIC del linealizador . . . . .                                                                                                          | 52 |
| 5.8  | Comparación entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 12 iteraciones en el algoritmo de CORDIC del linealizador . . . . .                                                                                                                 | 53 |
| 5.9  | Porcentaje de error entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 12 iteraciones en el algoritmo de CORDIC del linealizador . . . . .                                                                                                         | 53 |
| 5.10 | Comparación entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 15 iteraciones en el algoritmo de CORDIC del linealizador . . . . .                                                                                                                 | 54 |
| 5.11 | Porcentaje de error entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 15 iteraciones en el algoritmo de CORDIC del linealizador . . . . .                                                                                                         | 55 |



# Índice de tablas

|     |                                                                                                                                                                                                                                                                                             |    |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 2.1 | Modelos para un PV: ideal, con pérdidas en serie $R_s$ y con pérdidas en paralelo $R_p$ . . . . .                                                                                                                                                                                           | 10 |
| 2.2 | Sistema de coordenadas unificado (CORDIC): circular, linear e hiperbólico.<br>Tomado de [5] . . . . .                                                                                                                                                                                       | 12 |
| 3.1 | Signo $\delta$ de la iteración siguiente para las variables $X_{i+1}$ , $Y_{i+1}$ y $Z_{i+1}$ ,<br>comparando el signo de las variables $X_i$ , $Y_i$ y $Z_i$ contra el signo de $Y_i$<br>invertido . . . . .                                                                               | 22 |
| 3.2 | Comparación de resultados experimentales obtenidos por medio de una<br>simulación post-síntesis, a partir de los valores de entrada del rango de<br>convergencia, utilizando 8, 12 y 15 iteraciones en el algoritmo de CORDIC.<br>CLK=100MHz. . . . .                                       | 28 |
| 4.1 | Comparación de resultados experimentales obtenidos por medio de una<br>simulación post-síntesis, a partir de los valores de entrada de corriente y<br>tensión para el circuito de conversión-normalización. CLK=100MHz . . .                                                                | 40 |
| 5.1 | Comparación de resultados experimentales obtenidos por del sistema de<br>verificación implementado en una placa de desarrollo nexys-4, a partir de<br>los valores de entrada del del modelo del panel y utilizando 8, 12 y 15<br>iteraciones en el algoritmo de CORDIC. CLK=100MHz. . . . . | 51 |
| 5.2 | Resumen del reporte post implementación del uso de dispositivos generado<br>por la herramienta Vivado. . . . .                                                                                                                                                                              | 56 |
| 5.3 | Resumen del reporte post implementación de la potencia estática, dinámica<br>y total, de la herramienta Vivado, para el sistema de linealización-normalización.                                                                                                                             | 56 |
| 5.4 | Resumen del reporte generado por la herramienta Vivado que indica el<br>consumo de potencia de diversos elementos. . . . .                                                                                                                                                                  | 57 |



# Capítulo 1

## Introducción

### 1.1 Entorno del proyecto

Hoy en día es cada vez más común el tema de las energías limpias, dentro de estas: eólica y solar. La instalación de suministros con paneles fotovoltaicos ha llegado a ser una tendencia en Costa Rica, estos suministros son sistemas de autoconsumo de energía, y a su vez son utilizados para comercializar la energía a otras empresas.

Un sistema de abastecimiento de energía solar, requiere de paneles solares, acumuladores de energía, inversores (conversión de corriente continua en corriente alterna) y reguladores, sin embargo actualmente las redes de suministros no cuentan con un sistema regulador de tensión, que se encargue de ubicar el punto de operación de potencia máxima, debido a la variación de la corriente y la tensión del panel con respecto a la temperatura e irradiancia del medio en el que se encuentra, de manera que si la tensión varía, la potencia asociada a esa tensión también varía. El objetivo principal se centra en buscar el punto de tensión donde se obtenga la máxima potencia.

Debido a la importancia de la eficiencia energética en el campo de la electrónica, se desarrolló parte de un sistema en donde se puede aprovechar de una mejor manera la energía, este tema es de suma importancia en la producción de energía, principalmente en los paneles fotovoltaicos, se debe aprovechar las mejores condiciones ambientales y poder acoplar el sistema para una máxima producción de energía. El desarrollo de este proyecto se basa en aumentar la eficiencia del sistema completo para un panel previamente escogido, se utilizará un panel modelo KS10T de la empresa KYOCERA SOLAR, para esto se realizará una realimentación con un dispositivo que regula la tensión máxima que debe tener el panel.

El proyecto linealizador-normalizador se realizó en el Instituto Tecnológico de Costa Rica, Escuela de Ingeniería Electrónica, con el coordinador del SESLab Dr. Carlos Meza, y el coordinador del DCILab Dr. Alfonso Chacón estos laboratorios se encargan de presentar propuestas de sistemas electrónicos de gran utilidad para el desarrollo tecnológico y sostenibilidad, de manera que los recursos sean aprovechados de la mejor forma, brindan

soluciones innovadoras con energías limpias, enfatizándose en el uso de paneles solares, motores eléctricos, circuitos integrados, diseño digital, entre otros.

## 1.2 Descripción del problema y justificación

Anteriormente se realizó un estimador de parámetros por parte de Clevis Lozano estudiante del Instituto Tecnológico de Costa Rica, sin embargo este recibe en la entrada cuantificaciones lineales para calcular los parámetros requeridos. La curva característica  $i_{pv} - V_{pv}$  de una celda solar no tiene un comportamiento lineal, de manera que si se requiere estimar parámetros a partir de la corriente y tensión de este, se deben linealizar-normalizar las entradas y desnormalizar-deslinealizar las salidas. Para el modelo del panel se tienen cuatro tipos de configuraciones desde la más simple a la más compleja, tomando en cuenta las perdidas resistivas de las celdas, paralelas y serie.

El coprocesador numérico a desarrollar, debía satisfacer los siguientes requerimientos:

- Se debe basar en el formato IEEE 754, el cual es un estándar en coma flotante, para realizar operaciones aritméticas.
- Utilizar una arquitectura de 32 bits.
- Utilizar Verilog como lenguaje de descripción de hardware.
- Optimizar las unidades para requerir la menor cantidad de recursos.

## 1.3 Síntesis del problema

¿Cómo realizar la linealización y normalización en formato IEEE 754 para el sistema de optimización de paneles fotovoltaicos?

## 1.4 Enfoque de la solución

Primeramente se realizará un proceso de recopilación de información dentro de temas como: curvas y modelo de un PV, ecuaciones características de los PV, algoritmo de CORDIC, estándar IEEE 754 y operaciones en coma fija. Posteriormente, se utilizará este estándar para iniciar el diseño del linealizador y el normalizador del sistema general del panel fotovoltaico, este se puede observar en la figura 1.1.



**Figura 1.1:** Diagrama de solución para el sistema completo para aumentar la eficiencia de los paneles fotovoltaicos por medio de un linealizador, estimador de parámetros, deslinealizador.



**Figura 1.2:** Diagrama de solución para el sistema de linealización y normalización, con entradas de corriente y tensión del panel fotovoltaico y salidas de corriente y tensión linealizadas y normalizadas.

Para el diseño de los circuitos linealización-normalización de la figura 1.2 se deberá utilizar el diseño modular, ya que se brinda una mejor perspectiva de las etapas del diseño que se debe realizar, primeramente se asignan las entradas y salidas que requiere cada unidad. Una vez ejecutada la primera etapa de diseño se descompone en pequeños bloques funcionales y conexiones entre bloques.

Este diseño modular, se implementará utilizando el lenguaje HDL Verilog, y se verificarán comparando los resultados de un modelo en alto nivel realizado en Python, contra los resultados obtenidos en las simulaciones Post Place & Route.

Por último, se realizarán las pruebas en una FPGA artix-7 para comprobar el funcionamiento del hardware y sus respectivas comparaciones con las simulaciones.

## 1.5 Meta

La meta de este proyecto se basa en aprovechar de la mejor forma energía solar, aumentando la eficiencia del sistema de generación fotovoltaica de los paneles solares, e impulsar la utilización de energías limpias, que contribuyan a reducir las energías que son producidas por medio de hidrocarburos, al ser más caras y mucho más dañinas para el ambiente.

## 1.6 Objetivos y estructura

### 1.6.1 Objetivo general

Desarrollar una unidad de linealización y normalización para un estimador de parámetros Corriente-Tensión de un panel fotovoltaico.

### 1.6.2 Objetivos específicos

- Crear un circuito en formato IEEE 754, que linealice la corriente del modelo de un panel fotovoltaico, por medio de una operación logarítmica, con una corriente exponencial como parámetro de entrada y una corriente lineal ‘y’ en la salida.

*Indicador:* Verificar mediante un programa de alto nivel la precisión del algoritmo implementado en hardware con un error menor al 5%

- Crear un circuito que convierta de coma flotante a coma fija, la corriente lineal ‘y’ en la salida del linealizador.

*Indicador:* Verificar mediante un programa de alto nivel la precisión del convertidor implementado en hardware con un error menor al 5%

- Crear un circuito que normalice los parámetros de corriente lineal ‘y’ y tensión lineal ‘z’, ambos en coma fija, para las entradas del estimador.

*Indicador:* Verificar mediante un programa de alto nivel la precisión del normalizador implementado en hardware con un error menor al 5%

### 1.6.3 Estructura

El capítulo 2 se describen los conceptos teóricos que serán utilizados a través del desarrollo del proyecto. En el capítulo 3 se detalla el diseño del algoritmo de cálculo y control, implementación y los resultados obtenidos para el circuito de linealización. En el capítulo 4 se presentan el diseño del algoritmo y control, implementación y los resultados obtenidos para el circuito de normalización. El capítulo 5 muestra el sistema completo, junto con sus pruebas y resultados. El capítulo 6 se ofrecen conclusiones del proyecto, y recomendaciones. Finalmente, en el capítulo 7 se puede observar la bibliografía utilizada.



# Capítulo 2

## Marco teórico

### 2.1 Descripción

Actualmente en los sistemas de paneles fotovoltaicos, es de suma importancia la eficiencia energética, para esto se debe estudiar el funcionamiento del sistema, curvas características y sus parámetros, modelo matemático ideal y una aproximación real con perdidas, ecuaciones características obtenidas a partir de cada modelo, características del sistema que se requiere optimizar, algoritmos de cálculo, entre otros.

### 2.2 Panel Fotovoltaico

Existen muchos tipos de celdas solares [11]. El más común se compone de una junta *p-n*, la energía se genera por medio del efecto fotovoltaico y de la radiación electromagnética proveniente del sol, que incide sobre la capa del semiconductor. Los fotones al tener mayor energía que la banda prohibida del semiconductor crean un par electrón-hueco, y el campo eléctrico ejercido en la junta *p-n* mueve los electrones (*portadores*), produciendo una fotocorriente que es directamente proporcional a la radiación del sol [1]. Los semiconductores que componen el panel, poseen un comportamiento exponencial y no lineal muy similar al de un diodo [9].

### 2.2.1 Curvas Corriente-Tensión(I-V) para un PV



**Figura 2.1:** Curva característica de corriente(A)-tensión(V) para un panel fotovoltaico, (Tomado de [2])

La curva característica de un PV se puede obtener manteniendo fijos los parámetros de irradiancia( $S$ ) y temperatura( $T$ ), en condiciones controladas. Si se tiene una carga en las terminales de salida, la potencia entregada solo dependerá del valor de la carga, de manera que si la carga es pequeña (puntos M-N de la figura 2.1) el panel se comportará como una fuente de corriente, pero si la carga es grande (puntos PS de la figura 2.1) se comportará como una fuente de tensión [2].

Para realizar la caracterización de una celda se deben realizar las siguientes pruebas:

- *Corriente de corto circuito  $I_{sc}$* : Se define como el valor máximo de la corriente generada por el panel, en condiciones de cortocircuito  $V = 0$ .
- *Tensión de circuito abierto  $V_{oc}$* : Se define como el valor de tensión en la junta  $p-n$ , cuando se tiene una corriente generada  $I = 0$ .
- *Punto de máxima potencia*: El punto  $A$  de la figura 2.1 representa la potencia máxima de la carga resistiva,  $P_{max} = V_{max}I_{max}$ .

### 2.2.2 Modelos del panel fotovoltaico

Un panel fotovoltaico se puede modelar de manera simple (ideal), utilizando una fuente de corriente en paralelo con un diodo, la corriente de salida será proporcional a la radiación solar sobre la celda (foto-corriente).



**Figura 2.2:** Modelo simple ideal para un panel fotovoltaico, compuesto por un diodo y una fuente de corriente

La figura 2.2 muestra el modelo básico, sin embargo este se puede realizar de una manera mas compleja, incluyendo variables para las características del panel:

- Dependencia de la temperatura, corriente de saturación del diodo ( $I_s$ ) y foto corriente ( $I_g$ )
- Pérdidas debidas al flujo de corriente ( $R_s$ ) y pérdidas con referencia a tierra ( $R_p$ ).
- número de celdas en análisis  $n$ .



**Figura 2.3:** Modelo para un panel fotovoltaico, compuesto por un diodo, una fuente de corriente, perdidas resistivas por cada celda

A partir del modelo con pérdidas se puede deducir la ecuación que describe las corrientes  $i_{pv}$  e  $I_g$ , como sigue a continuación [4]:

$$i_{pv} = I_s - i_d + i_p \quad (2.1)$$

$$I_g = 2i_{pv} + \frac{V_{pv} + i_{pv}R_s}{R_p} - I_s + I_s e^{\frac{V_{pv} + i_{pv}V_{pv}}{nV_t}} \quad (2.2)$$

Despejando  $i_{pv}$

$$i_{pv} = \frac{1}{2} \left[ I_s + I_g - \frac{V_{pv} + i_{pv}R_s}{R_p} - I_s e^{\frac{V_{pv} + i_{pv}V_{pv}}{nV_t}} \right] \quad (2.3)$$

En general, la corriente que fluye por las terminales de un generador fotovoltaico está determinada por tres funciones de corriente:

- $I_g$ : Corriente generada debido al efecto fotoeléctrico.
- $i_d$ : Corriente de pérdida debida a la juntura p-n.
- $i_p$ : Corriente de pérdida de naturaleza resistiva.

Para obtener un modelo del comportamiento estático del generador fotovoltaico se supone lo siguiente:

- $I_g$ : depende de la Irradiancia ( $S$ ), pero no depende de la tensión en las terminales del generador fotovoltaico ( $V_{pv}$ )
- $i_p$  e  $i_d$ : dependen de la tensión  $V_{pv}$
- $i_p$ : Depende de la temperatura ( $T$ )

De esta forma, la expresión que define  $i_{pv}$ :

$$i_{pv} (V_{pv}, T, S) = i_g (V_{pv}) - i_d (V_{pv}, T) \quad (2.4)$$

Según se definan las funciones  $i_{pv}$  e  $i_d$ , se obtendrán modelos con complejidad y precisiones distintas, a partir de los siguientes casos:

**Tabla 2.1:** Modelos para un PV: ideal, con pérdidas en serie  $R_s$  y con pérdidas en paralelo  $R_p$

| Modelos | $i_g$ | $i_p$                         | $i_d$                                                           |
|---------|-------|-------------------------------|-----------------------------------------------------------------|
| 1       | $KS$  | -                             | $I_s (T) \left[ e^{\frac{V_{pv}}{V_t}} - 1 \right]$             |
| 2       | $KS$  | $G_p V_{pv}$                  | $I_s (T) \left[ e^{\frac{V_{pv}}{V_t}} - 1 \right]$             |
| 3       | $KS$  | -                             | $I_s (T) \left[ e^{\frac{V_{pv} + i_{pv}R_s}{V_t}} - 1 \right]$ |
| 4       | $KS$  | $G_p V_{pv} + G_p i_{pv} R_s$ | $I_s (T) \left[ e^{\frac{V_{pv} + i_{pv}R_s}{V_t}} - 1 \right]$ |

De manera general se tiene:

$$i_{pv} (V_{pv}) = G_p V_{pv} + G_p i_{pv} R_s \quad (2.5)$$

$$i_d (V_{pv}) = I_s (T) e^{\frac{V_{pv}}{V_t}} e^{\frac{i_{pv}R_s}{V_t}} - I_s (T) \quad (2.6)$$

El modelo general del comportamiento estático de un generador PV, también se puede representar de la siguiente manera:

$$i_{pv} = KS - G_p V_{pv} + I_s(T) - G_p i_{pv} R_s - I_s(T) e^{\frac{V_{pv}}{v_t}} e^{\frac{i_{pv} R_s}{v_t}} \quad (2.7)$$

$$I_s(T) e^{\frac{V_{pv}}{v_t}} e^{\frac{i_{pv} R_s}{v_t}} = KS - G_p V_{pv} + I_s(T) - G_p i_{pv} R_s - i_{pv} \quad (2.8)$$

La ecuación 2.8 es no lineal, aplicando una linealización, se tiene [3]:

$$y = \ln(KS - G_p V_{pv} + I_s(T) - G_p i_{pv} R_s - i_{pv}) \quad (2.9)$$

si  $I_g = KS \gg I_s$

$$y = \ln(KS - G_p V_{pv} - G_p i_{pv} R_s - i_{pv}) \quad (2.10)$$

$$z = V_{pv} + i_{pv} R_s \quad (2.11)$$

Posteriormente al proceso de cálculo de parámetros se tiene:

$$\theta_1 = \ln(I_s(T)) \quad (2.12)$$

$$\theta_2 = \alpha \quad (2.13)$$

## 2.3 Algoritmo de CORDIC

El algoritmo *Coordinate Rotational Digital Computer* (CORDIC) es un método numérico, en donde se realiza cierto número de iteraciones para encontrar el valor deseado, según sea la función que se desea calcular. Este algoritmo es utilizado para implementar funciones trigonométricas, logarítmicas y exponenciales. La facilidad de implementación, hace que sea uno de los algoritmos más utilizados en el ámbito de la electrónica digital. CORDIC implementado digitalmente utiliza desplazamientos, sumas, restas y tablas look-up con valores previamente precargados en una memoria ROM, que dependerán de la operación en cálculo. Para este algoritmo existe: el método circular, lineal e hiperbólico.

Las ecuaciones generales para el algoritmo de CORDIC se definen como:

$$X_{i+1} = X_i - md_i 2^{-i} Y_i \quad (2.14)$$

$$Y_{i+1} = Y_i - d_i 2^{-i} X_i \quad (2.15)$$

$$Z_{i+1} = Z_i - d_i e(i) \quad (2.16)$$

Donde  $e(i)$  se muestra en la tabla 2.2 según corresponde cada caso:

**Tabla 2.2:** Sistema de coordenadas unificado (CORDIC): circular, lineal e hiperbólico.  
Tomado de [5]

| m  | Sistema de coordenadas | Valor de $e(i)$      |
|----|------------------------|----------------------|
| 1  | Circular               | $\tan^{-1}(2^{-i})$  |
| 0  | Lineal                 | $2^{-1}$             |
| -1 | Hiperbólico            | $\tanh^{-1}(2^{-i})$ |

### 2.3.1 Sistema de coordenadas hiperbólico

Para el cálculo de algunas funciones con el algoritmo aumenta la complejidad, de manera que se deben utilizar las siguientes identidades [6]:

$$\tan z = \frac{\sin z}{\cos z} \quad (2.17)$$

$$\tanh z = \frac{\sinh z}{\cosh z} \quad (2.18)$$

$$\exp z = \sinh z + \cosh z \quad (2.19)$$

$$\ln \omega = 2 \tanh^{-1} \left( \frac{y}{x} \right) \quad (2.20)$$

Donde:

$$x = \omega + 1 \quad (2.21)$$

$$y = \omega - 1 \quad (2.22)$$

### 2.3.2 Logaritmo natural utilizando el algoritmo hiperbólico de CORDIC

Para la función  $\ln(\omega)$ , utilizando el algoritmo de CORDIC en modo hiperbólico [12], se debe calcular primeramente la función  $\tanh^{-1} \left( \frac{y}{x} \right)$  a partir de las siguientes ecuaciones:

$$X_{i+1} = X_i + d_i 2^{-i} Y_i \quad (2.23)$$

$$Y_{i+1} = Y_i + d_i 2^{-i} X_i \quad (2.24)$$

$$Z_{i+1} = Z_i - d_i \tanh^{-1}(2^{-i}) \quad (2.25)$$

Donde  $i$  es el indice de cada iteración. Las iteraciones  $4, 13, 40, \dots k, 3k+1$  se deberán repetir para garantizar la convergencia.  $d_i$  es el signo de  $Y_i$  invertido, es decir el cuando el signo de  $Y_i$  es negativo,  $d_i$  será positivo y viceversa.

Utilizando la ecuación 2.20, se definen los valores iniciales  $X_0 = \omega + 1$ ,  $Y_0 = \omega - 1$  y  $Z_0 = 0$ , cuando  $i = 0$ .

Cabe destacar que el rango de convergencia para este algoritmo [7] esta definido como:

$$0,106843 \leq \omega \leq 9,35947 \quad (2.26)$$

Donde  $\omega$  es el valor del argumento del logaritmo natural.

El resultado final de  $Z_i$ , contiene el valor de  $\tanh^{-1}\left(\frac{y}{x}\right)$ , sin embargo se debe multiplicar por un factor de 2 para completar el cálculo del logaritmo natural, según la identidad de la ecuación 2.20

### 2.3.3 Exponencial utilizando el algoritmo hiperbólico de CORDIC

Para una función  $e^{(\omega)}$ , con el algoritmo de CORDIC, se debe utilizar las ecuaciones 2.23, 2.24 y 2.25 de manera iterativa, donde el valor final de  $X$  y  $Y$ , son el resultado de  $\cosh(\omega)$  y  $\sinh(\omega)$  respectivamente. Se debe tomar en cuenta la repetición de las iteraciones ( $i$ )  $4, 13, 40, \dots k, 3k+1$  para garantizar la convergencia dando una mejor precisión en el cálculo.

Los valores iniciales se definen como *constantes*  $X_0 = 1,20753406$ ,  $Y_0 = 0$  y  $Z_0 = \omega$ , donde  $\omega$ , es el valor del argumento que se desea calcular, y  $d_i$  es el signo de  $Z_i$ .

Cabe destacar que el rango de convergencia para este algoritmo se puede definir como:

$$0 \leq \omega \leq 1 \quad (2.27)$$

El valor final del cálculo, se obtiene por medio de una suma de dos funciones, dadas en la identidad de la ecuación 2.19.

## 2.4 Coma flotante

La codificación para el formato coma flotante se realiza mediante el estándar *IEEE 754*, este requiere de tres campos en la palabra [10]:

- Signo
- Exponente
- Mantisa



**Figura 2.4:** Formato IEEE 754 coma flotante para 32 bits

Para el formato *IEEE 754* de la figura 2.4 en 32-bits [8] se asigna:

- 1 Bit para signo
- 8 Bits para exponente
- 23 Bits para mantisa

Donde el bit de signo representa un numero positivo si este es 0, de manera contraria representa un número negativo.

El exponente (8-bits) puede representar un rango desde 0 hasta 255, sin embargo se tiene:

- $[0 - 127]$  exponentes negativos
- $[128 - 255]$  exponentes positivos

De esta manera para convertir un exponente positivo, en el valor correspondiente del formato coma flotante se debe realizar la siguiente suma:  $exp_{float} = 127 + exp_{numero}$ . Por otro lado si se desea pasar de un valor decimal a coma flotante se deben realizar los siguientes pasos:

- Representar el signo con su debido bit
- Conversión decimal a binario coma fija
- Conversión binario a notación científica
- Agrupar en signo, exponente y mantisa

## 2.5 Coma fija

La representación de un número en coma fija cuenta con tres partes fundamentales:

- Signo
- Parte entera
- Parte fraccionaria

---

|     |        |              |
|-----|--------|--------------|
| Sgn | Entero | Fraccionario |
|-----|--------|--------------|

---

**Figura 2.5:** Formato para un número en coma fija

En la aritmética simple se utilizan los signos +/-, para saber si un número es positivo o negativo, para representar el signo en coma fija se utiliza el bit mas significativo. Si el número es positivo, el bit de signo será un 0 y si el número es negativo, será un 1 [13]. Si se requiere de una representación de un numero negativo en coma fija, se debe utilizar el complemento a 2 [14]. La coma se asigna de manera arbitraria según se requiera.



# Capítulo 3

## Sistema de linealización

La corriente  $i_{pv}$  generada por un panel, posee un comportamiento exponencial, de manera que se requiere de una linealización. Esta se realizará por medio de una función logarítmica que se estimará a través de un algoritmo de cálculo denominado CORDIC, el cual permite realizar una aproximación de la función de manera recursiva con una cantidad de iteraciones finita. El algoritmo de CORDIC para un logaritmo natural utiliza el sistema de coordenadas hiperbólico.

El rango de convergencia para este algoritmo es de  $0,106843 < T < 9,35947$  donde  $T$  es el argumento del logaritmo natural. El valor máximo  $T = 0,58A$  es seleccionado a partir de la corriente en condiciones máximas para el panel. Para aprovechar de una mejor forma el intervalo de convergencia del algoritmo, se puede escalar por medio de una división entre una constante  $C = 16$ , esta es escogida de manera que se pueda realizar el escalado a través de desplazamientos. El nuevo intervalo de convergencia es limitado por:  $0.00667769 < T < 0.58496687$ . Este desplazamiento en el rango de convergencia se realizó debido a que se pueden presentar valores de corriente mas bajos que  $0.106843A$ .

La constante C utilizada en el escalado se debe compensar en el logaritmo con la siguiente igualdad:

$$\ln(T) = \ln(16T) - \ln(16) \quad (3.1)$$

### 3.1 Algoritmo de CORDIC hiperbólico implementado en software

Para comprobar el debido funcionamiento del este algoritmo se crea un programa de alto nivel en Python.

```

def CordicLn(T): #Algoritmo de cordic para resolver un Ln

    #Condiciones iniciales
    Z_ant=0
    X_ant=T+1
    Y_ant=T-1

    #Look-up table
    Bm=[0.54930614, 0.25541281, 0.12565721, 0.06258157, 0.06258157, 0.03126
    i=0

    #Cantidad de desplazamientos por iteracion
    Em=[ 2**-1, 2**-2, 2**-3,2**-4,2**-4,2**-5,2**-6,2**-7,2**-7,2**-8,2**-9

    while i<23:

        Dm= -Y_ant/(abs(Y_ant))      # Signo de Y
        Z_act= Z_ant + Dm*2*Bm[i]   # Calcula el valor de Z actual
        X_act= X_ant + Em[i]*Dm*Y_ant # Calcula el valor X actual
        Y_act= Y_ant + Em[i]*Dm*X_ant # Calcula el valor Y actual
        Z_ant = Z_act   # Agrega el valor actual al valor anterior de Z
        Y_ant = Y_act   # Agrega el valor actual al valor anterior de Y
        X_ant = X_act   # Agrega el valor actual al valor anterior de X
        i = i + 1        # Contador para cada iteracion
        ln=Z_act         # Resultado para cada iteracion

    return ln #resultado final del logaritmo natural

>>>
>>> T=0.2
>>> CordicLn(16*T) - math.log(16)
-1.6094370822397814
>>> math.log(0.2)
-1.6094379124341003
>>>

```

**Figura 3.1:** Algoritmo de CORDIC en Python

En la figura 3.1 se observa el programa realizado para la verificación del algoritmo en alto nivel, para este se utilizan las ecuaciones para el algoritmo de CORDIC hiperbólico, descrito en el marco teórico. Este programa cuenta con las modificaciones realizadas en el rango de convergencia, con respecto al escalado y compensación.

Para simplificar el diseño e implementación del hardware, se realiza una serie de modificaciones en las ecuaciones del algoritmo:

- Se sustituye la resta del valor actual de  $Z_{i+1}$  por una suma.
- Se incluye el signo en la tabla LUT de Z.
- el resultado final del algoritmo se debe multiplicar por 2, sin embargo este escalado se puede realizar a los valores almacenados en la LUT de Z, esto para evitar una multiplicación.

### 3.2 Sistema de linealización implementado en hardware (CORDIC)



**Figura 3.2:** Bloque principal de linealización: Entradas y salidas para la unidad logaritmo natural basada en el algoritmo de CORDIC e implementado en hardware.

La figura 3.2 contiene el bloque general del algoritmo de CORDIC, poseen 4 entradas: CLK , T , Begin\_LN , RST\_LN y 4 salidas: ACK\_LN , RESULT , U\_F , O\_F



**Figura 3.3:** Sistema de linealización: Coprocesador coma flotante de 32bits basado en el algoritmo de CORDIC y una máquina de estados finita como control.

El sistema de linealización de la figura 3.3 cuenta con dos módulos principales:

- *Coprocesador Cordic*: Realiza todas las operaciones requeridas por el algoritmo, se encarga del manejo de los datos en el cálculo.
- *Control*: Este se encarga de proveer las señales de control requeridas por el coprocesador, según las condiciones que se tenga en cada estado.

Señales de datos:

- $T$ : Dato de entrada, argumento del logaritmo natural.
- $RESULT$ : Resultado de la operación logaritmo natural.

Señales de control:

- $CLK$ : Reloj del sistema.
- $Begin\_LN$ : Encargada de dar inicio a la operación logaritmo natural.
- $RST\_LN$ : Realiza un reset a la unidad CORDIC tanto para el coprocesador como para la máquina de estados.
- $ACK\_LN$ : Indica que el cálculo ya fue realizado.
- $Begin\_SUM$ : Se encarga de dar inicio a la unidad de suma-resta coma flotante.
- $ACK\_SUM$ : Indica que ha realizado el cálculo en la unidad de suma-resta coma flotante.
- $O\_F$ : Indica si la suma-resta en coma flotante tiene un over-flow.
- $U\_F$ : Indica si la suma-resta en coma flotante tiene un under-flow.
- $CLK\_DIR$ : Activa el enable del contador de iteraciones.
- $CONT\_ITER$ : Indica el número de iteración y sirve de comparación para que la máquina de estados pueda detenerse en el número de iteraciones que se requieran.
- $RST$ : Realiza el reset de todos los registros de la unidad.
- $MS\_1$ ,  $MS\_2$ ,  $MS\_3$ ,  $MS\_4$ : Realizan la selección de cada multiplexor, Mux1, Mux2, Mux3, Mux's4 respectivamente.
- $EN\_REG1X$ ,  $EN\_REG1Y$ ,  $EN\_REG1Z$ : Activa los enable de los registros de la primera etapa REG1X, REG1Y, REG1Z respectivamente, para almacenar datos.
- $EN\_REG2XYZ$ : Activa el enable del registro REG2XYZ de la segunda etapa.
- $EN\_REG2$ : Activa el enable del registro REG2 de la segunda etapa.
- $EN\_REG3$ : Activa el enable del registro REG3 del dato inicial.
- $EN\_REG4$ : Activa el enable del registro REG4 del dato final.

### 3.3 Diseño e implementación del coprocesador de linealización por medio del algoritmo de CORDIC

El diseño de este algoritmo se basa en una arquitectura segmentada, almacenando y procesando varios datos en las distintas etapas, para esto es de suma importancia una buena sincronización y así evitar datos erróneos a través del proceso de cálculo. Este coprocesador cuenta con el formato IEEE 754 de 32Bits, para una adecuada exactitud en la aproximación del logaritmo natural y poder utilizar un número menor de iteraciones.



**Figura 3.4:** Coprocesador segmentado para el cálculo de una función logarítmica con el algoritmo de CORDIC en hardware

En la figura 3.4 se puede observar la arquitectura en formato IEEE 754 coma flotante en 32-Bits diseñada para el algoritmo de CORDIC.

Esta etapa de linealización inicia con la carga de las condiciones iniciales, donde  $Z_0$  contiene un valor inicial cero. Para el valor inicial de  $X_0$  y  $Y_0$  primeramente se aplica el escalado  $16^*T$ , este se puede efectuar por medio de cuatro desplazamientos  $2^{-4}$ , por lo tanto este movimiento en formato coma flotante, se traduce como una suma de 4 en el exponente del argumento  $T$ , posteriormente se realizan las siguientes operaciones en coma flotante,  $X_0 = T + 1$  y  $Y_0 = T - 1$ . Estas tres constantes dan inicio al proceso de cálculo de manera iterativa, por lo que se requiere almacenarlas en un registro (*Registro1*) en la primera etapa de segmentación.

Este método (CORDIC) es un cálculo cruzado es decir, para el próximo valor  $X_i$  se requiere el valor de  $Y_0$  con un desplazamiento (resta en el exponente de la variable  $Y_0$ ) y un cambio de signo  $\delta_i$ . Para  $Y_i$  se aplica un concepto similar con valores de  $X_0$  según las ecuaciones que describen el algoritmo en modo hiperbólico. La variable de mayor interés es  $Z_i$  esta contiene el valor final del cálculo, para esto se requiere una ROM con valores previamente cargados ( $LUT_Z$ ) y el signo  $\delta$ .

Para el signo  $\delta$  de las operaciones en el algoritmo de CORDIC hiperbólico, se utiliza un circuito de comparación entre los signos de  $X_i$ ,  $Y_i$  y  $Z_i$  contra el signo de  $Y_i$  invertido, la siguiente tabla describe el funcionamiento del circuito diseñado:

**Tabla 3.1:** Signo  $\delta$  de la iteración siguiente para las variables  $X_{i+1}$ ,  $Y_{i+1}$  y  $Z_{i+1}$ , comparando el signo de las variables  $X_i$ ,  $Y_i$  y  $Z_i$  contra el signo de  $Y_i$  invertido

| Sign $X_0$ | Sign $Z_0$ | Sign $Y_0$ | Sign $\sim Y_0$ | Sign $X_i$ | Sign $Z_i$ | Sign $Y_i$ |
|------------|------------|------------|-----------------|------------|------------|------------|
| 0          | 0          | 0          | 1               | 1          | 1          | 1          |
| 0          | 0          | 1          | 0               | 0          | 0          | 1          |
| 0          | 1          | 0          | 1               | 1          | 0          | 1          |
| 0          | 1          | 1          | 0               | 0          | 1          | 1          |
| 1          | 0          | 0          | 1               | 0          | 1          | 1          |
| 1          | 0          | 1          | 0               | 1          | 0          | 1          |
| 1          | 1          | 0          | 1               | 0          | 0          | 1          |
| 1          | 1          | 1          | 0               | 1          | 1          | 1          |



**Figura 3.5:** Circuito de comparación de signo actual  $\delta$ , para las variables  $X_{i+1}$ ,  $Y_{i+1}$  y  $Z_{i+1}$  de la iteración siguiente, utilizando la tabla 3.1

A partir de la tabla 3.1 se extrae el circuito de comparación de signo de la figura 3.5, este es diseñado con compuerta  $XOR$  que poseen el mismo comportamiento que se describe en la tabla.

Dentro del diseño del linealizador se requiere de tablas de rápido acceso, precargadas con los valores constantes para cada iteración. para esto se utilizan dos Look-up tables "LUT", que son diseñadas por medio de memorias ROM's, de manera que puedan ser accesados en cualquier momento que sean requeridos por medio de la dirección. Dentro de las ROM's se dispone:

- $LUT_Z$ : Almacena los valores de  $-2 \cdot \operatorname{arctanh}(2^{-i})$ , para cada iteración.
- $LUT\_ITER$ : Almacena los desplazamientos que se deben realizar para cada iteración, esto debido a que las iteraciones 4 y 13 repiten desplazamientos como se menciona en el marco teórico.

El acceso a cada valor de la tablas se realiza mediante un único contador de iteraciones, este indica a cada tabla la dirección del dato que se quiere extraer. Ambas LUT se encuentran sincronizadas en cuanto al numero de iteración.

Anteriormente se describió el proceso para el cálculo de las constantes iniciales  $X_0$ ,  $Y_0$  y  $Z_0$ . El proceso para el cálculo de las variables  $X_{i+1}$ ,  $Y_{i+1}$  y  $Z_{i+1}$ , no se puede realizar de manera simultanea, ya que solo se cuenta con un sumador coma flotante, esta medida se tomó por reducción del área.

Las variables modificadas (desplazamiento y signo) son almacenadas en el *Registro 2*. La secuencia de cálculo toma primeramente los valores que se necesitan para  $X_{i+1}$ , posteriormente se realiza la suma  $X_i + \delta \cdot Y_{desplazado\_i}$  y se almacena el resultado en

el *Registro 1*. Seguidamente se procede con el cálculo de  $Y_{i+1}$  y se realiza la suma  $Y_i + \delta \cdot X_{desplazado\_i}$  almacenada en el *Registro 1*, por ultimo se calcula el valor de  $Z_{i+1}$ , con la suma  $Z_i + LUT_i$ , esta se almacena en el *Registro 1*, este proceso se realiza N iteraciones (N=número entero). La resta  $Z_i - Ln(16)$  contrarresta el efecto del escalado aplicado al argumento ( $T$ ), al inicio del cálculo del logaritmo natural. El resultado final  $Z_i$  contiene el valor  $Ln(T)$  y es almacenado en el *Registro 4*.

### 3.4 Sistema de control para la unidad de coprocesamiento CORDIC por medio de un máquina de estados finita (FSM)



**Figura 3.6:** Máquina de estados finitos para para la unidad de coprocesamiento CORDIC

El sistema de control necesita mucha sincronía, ya que los datos deben ser almacenados de manera correcta y estar listos con cierto tiempo ("setup-time") antes de que requeridos por otro segmento del coprocesador CORDIC. Se diseñó una máquina de estados finitos, donde inicialmente se calculan los valores iniciales de  $X_0$ ,  $Y_0$  y  $Z_0$ , posteriormente la máquina brinda las señales de control requeridas, dentro de una secuencia de cálculo de  $X_{i+1}$ ,  $Y_{i+1}$  y  $Z_{i+1}$  respectivamente, cada vez que se recorre esta secuencia, se realizará una cuenta de iteración. Esa máquina posee con una variable de entrada que indica el número de iteración en el que se encuentra el algoritmo, de manera que cuando se llega a la iteración N, finalice el cálculo.

### 3.5 Algoritmo de CORDIC implementado en verilog para una placa de desarrollo nexys-4

Este algoritmo se implementó por medio del lenguaje de descripción de hardware "Verilog". Inicialmente se realizaron pequeños bloques pertenecientes a cada elemento requerido por la arquitectura diseñada. Se desarrolló el coprocesador CORDIC y la unidad de control en bloques separados, de manera que se pudieran realizar pruebas sin dependencia de los bloques entre si, para una mejor depuración de errores, optimización y rediseño. Finalmente se procede a la etapa de pruebas, con simulaciones al bloque completo, como se muestra en la figura 3.7.



**Figura 3.7:** Simulación del linealizador implementado en Verilog, ingresando en la entrada un archivo de texto, con 1000 valores del intervalo de convergencia para el argumento del logaritmo natural

## 3.6 Simulación del circuito linealizador con algoritmo de CORDIC

Las simulaciones de la implementación del algoritmo, se realizaron mediante mil valores de entrada para el argumento del logaritmo natural, dentro del rango de convergencia, obteniendo mil valores de salida. Estos resultados experimentales se comparan con los valores reales, para dicha comparación se realizaron aproximaciones con 8, 12 y 15 iteraciones.

Primeramente se realiza una simulación que comprueba el funcionamiento en el rango de operación  $0,00667769 < T < 0,58496687$ . La linealización de los datos de prueba se realiza con la siguiente función:

$$\ln(T) \quad (3.2)$$

donde el argumento T es:

$$T = e^{-x} \quad (3.3)$$

El intervalo  $0,536 < x < 5,009$  se divide en mil valores, estos se ingresan a la entrada por medio de un archivo de texto. El circuito linealizador CORDIC toma los datos, le aplica la función 4.2 y devuelve mil valores a través de otro archivo de texto, que se utilizará para análisis posteriormente.

### 3.6.1 Resultados de la simulación del rango de convergencia del circuito linealizador CORDIC

Para implementar un algoritmo o método numérico en hardware, es de suma importancia verificar que este funcione de manera adecuada en el rango de convergencia definido. La comprobación de la unidad de linealización mediante el algoritmo de CORDIC, se realizó por medio de una serie de pruebas, variando la cantidad de iteraciones para poder observar las diferencias entre exactitud y tiempo de ejecución. Se programó una simulación ("testbench") con mil valores de entrada, ingresados por medio de un archivo de texto previamente editado con los datos de entrada, con la función exponencial anteriormente descrita en la ecuación 4.3.

En la tabla 5.1 se puede observar el resumen de los resultados más relevantes para las simulaciones del rango de convergencia con distinta cantidad de iteraciones del algoritmo de CORDIC.

**Tabla 3.2:** Comparación de resultados experimentales obtenidos por medio de una simulación post-síntesis, a partir de los valores de entrada del rango de convergencia, utilizando 8, 12 y 15 iteraciones en el algoritmo de CORDIC. CLK=100MHz.

|                                 | 8 iteraciones | 12 iteraciones | 15 iteraciones |
|---------------------------------|---------------|----------------|----------------|
| Error máximo (%)                | 2,72          | 0,259          | 0,129          |
| Error promedio (%)              | 0,40          | 0,0351         | 0,0257         |
| Desviación estándar             | 0,39          | 0,043          | 0,0197         |
| Número de ciclos                | 460           | 660            | 818            |
| Frecuencia de ejecución (kHz)   | 217,39        | 151,51         | 122,25         |
| Tiempo de ejecución ( $\mu s$ ) | 4,6           | 6,6            | 8,18           |



**Figura 3.8:** Datos de salida para la simulación post-síntesis del linealizador, mediante mil valores de entrada dentro del rango de convergencia utilizando 8 iteraciones en el algoritmo de CORDIC



**Figura 3.9:** Porcentaje de error para los datos de la simulación post-síntesis del linealizador, tomando mil valores de entrada dentro del rango de convergencia y 8 iteraciones para el algoritmo de CORDIC

Primeramente se realizó una simulación con 8 iteraciones, en la figura 3.8 se muestran los valores obtenidos a partir de la simulación post-síntesis. Para el cálculo de cada valor se requieren 460 ciclos de reloj, desde el momento en se activa la señal Begin\_LN hasta que se recibe la señal ACK\_LN, esta indica que se ha completado el cálculo. Es de suma importancia realizar la comparación entre el valor teórico y el valor calculado. Para cada valor se calculó el error, la gráfica se puede observar en la figura 3.9, donde el porcentaje de error máximo es de 2,72% y el porcentaje de error promedio es de 0,40%.



**Figura 3.10:** Datos de salida para la simulación post-síntesis del linealizador, mediante mil valores de entrada dentro del rango de convergencia utilizando 12 iteraciones en el algoritmo de CORDIC



**Figura 3.11:** Porcentaje de error para los datos de la simulación post-síntesis del linealizador, tomando mil valores de entrada dentro del rango de convergencia y 12 iteraciones para el algoritmo de CORDIC

Una mejor aproximación se puede realizar utilizando 12 iteraciones en el cálculo del logaritmo natural, en la figura 3.10 se pueden observar los resultados obtenidos. Se requieren 660 ciclos de reloj para ejecutar el cálculo completo. La figura 3.11 muestra el error en cada cálculo, donde el porcentaje de error máximo es de 0,259% y el porcentaje de error promedio es de 0,0351%.



**Figura 3.12:** Datos de salida para la simulación post-síntesis del linealizador, mediante mil valores de entrada dentro del rango de convergencia utilizando 15 iteraciones en el algoritmo de CORDIC



**Figura 3.13:** Porcentaje de error para los datos de la simulación post-síntesis del linealizador, tomando mil valores de entrada dentro del rango de convergencia y 8 iteraciones para el algoritmo de CORDIC

Utilizando 15 iteraciones en el cálculo del logaritmo natural se logra la mejor aproximación, sin embargo se requieren 818 ciclos de reloj y se vuelve más lento el proceso, en la figura 3.12 se pueden observar los resultados obtenidos. La figura 3.13 muestra el error en cada cálculo, donde el porcentaje de error máximo es de 0,129% y el porcentaje de error promedio es de 0,0257%.

En las figuras de error 3.9, 3.11 y 3.13 se puede observar que el comportamiento del algoritmo es más exacto cuando los valores de corriente de entrada del argumento de linealizador "T" son pequeños, a medida que este argumento se vuelve mayor el porcentaje de error también incrementa.

# Capítulo 4

## Sistema de conversión coma flotante a coma fija y normalización

El circuito implementado para la linealización se basa en el formato IEEE 754, sin embargo el estimador de parámetros, esta basado en un formato de coma fija. Se debe considerar una conversión entre ambos formatos, para esto se estudió cómo pasar de coma flotante a coma fija, ambos en 32-bits.

### 4.1 Diseño del sistema de conversión, normalización y control



**Figura 4.1:** Diagrama general de entradas y salidas para el convertidor coma flotante a coma fija y normalizador.

La figura 4.1 contiene el bloque general de entradas y salidas para el sistema de conversión y normalización , este posee 4 entradas: CLK , F , Begin\_FF , RST\_FF y 2 salidas: ACK\_FF , RESULT.



**Figura 4.2:** Sistema de conversión, normalización y control utilizando una máquina de estados. Señales de entrada, salida, datos y control.

El sistema de conversión y normalización de la figura 4.2 cuenta con dos módulos principales:

- *Convertidor-Normalizador*: Realiza todas las operaciones requeridas para la conversión del formato coma flotante-coma fija y de la normalización, este se encarga del manejo de los datos en el cálculo.
- *Control*: Se encarga de proveer las señales de control requeridas por el convertidor-normalizador, según las condiciones que se requiera en cada estado.

Señales de datos:

- *F*: Dato de entrada en formato IEEE 754.
- *RESULT*: Dato de salida en coma fija.

Señales de control:

- *CLK*: Reloj del sistema. Ejecuta ciclos de reloj con una frecuencia preestablecida.
- *Begin\_FF*: Se encarga de iniciar la la unidad e indica a la máquina de estados que se debe iniciar la secuencia.
- *RST\_FF*: Restablece los valores iniciales del sistema de conversión y normalización.
- *ACK\_FF*: Indica cuando la conversión y la normalización han sido realizadas.

## 4.2 Convertidor coma flotante - coma fija y normalizador



**Figura 4.3:** Diagrama general del sistema de conversión de coma flotante a coma fija y normalización corriente-tensión

En la figura 4.3 se puede observar el diagrama de solución, que se utilizó en el diseño de la arquitectura del convertidor-normalizador. Primeramente ingresa el número en formato IEEE 754 32-bits, seguidamente se efectúa la conversión a coma fija, en donde se asigna un bit de signo, 5 bits de parte entera y 26 bits para la parte fraccionaria, este dato se procesa en una etapa de normalización y se obtiene el resultado. Este valor final está normalizado para la corriente y tensión del panel,  $V = [0, 1]$  e  $i = [-1, 1]$ , para el formato coma fija solo se requiere: un bit de signo, un bit en la parte entera y 30 para la parte fraccionaria; como se muestra en la figura 4.3. El aumento de bits en la parte fraccionaria indica una mejor precisión en el resultado.



**Figura 4.4:** Circuito de conversión coma flotante a coma fija y normalización de corriente  $[-1, 1]$  y tensión  $[0, 1]$ , con un dato de entrada en coma flotante y una salida en coma fija normalizada.

Como se observa en la figura 4.4, la etapa de conversión de formatos contiene un comparador, este se utiliza para saber si el número, en formato IEEE 754 contiene un exponente mayor o menor que 127. Si el número es igual a 127, indica un exponente de 0, si es mayor que 127, la bandera de salida del comparador es igual a 1 ( $EXP\_Out = 1$ ) , si se da esta condición, se debe realizar la operación  $EXP - 127$ . Si el exponente es menor que 127, la bandera  $EXP\_Out$  es 0 y la operación es  $127 - EXP$ , ambas operaciones indican la cantidad de desplazamientos que se deben realizar en el desplazador de barril ("Barrel-shifter"), este se utiliza debido a que su construcción es puramente combinacional, por lo que no requiere ciclos de reloj para funcionar, esto disminuye el tiempo de cálculo en la etapa de conversión. La dirección de los desplazamientos se puede controlar mediante una señal que posee el desplazador de barril, esta es conectada a la bandera del comparador  $EXP\_Out$ . El dato de entrada para el "barrel-shifter" esta compuesto por el bit mas significativo en alto (fijo) y 23 bits de la mantisa del dato de entrada en coma flotante; este dato compuesto se le aplican los desplazamientos para obtener el resultado en coma fija.

Para normalizar un dato se requiere una división entre el máximo valor que se puede procesar, sin embargo en un circuito digital las divisiones se tornan complicadas y requieren de mucha área, por lo que se utiliza una multiplicación por una constante. Esta etapa de normalización tiene como entrada el valor convertido a coma fija, y es normalizado por medio de un multiplicador en coma fija, este requiere de una constante de normalización.

Las constantes de normalización se pueden calcular con la siguiente ecuación:

$$C_{norm} = \frac{1}{Valor_{MAX}} \quad (4.1)$$

La etapa de conversión y normalización se utiliza tanto para la corriente  $i_{pv}$  como para la tensión  $V_{pv}$  del panel, esta constante de normalización varia para cada circuito:

$$Cv_{norm} = \frac{1}{18,1} = 0,055248618 \quad (4.2)$$

$$Ci_{norm} = \frac{1}{Ln(0,00667769)} = 0,199641045 \quad (4.3)$$

Donde  $Cv_{norm}$  es la constante de normalización de la tensión y  $Ci_{norm}$  la constante de normalización de la corriente.

Posteriormente a la normalización, se debe tomar en cuenta el signo del valor inicial sin convertir (coma flotante). La unidad de conversión-normalización realiza una resta  $0 - Dato\_coma\_fija$ , y el multiplexor 2x1 del resultado selecciona el valor final en coma fija. Si el bit 32 del valor inicial es cero, el valor final en coma fija es positivo, de lo contrario el valor final en coma fija es negativo.

## 4.3 Control para el convertidor coma flotante - coma fija y normalizador

La arquitectura diseñada para el convertidor-normalizador en su mayoría es combinacional sin embargo requiere un control, que detecta si se deben realizar desplazamientos, y cuando se debe almacenar datos en registros.



**Figura 4.5:** Sistema de control para el convertidor-normalizador, diseñado mediante una máquina de estados finita

El control de esta arquitectura se realiza por medio de una máquina de estado finita. El funcionamiento de la maquina se describe a continuacion:

- Estado (a): Espera la señal *Begin\_FF* para que la unidad de conversión-linealización sea iniciada, de manera que se ejecute un reset en los registros.
- Estado (b): Guarda el dato en el *Registro 1*.

- Estado (c): Verifica la condición  $EXP = 127$ , esta determina si se deben realizar desplazamientos.
- Estado (f): Almacena en el desplazador de barril el dato convertido.
- Estado (g) Almacena el resultado final en el *Registro 2*.
- Estado (h) Indica mediante la bandera *ACK\_FF* que el dato ya fue convertido y normalizado.

## 4.4 Sistema de conversión-normalización implementado en verilog para una placa de desarrollo nexys-4

Este circuito se implementó por medio de el lenguaje de descripción de hardware "Verilog", realizando pequeños bloques pertenecientes a cada elemento requerido por la arquitectura diseñada. Se implementa la unidad de conversión-normalización y la unidad de control en bloques separados, de manera que se pudieran realizar pruebas sin dependencia de los bloques entre si, para una mejor depuración de errores y re-diseño. Se realizan las simulaciones al bloque completo y se verifica su funcionamiento como se muestra en la figura 4.6.



**Figura 4.6:** Simulación del circuito de conversión y normalización, ingresando en la entrada un archivo de texto, con 1000 valores de corriente lineal.

## 4.5 Resultados de la simulación post-síntesis del sistema de conversión-normalización

En la implementación de un diseño en hardware, es de suma importancia simular y verificar que este funcione de manera adecuada al comportamiento esperado teóricamente. Para la comprobación de la unidad de conversión-normalización, se realizó una serie de

pruebas, programando una simulación ("testbench") con mil valores de entrada, ingresados por medio de un archivo de texto previamente editado, este contiene los datos de entrada del comportamiento según el modelo del panel. Las pruebas de esta unidad se realizaron con valores de corriente  $i_{pv}$  y valores de tensión  $V_{pv}$ , como se muestra en la tabla 4.1.

**Tabla 4.1:** Comparación de resultados experimentales obtenidos por medio de una simulación post-síntesis, a partir de los valores de entrada de corriente y tensión para el circuito de conversión-normalización. CLK=100MHz

|                                          | Corriente | Tensión   |
|------------------------------------------|-----------|-----------|
| Error máximo (%)                         | 0,0024837 | 0,0024837 |
| Error promedio (%)                       | 0,002478  | 0,002478  |
| Desviación estándar ( $\times 10^{-6}$ ) | 1,94953   | 1,94953   |
| Número de ciclos                         | 8         | 8         |
| Frecuencia de ejecución (MHz)            | 12.5      | 12.5      |
| Tiempo de ejecución (ns)                 | 80        | 80        |



**Figura 4.7:** Comparación entre la conversión-normalización de corriente  $i_{pv}$  teórica y la simulación post-síntesis del circuito

En la figura 4.7 se presenta la comparación entre los resultados obtenidos teóricamente y experimentalmente, a través de la simulación post-síntesis del circuito normalizador-linealizador, este toma datos de entrada con valores de corriente en formato coma flotante y retorna valores de corriente normalizados y en formato coma fija. Estos resultados se pueden comparar por medio del porcentaje de error asociado entre el valor teórico y experimental .



**Figura 4.8:** Porcentaje de error entre la conversión-normalización de corriente  $i_{pv}$  teórica y experimental del circuito

En la figura 4.8 se puede observar el error entre la conversión de la corriente normalizada teórica y experimental, con un error porcentual máximo de 0,0024837%, un error promedio de 0,002478% y una desviación estándar de  $1,94953 \cdot 10^{-6}$ .



**Figura 4.9:** Comparación entre la conversión-normalización de tensión  $V_{pv}$  teórica y la simulación post-síntesis del circuito



**Figura 4.10:** Porcentaje de error entre la conversión-normalización de tensión  $V_{pv}$  teórica y del circuito

Un análisis similar al que se realizó para la conversión-normalización de la corriente, se utiliza para los resultados de la tensión. En la figura 4.9 se muestran los resultados obtenidos con una tensión de entrada y su normalización, tanto teórico como experimental. Se puede calcular el porcentaje de error entre ambas curvas (teórica y experimental). En la figura 4.10 se puede observar el error con un máximo de 0,0024837%, un error promedio de 0,002478% y una desviación estándar de  $1,94953 \cdot 10^{-6}$ .

Esta unidad contiene muchos bloques combinacionales, por lo que se requieren pocos ciclos de reloj en la máquina de estados para realizar la conversión y la normalización. Se requieren 8 ciclos de reloj para que el resultado sea concluido, esto se puede comprobar por medio de las simulaciones efectuadas al circuito, como se mostró en la figura 4.6 .



# Capítulo 5

## Sistema de linealización, conversión coma flotante a coma fija y normalización

En la implementación del circuito completo se utilizan dos etapas:

- *Corriente  $i_{pv}$* : El bloque para la corriente requiere las etapas de linealización, conversión de la salida del linealizador de coma flotante a coma fija, y un normalizador con una salida de corriente entre el rango [-1,1].
- *Tensión  $V_{pv}$* : La tensión del panel se trabaja de manera lineal, solo se requiere de un normalizador que contenga la salida de tensión entre el intervalo [0,1].



**Figura 5.1:** Diseño general de entradas y salidas para el sistema de linealización, conversión y normalización de corriente y tensión para un panel fotovoltaico.

El sistema de la figura 5.1 cuenta con 6 entradas y 4 salidas, estas se describen a continuación.

Entradas:

- *CLK*: Reloj del sistema.

- $I$ : Dato de corriente no lineal, en formato IEEE 754
- $V$ : Dato de tensión en formato IEEE 754
- $RST\_LN\_FF$ : Reset para las unidades de corriente y tensión.
- $Begin\_FSM\_I$ : Inicia la máquina de estados del linealizador de corriente.
- $Begin\_FSM\_V$ : Inicia la máquina de estados de el convertidor coma flotante-coma fija para la tensión.

Salidas:

- $ACK\_I$ : Indica que el resultado de las operaciones para la corriente se encuentra listo.
- $ACK\_V$ : Indica que el resultado de las operaciones para la tensión se encuentra listo.
- $RESULT\_I$ : Resultado de corriente lineal y normalizado en formato coma fija.
- $RESULT\_V$ : Resultado de tensión normalizado en formato coma fija.



**Figura 5.2:** Sistema de linealización, conversión y normalización de corriente y tensión para un panel fotovoltaico, con entradas: corriente  $i_{pv}$  y tensión  $V_{pv}$  y salidas de corriente y tensión lineales y normalizadas

La figura 5.2 muestra la distribución de bloques funcionales sincronizados con un mismo reloj ( $CLK$ ), para la corriente  $i_{pv}$  y tensión  $V_{pv}$  del panel fotovoltaico. Dentro de la sección de corriente se realiza primeramente la linealización, iniciando con las señales  $RST\_LN\_FF$  y  $Begin\_FSM\_I$  y el dato de entrada  $I$  (corriente  $i_{pv}$ ), una vez ejecutada la operación se envía una señal indicando que el dato esta listo  $ACK\_LN$ ; esta se conecta a la señal de entrada e inicio del convertidor-normalizador de corriente  $Begin\_FF$ . Un ciclo de reloj antes de que inicie la conversión-normalizacion, el resultado de la linealización ( $RESULT$ ) esta listo, este resultado linealizado se conecta a la entrada  $F$  del convertidor-

normalizador. La ejecución del resultado final linealizado y normalizado, se comprueba con la señal ACK\_I, esta indica que la conversión-normalización fue realizada y el resultado se encuentra en RESULT\_I (corriente lineal y normalizada en coma fija  $y'$ ).

El bloque de tensión funciona de manera similar al de corriente, iniciando con las señales RST\_LN\_FF y Begin\_FSM\_V y el dato de entrada V (tensión  $V_{pv}$ ). Una vez ejecutada la operación se envía una señal indicando que el dato esta listo ACK\_V y el resultado se despliega en RESULT\_V (tensión normalizada en coma fija  $z'$ ).

## 5.1 Sistema para realizar las pruebas en una placa de desarrollo Nexys-4

Para desarrollar las pruebas en la FPGA, se requirió diseñar e implementar un circuito para insertar datos a la entrada del linealizador-normalizador, sean procesados y posteriormente enviados por medio de transmisión serial hacia un computador.

En la figura 5.3 se muestra el diagrama de flujo utilizado para realizar las pruebas de simulación y comprobación de los resultados experimentales del circuito completo.



**Figura 5.3:** Diagrama de flujo general para el ambiente de verificación utilizado en el procesamiento de datos del circuito de linealización, ingresando los datos de entrada por medio de una memoria ROM y enviando los datos de salida por medio de transmisión serial (UART) desde la nexys-4 hacia un computador (Tomado de [15]).



**Figura 5.4:** Sistema de verificación para el linealizador, ingresando los datos de entrada por medio de una memoria ROM y enviando los datos de salida por medio de transmisión serial (UART) desde la nexys-4 hacia un computador

El diagrama de la figura 5.4 muestra el sistema utilizado. Primeramente se ingresan 1024 datos almacenados en una memoria ROM. Un archivo de texto contiene los datos de entrada para el linealizador-normalizador y se carga desde la memoria ROM. Para direccionar esta memoria se cuenta con un contador de 10 bits. La sección de transmisión posee una unidad UART (transmisión serial), esta se utiliza para enviar los resultados de la unidad de linealización-normalización hacia el computador. Los resultados linealizados-normalizados tienen un formato coma fija de 32 bits y el uart envía únicamente paquetes de 8 bits, por lo que se requiere enviar 4 paquetes por cada resultado, esto se logra por medio de una configuración de un multiplexor 4x1 y un contador; las entradas del multiplexor contienen el resultado dividido en paquetes de 8 bits, por medio del contador se selecciona el multiplexor según sea el paquete que se desea enviar. Por último se cuenta con un control para el circuito, este se encarga de llevar la sincronía de los datos. Se realiza una carga en el contador de la memoria ROM, este dirige la primera posición de la ROM y se inicia el procesamiento por parte de la unidad de linealización-normalización, con la señal *Begin\_op*; el control espera a que el resultado esté listo por medio de la señal ACK. Cuando se da la condición ACK=High, el sistema se encuentra listo para transmitir, el contador del multiplexor selecciona el primer paquete y lo envía. El siguiente paquete se puede transmitir hasta que el modulo UART envíe de vuelta al control, la señal *TX\_DONE*, así sucesivamente hasta que se envíen los 4 paquetes. Cuando la selección del multiplexor está en 2b'11 (contador del multiplexor), la señal *max\_tick\_mux* indica al control que debe realizar una cuenta para la dirección de la ROM y así tomar el siguiente dato a procesar. Este proceso se repite hasta que la cuenta de las direcciones de la ROM es 1023 y la señal *max\_tick\_add* = 1. La recepción de datos desde el computador se

realizó por medio de un puerto USB y un "script" realizado en Matlab. Este recibe los paquetes de un byte en hexadecimal y los concatena en paquetes de 4 bytes, para formar el dato en 32 bits, posteriormente se convierte a decimal.

## 5.2 Simulación del sistema de linealización, conversión coma flotante a coma fija y normalización, implementado en hardware mediante verilog

Este circuito se implementó por medio de la unión de los bloques anteriormente diseñados, implementados y simulados.

Para esta comprobacion se utilizaron 1000 valores que describen el comportamiento real de un PV, utilizando el modelo del panel. Este toma un valor de tensión  $V_{pv}$  para cada valor de tiempo a partir de la ecuación 5.1, y se sustituye en la ecuación 5.2 obteniendo valores de corriente de entrada  $i_{pv}$  para el linealizador.

$$V_{pv} = V_{cte} + 0.3 * V_{cte} * \sin(2 * \pi * 100 * t) \quad (5.1)$$

$$i_{pv} = Ig - \frac{V_{pv}}{R_p} - Is * \left( e^{\frac{V_{pv} * \alpha}{2}} \right) \quad (5.2)$$



**Figura 5.5:** Simulación del sistema de linealización-conversión-normalización de corriente y sistema de conversión- normalización de tensión para un panel fotovoltaico

La simulación básica ”behavioral” efectuada por Vivado, verifica el funcionamiento adecuado del circuito a manera de software y de lógica sin embargo no es suficiente ya que se debe realizar la síntesis e implementación, para esto se realizan las simulaciones post-synthesis y post-implementation, tanto del funcionamiento como de los retardos del sistema. La figura 5.5 muestra la simulación de tiempos posterior a la implementación, utilizando los valores de entrada de tensión y corriente a partir del modelo del panel.

### **5.3 Resultados del sistema de linealización, conversión coma flotante a coma fija y normalización implementado en una placa de desarrollo nexys-4**

Las simulaciones para el circuito completo brindan una mejor información acerca del porcentaje de error total obtenido dentro de la conexión de las tres etapas linealización, conversión y normalización. Se efectuaron las simulaciones de temporización y funcionalidad posterior a la síntesis, obteniendo resultados experimentales para realizar una comparación contra los teóricos esperados.

En el capítulo 3 se demostró el funcionamiento del linealizador con 8,12 y 15 iteraciones para el rango de convergencia del algoritmo de CORDIC, en este capítulo se utiliza el mismo principio de verificación, sin embargo se debe contemplar el error del normalizador, por lo que se realizan pruebas y comparaciones similares utilizando como datos de entrada un barrido de 1000 valores ingresados en el modelo teórico del panel fotovoltaico, esto con el fin de observar un comportamiento similar al real. Los valores de corriente son pequeños debido a la diferencia de corrientes y perdidas en el panel fotovoltaico, por lo que los porcentajes de error serán menores debido a que el circuito posee una mejor aproximación; en el extremo inferior del intervalo de convergencia del algoritmo CORDIC. La visualización de los resultados obtenidos se realiza de una mejor manera mediante gráficos que indican como se comporta el circuito ante datos de entrada, salida, y porcentaje de error. A partir de los resultados de las simulaciones, se puede analizar la frecuencia de ejecución a la que se obtiene un resultado linealizado-normalizado, esta depende del número de iteraciones que se utilice. El tiempo de ejecución de la unidad completa, contempla los ciclos de cada uno de los bloques funcionales que componen la ruta de ejecución de la corriente este circuito. Si tomamos el bloque para la tensión, este solo cuenta con la conversión-normalización y no depende del número de iteraciones por lo que se requieren de 8 ciclos de reloj por cada dato.

**Tabla 5.1:** Comparación de resultados experimentales obtenidos por del sistema de verificación implementado en una placa de desarrollo nexys-4, a partir de los valores de entrada del modelo del panel y utilizando 8, 12 y 15 iteraciones en el algoritmo de CORDIC. CLK=100MHz.

|                                 | 8 iteraciones | 12 iteraciones | 15 iteraciones |
|---------------------------------|---------------|----------------|----------------|
| Error máximo (%)                | 0,922         | 0,259          | 0,129          |
| Error promedio (%)              | 0,455         | 0,0351         | 0,0257         |
| Desviación estándar             | 0,2695        | 0,0253         | 0,0082         |
| Número de ciclos                | 468           | 668            | 826            |
| Frecuencia de ejecución (kHz)   | 217           | 151            | 121            |
| Tiempo de ejecución ( $\mu s$ ) | 4,68          | 6,68           | 8,26           |

Utilizando 8 iteraciones en el algoritmo de CORDIC y a partir de las simulaciones post-síntesis efectuadas por medio de la herramienta Vivado, se requiere de 468 ciclos de reloj para completar la ejecución de un dato, este se compone de 460 ciclos de reloj para el linealizador y 8 ciclos de reloj para el convertidor-normalizador, donde la velocidad de ejecución es de  $4,68\mu s$  (217kHz) con un reloj de sistema de 100MHz.



**Figura 5.6:** Comparación entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 8 iteraciones en el algoritmo de CORDIC del linealizador



**Figura 5.7:** Porcentaje de error entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 8 iteraciones en el algoritmo de CORDIC del linealizador

En la figura 5.6 se puede observar la comparación entre los datos obtenidos del circuito implementado en una placa nexys-4, contra los datos teóricos al realizar la misma función del circuito. Debido a que son solo 8 iteraciones el circuito posee un resultados aceptables pero poco exactos. El gráfico muestra que el algoritmo trata de mantenerse cerca de los valores reales, sin embargo posee un comportamiento escalonado, en donde para cierta cantidad de valores de entrada posee un mismo valor de salida constante cercano al valor real.

La figura 5.7 muestra el porcentaje de error asociado a cada valor de entrada linealizado y normalizado en formato coma fija, donde el porcentaje de error máximo es de 0,922% y un porcentaje de error promedio de 0,455% y una desviación estándar de 0,2695, esto para valores de corriente derivados a partir del modelo teórico del panel fotovoltaico.

Utilizando 12 iteraciones en el algoritmo de CORDIC, se requiere de 668 ciclos de reloj para realizar el procesamiento completo de un dato de entrada, 660 ciclos de reloj son utilizados por el linealizador y 8 ciclos de reloj para el convertidor-normalizador. Este se ejecuta con una velocidad de  $6.68\mu s$  (151kHz), utilizando un reloj de sistema de 100MHz.



**Figura 5.8:** Comparación entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 12 iteraciones en el algoritmo de CORDIC del linealizador



**Figura 5.9:** Porcentaje de error entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 12 iteraciones en el algoritmo de CORDIC del linealizador

En la figura 5.8 se puede observar la comparación entre los datos obtenidos experimentalmente contra los datos teóricos al realizar la misma función del circuito utilizando 12 iteraciones. Brinda una mejor exactitud contra 8 iteraciones y se puede observar que presenta una mayor suavidad en la curva, sin embargo presenta un comportamiento escalonado pero con valores más cercanos a la curva real. La figura 5.9 muestra el porcentaje de error asociado a cada valor de entrada linealizado con 12 iteraciones y normalizado en formato coma fija. Donde el porcentaje de error máximo es de 0,0897% y un porcentaje de error promedio de 0,0345% y una desviación estándar de 0,0253, esto para valores de corriente derivados a partir del modelo teórico del panel fotovoltaico.

En el sistema del panel es de suma importancia el tiempo de muestreo según sea la frecuencia del panel, esto implica velocidad de ejecución dentro del cálculo. Se logró determinar que con 15 iteraciones se obtienen resultados con muy buena exactitud, sin embargo el tiempo de ejecución aumenta a 826 ciclos de reloj, tomando en cuenta que 818 ciclos son requeridos por el linealizador y 8 ciclos de reloj para la conversión de formato IEEE 754 a coma fija y normalización. Donde la velocidad de ejecución es de  $8.26\mu s$  (121kHz) con un reloj de sistema de 100MHz.



**Figura 5.10:** Comparación entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 15 iteraciones en el algoritmo de CORDIC del linealizador



**Figura 5.11:** Porcentaje de error entre el valor teórico y el valor obtenido del circuito de linealización-conversión-normalización de corriente con 15 iteraciones en el algoritmo de CORDIC del linealizador

Con 15 iteraciones el valor experimental es muy similar al valor teórico, como se observa en la figura 5.10, y se puede comprobar en la figura 5.11 donde se muestra que el porcentaje de error es muy cercano a cero, con un valor máximo de 0,0483% y un error promedio de 0,0292% y una desviación estándar de 0,0082, esto para valores de corriente derivados a partir del modelo teórico del panel fotovoltaico.

El sistema de optimización se utilizará en un panel fotovoltaico que posee una frecuencia de 100kHz, es decir que el sistema de optimización debe realizar un cálculo completo a una velocidad mayor que el panel. Aproximadamente el sistema de linealización y normalización toma un 40% del total del tiempo de ejecución del sistema de optimización, por lo que se requiere realizar el cálculo en el tiempo indicado, para esto se deberá utilizar 8 iteraciones.

## 5.4 Recursos utilizados

**Tabla 5.2:** Resumen del reporte post implementación del uso de dispositivos generado por la herramienta Vivado.

| Recurso | Utilizados | Disponibles | Utilizados% |
|---------|------------|-------------|-------------|
| LUT     | 1017       | 63400       | 1.60        |
| FF      | 912        | 126800      | 0.72        |
| DSP     | 4          | 240         | 1.67        |
| IO      | 134        | 210         | 63.81       |
| BUFG    | 1          | 32          | 3.12        |

En la tabla 5.2 se muestra el uso de recursos para la implementación el circuito completo en la Nexys4, el máximo recurso utilizado son los puertos I/O debido a que se requieren 32 bits en cada entrada I,V y 32 bits en cada salida RESULT\_I , RESULT\_V, sin embargo el uso de los demás recursos es sumamente bajo, el uso de los I/O se reducirá debido a que este circuito se deben acoplar a otro bloques del sistema de optimización.

## 5.5 Reporte de tiempos

Dentro del reporte de tiempos se analizan las peores rutas ”ruta critica”, para un buen diseño se requiere de un slack positivo. El mayor slack del circuito linealizador-normalizador es de 4.5 lo que indica que los datos llegan a tiempo, con este slack se puede aproximar que el circuito puede funcionar a una frecuencia de 200MHz.

## 5.6 Consumo de potencia

Con la ayuda de las herramientas de análisis de potencia de Vivado, se pudo obtener los resultados que pertenecen al consumo de potencia, tanto estática como dinámica. En la tabla 5.3 se muestra el valor para cada consumo, y el total.

**Tabla 5.3:** Resumen del reporte post implementación de la potencia estática, dinámica y total, de la herramienta Vivado, para el sistema de linealización-normalización.

| Potencia | Consumo de potencia (mW) |
|----------|--------------------------|
| Dinámica | 11                       |
| Estática | 91                       |
| Total    | 102                      |

Para los recursos utilizados se puede realizar un estudio de consumo de potencia dinámica, estos resultados se muestran en la tabla 5.4 donde el mayor consumo de potencia se presenta por parte del reloj del sistema y señales, las señales que poseen un valor de cero no se refieren a un consumo nulo, si no que es relativamente pequeño en comparación con las señales mas criticas.

**Tabla 5.4:** Resumen del reporte generado por la herramienta Vivado que indica el consumo de potencia de diversos elementos.

| On-chip (mW) | Consumo de potencia (mW) |
|--------------|--------------------------|
| Clocks       | 4                        |
| Signals      | 4                        |
| Logic        | 3                        |
| DSP          | 0                        |
| I/O          | 0                        |



# Capítulo 6

## Conclusiones y recomendaciones

### 6.1 Conclusiones

- Se comprobó que es posible sintetizar la unidad de linealización-normalización con precisión aceptable utilizando versiones reducidas del estándar IEEE 754 (32bits).
- Se comprobó en el circuito linealizador que a mayor numero de iteraciones mayor exactitud presenta el resultado, sin embargo requiere un mayor tiempo de ejecución.
- Se verificó que para el circuito linealizador, el porcentaje de error máximo fue de 2.74% con 8 iteraciones en el rango de convergencia del algoritmo de CORDIC.
- Se comprobó que para el circuito convertidor-normalizador tanto de corriente como de tensión, el porcentaje de error máximo fue de 0,0024%.
- Se concluyó que se debe utilizar 8 iteraciones para cumplir con el tiempo de ejecución del linealizador-normalizador en el sistema de optimización para paneles solares.
- Se determinó que el módulo de la corriente consume más recursos que el módulo de tensión, dado que la corriente requiere de un modulo de linealización y a su vez mayor cantidad de hardware.

### 6.2 Recomendaciones

- Se utilizó un único sumador coma flotante para reducir el área del circuito sin embargo el espacio utilizado en la FPGA es muy poco, por lo tanto se podría realizar modificaciones para reducir el número de ciclos de cada iteración de la máquina de estados, implementando una arquitectura con cálculo de  $X_i$ ,  $Y_i$  y  $Z_i$  de manera paralela, es decir utilizar un sumador de coma flotante para cada variable de manera que se realicen los cálculos simultáneos, esta variación implica un aumento en el área sin embargo le aumentaría al alrededor de 3 veces más la velocidad de ejecución.
- Si se utiliza algún otro tipo de panel con el sistema y se requiere un rango de linealización más amplio se puede utilizar un algoritmo de CORDIC hiperbólico con una extensión de las iteraciones, agregando dos iteraciones negativas se puede

extender, de manera que no sea tan limitado, sin embargo se requiere de mayor cantidad de recursos para la implementación de estas dos iteraciones y puede ser mas lento en ejecución.

# Capítulo 7

## bibliográficas

- [1] Suskis, Pavels, and Ilya Galkin. "Enhanced photovoltaic panel model for MATLAB-simulink environment considering solar cell junction capacitance." Industrial Electronics Society, IECON 2013-39th Annual Conference of the IEEE. IEEE, 2013.
- [2] González-Longatt, Francisco M. "Model of photovoltaic module in Matlab." II CIBE-LEC 2005 (2005): 1-5.
- [3] C. Meza, R. Ortega. "Control and estimation scheme for PV central inventers", in 24th International Conference on information, Communication and Automation Technologies, Nov, 2013
- [4] Chiang, Ching-Tsan, Tung-Sheng Chiang, and Hou-Sheng Huang. "Modeling a photovoltaic power system by CMAC-GBF." Photovoltaic Energy Conversion, 2003. Proceedings of 3rd World Conference on. Vol. 3. IEEE, 2003.
- [5] Ibrahim, Muhammad Nasir, et al. "Hardware Implementation of Math Module Based on CORDIC Algorithm Using FPGA." Parallel and Distributed Systems (ICPADS), 2013 International Conference on. IEEE, 2013.
- [6] Walther, John S. "A unified algorithm for elementary functions." Proceedings of the May 18-20, 1971, spring joint computer conference. ACM, 1971.
- [7] Llamocca-Obregón, Daniel R., and Carla P. Agurto-Ríos. "A fixed-point implementation of the expanded hyperbolic CORDIC algorithm." Latin American applied research 37.1 (2007): 83-91.
- [8] Whitehead, Nathan, and Alex Fit-Florea. "Precision and performance: Floating point and IEEE 754 compliance for NVIDIA GPUs." rm (A+ B) 21 (2011): 1-1874919424.
- [9] Bello, C., et al. "Relevador portátil de curvas IV de paneles fotovoltaicos como herramienta de diagnostico in situ de sistemas de generación fotovoltaica." Avances en Energías Renovables y Medio Ambiente 13 (2009): 77-83.
- [10] Raygoza, Juan José, et al. "Implementación en hardware de un sumador de punto flotante basado en el estándar IEEE 754-2008." e-Gnosis 7 (2009).

- [11] Bube, Richard. Fundamentals of solar cells: photovoltaic solar energy conversion. Elsevier, 2012.
- [12] Boudabous, Anis, et al. "Implementation of hyperbolic functions using CORDIC algorithm." Microelectronics, 2004. ICM 2004 Proceedings. The 16th International Conference on. IEEE, 2004.
- [13] Mano, M. Morris. Arquitectura de computadoras. Pearson Educación, 1994.
- [14] Floyd, Thomas L. Fundamentos de sistemas digitales. Vol. 7. Prentice Hall, 2006.
- [15] C. Salazar. "Implementación de un microprocesador de aplicación específica para la ejecución del algoritmo de modelos ocultos de Markov en el reconocimiento de patrones acústicos", Escuela de Ingeniería en Electrónica, Instituto Tecnológico de Costa Rica, Dic, 2015