Lenia

De Wikipedia, la enciclopedia libre
Un ejemplo de patrón autónomo de Lenia.
Una animación que muestra el movimiento de un planeador en Lenia.

Lenia es una familia de autómatas celulares creada por Bert Wang-Chak Chan. [1][2][3]​ Lenia pretende ser una generalización continua del Juego de la vida de Conway, con estados, y espacio continuos. Como consecuencia de su dominio continuo de alta resolución, los patrones autónomos complejos ("formas de vida" o "naves espaciales") generados en Lenia son diferentes de los que aparecen en otros autómatas celulares, siendo "geométricos, metaméricos, difusos, resistentes, adaptativos y de reglas genéricas". [1]

Lenia ganó el Concurso de Criaturas Virtuales de 2018 en la Conferencia de Computación Genética y Evolutiva en Kioto, [4]​ una mención de honor para el Premio de Arte ALIFE en ALIFE 2018 en Tokio, [5]​ y la Publicación Destacada de 2019 de la International Society for Artificial Life (ISAL). [6]

Reglas[editar]

Actualizaciones iterativas[editar]

Sea la red o cuadrícula conteniendo un conjunto de estados . Como muchos autómatas celulares, Lenia es actualizado de forma iterativa; cada estado de salida es una función pura del estado anterior, de modo que

dónde es el estado inicial y es la regla global, que representa la aplicación de la regla local sobre cada sitio . De este modo .

Si la simulación es avanzada por en cada paso de tiempo, entonces la resolución de tiempo .

Conjuntos de estados[editar]

Sea con un máximo . Este es el conjunto de estados del autómata y caracteriza los posibles estados que se pueden encontrar en cada sitio. más grandes corresponden a resoluciones de estado más altas en la simulación. Muchos autómatas celulares utilizan la resolución de estado más baja posible, es decir . Lenia permite resoluciones mucho más altas. Tenga en cuenta que el valor real en cada sitio no está en sino más bien un múltiplo entero de  ; por lo tanto tenemos para todo . Por ejemplo, dado , .

Vecindarios[editar]

Una vecindad de Moore de 9 cuadrados como los que se utilizan en el Juego de la vida.
Los vecinos de "bola" utilizados por Lenia.

Matemáticamente, los vecinos como los del Juego de la vida pueden ser representados utilizando un conjunto de vectores de posición en . Para el clásico vecindario de Moore utilizado por el Juego de la vida, por ejemplo,  ; es decir, un cuadrado de tamaño 3 centrado en cada sitio.

En el caso de Lenia, el vecindario es en cambio una bola de radio centrada en un sitio, , que puede incluir el propio sitio original.

Tenga en cuenta que los vectores de vecindad no son la posición absoluta de los elementos, sino más bien un conjunto de posiciones relativas (deltas) con respecto a cualquier sitio determinado.

Regla local[editar]

Existen variantes discretas y continuas de Lenia. Sea un vector en dentro representando la posición de un sitio dado, y el conjunto de sitios vecinos de . Ambas variaciones comprenden dos etapas:

  1. Usando un kernel (núcleo) de convolución para calcular la distribución potencial .
  2. Usando una mapeo (función) de crecimiento para calcular la distribución de crecimiento final .

Una vez es calculado, se escala según la resolución de tiempo elegida y es agregado al valor del estado original:

Aquí, la función de corte (clip) está definida por .

Para Lenia discreta y continua, las reglas locales se definen de la siguiente manera:

Generación del kernel (núcleo)[editar]

El shell del kernel, el esqueleto del kernel y las funciones de crecimiento de Lenia.

Hay muchas formas de generar el kernel de convolución. . El kernel final es la composición de un shell (caparazón) del kernel. y un esqueleto de kernel .


Para el shell del kernel , Chan da varias funciones que se definen radialmente . Las funciones del shell del kernel son unimodales y están sujetas a la restricción (y típicamente, también ). Las funciones del kernel de ejemplo incluyen:

Aquí, es la función indicadora . Una vez que se ha definido el shell del kernel, el esqueleto del kernel se utiliza para expandirlo y calcular los valores reales del kernel transformando el shell en una serie de anillos concéntricos . La altura de cada anillo está controlada por un vector de pico del kernel. , dónde es el rango del vector de parámetros. Entonces el esqueleto del kernel Se define como
El kernel final es, por lo tanto
tal que está normalizado para tener una suma de elementos de y (para la conservación de masa ), con para el caso discreto, y en el caso continuo.

Mapeos de crecimiento[editar]

El mapeo del crecimiento , que es análogo a una función de activación, puede ser cualquier función unimodal, no monótona y que acepte parámetros . Algunos ejemplos incluyen

dónde es un valor potencial extraído de .

El juego de la vida[editar]

El Juego de la vida puede considerarse como un caso especial de Lenia discreta con . En este caso, el kernel sería rectangular, con la función

y la regla de crecimiento también rectangular, con .

Patrones[editar]

Algunos ejemplos de la gran variedad de "especies" de Lenia.

Al variar el kernel convolucional, el mapeo de crecimiento y la condición inicial, se han descubierto en Lenia más de 400 "especies" de "vida", que muestran "autoorganización, autorreparación, simetrías bilaterales y radiales, dinámica locomotora y, a veces, una naturaleza caótica". [7]​ Chan ha creado una taxonomía para estos patrones. [1]

Trabajo relacionado[editar]

Autómatas celulares como una red neuronal convolucional. [8]

Otros trabajos han notado la gran similitud entre las reglas de actualización de los autómatas celulares y las convoluciones. De hecho, estos trabajos se han centrado en la reproducción de autómatas celulares utilizando redes neuronales convolucionales simplificadas. Mordvintsev et al. investigó el surgimiento de la generación de patrones autorreparadores. [9]​ Gilpin descubrió que cualquier autómata celular podría representarse como una red neuronal convolucional y entrenó redes neuronales para reproducir autómatas celulares existentes [8]

Desde este punto de vista, los autómatas celulares pueden verse como un caso especial de redes neuronales convolucionales recurrentes . La regla de actualización de Lenia también puede verse como una convolución de una sola capa (el "campo potencial" ) con una función de activación (el "mapeo de crecimiento" ). Sin embargo, Lenia utiliza kernels fijos mucho más grandes y no se entrenan mediante el descenso de gradiente.

Véase también[editar]

Enlaces externos[editar]

Referencias[editar]

  1. a b c Chan, Bert Wang-Chak (15 de octubre de 2019). «Lenia: Biology of Artificial Life». Complex Systems 28 (3): 251-286. arXiv:1812.05433. doi:10.25088/ComplexSystems.28.3.251.  Error en la cita: Etiqueta <ref> no válida; el nombre «:0» está definido varias veces con contenidos diferentes
  2. «Lenia». chakazul.github.io. Consultado el 12 de octubre de 2021. 
  3. Roberts, Siobhan (28 de diciembre de 2020). «The Lasting Lessons of John Conway’s Game of Life». The New York Times (en inglés estadounidense). ISSN 0362-4331. Consultado el 13 de octubre de 2021. 
  4. «The virtual creatures competition». virtualcreatures.github.io. Consultado el 12 de octubre de 2021. 
  5. «ALife Art Award 2018». ALIFE Art Award 2018 (en inglés estadounidense). Consultado el 12 de octubre de 2021. 
  6. «2020 ISAL Awards: Winners». 
  7. «Lenia». chakazul.github.io. Consultado el 13 de octubre de 2021. 
  8. a b Gilpin, William (4 de septiembre de 2019). «Cellular automata as convolutional neural networks». Physical Review E (en inglés) 100 (3): 032402. ISSN 2470-0045. arXiv:1809.02942. doi:10.1103/PhysRevE.100.032402.  Error en la cita: Etiqueta <ref> no válida; el nombre «Gilpin 032402» está definido varias veces con contenidos diferentes
  9. Mordvintsev, Alexander; Randazzo, Ettore; Niklasson, Eyvind; Levin, Michael (11 de febrero de 2020). «Growing Neural Cellular Automata». Distill (en inglés) 5 (2): e23. ISSN 2476-0757. doi:10.23915/distill.00023.