Ir al contenido

Inteligencia artificial (videojuegos)

De Wikipedia, la enciclopedia libre

La inteligencia artificial en los videojuegos se utiliza para generar comportamientos responsivos, adaptativos o inteligentes principalmente en personajes no jugables (NPC) similares a la inteligencia humana. La inteligencia artificial ha sido una parte integral de los videojuegos desde sus inicios en 1948, visto por primera vez en el juego Nim. [1]​Se utiliza para mejorar la experiencia del jugador en lugar del aprendizaje automático o la toma de decisiones.

Durante la «época dorada de los videojuegos arcade», la idea de oponentes de IA se popularizó en gran medida en forma de niveles de dificultad graduados, patrones de movimiento distintos y eventos en el juego que dependían de la participación del jugador. Los juegos modernos a menudo implementan técnicas existentes, como la búsqueda de caminos y los árboles de decisión, para guiar las acciones de los NPC. La IA se utiliza a menudo en mecanismos que no son inmediatamente visibles para el usuario, como la extracción de datos y la generación de contenido procedimental.[2]​Uno de los ejemplos más infames de esta tecnología NPC y niveles de dificultad graduales se puede encontrar en el juego «Punch-Out!!».[3]

A diferencia de lo que se podría pensar, la IA en los videojuegos no se enfoca en desarrollar una inteligencia artificial completa capaz de pasar el test de Turing y simular una mente humana. En su lugar, se centra en crear comportamientos específicos y realistas para los personajes no jugadores.

Descripción

[editar]

El término «IA de juego» («game ai» en inglés) se utiliza para referirse a un amplio conjunto de algoritmos que también incluyen técnicas de la teoría del control, la robótica, la infografía y la informática en general, y, por lo tanto, la IA de los videojuegos a menudo puede no constituir una «verdadera IA» en el sentido de que dichas técnicas no necesariamente facilitan el aprendizaje por computadora u otros criterios estándar, constituyendo únicamente «computación automatizada» o un conjunto predeterminado y limitado de respuestas a un conjunto predeterminado y limitado de entradas.[4][5][6]

Expertos en el campo de la inteligencia artificial han argumentado que la IA de videojuegos no es inteligencia verdadera, sino una palabra de moda publicitaria utilizada para describir programas informáticos que usan simples algoritmos de clasificación y coincidencia para crear la ilusión de comportamiento inteligente, mientras otorgan al software un «aura engañosa» de complejidad y avance científico o tecnológico.[4][5][6][7]​Dado que la IA del juego para NPC se centra en la apariencia de inteligencia y una buena jugabilidad dentro de las restricciones del entorno, su enfoque es muy diferente al de la IA tradicional.

Historia

[editar]

Los juegos siempre han sido un área de investigación en inteligencia artificial desde sus inicios. Uno de los primeros ejemplos de IA es el juego computarizado Nim, creado en 1951 y publicado en 1952. A pesar haber sido tecnología avanzada para su época, 20 años antes, el juego de arcade «Pong», tenía la forma de una caja relativamente pequeña y podía ganar regularmente incluso contra jugadores altamente hábiles.[1]​En 1951, utilizando la máquina Ferranti Mark 1 de la Universidad de Mánchester, Christopher Strachey programó un juego de damas y Dietrich Prinz programó uno para ajedrez.[8]​Estos estuvieron entre los primeros programas de computadora jamás escritos. El programa de damas de Arthur Samuel, desarrollado a mediados de los años 50 y principios de los 60, finalmente alcanzó la habilidad suficiente para desafiar a un aficionado experto.[9]​El trabajo en damas y ajedrez culminaría con la derrota de Garry Kasparov por la computadora Deep Blue de IBM en 1997. Los primeros videojuegos desarrollados en las décadas de 1960 y 1970, como Spacewar!, Pong y Gotcha (1973), fueron juegos implementados con lógica discreta y basados estrictamente en la competencia entre dos jugadores, sin inteligencia artificial.

Los juegos que presentaban un modo para un jugador con enemigos comenzaron a aparecer en la década de 1970. Los primeros juegos notables para salas de juegos aparecieron en 1974: Speed Race de Taito (juego de carreras) y Qwak y Pursuit de Atari (juego de disparos con pistola de luz y simulador de combate aéreo respectivamente). Dos juegos de ordenador basados ​​en texto, Star Trek (1971) y Hunt the Wumpus (1973), también tenían enemigos. El movimiento enemigo se basaba en patrones almacenados. La incorporación de microprocesadores permitiría más cálculo y elementos aleatorios superpuestos en patrones de movimiento.

Jugadores en bicicletas compitiendo por ser el último en quedar eliminado, en GLtron.

Fue durante la «época dorada de los videojuegos arcade» que la idea de oponentes con inteligencia artificial se popularizó ampliamente, gracias al éxito de Space Invaders (1978), que presentaba un nivel de dificultad creciente, patrones de movimiento distintos y eventos dentro del juego basados en funciones hash generadas a partir de las acciones del jugador. Galaxian (1979) presentó movimientos enemigos más complejos y variados, incluyendo maniobras individuales de enemigos que se salían de la formación. Pac-Man (1980) introdujo patrones de inteligencia artificial en los juegos de laberintos, con la peculiaridad adicional de diferentes personalidades para cada enemigo. Karate Champ (1984) luego introdujo patrones de inteligencia artificial en los juegos de lucha. First Queen (1988) fue un juego de rol de acción táctica que presentaba personajes que podían ser controlados por la IA de la computadora para seguir al líder.[10][11]​El videojuego de rol Dragon Quest IV (1990) introdujo un sistema de «tácticas» que permitía al jugador ajustar las rutinas de inteligencia artificial de los NPC durante la batalla, un concepto que luego fue presentado en el género de acción RPG por Secret of Mana (1993).

Juegos de fútbol como Madden Football, Earl Weaver Baseball y Tony La Russa Baseball basaron su IA en un intento de duplicar en la computadora el estilo de entrenamiento o gestión de la celebridad seleccionada. Los títulos deportivos posteriores permitieron a los usuarios «sintonizar» variables en la IA para producir una estrategia de gestión o entrenamiento definida por el jugador.

Un robot compitiendo en Robocup.

La aparición de nuevos géneros de videojuegos en los años 90 impulsó el uso de herramientas formales de inteligencia artificial como las máquinas de estados finitos. Los juegos de estrategia en tiempo real exigieron a la IA manejar muchos objetos, información incompleta, problemas de búsqueda de rutas, decisiones en tiempo real y planificación económica, entre otras cosas.[12]​ Por ejemplo, Herzog Zwei (1989) tenía un sistema de búsqueda de rutas prácticamente «roto», mientras que Dune II (1992) atacaba la base del jugador en línea recta y usaba numerosos trucos.[12]​Aunque los primeros juegos del género tuvieron problemas notorios, los juegos posteriores del género exhibieron una IA más sofisticada.

Juegos posteriores han utilizado métodos de IA de tipo Top-down y bottom-up, como el comportamiento emergente y la evaluación de las acciones del jugador en juegos como Creatures o Black & White. Façade (historia interactiva) fue lanzado en 2005 y utilizó diálogos interactivos múltiples y la IA como aspecto principal del juego.

Los juegos han proporcionado un entorno para desarrollar inteligencia artificial con aplicaciones potenciales más allá. Algunos ejemplos incluyen a Watson, una computadora que juega Jeopardy!, y el torneo RoboCup, donde se entrenan robots para competir en fútbol.[13]

Usos

[editar]

Videojuegos modernos

[editar]
Árbol de decisión con sus diferentes elementos: nodo, vectores, flechas y etiquetas

Los algoritmos heurísticos/de IA de juegos se utilizan en una amplia variedad de campos bastante dispares dentro de un juego. El más conocido es el control de cualquier NPC del juego, aunque el «scripting» (árbol de decisiones) es actualmente el medio de control más común.[14]​Estos árboles de decisiones escritos a mano a menudo resultan en «estupidez artificial», como comportamientos repetitivos, pérdida de inmersión o comportamientos anormales en situaciones que los desarrolladores no planearon.[15]​La búsqueda de camino, otro uso común de la IA, es muy utilizada en juegos de estrategia en tiempo real. La búsqueda de camino es el método para determinar cómo llevar un personaje no jugable (NPC) de un punto a otro en un mapa, teniendo en cuenta el terreno, los obstáculos y posiblemente la «niebla de guerra».[16][17]​Los videojuegos comerciales suelen utilizar un "buscador de caminos basado en cuadrícula" rápido y simple, en el que el terreno se mapea en una cuadrícula rígida de cuadrados uniformes y se aplica un algoritmo de búsqueda de caminos como A* o IDA* a la cuadrícula.[18][19][20]​En lugar de simplemente una cuadrícula rígida, algunos juegos usan polígonos irregulares y ensamblan una malla de navegación a partir de las áreas del mapa hacia las que los NPC pueden caminar.[18][21]​Como tercer método, a veces resulta conveniente para los desarrolladores seleccionar manualmente «puntos de ruta» que los personajes no jugables (NPCs) deben utilizar para navegar; el costo es que dichos puntos de ruta pueden crear movimientos de aspecto artificial. Además, los puntos de ruta tienden a funcionar peor que las mallas de navegación en entornos complejos.[22][23]​La navegación en juegos de estrategia dinámica con un gran número de unidades, como Age of Empires (1997) o Civilization V (2010), a menudo funciona mal; Las unidades a menudo se interponen en el camino de otras unidades.[23]

En lugar de mejorar la IA del juego para resolver adecuadamente un problema difícil en el entorno virtual, suele ser más rentable simplemente modificar el escenario para hacerlo más manejable. Si la búsqueda de rutas se atasca en un obstáculo específico, un desarrollador puede simplemente mover o eliminar el obstáculo.[24]​Por ejemplo, en Half-Life (1998), el algoritmo de búsqueda de caminos a veces fallaba en encontrar una manera razonable para que todos los NPC escaparan de una granada lanzada; en lugar de permitir que los PNCs intentaran escapar torpemente y arriesgarse a parecer estúpidos, los desarrolladores los programaron para que se agacharan y se cubrieran en su lugar en esa situación.[25]

Generación de contenido procedimental (PCG)

[editar]
Diagrama de Voronoi en movimiento creado con nueve semillas utilizando la distancia euclidiana

La generación de contenido procedimental (PCG) es una técnica de inteligencia artificial para crear contenido dentro del juego de forma autónoma a través de algoritmos con una mínima participación de los diseñadores. El PCG se utiliza típicamente para generar dinámicamente características del juego como niveles, diálogos de NPCs y sonidos. Los desarrolladores ingresan parámetros específicos para guiar a los algoritmos en la creación de contenido. El PCG ofrece numerosas ventajas tanto desde el punto de vista del desarrollo como de la experiencia del jugador. Los estudios de juegos pueden gastar menos dinero en artistas y ahorrar tiempo en producción.[26]​Los jugadores disfrutan de una experiencia nueva y altamente reproducible, ya que el juego genera contenido nuevo cada vez que juegan. El PCG permite que el contenido del juego se adapte en tiempo real a las acciones del jugador.[27]

Niveles generados procedimentalmente

[editar]

Los algoritmos generativos (una forma rudimentaria de IA) se han utilizado para la creación de niveles durante décadas. El icónico juego de computadora de mazmorras Rogue de 1980 es un ejemplo fundamental. Los jugadores tienen la tarea de descender a través de los niveles cada vez más difíciles de una mazmorra para recuperar el Amuleto de Yendor. Los niveles de la mazmorra se generan algorítmicamente al comienzo de cada juego. El archivo de guardado se elimina cada vez que el jugador muere.[28]​La generación algorítmica de mazmorras crea una jugabilidad única que de otro modo no estaría ahí, ya que el objetivo de recuperar el amuleto es el mismo cada vez.

Las opiniones sobre la generación total de niveles como se ve en juegos como Rogue pueden variar. Algunos desarrolladores pueden ser escépticos sobre la calidad del contenido generado y desean crear un mundo con una sensación más «humana», por lo que usarán PCG con más moderación.[29]​Por consiguiente, solo utilizarán la generación procedural para crear componentes específicos de un nivel diseñado manualmente. Un ejemplo notable de esto es el juego de disparos táctico de Ubisoft, Tom Clancy's Ghost Recon Wildlands (2017). Los desarrolladores utilizaron un algoritmo de búsqueda de caminos entrenado con un conjunto de datos de mapas reales para crear redes de carreteras que serpentearan a través de aldeas hechas a mano dentro del mundo del juego.[30]

A medida que la IA ha avanzado, los objetivos de los desarrolladores están cambiando hacia la creación de repositorios masivos de niveles a partir de conjuntos de datos. En 2023, investigadores de la Universidad de Nueva York y la Universidad de Witwatersrand entrenaron un gran modelo de lenguaje para generar niveles al estilo del juego de rompecabezas Sokoban de 1981. Descubrieron que el modelo sobresalía en la generación de niveles con características específicas solicitadas, como el nivel de dificultad o el diseño.[31]​Sin embargo, los modelos actuales, como el utilizado en el estudio, requieren grandes conjuntos de datos de niveles para ser efectivos. Concluyeron que, aunque prometedores, el alto costo de datos de los grandes modelos de lenguaje supera actualmente los beneficios para esta aplicación.[31]

Los primeros PC carecían de capacidades sonoras reales (primer modelo de IBM, 1981).

Música y sonido generados procedimentalmente

[editar]

La música de un videojuego es una expresión importante del tono emocional de una escena para el jugador. Los efectos de sonido, como el ruido de un arma golpeando a un enemigo, ayudan a indicar el efecto de las acciones del jugador. Generar estos en tiempo real crea una experiencia atractiva para el jugador porque el juego es más responsivo a su entrada.[31]​Un ejemplo es el juego de aventuras Proteus de 2013, donde un algoritmo adapta dinámicamente la música según el ángulo desde el que el jugador ve el paisaje del juego.[28]

Árbol de búsqueda Monte Carlo (MCTS)

[editar]

El método de búsqueda de árbol de Monte Carlo proporciona una experiencia de juego más atractiva al crear obstáculos adicionales que el jugador debe superar.[32]​El MCTS consiste en un diagrama de árbol en el que la IA esencialmente juega al tic-tac-toe. Dependiendo del resultado, selecciona un camino que produce el siguiente obstáculo para el jugador. En videojuegos complejos, estos árboles pueden tener más ramas, siempre que el jugador pueda encontrar varias estrategias para superar el obstáculo. En la encuesta del año 2022,[33]​se podía obtener información sobre aplicaciones recientes del algoritmo MCTS en varios dominios de juegos, como juegos combinatorios de información perfecta, juegos de estrategia (incluidos RTS), juegos de cartas, etc.

Usos en juegos más allá de los NPC

[editar]
Redes generativas adversarias (GAN)
[editar]
Las máquinas kernel se utilizan para calcular funciones separables no lineales en una función separable linealmente de mayor dimensión

En lugar de la generación de procedimientos, algunos investigadores han utilizado redes generativas adversarias (GAN) para crear contenido nuevo. Las GANs son una clase de algoritmos de inteligencia artificial que se utilizan en el aprendizaje no supervisado, implementadas por un sistema de dos redes neuronales que compiten mutuamente en una especie de juego de suma cero.

Esta técnica puede generar fotografías que parecen auténticas a observadores humanos. Por ejemplo, una fotografía sintética de un gato que consiga engañar al discriminador (una de las partes funcionales del algoritmo), es probable que lleve a una persona cualquiera a aceptarlo como una fotografía real.

En 2018, investigadores de la Universidad de Cornwall entrenaron una GAN en mil niveles creados por humanos para Doom; Tras el entrenamiento, el prototipo de red neuronal pudo diseñar por sí solo nuevos niveles jugables. De manera similar, investigadores de la Universidad de California crearon un prototipo de GAN para generar niveles para Super Mario.[34]​En 2020, Nvidia mostró un clon de Pac-Man creado por GAN; La GAN aprendió a recrear el juego viendo 50 000 partidas (en su mayoría generadas por bots).[35]

Avances en IA

[editar]

Los avances recientes en IA para videojuegos han llevado a comportamientos más complejos y adaptativos en personajes no jugables (NPC). Por ejemplo, los sistemas de IA ahora utilizan técnicas sofisticadas como árboles de decisión y máquinas de estado para mejorar las interacciones y el realismo de los NPC.[36]​Los avances recientes en IA para videojuegos también se han centrado en mejorar los comportamientos dinámicos y adaptativos de los NPC. Por ejemplo, una investigación reciente ha explorado el uso de redes neuronales complejas para permitir que los NPC aprendan y adapten su comportamiento en función de las acciones del jugador, mejorando la experiencia de juego general.[37]

Referencias

[editar]
  1. a b Redheffer, Raymond. «Una máquina para jugar al juego NIM». The American Mathematical Monthly (en inglés) 55 (6): 343-349. ISSN 0002-9890. doi:10.1080/00029890.1948.11999249. 
  2. Yannakakis, Geogios N (2012). «La IA en los juegos supervisadas». Proceedings of the 9th conference on Computing Frontiers. pp. 285-292. ISBN 9781450312158. S2CID 4335529. doi:10.1145/2212908.2212954. Archivado desde el original el 8 August 2014. 
  3. «La historia del juego 'Punch-Out!!'». ESPN.com (en inglés). 27 de noviembre de 2008. Consultado el 11 de agosto de 2024. 
  4. a b Bogost, Ian (March 2017). «La 'inteligencia artificial' ha perdido importancia». Consultado el 22 July 2017. 
  5. a b Kaplan, Jerry (March 2017). «AI's PR Problem». MIT Technology Review. 
  6. a b Eaton, Eric; Dietterich, Tom; Gini, Maria (December 2015). «¿Quien habla en nombre de las IA?». AI Matters 2 (2): 4-14. S2CID 207233310. doi:10.1145/2847557.2847559. 
  7. «¿Porqué los videojuegos no son un buen significado de lo que son las IAs?». 19 December 2019. 
  8. "Una historia breve de la informática" de AlanTuring.net.
  9. , Schaeffer, Jonathan. One Jump Ahead:: Challenging Human Supremacy in Checkers, 1997, 2009, Springer, ISBN 978-0-387-76575-4. Chapter 6.
  10. Videojuego 'First Queen' en MobyGames
  11. «Sitio Oficial». Consultado el 19 de mayo de 2011. 
  12. a b Schwab, 2004, pp. 97–112
  13. Inteligencia emergente en juegos 17 de febrero de 2011.
  14. Good, Owen S. (5 August 2017). «El mod de Skyrim hace que las interacciones con los NPC sean menos escritas y más parecidas a las de los Sims». Polygon. Consultado el 16 April 2018. 
  15. Lara-Cabrera, R., Nogueira-Collazo, M., Cotta, C., & Fernández-Leiva, A. J. (2015). Inteligencia artificial en videojuegos: un reto para la comunidad científica.
  16. Yannakakis, G. N. (2012, May). Revisión de la IA del juego. En actas de la novena conferencia sobre fronteras de la informática (pp. 285–292). ACM.
  17. Hagelback, Johan, and Stefan J. Johansson. "Enfrentar la niebla de guerra en un entorno de juego de estrategia en tiempo real". En Inteligencia Computacional y Juegos, 2008. CIG'08. IEEE Symposium On, pp. 55-62. IEEE, 2008.
  18. a b Abd Algfoor, Zeyad; Sunar, Mohd Shahrizal; Kolivand, Hoshang (2015). «Un estudio exhaustivo sobre técnicas de búsqueda de caminos para la robótica y los videojuegos». International Journal of Computer Games Technology 2015: 1-11. 
  19. Yap, Peter. "Búsqueda de rutas basada en cuadrículas". En Conferencia de la Sociedad Canadiense de Estudios Computacionales de Inteligencia, pp. 44-55. Springer, Berlin, Heidelberg, 2002.
  20. Sturtevant, N. R. (June 2012). «Benchmarks for Grid-Based Pathfinding». IEEE Transactions on Computational Intelligence and AI in Games 4 (2): 144-148. S2CID 2864753. doi:10.1109/TCIAIG.2012.2197681. 
  21. Goodwin, S. D., Menon, S., & Price, R. G. (2006). Pathfinding in open terrain. In Proceedings of International Academic Conference on the Future of Game Design and Technology.
  22. Nareyek, A. (2004). AI in computer games. Queue, 1(10).
  23. a b Cui, X., & Shi, H. (2011). A*-based pathfinding in modern computer games. International Journal of Computer Science and Network Security, 11(1), 125-130.
  24. «Técnicas e ideales de diseño para videojuegos». Byte Magazine 7 (12). 1982. p. 100. 
  25. Lidén, L. (2003). Artificial stupidity: The art of intentional mistakes. AI game programming wisdom, 2, 41-48.
  26. van der Linden, Roland; Lopes, Ricardo; Bidarra, Rafael (2014-03). «Procedural Generation of Dungeons». IEEE Transactions on Computational Intelligence and AI in Games 6 (1): 78-89. ISSN 1943-0698. doi:10.1109/TCIAIG.2013.2290371. Consultado el 11 de agosto de 2024. 
  27. Seidel, Stefan; Berente, Nicholas; Lindberg, Aron; Lyytinen, Kalle; Nickerson, Jeffrey V (9 de noviembre de 2020). «Artificial Intelligence and Video Game Creation: A Framework for the New Logic of Autonomous Design». Journal of Digital Social Research 2 (3). ISSN 2003-1998. doi:10.33621/jdsr.v2i3.46. Consultado el 11 de agosto de 2024. 
  28. a b Liapis, Antonios (2021). «Artificial Intelligence for Designing Games». Artificial Intelligence and the Arts. Computational Synthesis and Creative Systems. pp. 277-310. ISBN 978-3-030-59474-9. doi:10.1007/978-3-030-59475-6_11. 
  29. Todd, Graham; Earle, Sam; Nasir, Muhammad Umair; Green, Michael Cerny; Togelius, Julian (2023). «Level Generation Through Large Language Models». Proceedings of the 18th International Conference on the Foundations of Digital Games. pp. 1-8. ISBN 978-1-4503-9855-8. arXiv:2302.05817. doi:10.1145/3582437.3587211. 
  30. Seidel, Stefan; Berente, Nicholas; Lindberg, Aron; Lyytinen, Kalle; Nickerson, Jeffrey V (9 de noviembre de 2020). «Artificial Intelligence and Video Game Creation: A Framework for the New Logic of Autonomous Design». Journal of Digital Social Research 2 (3). ISSN 2003-1998. doi:10.33621/jdsr.v2i3.46. Consultado el 11 de agosto de 2024. 
  31. a b c Todd, Graham; Earle, Sam; Nasir, Muhammad Umair; Green, Michael Cerny; Togelius, Julian (12 de abril de 2023). Level Generation Through Large Language Models (en inglés). ACM. pp. 1-8. ISBN 978-1-4503-9855-8. doi:10.1145/3582437.3587211. Consultado el 11 de agosto de 2024. 
  32. Statt, Nick (9 March 2019). «CÓMO LA INTELIGENCIA ARTIFICIAL REVOLUCIONARÁ LA FORMA DE DESARROLLAR Y JUGAR LOS VIDEOJUEGOS». Consultado el 23 February 2020. 
  33. Świechowski, Maciej; Godlewski, Konrad; Sawicki, Bartosz; Mańdziuk, Jacek (2022). «Monte Carlo Tree Search: a review of recent modifications and applications». Artificial Intelligence Review 56 (3): 2497-2562. S2CID 232147848. arXiv:2103.04931. 
  34. «La IA crea nuevos niveles para Doom». BBC News. 8 de mayo de 2018. Consultado el 17 de mayo de 2018. 
  35. Vincent, James (22 de mayo de 2020). «La IA de Nvidia recrea Pac-Man desde cero con sólo verlo jugar». The Verge (en inglés). Consultado el 28 de mayo de 2020. 
  36. Procedural Content Generation in Games (en inglés). doi:10.1007/978-3-319-42716-4.pdf. Consultado el 11 de agosto de 2024. 
  37. Carli, Daniel Michelon De; Bevilacqua, Fernando; Tadeu Pozzer, Cesar; d'Ornellas, Marcos Cordeiro (2011-11). «A Survey of Procedural Content Generation Techniques Suitable to Game Development». 2011 Brazilian Symposium on Games and Digital Entertainment: 26-35. doi:10.1109/SBGAMES.2011.15. Consultado el 11 de agosto de 2024.