Inteligencia Artificial en Videojuegos móviles

Inteligencia Artificial en Videojuegos móviles

Tekken screenshotPara garantizar el éxito comercial de los videojuegos para móviles es necesario asegurar un algoritmo de Inteligencia Artificial que suponga al jugador un desafío ni demasiado elevado ni demasiado bajo.

Pese a que ya existen soluciones óptimas para PC y videoconsola, trasladarlas a dispositivos móviles constituye un verdadero reto dadas las limitaciones que imponen al desarrollador. Además hay que considerar cierta clase de juegos conocidos como juegos con información imperfecta. Por ejemplo el póquer, donde los jugadores no tienen información completa del estado del juego.

En estos casos muchos de los agentes IA pueden presentar un comportamiento más aleatorio que inteligente, por lo que se precisa el uso de algoritmos de inferencia por parte de la máquina que le permitan intuir las intenciones del oponente, tal y como hacemos los seres humanos.

La mejor forma en la que un algoritmo IA obtendría información de su oponente sería infiriendo información sobre su estilo de juego y de su tendencia a reaccionar ante determinadas situaciones. Por tanto el algoritmo de aprendizaje iría compilando un perfil del comportamiento de dicho jugador. Así, cada comportamiento podría ser identificado con una clase o categoría: jugador agresivo, esquivo, etc. Al fin y al cabo de lo que se trata es de un problema de reconocimiento de patrones.

Esquema de reconocimiento de patrones

Este conocimiento podría ser usado en futuras partidas para predecir algunos movimientos, por lo que el sistema iría aprendiendo de su propia experiencia.

Hay básicamente dos métodos de predicción:

  1. discriminativo
  2. no-discriminativo.

Predicción discriminativa

Uno de los métodos de clasificación discriminativa más eficaces son las máquinas de soporte vectorial o SVM (Support Vector Machine). Sin entrar en detalles matemáticos, un algoritmo basado en SVM construye un modelo capaz de predecir si una muestra nueva (cuya categoría desconocemos) pertenece a una categoría o a la otra.

Pacman screenshot

Estas predicciones presentan algunas de las ventajas de las redes neuronales al utilizar un reducido número de parámetros: la solución puede ser expresada como una forma muy simple de combinación de funciones que dependen de las instancias de entrenamiento (muestras) en el espacio original. Su principal problema es que el rendimiento se reduce notablemente cuando el conjunto de entrenamiento es muy grande, por lo tanto funcionaría bien en videojuegos relativamente sencillos como por ejemplo un PacMan.

Predicción no-discriminativa

Por el contrario, el modelo no-discriminativo o bayesiano estimaría la predicción en base a la regla de Bayes (la probabilidad de que un jugador realice tal movimiento, dado que antes ha realizado este otro) y entonces cada nueva instancia se compararía con la clase más probable.

Así, el sistema no discriminativo tiende a ser más eficiente en dispositivos móviles, ya que consume menos recursos computacionales que los métodos discriminativos, a pesar de que estos últimos presenten un mejor desempeño deliberativo. Por tanto se adapta mejor a juegos donde necesitamos un mayor procesamiento de datos en tiempo real con muchas fuentes de incertidumbre (por ejemplo el mítico StarCraft, que por cierto estará disponible muy pronto en Android mediante controles táctiles).

Starcraft screenshot

Si os interesa profundizar en este tema os recomiendo la lectura de los siguientes artículos:

  • Bayesian Programming and Learning for Multi-Player Video Games. Gabriel Synnaeve | Link
  • Enhancing Artificial Intelligence on a Real Mobile Game, Fabio Aiolli ,Claudio E. Palazzi | Link
Previous LEAP: Agentes Inteligentes en dispositivos móviles
Next Integrar Motores de Inferencia en Android

About author

Angel
Angel 169 posts

Siempre quise ser inventor y escritor. Pero mientras tanto trabajo en Alemania como Ingeniero de Telecomunicaciones, y de vez en cuando escribo aquí sobre Ciencia y Tecnología. Me gustan los robots y los libros (analógicos).

You might also like

Desarrollo 4 Comments

Cuándo dejar de ver el Mundo como un Ingeniero: quien esté libre de optimizar…

Confucio reunió a sus discípulos y les dijo: “Un optimista ve un vaso medio lleno. Un pesimista ve un vaso medio vacío. Un ingeniero ve un vaso demasiado grande“. Lo

Tecnologia & Ciencia 12 Comments

Definición de máquina de Turing y ejemplos

¿Qué es una máquina de Turing (MT)? ¿Cual es su cometido? En esta entrada nos introduciremos en el ámbito de la computación, intentando entender una pequeña parte de la misma

Tutorial 0 Comments

Importar en phpMyAdmin: ¿cómo incrementar el límite de fichero?

A veces necesitamos importar una base de datos de gran tamaño utilizando el gestor de phpMyAdmin. Si el máximo permitido es insuficiente para realizar dicha importación, debemos “agrandarle la boca”. Para

Developer Angel, una interesante forma de invertir en una Start-up

El otro día estuvimos charlando un buen rato con @miguelfc (CEO de Spiral Startups) sobre un problema muy recurrente a la hora de poner en marcha una empresa innovadora de base tecnológica:

Desarrollo 3 Comments

¿Qué es un TPV Virtual y qué le podemos exigir?

Últimamente hemos recibido consultas de algunos empresarios y desarrolladores que desean instalar una plataforma software que les permita iniciar actividades de comercio electrónico. En ese sentido, hay muchísimas soluciones cuya

Google 1Comments

Navidades sin Nexus 4

Pésima gestión de Google en la distribución de hardware. La Nexus 4 está agotada y la fecha de vuelta es todavía una incógnita

Tutorial 1Comments

How-to: Parsear variables JSON con PHP

Puede ocurrir que nos interese decodificar un objeto JSON en una variable PHP. A mí me ha costado un pequeño dolor de cabeza, así que os transmito la lección aprendida

Tecnologia & Ciencia

Framework: ¿Por qué es mejor usarlos?

Un Framework es un conjunto de librerías y conceptos preparados para ser utilizados en tus proyectos. Te olvidarás de muchos problemas tediosos, que otros programadores ya han solucionado. Soluciones que

Tecnologia & Ciencia 1Comments

Monsta, un cliente web FTP gratuito y abierto

¿Que es Monsta FTP? Es un cliente FTP de código abierto que puedes instalar fácilmente en cualquier servidor web. Está programado en PHP/Ajax y es muy sencillo de desplegar (sólo 2

1 Comment

Leave a Reply