Алгоритм Витерби — различия между версиями
Gfv (обсуждение | вклад) |
Shersh (обсуждение | вклад) м |
||
Строка 23: | Строка 23: | ||
<code> | <code> | ||
//функция возвращает вектор X {{---}} последовательность номеров наиболее вероятных состояний, которые привели к данным наблюдениям. | //функция возвращает вектор X {{---}} последовательность номеров наиболее вероятных состояний, которые привели к данным наблюдениям. | ||
− | '''viterbi''' (O, S, <tex> \pi </tex>, Y, A, B) | + | '''viterbi'''(O, S, <tex> \pi </tex>, Y, A, B): |
'''for''' i = 1..K | '''for''' i = 1..K | ||
TState[i, 1] = <tex> \pi </tex>[i] * B[i, Y[i]] | TState[i, 1] = <tex> \pi </tex>[i] * B[i, Y[i]] | ||
Строка 33: | Строка 33: | ||
//функция arg max() ищет максимум выражения в скобках и возвращает аргумент (в нашем случае <tex>k</tex>), при котором достигается этот максимум. | //функция arg max() ищет максимум выражения в скобках и возвращает аргумент (в нашем случае <tex>k</tex>), при котором достигается этот максимум. | ||
X[T] = <tex> \arg\max_{1 \leqslant k\leqslant K} \limits </tex>(TState[k, T]) | X[T] = <tex> \arg\max_{1 \leqslant k\leqslant K} \limits </tex>(TState[k, T]) | ||
− | '''for''' i = T | + | '''for''' i = T '''downto''' 2 |
X[i - 1] = TIndex[X[i], i] | X[i - 1] = TIndex[X[i], i] | ||
'''return''' X | '''return''' X |
Версия 21:53, 17 ноября 2013
Содержание
История
Алгоритм Витерби был представлен в 1967 году для декодирования сверточных кодов, поступающих через зашумленный канал связи. В 1969 году Омура (Omura) показал, что основу алгоритма Витерби составляет оценка максимума правдоподобия.
Описание
Алгоритм Витерби позволяет сделать наилучшее предположение о последовательности состояний скрытой Марковской модели на основе последовательности наблюдений. Эта последовательность состояний называется путем Витерби.
Определение: |
Путь Витерби — наиболее правдоподобная последовательность скрытых состояний. |
Пусть задано пространство наблюдений , пространство состояний , последовательность наблюдений , матрица переходов из -того состояния в -ое, размером , матрица эмиссии размера , которая определяет вероятность наблюдения из состояния , массив начальных вероятностей размером , показывающий вероятность того, что начальное состояние . Путь — последовательность состояний, которые привели к последовательности наблюдений .
Алгоритм
Создадим две матрицы
и размером . Каждый элемент содержит вероятность того, что на -ом шаге мы находимся в состоянии . Каждый элемент содержит индекс наиболее вероятного состояния на -ом шаге.Шаг 1. Заполним первый столбец матриц
на основании начального распределения, и нулями.Шаг 2. Последовательно заполняем следующие столбцы матриц
и , используя матрицы вероятностей эмиссий и переходов.Шаг 3. Рассматривая максимальные значения в столбцах матрицы
, начиная с последнего столбца, выдаем ответ.Псевдокод
//функция возвращает вектор X — последовательность номеров наиболее вероятных состояний, которые привели к данным наблюдениям. viterbi(O, S,, Y, A, B): for i = 1..K TState[i, 1] = [i] * B[i, Y[i]] TIndex[i, 1] = 0 for i = 2..T for j = 1..K TState[j, i] = (TState[k, i - 1] * A[k, j] * B[j, Y[i]]) TIndex[j, i] = (TState[k, i - 1] * A[k, j] * B[j, Y[i]]) //функция arg max() ищет максимум выражения в скобках и возвращает аргумент (в нашем случае ), при котором достигается этот максимум. X[T] = (TState[k, T]) for i = T downto 2 X[i - 1] = TIndex[X[i], i] return X
Таким образом, алгоритму требуется
времени.Применение
Алгоритм используется в CDMA и GSM цифровой связи, в модемах и космических коммуникациях. Он нашел применение в распознавании речи и письма, компьютерной лингвистике и биоинформатике, а также в алгоритме свёрточного декодирования Витерби.