Расчёт вероятности поглощения в состоянии — различия между версиями
(→Литература) |
Hazzus (обсуждение | вклад) м |
||
Строка 6: | Строка 6: | ||
|proof= | |proof= | ||
Пусть этот переход будет осуществлён за r шагов: i → <tex>i_{1}</tex> → <tex>i_{2}</tex> → ... → <tex>i_{r-1}</tex> → j, где все <tex>i, i_{1}, ... i_{r-1}</tex> являются несущественными. | Пусть этот переход будет осуществлён за r шагов: i → <tex>i_{1}</tex> → <tex>i_{2}</tex> → ... → <tex>i_{r-1}</tex> → j, где все <tex>i, i_{1}, ... i_{r-1}</tex> являются несущественными. | ||
− | Тогда рассмотрим сумму <tex>\sum\limits_{\forall(i_{1} ... i_{r-1})} {p_{i, i_{1}} \cdot p_{i_{1}, i_{2}} \cdot ... \cdot p_{i_{r-1}, j}} = Q^{r-1} \cdot R</tex>, где Q - матрица переходов между несущественными состояниями, R - из несущественного в существенное. | + | Тогда рассмотрим сумму <tex>\sum\limits_{\forall(i_{1} ... i_{r-1})} {p_{i, i_{1}} \cdot p_{i_{1}, i_{2}} \cdot ... \cdot p_{i_{r-1}, j}} = Q^{r-1} \cdot R</tex>, где <tex>Q</tex> - матрица переходов между несущественными состояниями, R - из несущественного в существенное. |
Матрица G определяется их суммированием по всем длинам пути из i в j: <tex>G = \sum\limits_{r = 1}^{\infty}{Q^{r-1} \cdot R} = (I + Q + Q^{2} + Q^{3} + ...) \cdot R = NR</tex>, т.к. <tex>(I + Q + Q^2 + ...) \cdot (I - Q) = I - Q + Q - Q^{2} + ... = I</tex>, а фундаментальная матрица марковской цепи <tex>N = (I - Q)^{-1}</tex> }} | Матрица G определяется их суммированием по всем длинам пути из i в j: <tex>G = \sum\limits_{r = 1}^{\infty}{Q^{r-1} \cdot R} = (I + Q + Q^{2} + Q^{3} + ...) \cdot R = NR</tex>, т.к. <tex>(I + Q + Q^2 + ...) \cdot (I - Q) = I - Q + Q - Q^{2} + ... = I</tex>, а фундаментальная матрица марковской цепи <tex>N = (I - Q)^{-1}</tex> }} | ||
=Псевдокод= | =Псевдокод= |
Версия 13:34, 12 марта 2018
Поглощающее(существенное) состояние цепи Маркова - состояние с вероятностью перехода в самого себя
. Составим матрицу G, элементы которой равны вероятности того, что, выйдя из i, попадём в поглощающее состояние j.Теорема: |
Доказательство: |
Пусть этот переход будет осуществлён за r шагов: i → Матрица G определяется их суммированием по всем длинам пути из i в j: → → ... → → j, где все являются несущественными. Тогда рассмотрим сумму , где - матрица переходов между несущественными состояниями, R - из несущественного в существенное. , т.к. , а фундаментальная матрица марковской цепи |
Псевдокод
Пусть
for i = 0 to m - 1 if input[i][0] == input[i][1] and input[i][2] == 1 absorbing[input[i][0]] = true abs++
Найдем число несущественных состояний
count_q = 0 count_r = 0 for i = 0 to n - 1 if absorbing[i] position[i] = count_r count_r++ else position[i] = count_q count_q++ for i = 0 to m - 1 if absorbing[input[i][1]] if !absorbing[input[i][0]] R[position[input[i][0]]][position[input[i][1]]] = input[i][2] else Q[position[input[i][0]]][position[input[i][1]]] = input[i][2]
Найдем Матрицу
for i = 0 to nonabs - 1 N[i][i] = 1 E[i][i] = 1 for j = 0 to nonabs - 1 E[i][j] -= Q[i][j]
Теперь приведем матрицу
for i = 0 to nonabs - 1 if E[i][i]1 mul = E[i][i] for j = 0 to nonabs - 1 E[i][j] /= mul N[i][j] /= mul for row = 0 to nonabs - 1 if i row mul = E[row][i] for j = 0 to nonabs - 1 E[row][j] -= mul * E[i][j] N[row][j] -= mul * N[i][j]
В результате
for i = 0 to nonabs - 1 for j = 0 to abs - 1 G[i][j] = 0 for k = 0 to nonabs - 1 G[i][j] += N[i][k] * R[k][j]
Выведем ответ: в
for i = 0 to n - 1 prob = 0 if absorbing[i] for j = 0 to nonabs - 1 prob += G[j][position[i]] prob++ prob /= n println(prob)
Литература
- Википедия - Цепи Маркова
- Кемени Дж., Снелл Дж. "Конечные цепи Маркова".