

#### CENTRO DE INVESTIGACIÓN Y DE ESTUDIOS AVANZADOS DEL IPN





Departamento de Ingeniería Eléctrica Sección de Electrónica del Estado Sólido

#### "Prototipo en FPGA de Red Neuronal con Memristores"

*Tesis que presenta:* Ing. Erick Moreno Cuellar

*Directores de Tesis:* Dr. Felipe Gómez Castañeda Dr. José Antonio Moreno Cadenas





## Contenido

- •<u>Objetivos</u>
- Introducción
- •Modelo Bipolar con Umbral del Memristor controlado por voltaje
- •Redes Neuronales Pulsadas
- •Algoritmos Metaheurísticos
- Resultados
- Conclusiones
- •Referencias





# Objetivos

#### General

Simular e implementar un modelo del Memristor en tecnología digital usando un sistema FPGA y mostrar diferentes aplicaciones.

#### **Específicos**

Implementar el modelo bipolar con umbral del memristor controlado por voltaje en la tarjeta Nexys 4DDR.

- Simular e implementar una neurona pulsada accesible computacionalmente para uso en FPGA.
- ≻Reproducir el experimento Pavlov's Dog usando el memristor como sinapsis entre neuronas.
- >Implementar una red neuronal pulsada con Memristores para el reconocimiento de caracteres.
- ≻Realizar una red de Memristores usándolos como análogo del algoritmo de hormigas.
- Simular una red de Memristores usada para la detección de bordes en imágenes.





## Contenido

#### Objetivos

#### •Introducción

- •Modelo Bipolar con Umbral del Memristor controlado por voltaje
- •Redes Neuronales Pulsadas
- •Algoritmos Metaheurísticos
- •Resultados
- Conclusiones
- •Referencias





# Introducción

El memristor, un dispositivo eléctrico propuesto por Chua plantea nuevas formas de interactuar con el resto de dispositivos electrónicos, puesto que combina dos funciones (almacenamiento y procesamiento) en un solo elemento.







# Evolución de elementos resistivos controlados por corriente



Figura 3 Interpretación de la familia de memristores según Biolek, ref .[9]





## Contenido

•Objetivos

Introducción

•Modelo Bipolar con Umbral del Memristor controlado por voltaje

•Redes Neuronales Pulsadas

•Algoritmos Metaheurísticos

•*Resultados* 

Conclusiones

•Referencias





# Modelo del Memristor Usado

Un simulador del Memristor debe contar con ciertas características[2]:

- 1. Un amplio rango de Memristancia.
- 2. No volatilidad.
- 3. Configuración del estado inicial.
- 4. Operación flotante.
- 5. Operatividad para alta frecuencia y señales continuas de entrada.
- 6. Capaz de interconectarse con otros dispositivos.







# Modelo del Memristor Usado

Modelo bipolar con umbral controlado por voltaje

1.  $i(t) = M^{-1} \cdot v(t)$ 2.  $\dot{M} = b \cdot v + \frac{1}{2}(a - b) \cdot (|v + v_T| - |v - v_T|) \cdot \theta(M - R_{ON}) \cdot \theta(R_{OFF} - M)$ 

Circuito utilizado para simular el aprendizaje de la ameba [3] y [4]







Figura 5 Cambio de R dependiendo del voltaje aplicado





## Contenido

Objetivos

Introducción

•Modelo Bipolar con Umbral del Memristor controlado por voltaje

•<u>Redes Neuronales Pulsadas</u>

•Algoritmos Metaheurísticos

•*Resultados* 

Conclusiones

•Referencias





# Redes Neuronales Pulsadas









# Redes Neuronales Pulsadas





Figura 8 Proceso Spike-Timing-Dependent-Plasticity (STDP), mostrando el cambio de los pesos sinápticos (1998).







## Contenido

•Objetivos

Introducción

•Modelo Bipolar con Umbral del Memristor controlado por voltaje

•Redes Neuronales Pulsadas

- •Algoritmos Metaheurísticos
- •*Resultados*
- Conclusiones
- •Referencias





# Algoritmos Metaheurísticos



Figura 10 Función objetivo con mínimos locales, tomado de [6]

- Las Metaheurísticas distribuidas permiten la salida de una solución particular.
- Ayudan a realizar una mejor búsqueda contra los mínimos locales.









Figura 11 Ejemplo, algoritmo de hormigas proveniente de [6]

Propagación estocástica de agentes (hormigas)

1.- 
$$p_{ij,k} = \frac{\tau_{ij}^{\alpha}\eta_{ij}^{\beta}}{\sum\limits_{m} \tau_{im}^{\alpha}\eta_{im}^{\beta}},$$

2.- 
$$\tau_{ij}(k+1) = (1-\rho)\tau_{ij}(k) + \nu \frac{Q}{L_k},$$



# Algoritmo Metaheurístico de Colonia de Hormigas



| Naturaleza          | Algoritmo de Hormigas     | Memcomputing             |
|---------------------|---------------------------|--------------------------|
| Hábitat natural     | Grafo                     | Red de memristores       |
| Hormigas            | Hormigas artificiales     | Electrones               |
| Longitud del camino | Reciproco de la distancia | Conductancia             |
| Feromonas           | Feromonas artificiales    | Memoria del dispositivo  |
| Evaporación de      | Evaporación artificial de | Estado de relajación del |
| feromonas           | feromonas                 | dispositivo              |
| Comportamiento de   | Reglas de selección       | Leyes de Kirchhoff       |
| búsqueda            |                           |                          |



Tabla de equivalencia propuesta por Y. V. Pershin y M. Di Ventra [7].

Figura 12 Red de Memristores, análogos al algoritmo de optimización de hormigas





## Contenido

Objetivos

Introducción

•Modelo Bipolar con Umbral del Memristor controlado por voltaje

•Redes Neuronales Pulsadas

•Algoritmos Metaheurísticos

•<u>Resultados</u>

Conclusiones

•Referencias



# Desarrollo de prototipo en FPGA (proceso)





# Resultados: Simulación e Implementación del Memristor



Implementación del Memristor en el FPGA

| Nexys 4 DDR Artix-7 |             |                           |
|---------------------|-------------|---------------------------|
| DSPs                | 20 (8.3%)   | Punto flotante<br>32 bits |
| LUTs                | 3141 (5%)   | 0 - 0.00                  |
| Registers           | 38 (<0.6%)  |                           |
|                     |             |                           |
| Nexys 4 D           | Punto fijo  |                           |
| DSPs                | 18 (7.5%)   | 18 bits                   |
| LUTs                | 3487 (5.5%) |                           |
| Registers           | 76(<0.6%)   |                           |
|                     |             |                           |





# Resultados: Simulación e Implementación del Memristor

Modelo bipolar con umbral controlado por voltaje





Simulación e Implementación del Memristor



 $a = -2000 \frac{\Omega}{V_{rs}}, b = -190\ 000 \frac{\Omega}{V_{rs}}, \Delta t = 0.0005s, V_T = 1V, R_{min} = 100\Omega, R_{max} = 10k\Omega$ 







## Simulación e Implementación del Memristor



Comparación entre la simulación realizada con Simulink (línea puntada roja) y los resultados obtenidos en la implementación realizada con System Generator y el FPGA.





## Resultados: Verificación de los Fingerprints



System Generator en cosimulación con la tarjeta Nexys 4 DDR Artix 7 FPGA

Figura 17 Verificación de los fingerprints en System Generator

Valores utilizados en todos los casos

$$a = -2000 \frac{\Omega}{V \cdot s}$$
,  $b = -190\ 000 \frac{\Omega}{V \cdot s}$ ,  $\Delta t = 0.0001s$ ,  $V_T = 1V$ ,  $R_{min} = 100\Omega$ ,  $R_{max} = 10k\Omega$ ,  $R_{init} = R_{max}$ 

El voltaje aplicado es:  $v(t) = 3\sin(2\pi f t)$ 





#### Capacidad de ajuste multi-estado.



Figura 18 Comparación entre resultados de Simulink y System Generator





## Simulación e Implementación de la Neurona



Implementación de la neurona en el FPGA





#### Simulación e Implementación de la Neurona







#### Simulación e Implementación de la Neurona







## Resultados: "Pavlov's dog"



Figura 21 Ejemplo del experimento Pavlov's dog y diagrama a implementar.





#### Resultados: ANN con Memoria Asociativa



Implementación de ANN en el FPGA

| Nexys 4 DDR Artix-7 |             |  |  |
|---------------------|-------------|--|--|
| DSPs                | 81 (34%)    |  |  |
| LUTs                | 15359 (22%) |  |  |
| Registers           | 403 (<1%)   |  |  |



Figura 22 Nexys 4 DDR Artix-7





#### Resultados: ANN con Pavlov's dog







#### Resultados: ANN con Pavlov's dog



Figura 24 Cambio de Memristancia en el experimento Pavlov's dog implementado

Valores utilizados en la ANN

$$a = 0 \frac{\Omega}{V \cdot s}$$
,  $b = -15\ 000 \frac{\Omega}{V \cdot s}$ ,  $\Delta t = 0.0001s$ ,  $V_T = 4V$ ,  $R_{min} = 675\Omega$ ,  $R_{max} = 10k\Omega$ ,  $R_{init\ sonido} = R_{max}$ ,  $R_{init\ comida} = R_{min}$ 





#### Resultados: Reconocimiento de caracteres en una

matriz dinámica

Implementación matriz 3x3 en FPGA

| Nexys 4 DDR Artix-7 |             |  |  |
|---------------------|-------------|--|--|
| DSPs                | 194 (81%)   |  |  |
| LUTs                | 33075 (52%) |  |  |
| Registers           | 954 (<1%)   |  |  |



Nexys 4 DDR Artix-7







Resultados: Reconocimiento de caracteres en una matriz dinámica

Figura 25 Alfabeto y números en matriz 3x3



Figura 26 Resultados a) Cambio de pesos sinápticos (Memristancia), b)MSE al reconocer los caracteres





Resultados: Uso del memristor en redes para realizar un análogo del algoritmo de hormigas



1.  $i(t) = M^{-1} \cdot v(t)$ 2.  $\dot{M} = \left[b \cdot v + \frac{1}{2}(a - b) \cdot (|v + v_T| - |v - v_T|) \cdot \theta(M - R_{ON}) \cdot \theta(R_{OFF} - M)\right] + \Gamma M$   $\Gamma = 50$ 



Nexys 4 DDR Artix-7

240(100%)

34165(54%)

638(>1%)

DSPs

LUTs

Registers



# Resultados: Uso del memristor en redes para realizar un análogo del algoritmo de hormigas



Figura 28 a) Cambio de Memductancia, b) Cambio de Memristancia

$$a = 0 \frac{\Omega}{V \cdot s}$$
,  $b = -190000 \frac{\Omega}{V \cdot s}$ ,  $\Delta t = 0.0001s$ ,  $V_T = 0.035V$ ,  $R_{min} = 400\Omega$ ,  $R_{max} = 1M\Omega$ ,  $R_{init} = 100K\Omega$ .







Figura 30 Posibles caminos a recorrer por las hormigas [8]

$$\eta_{(i,j)} = \frac{1}{I_{\text{Max}}} \begin{bmatrix} |I(i,j-1) - I(i,j+1)| \\ + |I(i-1,j) - I(i+1,j)| \end{bmatrix}$$

2).  

$$p_{\text{path}_{m}} = \frac{\prod_{(i_{t},j_{t})\in\text{path}_{m}} \tau_{(i_{t},j_{t})}^{\alpha} (1/\text{Le}_{\text{path}_{m}})^{\beta}}{\sum_{f=1}^{M} \prod_{(i_{t},j_{t})\in\text{path}_{f}} \tau_{(i_{t},j_{t})}^{\alpha} (1/\text{Le}_{\text{path}_{f}})^{\beta}}$$

$$\text{Le}_{\text{path}_{m}} = \sum_{(i_{t},j_{t})\in\text{path}_{m}} \eta_{(i_{t},j_{t})}^{-1}$$

3). 
$$\tau_{(i,j)}(k+1) = (1-\rho)\tau_{(i,j)} + \frac{\nu Q}{\text{Le}_{\text{path}_m}}$$





1)- 
$$\eta_{(i,j)} = \frac{1}{I_{\text{Max}}} \begin{bmatrix} |I(i,j-1) - I(i,j+1)| \\ +|I(i-1,j) - I(i+1,j)| \end{bmatrix}$$





Figura 32 Caminos propuestos a recorrer



Figura 33 Imagen elegida para realizar el algoritmo







Figura 34 Imagen original



Figura 35 Feromonas, 7t, ini2, 2s



Figura 36 Memristores 0.01t (100t). 3uA, ini2, 41s

$$a = 0 \frac{\Omega}{V \cdot s}$$
,  $b = -196\ 000\ 000 \frac{\Omega}{V \cdot s}$ ,  $\Delta t = 0.0001s$ ,  $V_T = 0.035V$ ,  $R_{min} = 400\Omega$ ,  $R_{max} = 1M\Omega$ ,  $\Gamma = 50$ , I=3uA.







Figura 37 Imagen Lenna original

Figura 38 Feromonas, 7t, ini1, 2s

Figura 39 Feromonas, 7t, ini2, 2s

Figura 40 Memristores 0.01t.(100t) 3uA, ini2. 18s

Figura 41 Memristores 0.01t.(100t) 6uA, ini2, 18s







Figura 42 Imagen original





Figura 45 Algoritmo Canny, 3s

Figura 43 Feromonas, 7t, ini2, 3s

Figura 44 Memristores 0.01t(100t), 3uA, ini2, 62s





# Conclusiones

>Se concluye que el modelo del memristor bipolar con umbral controlado por voltaje es viable para utilizarse en otras implementaciones, ya que demostró ser capaz de ajustarse a los distintos usos que se le dieron.

Dada la versatilidad del modelo del memristor, este resulta útil para ser modificado y obtener comportamientos mas complejos del memristor.

Los recursos utilizados por el memristor pueden ser optimizados dependiendo de la aplicación.





# Conclusiones

➢La neurona simplificada funciona correctamente, y es posible optimizarla para que los recursos consumidos del FPGA sean mínimos sin perder sus características.

Se comprobó la propuesta del memristor como análogo del algoritmo de hormigas.

Se obtuvieron mejores resultados del procesamiento de imágenes con memristores vs el algoritmo de hormigas clásico.





# Referencias

[1] D. B. Strukov, G. S. Snider, D. R. Stewart and R. S. Williams, "The Missing Memristor Found", Nature 453, 80-83, 2008.

[2] V. Ntinas, I. Vourkas, A. Abusleme, G. CH. Sirakoulis and A. Rubio, *"Experimental Study of Artificial Neural Networks Using a Digital Memristor Simulator"*, Transactions on Neural Networks and Learning Systems, VOL. 29, NO. 10, 2018.

[3] Y. V. Pershin, S. La Fontaine and M. Di Ventra, "Memristive Model of Amoeba Learning", Physical Review E 80, 021926 2009.

[4] T. Saigusa, "Amoebae Anticipate Periodic Events", Physical Review Letters , January 2008.

[5] B. Linares-Barranco and T. Serrano-Gotarredona *"Memristance Can Explain Spike-Time-Dependent-Plasticity in Neural Synapses"*, NaturePrecedings, 2009.

[6] P. Siarry (Editor), "Metaheuristics", Springer International Publishing, Switzerland, 2016.

[7] Y. V. Pershin and M. Di Ventra, "Memcomputing and Swarm Intelligence", eprint arXiv:1408.6741, 2014.

[8] Z. Pajouhi and K. Roy, "Image Edge Detection Based on Swarm Intelligence Using Memristive Networks", IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 37, no. 9, pp. 1774-1787, 2018

D. Biolek and Z. Biolek, "About Fingerprints of Chua's Memristors" IEEE Circuits and Systems Magazine, vol. 18, no. 2, pp. 35-47, 2018.

#### Datos

 $\mu v$ : movilidad iónica promedio 10^-14 m^2/S^-1V^-1

Lenna 220x220

Canny 510x341

Peras 450x253