Q-learning es una técnica de aprendizaje por refuerzo utilizada en aprendizaje automático. El objetivo del Q-learning es aprender una serie de normas que le diga a un agente qué acción tomar bajo qué circunstancias. No requiere un modelo del entorno y puede manejar problemas con transiciones estocásticas y recompensas sin requerir adaptaciones.

Para cualquier proceso de decisión de Markov finito (PDMF) (finite Markov decision process en inglés), Q-learning encuentra una política óptima en el sentido de que maximiza el valor esperado de la recompensa total sobre todos los pasos sucesivos, empezando desde el estado actual.[1]​ Q-learning puede identificar una norma de acción-selección óptima para cualquier PDMF, dado un tiempo de exploración infinito y una norma parcialmente aleatoria[1]​ "Q" nombra la función que devuelve la recompensa que proporciona el refuerzo y representa la "calidad" de una acción tomada en un estado dado.[2]

Aprendizaje por refuerzo

editar

El aprendizaje por refuerzo involucra a un agente, un conjunto de estados  , y un conjunto   de acciones por estado. Llevando a cabo una acción  , el agente pasa de un estado   a otro. La ejecución de una acción en un estado concreto le proporciona una recompensa al agente (una puntuación numérica).

El objetivo del agente es maximizar su recompensa total. Lo hace sumando la máxima recompensa alcanzable, en estados futuros, a la recompensa por alcanzar su estado actual, influyendo eficazmente en la acción actual por la futura recompensa potencial. Esta recompensa potencial es una suma ponderada de la esperanza matemática de las recompensas de los futuros pasos empezando desde el estado actual.

Como ejemplo, considérese el proceso de subir a un tren, en el que la recompensa se mide por el tiempo total de embarque en negativo (en otras palabras, el coste de subir al tren es igual a la rapidez del embarque). Una estrategia es entrar al tren tan pronto como se abran las puertas, minimizando el tiempo inicial de espera. No obstante, si el tren está lleno, la entrada será más lenta porque los pasajeros del interior estarán luchando por salir simultáneamente. El tiempo de embarque, o el coste, es:

  • 0 segundos de espera + 15 segundos de lucha

Al día siguiente, por azar (exploración), en lugar de subir inmediatamente, el pasajero deja salir a los pasajeros del interior antes de subir al tren. En este caso el tiempo de entrada será mayor, pero el tiempo total de embarque se reduce, ya que los pasajeros del interior salen más rápidamente. Este camino tendrá+ una recompensa más alta que la del día anterior puesto que el tiempo de embarque es ahora:

  • 5 segundos de espera + 0 segundo de lucha

A través de la exploración, se descubre que el coste total de esperar es menor a pesar de que la espera inicial es una acción con un coste inmediato mayor, comparado con la estrategia de entrar lo más rápidamente posible. Por ello, esperar a que otros pasajeros salgan del tren antes de entrar supone una estrategia con mayor recompensa.

Algoritmo

editar
 
Tabla de estados de Q-learning por acciones inicializada a cero, entonces cada celda se actualiza con entrenamiento.

El peso de un paso en un estado  pasos en el futuro se calcula como  .   (el factor de descuento) es un número entre 0 y 1 ( ) y evalúa las recompensas recibidas anteriormente con un valor mayor que las recibidas posteriormente (reflejando el valor de un "buen inicio"). también puede ser interpretada como la probabilidad de tener éxito (o sobrevivir) en cada paso  .

El algoritmo, por tanto, tiene una función que calcula la calidad de una combinación estado-acción:

 .

Antes que comience el aprendizaje,   se inicializa a un valor arbitrario constante (escogido por el programador). Después, en cada tiempo   el agente selecciona una acción  , observa una recompensa  , introduce un estado nuevo   (Que depende del estado anterior   y de la acción seleccionada), y  se actualiza. El núcleo del algoritmo es una actualización del valor de la iteración simple, haciendo la media ponderada del valor antiguo y la información nueva:

 

Donde   es la recompensa recibida al pasar del estado   al estado  , y   es el índice de aprendizaje ( ).

Un episodio del algoritmo termina cuando el estado  es un estado final o terminal. Aun así, Q-learning también puede aprender en tareas sin episodios. Si el factor de descuento es menor que 1, los valores de acción son finitos incluso si el problema puede contener bucles infinitos.

Para todos los estados finales  ,   nunca se actualiza, pero se fija al valor de recompensa   observado para el estado  . En la mayoría de los casos,   puede ser igualado a 0.

Influencia de variables

editar

Exploración vs beneficio

editar

El índice de aprendizaje o tamaño del paso determina hasta qué punto la información adquirida sobrescribe la información vieja. Un factor de 0 hace que el agente no aprenda (únicamente aprovechando el conocimiento previo), mientras un factor de 1 hace que el agente considere solo la información más reciente (ignorando el conocimiento previo para explorar posibilidades).

En entornos totalmente deterministas, un índice de aprendizaje de   es óptimo.  Cuándo el problema es estocástico, el algoritmo converge bajo determinadas condiciones técnicas en el índice de aprendizaje que requiere un descenso hasta cero. En la práctica, a menudo se utiliza un índice de aprendizaje constante, como  para todo  .  [3]

Factor de descuento

editar

El factor de descuento   determina la importancia de recompensas futuras. Un factor de 0 hará que el agente sea "miope" (o corto de miras) por considerar únicamente las recompensas actuales, i.e.   (en la regla de actualización anterior), mientras que un factor que se acerca a 1 hará que luche por una recompensa alta a largo plazo. 

Si el factor de descuento es mayor o igual a 1, los valores de acción pueden divergir. Para  , sin un estado terminal, o si el agente nunca llega a uno, todos los historiales se vuelven infinitamente largos, y funciones aditivas, recompensas discontinuas generalmente tienden a infinito.[4]​ Incluso con un factor de descuento ligeramente menor que 1, el aprendizaje de Q-función lleva a la propagación de errores e inestabilidades cuando la función de valor está aproximada con una red neuronal artificial.[5]​ En ese caso, empezando con un factor de descuento menor y aumentándolo hacia su valor final se acelera el aprendizaje.[6]

Condiciones iniciales (Q0)

editar

Al ser Q-learning un algoritmo iterativo, implícitamente supone una condición inicial antes de que se de la primera actualización. Los valores iniciales altos, también conocidos como "condiciones iniciales optimistas",[7]​ pueden promover la exploración: independientemente de la acción seleccionada, la regla de actualización provocará que tenga valores menores que la otra alternativa, y por tanto aumentará su probabilidad de elección. La primera recompensa   puede ser utilizada para reiniciar las condiciones iniciales.[8]​ Según esta idea, la primera vez que se elige una acción, se fija el valor de la recompensa a  . Esto permite el aprendizaje inmediato en caso de recompensas deterministas fijas. Un modelo que incorpore reinicialización de condiciones iniciales (RCI), tiende a pronosticar el comportamiento de los participantes mejor que un modelo que suponga cualquier condición inicial arbitraria (CIA).[8]​ Sin embargo, la RCI parece ser consistente con el comportamiento humano en repetidos experimentos de elección binaria.[8]

Implementación

editar

Q-learning simplemente guarda información en tablas. Esta aproximación flaquea con números crecientes de acciones/estados.

Aproximación de funciones

editar

Q-learning se puede combinar con aproximación de funciones.[9]​ Esto hace posible la aplicación del algoritmo a problemas más largos, incluso cuando el espacio de estados es continuo.

Una solución es utilizar una red neuronal artificial (adaptado) como aproximador de funciones.[10]​ La aproximación de funciones puede acelerar el aprendizaje en problemas finitos, debido a que el algoritmo puede generalizar experiencias previas a estados no vistos anteriormente.

Cuantificación

editar

Esta técnica para disminuir el espacio de acciones/estados cuantifica los posibles valores. Considérese el ejemplo de aprender a equilibrar un palo en un dedo. Para describir un estado en un punto concreto en el tiempo involucra la posición del dedo en el espacio, su velocidad, el ángulo del palo y la velocidad angular del palo. Esto produce un vector de cuatro elementos que describe un estado, i.e. una captura de un estado codificado con cuatro valores. El problema es que están presentes infinitos estados posibles. Para encoger el espacio posible de las acciones válidas se pueden descartar muchos valores. La distancia exacta del dedo desde su posición de inicio (-infinito a infinito) no se conoce, sino si está lejos (cerca, lejos).

Historia

editar

Q-learning fue introducido por Watkins[11]​ en 1989. Watkins presentó una prueba de convergencia a Dayan[12]​ en 1992. Una prueba matemática más detallada fue expuesta por Tsitsiklis[13]​ en 1994, y por Bertsekas y Tsitsiklis en su libro de 1996 Neuro-Dynamic Programming.[14]

Watkins lo señalaba ya el título de la tesis de su doctorado “Learning from delayed rewards” (Aprendiendo de las recompensas tardías). Ocho años antes en 1981 el mismo problema, bajo el nombre de “aprendizaje por refuerzo tardío”, que fue solucionado por Bozinovski's Crossbar Adaptive Array (CAA).[15][16]​ La matriz de memoria W(a,s) es exactamente igual que la Q-table de Q-learning de ocho años más tarde. La arquitectura introdujo el término “evaluación de estado” en aprendizaje por refuerzo. El algoritmo de aprendizaje crossbar (escrito en pseudocódigo matemático en papel) realiza los siguientes cálculos en cada iteración:

  • En el estado s efectúa la acción a;
  • En consecuencia recibe el estado s';
  • Realiza la valuación del estado v(s');
  • Actualiza el valor crossbar W'(a,s) = W(a,s) + v(s').

El término “refuerzo secundario” viene de la teoría de aprendizaje animal, utilizada para modelar los valores de estado a través de propagación hacia atrás: el valor de estado v(s') de la situación consecuente es propagado hacia atrás hacia las situaciones encontradas previamente. CAA calcula los valores de estados verticalmente y las acciones horizontalmente (el "crossbar"). Grafos de demostración nos muestran los estados contenidos en el aprendizaje por refuerzo tardío (deseables, indeseables, y estados neutros), que han sido calculados por la función de evaluación de estados. Este sistema de aprendizaje fue el precursor del algoritmo Q-learning.[17]

En 2014 Google DeepMind patentó una aplicación de Q-learning de cara al aprendizaje profundo, llamado "aprendizaje de refuerzo profundo" o "Q-learning profundo" que puede jugar a los juegos Atari 2600 en niveles humanos expertos.[18]

Variantes

editar

Q-learning profundo

editar

El sistema DeepMind utilizó redes neuronales convolucionales profundas, con capas de filtros convolucionados enladrillados para asemejar los efectos de los campos receptivos. El aprendizaje por refuerzo es inestable o divergente cuando un aproximador de funciones no lineales se utiliza para representar Q. Esta inestabilidad proviene de la correlación presente en las secuencias de observación, el hecho de que actualizaciones pequeñas de Q puedan cambiar significativamente la política y la distribución de los datos, y las correlaciones entre Q y los valores objetivo.

La técnica utilizó repetición de experiencia, un mecanismo biológicamente inspirado que usa una muestra aleatoria de acciones previas en vez de la acción más reciente para continuar.[2]​ Esto elimina las correlaciones en la secuencia de observación y suaviza los cambios en la distribución de los datos. La actualización iterativa ajusta Q de cara a los valores objetivo que solo se actualizan periódicamente, reduciendo más adelante las correlaciones con el objetivo.[19]

Q-learning doble

editar

Puesto que el valor futuro máximo aproximado de una acción en Q-learning se evalúa utilizando la misma función Q que en la política de acción actualmente seleccionada, en entornos ruidosos Q-learning a veces puede sobrestimar los valores de la acción, retrasando el aprendizaje. Se propuso una variante llamada Q-learning doble para corregir esto. Q-learning doble[20]​ es un algoritmo de aprendizaje por refuerzo sin política, donde una política diferente se utiliza para la evaluación del valor que se usa para seleccionar próxima acción.

En la práctica, dos funciones de valor diferentes se entrenan en  una moda simétrica mutua usando experiencias separadas,  y  .   El paso de actualización de Q-learning doble es, por tanto, así:

 , y

Ahora el valor estimado del futuro descontado se evalúa utilizando una política diferente, lo cual soluciona el problema de la sobrestimación.

Este algoritmo se combinó más tarde con aprendizaje profundo, como el algoritmo DQN, resultando en doble DQN, el cual supera en rendimiento el algoritmo DQN original.[21]

Q-learning tardío es una implementación alternativa del algoritmo Q-learning online, con aprendizaje correcto probablemente aproximado (PAC).[22]

El "Avaro GQ" es una variante de Q-learning para combinarlo con aproximación de funciones (lineales).[23]​ La ventaja del "Avaro GQ" es que la convergencia es garantizada incluso cuando la aproximación de funciones se usa para estimar los valores de acción.

Véase también

editar

Referencias

editar
  1. a b Francisco S. Melo, "Convergencia de Q-aprendiendo: una prueba sencilla"
  2. a b Matiisen, Tambet (19 de diciembre de 2015). «Demystifying Deep Reinforcement Learning | Computational Neuroscience Lab». neuro.cs.ut.ee (en inglés estadounidense). Consultado el 6 de abril de 2018. 
  3. Aprendizaje de refuerzo: Una Introducción. Richard Sutton y Andrew Barto. MIT Prensa, 1998.
  4. Stuart J. Russell; Peter Norvig (2010). Artificial Intelligence: A Modern Approach (Third edición). Prentice Hall. p. 649. ISBN 978-0136042594. 
  5. Baird, Leemon (1995). «Residual algorithms: Reinforcement learning with function approximation». ICML. 
  6. MISSING LINK.. 
  7. «Archived copy». Archivado desde el original el 8 de septiembre de 2013. Consultado el 18 de julio de 2013. 
  8. a b c Shteingart, H; Neiman, T; Loewenstein, Y (May 2013). «The Role of First Impression in Operant Learning». J Exp Psychol Gen 142 (2): 476-88. PMID 22924882. doi:10.1037/a0029550. 
  9. Hasselt, Hado van (5 de marzo de 2012). «Reinforcement Learning in Continuous State and Action Spaces». En Wiering, ed. Reinforcement Learning: State-of-the-Art. Springer Science & Business Media. pp. 207–251. ISBN 978-3-642-27645-3. 
  10. Tesauro, Gerald (March 1995). «Temporal Difference Learning and TD-Gammon». Communications of the ACM 38 (3): 58-68. doi:10.1145/203330.203343. Archivado desde el original el 9 de febrero de 2010. Consultado el 8 de febrero de 2010. 
  11. Watkins, C.J.C.H. (1989), Learning from Delayed Rewards, Cambridge University .
  12. Watkins Y Dayan, C.J.C.H., (1992), 'Q-aprendiendo.Aprendizaje de máquina'
  13. Tsitsiklis, J., (1994), 'Aproximación Estocástica Asíncrona y Q-aprendiendo. Aprendizaje de máquina'
  14. Bertsekas Y Tsitsiklis, (1996), 'Neuro-Programación Dinámica. Athena Científica'
  15. Bozinovski, S. (15 de julio de 1999). «Crossbar Adaptive Array: The first connectionist network that solved the delayed reinforcement learning problem». En editor-Dobnikar, ed. Artificial Neural Nets and Genetic Algorithms: Proceedings of the International Conference in Portorož, Slovenia, 1999. Springer Science & Business Media. pp. 320-325. ISBN 978-3-211-83364-3. 
  16. Bozinovski, S. (1982). «A self learning system using secondary reinforcement». En Trappl, Robert, ed. Cybernetics and Systems Research: Proceedings of the Sixth European Meeting on Cybernetics and Systems Research. North Holland. pp. 397-402. ISBN 978-0-444-86488-8. 
  17. Barto, A. (24 de febrero de 1997). «Reinforcement learning». En Omidvar, ed. Neural Systems for Control. Elsevier. ISBN 978-0-08-053739-9. 
  18. «Methods and Apparatus for Reinforcement Learning, US Patent #20150100530A1». US Patent Office. 9 de abril de 2015. Consultado el 28 de julio de 2018. 
  19. Mnih, Volodymyr (2015). Human-level control through deep reinforcement learning 518. pp. 529-533. 
  20. van Hasselt, Hado (2011). «Double Q-learning» (PDF). Advances in Neural Information Processing Systems 23: 2613-2622. 
  21. van Hasselt, Hado; Guez, Arthur; Silver, David (2015). «Deep reinforcement learning with double Q-learning» (PDF). AAAI Conference on Artificial Intelligence: 2094-2100. Archivado desde el original el 6 de febrero de 2020. Consultado el 5 de enero de 2019. 
  22. Strehl, Alexander L.; Li, Lihong; Wiewiora, Eric; Langford, John; Littman, Michael L. (2006). «=Pac model-free reinforcement learning». Proc. 22nd ICML. 
  23. Maei, Hamid (2010). «Toward off-policy learning control with function approximation in Proceedings of the 27th International Conference on Machine Learning». Archivado desde el original el 8 de septiembre de 2012. Consultado el 5 de enero de 2019. 

Enlaces externos

editar