# Temporal difference learning

__: Computer programming concept__

**Short description**Machine learning and data mining |
---|

**Temporal difference** (**TD**) **learning** refers to a class of model-free reinforcement learning methods which learn by bootstrapping from the current estimate of the value function. These methods sample from the environment, like Monte Carlo methods, and perform updates based on current estimates, like dynamic programming methods.^{[1]}

While Monte Carlo methods only adjust their estimates once the final outcome is known, TD methods adjust predictions to match later, more accurate, predictions about the future before the final outcome is known.^{[2]} This is a form of bootstrapping, as illustrated with the following example:

Suppose you wish to predict the weather for Saturday, and you have some model that predicts Saturday's weather, given the weather of each day in the week. In the standard case, you would wait until Saturday and then adjust all your models. However, when it is, for example, Friday, you should have a pretty good idea of what the weather would be on Saturday – and thus be able to change, say, Saturday's model before Saturday arrives.

^{[2]}

Temporal difference methods are related to the temporal difference model of animal learning.^{[3]}^{[4]}^{[5]}^{[6]}^{[7]}

## Mathematical formulation

The tabular TD(0) method is one of the simplest TD methods. It is a special case of more general stochastic approximation methods. It estimates the state value function of a finite-state Markov decision process (MDP) under a policy [math]\displaystyle{ \pi }[/math]. Let [math]\displaystyle{ V^\pi }[/math] denote the state value function of the MDP with states [math]\displaystyle{ (S_t)_{t\in\mathbb{N}} }[/math], rewards [math]\displaystyle{ (R_t)_{t\in\mathbb{N}} }[/math] and discount rate^{[8]} [math]\displaystyle{ \gamma }[/math] under the policy [math]\displaystyle{ \pi }[/math]:^{[9]}

- [math]\displaystyle{ V^\pi(s) = E_{a \sim \pi}\left\{\sum_{t=0}^\infty \gamma^tR_{t+1}\Bigg| S_0=s\right\}. }[/math]

We drop the action from the notation for convenience. [math]\displaystyle{ V^\pi }[/math] satisfies the Hamilton-Jacobi-Bellman Equation:

- [math]\displaystyle{ V^\pi(s)=E_{\pi}\{R_1 + \gamma V^\pi(S_1)|S_0=s\}, }[/math]

so [math]\displaystyle{ R_1 + \gamma V^\pi(S_1) }[/math] is an unbiased estimate for [math]\displaystyle{ V^\pi(s) }[/math]. This observation motivates the following algorithm for estimating [math]\displaystyle{ V^\pi }[/math].

The algorithm starts by initializing a table [math]\displaystyle{ V(s) }[/math] arbitrarily, with one value for each state of the MDP. A positive learning rate [math]\displaystyle{ \alpha }[/math] is chosen.

We then repeatedly evaluate the policy [math]\displaystyle{ \pi }[/math], obtain a reward [math]\displaystyle{ r }[/math] and update the value function for the current state using the rule:^{[10]}

- [math]\displaystyle{ V(S_t) \leftarrow (1 - \alpha) V(S_t) + \underbrace{\alpha}_{\text{learning rate}} [ \overbrace{R_{t+1} + \gamma V(S_{t+1})}^{\text{The TD target}} ] }[/math]

where [math]\displaystyle{ S_t }[/math] and [math]\displaystyle{ S_{t+1} }[/math] are the current and next states, respectively. The value [math]\displaystyle{ R_{t+1} + \gamma V(S_{t+1}) }[/math] is known as the TD target, and [math]\displaystyle{ R_{t+1} + \gamma V(S_{t+1}) - V(S_t) }[/math] is known as the TD error.

## TD-Lambda

**TD-Lambda** is a learning algorithm invented by Richard S. Sutton based on earlier work on temporal difference learning by Arthur Samuel.^{[11]} This algorithm was famously applied by Gerald Tesauro to create TD-Gammon, a program that learned to play the game of backgammon at the level of expert human players.^{[12]}

The lambda ([math]\displaystyle{ \lambda }[/math]) parameter refers to the trace decay parameter, with [math]\displaystyle{ 0 \leqslant \lambda \leqslant 1 }[/math]. Higher settings lead to longer lasting traces; that is, a larger proportion of credit from a reward can be given to more distant states and actions when [math]\displaystyle{ \lambda }[/math] is higher, with [math]\displaystyle{ \lambda = 1 }[/math] producing parallel learning to Monte Carlo RL algorithms.^{[13]}

## In neuroscience

The TD algorithm has also received attention in the field of neuroscience. Researchers discovered that the firing rate of dopamine neurons in the ventral tegmental area (VTA) and substantia nigra (SNc) appear to mimic the error function in the algorithm.^{[3]}^{[4]}^{[5]}^{[6]}^{[7]} The error function reports back the difference between the estimated reward at any given state or time step and the actual reward received. The larger the error function, the larger the difference between the expected and actual reward. When this is paired with a stimulus that accurately reflects a future reward, the error can be used to associate the stimulus with the future reward.

Dopamine cells appear to behave in a similar manner. In one experiment measurements of dopamine cells were made while training a monkey to associate a stimulus with the reward of juice.^{[14]} Initially the dopamine cells increased firing rates when the monkey received juice, indicating a difference in expected and actual rewards. Over time this increase in firing back propagated to the earliest reliable stimulus for the reward. Once the monkey was fully trained, there was no increase in firing rate upon presentation of the predicted reward. Subsequently, the firing rate for the dopamine cells decreased below normal activation when the expected reward was not produced. This mimics closely how the error function in TD is used for reinforcement learning.

The relationship between the model and potential neurological function has produced research attempting to use TD to explain many aspects of behavioral research.^{[15]}^{[16]} It has also been used to study conditions such as schizophrenia or the consequences of pharmacological manipulations of dopamine on learning.^{[17]}

## See also

## Notes

- ↑ Sutton & Barto (2018), p. 133.
- ↑
^{2.0}^{2.1}Sutton, Richard S. (1 August 1988). "Learning to predict by the methods of temporal differences" (in en).*Machine Learning***3**(1): 9–44. doi:10.1007/BF00115009. ISSN 1573-0565. https://link.springer.com/article/10.1007/BF00115009. Retrieved 4 April 2023. - ↑
^{3.0}^{3.1}Schultz, W, Dayan, P & Montague, PR. (1997). "A neural substrate of prediction and reward".*Science***275**(5306): 1593–1599. doi:10.1126/science.275.5306.1593. PMID 9054347. - ↑
^{4.0}^{4.1}Montague, P. R.; Dayan, P.; Sejnowski, T. J. (1996-03-01). "A framework for mesencephalic dopamine systems based on predictive Hebbian learning".*The Journal of Neuroscience***16**(5): 1936–1947. doi:10.1523/JNEUROSCI.16-05-01936.1996. ISSN 0270-6474. PMID 8774460. PMC 6578666. http://papers.cnl.salk.edu/PDFs/A%20Framework%20for%20Mesencephalic%20Dopamine%20Systems%20Based%20on%20Predictive%20Hebbian%20Learning%201996-2938.pdf. - ↑
^{5.0}^{5.1}Montague, P.R.; Dayan, P.; Nowlan, S.J.; Pouget, A.; Sejnowski, T.J. (1993). "Using aperiodic reinforcement for directed self-organization".*Advances in Neural Information Processing Systems***5**: 969–976. http://www.gatsby.ucl.ac.uk/~dayan/papers/mdnps93.pdf. - ↑
^{6.0}^{6.1}Montague, P. R.; Sejnowski, T. J. (1994). "The predictive brain: temporal coincidence and temporal order in synaptic learning mechanisms".*Learning & Memory***1**(1): 1–33. doi:10.1101/lm.1.1.1. ISSN 1072-0502. PMID 10467583. - ↑
^{7.0}^{7.1}Sejnowski, T.J.; Dayan, P.; Montague, P.R. (1995). "Predictive Hebbian learning".*Proceedings of the eighth annual conference on Computational learning theory - COLT '95*. pp. 15–18. doi:10.1145/225298.225300. ISBN 0897917235. - ↑ Discount rate parameter allows for a time preference toward more immediate rewards, and away from distant future rewards
- ↑ Sutton & Barto (2018), p. 134.
- ↑ Sutton & Barto (2018), p. 135.
- ↑ Sutton & Barto (2018), p. 130?.
- ↑ Tesauro (1995).
- ↑ Sutton & Barto (2018), p. 175.
- ↑ Schultz, W. (1998). "Predictive reward signal of dopamine neurons".
*Journal of Neurophysiology***80**(1): 1–27. doi:10.1152/jn.1998.80.1.1. PMID 9658025. - ↑ Dayan, P. (2001). "Motivated reinforcement learning".
*Advances in Neural Information Processing Systems*(MIT Press)**14**: 11–18. http://books.nips.cc/papers/files/nips14/CS01.pdf. - ↑ Tobia, M. J., etc. (2016). "Altered behavioral and neural responsiveness to counterfactual gains in the elderly".
*Cognitive, Affective, & Behavioral Neuroscience***16**(3): 457–472. doi:10.3758/s13415-016-0406-7. PMID 26864879. - ↑ Smith, A., Li, M., Becker, S. and Kapur, S. (2006). "Dopamine, prediction error, and associative learning: a model-based account".
*Network: Computation in Neural Systems***17**(1): 61–84. doi:10.1080/09548980500361624. PMID 16613795.

### Works cited

- Sutton, Richard S.; Barto, Andrew G. (2018).
*Reinforcement Learning: An Introduction*(2nd ed.). Cambridge, MA: MIT Press. http://www.incompleteideas.net/book/the-book.html. - Tesauro, Gerald (March 1995). "Temporal Difference Learning and TD-Gammon".
*Communications of the ACM***38**(3): 58–68. doi:10.1145/203330.203343. http://www.research.ibm.com/massive/tdl.html.

## Further reading

- Meyn, S. P. (2007).
*Control Techniques for Complex Networks*. Cambridge University Press. ISBN 978-0521884419. See final chapter and appendix. - Sutton, R. S.; Barto, A. G. (1990). "Time Derivative Models of Pavlovian Reinforcement".
*Learning and Computational Neuroscience: Foundations of Adaptive Networks*: 497–537. http://incompleteideas.net/sutton/papers/sutton-barto-90.pdf.

## External links

- Connect Four TDGravity Applet (+ mobile phone version) – self-learned using TD-Leaf method (combination of TD-Lambda with shallow tree search)
- Self Learning Meta-Tic-Tac-Toe Example web app showing how temporal difference learning can be used to learn state evaluation constants for a minimax AI playing a simple board game.
- Reinforcement Learning Problem, document explaining how temporal difference learning can be used to speed up Q-learning
- TD-Simulator Temporal difference simulator for classical conditioning

Original source: https://en.wikipedia.org/wiki/Temporal difference learning.
Read more |