- basic algorithms
- car washes
- course networking
- Eleanor Duckworth
- enough basic algorithms
- experienced software
- free products
- given Web
- Haskell
- HTML
- lowkey travel
- minimum viable product
- operating systems
- Other People's Money
- Peter Thiel
- php
- Python
- search engine
- search engine
- software engineering
- Stanford
- Steven Gary Blank
- Texas
- Unix
- viral marketing
- web app
- web ideas
- web scale
- web shop

**Markov decision processes (MDPs)**, named after Andrey Markov, provide a mathematical framework for modeling decision-making in situations where outcomes are partly random and partly under the control of a decision maker. MDPs are useful for studying a wide range of optimization problems solved via dynamic programming and reinforcement learning. MDPs were known at least as early as the 1950s (cf. Bellman 1957). Much research in the area was spawned due to Ronald A. Howard's book, *Dynamic Programming and Markov Processes*, in 1960. Today they are used in a variety of areas, including robotics, automated control, economics and manufacturing.

More precisely, a Markov Decision Process is a discrete time stochastic control process. At each time step, the process is in some state , and the decision maker may choose any action that is available in state . The process responds at the next time step by randomly moving into a new state , and giving the decision maker a corresponding reward .

The probability that the process moves into its new state is influenced by the chosen action. Specifically, it is given by the state transition function . Thus, the next state depends on the current state and the decision maker's action . But given and , it is conditionally independent of all previous states and actions; in other words, the state transitions of an MDP possess the *Markov property*.

Markov decision processes are an extension of Markov chains; the difference is the addition of actions (allowing choice) and rewards (giving motivation). Conversely, if only one action exists for each state and all rewards are zero, a Markov decision process reduces to a Markov chain.

## Definition

Example of a simple MDP with 3 states and 2 actions.

A Markov decision process is a 4-tuple , where

- is a finite set of states,
- is a finite set of actions (alternatively, is the finite set of actions available from state ),
- is the probability that action in state at time will lead to state at time ,
- is the immediate reward (or expected immediate reward) received after transition to state from state with transition probability .

(The theory of Markov decision processes does not actually require or to be finite,^{[citation needed]} but the basic algorithms below assume that they are finite.)

## Problem

The core problem of MDPs is to find a *policy* for the decision maker: a function that specifies the action that the decision maker will choose when in state . Note that once a Markov decision process is combined with a policy in this way, this fixes the action for each state and the resulting combination behaves like a Markov chain.

The goal is to choose a policy that will maximize some cumulative function of the random rewards, typically the expected discounted sum over a potentially infinite horizon:

- (where we choose )

where is the discount factor and satisfies . (For example, when the discount rate is r.) is typically close to 1.

Because of the Markov property, the optimal policy for this particular problem can indeed be written as a function of only, as assumed above.

## Algorithms

MDPs can be solved by linear programming or dynamic programming. In what follows we present the latter approach.

Suppose we *know* the state transition function and the reward function , and we wish to calculate the policy that maximizes the expected discounted reward.

The standard family of algorithms to calculate this optimal policy requires storage for two arrays indexed by state: *value* , which contains real values, and *policy* which contains actions. At the end of the algorithm, will contain the solution and will contain the discounted sum of the rewards to be earned (on average) by following that solution from state .

The algorithm has the following two kinds of steps, which are repeated in some order for all the states until no further changes take place. They are

Their order depends on the variant of the algorithm; one can also do them for all states at once or state by state, and more often to some states than others. As long as no state is permanently excluded from either of the steps, the algorithm will eventually arrive at the correct solution.

### Notable variants

#### [edit] Value iteration

In value iteration (Bellman 1957), which is also called backward induction, the array is not used; instead, the value of is calculated whenever it is needed. Shapley's 1953 paper on stochastic games included as a special case the value iteration method for MDPs, but this was recognized only later on.^{[1]}

Substituting the calculation of into the calculation of gives the combined step:

This update rule is iterated for all states until it converges with the left-hand side equal to the right-hand side (which is the *Bellman equation* for this problem).

#### [edit] Policy iteration

In policy iteration (Howard 1960), step one is performed once, and then step two is repeated until it converges. Then step one is again performed once and so on.

Instead of repeating step two to convergence, it may be formulated and solved as a set of linear equations.

This variant has the advantage that there is a definite stopping condition: when the array does not change in the course of applying step 1 to all states, the algorithm is completed.

#### [edit] Modified policy iteration

In modified policy iteration (van Nunen, 1976; Puterman and Shin 1978), step one is performed once, and then step two is repeated several times. Then step one is again performed once and so on.

#### [edit] Prioritized sweeping

In this variant, the steps are preferentially applied to states which are in some way important - whether based on the algorithm (there were large changes in or around those states recently) or based on use (those states are near the starting state, or otherwise of interest to the person or program using the algorithm).

## Extensions and generalizations

A Markov decision process is a stochastic game with only one player.

### [edit] Partial observability

Main article: partially observable Markov decision process

The solution above assumes that the state is known when action is to be taken; otherwise cannot be calculated. When this assumption is not true, the problem is called a partially observable Markov decision process or POMDP.

### [edit] Reinforcement Learning

If the probabilities or rewards are unknown, the problem is one of reinforcement learning (Sutton and Barto, 1998).

For this purpose it is useful to define a further function, which corresponds to taking the action and then continuing optimally (or according to whatever policy one currently has):

While this function is also unknown, experience during learning is based on pairs (together with the outcome ); that is, "I was in state and I tried doing and happened"). Thus, one has an array and uses experience to update it directly. This is known as Q-learning.

Reinforcement learning can solve Markov decision processes without explicit specification of the transition probabilities; the values of the transition probabilities are needed in value and policy iteration. In reinforcement learning, instead of explicit specification of the transition probabilities, the transition probabilities are accessed through a simulator that is typically restarted many times from a uniformly random initial state. Reinforcement learning can also be combined with function approximation to address problems with a very large number of states.

## Continuous-time Markov Decision Process

In **Discrete-time Markov Decision Process**, decisions are made at discrete time epoch. However, for **Continuous-time Markov Decision Process**, decisions can be made at any time when decision maker wants. Different than Discrete-time Markov Decision Process, Continuous-time Markov Decision Process could better model the decision making process when the interested system has continuous dynamics, i.e., the system dynamics is defined by Partial Differential Equations(PDEs).

### [edit] Definition

In order to discuss the Continuous-time Markov Decision Process, we introduce two sets of notations:

If the state space and action space are finite,

- : State space;
- : Action space;
- : , transition rate function;
- : , a reward function.

If the state space and action space are continuous,

- : State space.;
- : Space of possible control;
- : , a transition rate function;
- : , a reward rate function,( and is the reward function we discussed in previous case.)

### Problem

Like the Discrete-time Markov Decision Processes, in Continuous-time Markov Decision Process we want to find the optimal *policy* or *control* which could give us the optimal expected integrated reward:

Where

### [edit] Linear programming formulation

If the state space and action space are finite, we could use linear programming formulation to find the optimal policy, which was one of the earliest solution approaches. Here we only consider the ergodic model, which means our continuous-time MDP become ergodic Continuous-time Markov Chain under stationary policy. Under this assumption, although the decision maker could make decision at any time, on the current state, he could not get more benefit to make more than one actions. It is better for him to take action only at the time when system transit from current state to another state. Under some conditions,(for detail check Corollary 3.14 of *Continuous-Time Markov Decision Processes*), if our optimal value function is independent of state i, we will have a following equation:

If there exists a function , then will be the smallest g could satisfied the above equation. In order to find the , we could have the following linear programming model:

- Primal linear program(P-LP)

- Dual linear program(D-LP)

is a feasible solution to the D-LP if is nonnative and satisfied the constraints in the D-LP problem. A feasible solution to the D-LP is said to be an optimal solution if

for all feasible solution y(i,a) to the D-LP. Once we found the optimal solution , we could use those optimal solution to establish the optimal policies.

### Hamilton-Jacobi-Bellman equation

In Continuous-time MDP, if the state space and action space are continuous, the optimal criterion could be found by solving Hamilton-Jacobi-Bellman partial differential equation. In order to discuss the HJB equation, we need to reformulate our problem

D() is the terminal reward function, is the system state vector, is the system control vector we try to find. f() shows how the state vector change over time. Hamilton-Jacobi-Bellman equation is as follows:

We could solve the equation to find the optimal control , which could give us the optimal value

### [edit] Application

Queueing system, epidemic processes, Population process.

## Alternative notations

The terminology and notation for MDPs are not entirely settled. There are two main streams — one focuses on maximization problems from contexts like economics, using the terms action, reward, value and calling the discount factor or , while the other focuses on minimization problems from engineering and navigation, using the terms control, cost, cost-to-go and calling the discount factor . In addition, the notation for the transition probability varies.

in this article

alternative

comment

action

control

reward

cost

is the negative of

value

cost-to-go

is the negative of

policy

policy

discounting factor

discounting factor

transition probability

transition probability

In addition, transition probability is sometimes written , or, rarely,

## See also

- Partially observable Markov decision process
- Dynamic programming
- Bellman equation for applications to economics.
- Hamilton–Jacobi–Bellman equation
- Optimal control

- Andrey Markov
- Applied mathematics
- basic algorithms
- basic algorithms
- Bellman equation
- correct solution
- cs
- Dynamic programming
- Equations
- feasible solution
- Machine learning
- manufacturing
- Markov chain
- Markov decision process
- Markov models
- Mathematics
- programming
- Reinforcement learning
- Ronald A. Howard
- Statistics
- Stochastic processes