IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 维特比算法 -> 正文阅读

[数据结构与算法]维特比算法

一、概述

??维特比算法是安德鲁.维特比(Andrew Viterbi)于1967年为解决通信领域中的解码问题而提出的,它同样广泛用于解决自然语言处理中的解码问题,隐马尔可夫模型的解码是其中典型的代表。无论是通信中的解码问题还是自然语言处理中的解码问题,本质上都是要在一个篱笆网络中寻找得到一条最优路径。
??所谓篱笆网络,指的是单向无环图,呈层级连接,各层节点数可以不同。如图是一个篱笆网络,连线上的数字是节点间概念上的距离(如间距、代价、概率等),现要找到一条从起始点到终点的最优路径。
在这里插入图片描述
??在实际问题中,节点数和层数往往是大量的,因而采取遍历所有的路径计算其距离进行比较的方式是不可行的。维特比算法正是通过动态规划的方式高效求得这条最优路径。


二、维特比算法

1.算法原理

??该问题具有这样一个特性,对于最优(如最短距离)的路径,任意一段子路径一定是该段两端点间所有可达路径中最优的,如若不然,将该段中更优的子路径接到两端点便构成了另一个整体最优路径,这是矛盾的。或者说,最优路径中,从起始点到由近及远的任一点的子路径,一定是该段所有可达路径中最优的。也即,整体最优,局部一定最优。
在这里插入图片描述
??该特性也就是说,对每个节点而言,如果最优路径经过这一点,则一定是经过从起始点到这点的这段最优路径。那么,只要从头开始,由局部向整体推进,渐次地找到起始点到当前点的最优路径,算至终点便得到了整体最优路径。这样的方式叫做动态规划,是维特比算法的基本思想。
维特比算法求解篱笆网络最短路径的过程为:
??从第一层开始,对每一层的每一个节点,计算出起始点到它的最短距离,并记录下相应最短路径下它的前一个节点,逐层递推,算至终止点时便得到了整体最短距离,再依照节点记录下的前置节点进行回溯,就得到了最短路径的序列。对第 i i i层第 j j j个节点 P i , j P_{i,j} Pi,j?,假设起始点到它的最短距离为 D ( P i , j ) D\left( P_{i,j} \right) D(Pi,j?),相应最短路径下它的前一个节点为 P r e ( P i , j ) Pre\left( P_{i,j} \right) Pre(Pi,j?),则

D ( P i , j ) = min ? 1 ≤ k ≤ N [ D i ? 1 , k + d ( P i ? 1 , k , P i , j ) ] D\left( P_{i,j} \right)=\min_{1\leq k \leq N}{\left[ D_{i-1,k}+d(P_{i-1,k},P_{i,j}) \right]} D(Pi,j?)=1kNmin?[Di?1,k?+d(Pi?1,k?,Pi,j?)]
也就是,对前一层的所有节点,计算每一个节点的记录的最短距离D与它到当前节点的距离d的和,取其中最小的那个值(其中, d ( A , B ) d(A,B) d(A,B)表示A,B两节点间的距离。).

P r e ( P i , j ) = P i ? 1 , j ? = a r g min ? 1 ≤ k ≤ N [ D i ? 1 , k + d ( P i ? 1 , k , P i , j ) ] Pre\left( P_{i,j} \right)=P_{i-1,j\ast}=arg\min_{1\leq k \leq N}{\left[ D_{i-1,k}+d(P_{i-1,k},P_{i,j}) \right]} Pre(Pi,j?)=Pi?1,j??=arg1kNmin?[Di?1,k?+d(Pi?1,k?,Pi,j?)]
也就是,满足距离最短的那条路径上在前一层的节点.


2.示例

??在如下网络中,连线上的数字是节点间的距离,求S点到E点的最短距离和与之对应的路径。
在这里插入图片描述
第一层:
对节点 P 1 , 1 P_{1,1} P1,1?
起始点到它只有一条路径,最短距离 D ( P 1 , 1 ) = 2 D(P_{1,1})=2 D(P1,1?)=2,前一个节点 P r e ( P 1 , 1 ) = S Pre(P_{1,1}) = S Pre(P1,1?)=S

对节点 P 1 , 2 P_{1,2} P1,2?
起始点到它只有一条路径,最短距离 D ( P 1 , 2 ) = 1 D(P_{1,2}) = 1 D(P1,2?)=1,前一个节点 P r e ( P 1 , 2 ) = S Pre(P_{1,2}) = S Pre(P1,2?)=S

对节点 P 1 , 3 P_{1,3} P1,3?
起始点到它只有一条路径,最短距离 D ( P 1 , 3 ) = 3 D(P_{1,3}) = 3 D(P1,3?)=3,前一个节点 P r e ( P 1 , 3 ) = S Pre(P_{1,3}) = S Pre(P1,3?)=S
在这里插入图片描述
第二层:
对节点 P 2 , 1 P_{2,1} P2,1?
D ( P 1 , 1 ) + d ( P 1 , 1 , P 2 , 1 ) = 2 + 3 = 5 D(P_{1,1}) + d(P_{1,1},P_{2,1}) = 2 + 3 = 5 D(P1,1?)+d(P1,1?P2,1?)=2+3=5
D ( P 1 , 2 ) + d ( P 1 , 2 , P 2 , 1 ) = 1 + 2 = 3 D(P_{1,2}) + d(P_{1,2},P_{2,1}) = 1 + 2 = 3 D(P1,2?)+d(P1,2?P2,1?)=1+2=3
D ( P 1 , 3 ) + d ( P 1 , 3 , P 2 , 1 ) = 3 + 9 = 12 D(P_{1,3}) + d(P_{1,3},P_{2,1}) = 3 + 9 = 12 D(P1,3?)+d(P1,3?P2,1?)=3+9=12
最短距离 D ( P 2 , 1 ) = m i n { 5 , 3 , 12 } = 3 D(P_{2,1}) = min\left\{ 5,3,12 \right\} = 3 D(P2,1?)=min{5,3,12}=3,前一个节点 P r e ( P 2 , 1 ) = P 1 , 2 Pre(P_{2,1}) = P_{1,2} Pre(P2,1?)=P1,2? ;

对节点 P 2 , 2 P_{2,2} P2,2?
D ( P 1 , 1 ) + d ( P 1 , 1 , P 2 , 2 ) = 2 + 6 = 8 D(P_{1,1}) + d(P_{1,1},P_{2,2}) = 2 + 6 = 8 D(P1,1?)+d(P1,1?P2,2?)=2+6=8
D ( P 1 , 2 ) + d ( P 1 , 2 , P 2 , 2 ) = 1 + 5 = 6 D(P_{1,2}) + d(P_{1,2},P_{2,2}) = 1 + 5 = 6 D(P1,2?)+d(P1,2?P2,2?)=1+5=6
D ( P 1 , 3 ) + d ( P 1 , 3 , P 2 , 2 ) = 3 + 2 = 5 D(P_{1,3}) + d(P_{1,3},P_{2,2}) = 3 + 2 = 5 D(P1,3?)+d(P1,3?P2,2?)=3+2=5
最短距离 D ( P 2 , 2 ) = m i n { 8 , 6 , 5 } = 5 D(P_{2,2}) = min\left\{ 8,6,5 \right\} = 5 D(P2,2?)=min{8,6,5}=5,前一个节点 P r e ( P 2 , 2 ) = P 1 , 3 Pre(P_{2,2}) = P_{1,3} Pre(P2,2?)=P1,3? ;

对节点 P 2 , 3 P_{2,3} P2,3?
D ( P 1 , 1 ) + d ( P 1 , 1 , P 2 , 3 ) = 2 + 4 = 6 D(P_{1,1}) + d(P_{1,1},P_{2,3}) = 2 + 4 = 6 D(P1,1?)+d(P1,1?P2,3?)=2+4=6
D ( P 1 , 2 ) + d ( P 1 , 2 , P 2 , 3 ) = 1 + 7 = 8 D(P_{1,2}) + d(P_{1,2},P_{2,3}) = 1 + 7 = 8 D(P1,2?)+d(P1,2?P2,3?)=1+7=8
D ( P 1 , 3 ) + d ( P 1 , 3 , P 2 , 3 ) = 3 + 6 = 9 D(P_{1,3}) + d(P_{1,3},P_{2,3}) = 3 + 6 = 9 D(P1,3?)+d(P1,3?P2,3?)=3+6=9
最短距离 D ( P 2 , 3 ) = m i n { 6 , 8 , 9 } = 6 D(P_{2,3}) = min\left\{ 6,8,9 \right\} = 6 D(P2,3?)=min{6,8,9}=6,前一个节点 P r e ( P 2 , 3 ) = P 1 , 1 Pre(P_{2,3}) = P_{1,1} Pre(P2,3?)=P1,1? ;
在这里插入图片描述
第三层:
对节点 P 3 , 1 P_{3,1} P3,1?
D ( P 2 , 1 ) + d ( P 2 , 1 , P 3 , 1 ) = 3 + 9 = 12 D(P_{2,1}) + d(P_{2,1},P_{3,1}) = 3 + 9 = 12 D(P2,1?)+d(P2,1?P3,1?)=3+9=12
D ( P 2 , 2 ) + d ( P 2 , 2 , P 3 , 1 ) = 5 + 2 = 7 D(P_{2,2}) + d(P_{2,2},P_{3,1}) = 5 + 2 = 7 D(P2,2?)+d(P2,2?P3,1?)=5+2=7
D ( P 2 , 3 ) + d ( P 2 , 3 , P 3 , 1 ) = 6 + 6 = 12 D(P_{2,3}) + d(P_{2,3},P_{3,1}) = 6 + 6 = 12 D(P2,3?)+d(P2,3?P3,1?)=6+6=12
最短距离 D ( P 3 , 1 ) = m i n { 12 , 7 , 12 } = 7 D(P_{3,1}) = min\left\{ 12,7,12 \right\} = 7 D(P3,1?)=min{12,7,12}=7,前一个节点 P r e ( P 3 , 1 ) = P 2 , 2 Pre(P_{3,1}) = P_{2,2} Pre(P3,1?)=P2,2?;

对节点 P 3 , 2 P_{3,2} P3,2?
D ( P 2 , 1 ) + d ( P 2 , 1 , P 3 , 2 ) = 3 + 3 = 6 D(P_{2,1}) + d(P_{2,1},P_{3,2}) = 3 + 3 = 6 D(P2,1?)+d(P2,1?P3,2?)=3+3=6
D ( P 2 , 2 ) + d ( P 2 , 2 , P 3 , 2 ) = 5 + 6 = 11 D(P_{2,2}) + d(P_{2,2},P_{3,2}) = 5 + 6 = 11 D(P2,2?)+d(P2,2?P3,2?)=5+6=11
D ( P 2 , 3 ) + d ( P 2 , 3 , P 3 , 2 ) = 6 + 3 = 9 D(P_{2,3}) + d(P_{2,3},P_{3,2}) = 6 + 3 = 9 D(P2,3?)+d(P2,3?P3,2?)=6+3=9
最短距离 D ( P 3 , 2 ) = m i n { 6 , 11 , 9 } = 6 D(P_{3,2}) = min\left\{ 6,11,9 \right\} = 6 D(P3,2?)=min{6,11,9}=6,前一个节点 P r e ( P 3 , 2 ) = P 2 , 1 Pre(P_{3,2}) = P_{2,1} Pre(P3,2?)=P2,1?;

对节点 P 3 , 3 P_{3,3} P3,3?
D ( P 2 , 1 ) + d ( P 2 , 1 , P 3 , 3 ) = 3 + 8 = 11 D(P_{2,1}) + d(P_{2,1},P_{3,3}) = 3 + 8 = 11 D(P2,1?)+d(P2,1?P3,3?)=3+8=11
D ( P 2 , 2 ) + d ( P 2 , 2 , P 3 , 3 ) = 5 + 7 = 12 D(P_{2,2}) + d(P_{2,2},P_{3,3}) = 5 + 7 = 12 D(P2,2?)+d(P2,2?P3,3?)=5+7=12
D ( P 2 , 3 ) + d ( P 2 , 3 , P 3 , 3 ) = 6 + 4 = 10 D(P_{2,3}) + d(P_{2,3},P_{3,3}) = 6 + 4 = 10 D(P2,3?)+d(P2,3?P3,3?)=6+4=10
最短距离 D ( P 3 , 3 ) = m i n { 11 , 12 , 10 } = 10 D(P_{3,3}) = min\left\{ 11,12,10 \right\} = 10 D(P3,3?)=min{11,12,10}=10,前一个节点 P r e ( P 3 , 3 ) = P 2 , 3 Pre(P_{3,3}) = P_{2,3} Pre(P3,3?)=P2,3?;
在这里插入图片描述
第四层(终点):
对节点 E E E
D ( P 3 , 1 ) + d ( P 3 , 1 , E ) = 7 + 3 = 10 D(P_{3,1}) + d(P_{3,1},E) = 7 + 3 = 10 D(P3,1?)+d(P3,1?E)=7+3=10
D ( P 3 , 2 ) + d ( P 3 , 2 , E ) = 6 + 7 = 13 D(P_{3,2}) + d(P_{3,2},E) = 6 + 7 = 13 D(P3,2?)+d(P3,2?E)=6+7=13
D ( P 3 , 3 ) + d ( P 3 , 3 , E ) = 10 + 6 = 16 D(P_{3,3}) + d(P_{3,3},E) = 10 + 6 = 16 D(P3,3?)+d(P3,3?E)=10+6=16
最短距离 D ( E ) = m i n { 10 , 13 , 16 } = 10 D(E) = min\left\{ 10,13,16 \right\} = 10 D(E)=min{10,13,16}=10,前一个节点 P r e ( E ) = P 3 , 1 Pre(E) = P_{3,1} Pre(E)=P3,1?;
在这里插入图片描述
P r e ( E ) = P 3 , 1 Pre(E) = P_{3,1} Pre(E)=P3,1? P r e ( P 3 , 1 ) = P 2 , 2 Pre(P_{3,1}) = P_{2,2} Pre(P3,1?)=P2,2? P r e ( P 2 , 2 ) = P 1 , 3 Pre(P_{2,2}) = P_{1,3} Pre(P2,2?)=P1,3? P r e ( P 1 , 3 ) = S Pre(P_{1,3}) = S Pre(P1,3?)=S
故最短距离为10,与之对应的路径为( S S S P 1 , 3 P_{1,3} P1,3? P 2 , 2 P_{2,2} P2,2? P 3 , 1 P_{3,1} P3,1? E E E).


三、隐马尔可夫模型的解码

1.问题描述

??隐马尔可夫模型(HMM)的解码问题指,给定模型和输出序列,如何找出最有可能产生这个输出的状态序列。自然语言处理中,也即如何通过观测信号确定最有可能对应的实际语义。在状态序列上,每个状态位是状态集合中的元素之一,因此该问题等价于在状态集合中的节点构成的有向网络(篱笆网络)中找出一条概率最大的路径(最优路径),如图。该问题可以通过维特比算法得到高效的解决。
在这里插入图片描述

2.算法叙述

??假设 P ( s t , j ) P(s_{t,j}) P(st,j?)表示从起始时刻到 s t , j s_{t,j} st,j?的最优路径的概率, P r e ( s t , j ) Pre(s_{t,j}) Pre(st,j?)表示从起始时刻到 s t , j s_{t,j} st,j?的最优路径上前一个节点,则隐马尔可夫模型的维特比解码算法为:

输入:隐马尔可夫模型 λ = ( π , A , B ) \lambda=(\pi,A,B) λ=(π,A,B)和观测 O = ( o 1 , o 2 , . . . , o T ) O=(o_1,o_2,...,o_T) O=(o1?,o2?,...,oT?)
输出:最优状态序列 S ? = ( s 1 ? , s 2 ? , . . . , s T ? ) S^{\ast}=(s_{1}^{\ast},s_{2}^{\ast},...,s_{T}^{\ast}) S?=(s1??,s2??,...,sT??).
(1)初始化
???? P ( s 1 , j ) = π j b j ( o 1 ) P(s_{1,j})=\pi_{j}b_{j}(o_1) P(s1,j?)=πj?bj?(o1?)
???? P r e ( s 1 , j ) = N o n e Pre(s_{1,j})=None Pre(s1,j?)=None j = 1 , 2 , . . . , N j=1,2,...,N j=1,2,...,N

(2)递推
?对 t = 2 , 3 , . . . , T t=2,3,...,T t=2,3,...,T
P ( s t , j ) = max ? 1 ≤ k ≤ N [ P ( s t ? 1 , k ) a k j ] b j ( o t ) P(s_{t,j})=\max_{1\leq k \leq N}{\left[ P(s_{t-1,k})a_{kj} \right]b_{j}(o_t)} P(st,j?)=1kNmax?[P(st?1,k?)akj?]bj?(ot?)
P r e ( s t , j ) = a r g max ? 1 ≤ k ≤ N [ P ( s t ? 1 , k ) a k j ] Pre(s_{t,j})=arg\max_{1\leq k \leq N}{\left[ P(s_{t-1,k})a_{kj} \right]} Pre(st,j?)=arg1kNmax?[P(st?1,k?)akj?] j = 1 , 2 , . . . , N j=1,2,...,N j=1,2,...,N.

(3)递推终止
?最大概率 P ? = max ? 1 ≤ j ≤ N P ( s T , j ) P^{\ast}=\max_{1\leq j \leq N}{P(s_{T,j})} P?=1jNmax?P(sT,j?)
?最优路径上的最后一个状态 s T ? = a r g max ? 1 ≤ j ≤ N [ P ( s T , j ) ] s_{T}^{\ast}=arg\max_{1\leq j \leq N}{\left[ P(s_{T,j}) \right]} sT??=arg1jNmax?[P(sT,j?)]

(4)回溯路径,确定最优状态序列
???? S ? = ( s 1 ? , s 2 ? , . . . , s T ? 1 ? , s T ? ) S^{\ast}=\left( s_{1}^{\ast},s_{2}^{\ast},...,s_{T-1}^{\ast},s_{T}^{\ast} \right) S?=(s1??,s2??,...,sT?1??,sT??)
????? = ( P r e ( s 2 ? ) , P r e ( s 3 ? ) , . . . , P r e ( s T ? ) , s T ? ) =\left( Pre(s_{2}^{\ast}),Pre(s_{3}^{\ast}), ...,Pre(s_{T}^{\ast}),s_{T}^{\ast}\right) =(Pre(s2??),Pre(s3??),...,Pre(sT??),sT??)


3.示例

(参考自《统计学习方法》)
状态集合 Q = { q 1 , q 2 , q 3 } Q=\left\{ q_1, q_2, q_3 \right\} Q={q1?,q2?,q3?},观测集合 V = { 0 , 1 } V=\left\{ 0,1 \right\} V={0,1},模型 λ = ( π , A , B ) \lambda=\left( \pi,A,B \right) λ=(π,A,B)

A = [ 0.5 0.2 0.3 0.3 0.5 0.2 0.2 0.3 0.5 ] A=\begin{bmatrix} 0.5 & 0.2 & 0.3 \\ 0.3 & 0.5 & 0.2 \\ 0.2 & 0.3 & 0.5 \\ \end{bmatrix} A=???0.50.30.2?0.20.50.3?0.30.20.5???? , B = [ 0.5 0.5 0.4 0.6 0.7 0.3 ] B=\begin{bmatrix} 0.5 & 0.5 \\ 0.4 & 0.6 \\ 0.7 & 0.3 \end{bmatrix} B=???0.50.40.7?0.50.60.3????, π = ( 0.2 , 0.4 , 0.4 ) T \pi=\left( 0.2, 0.4, 0.4 \right)^{T} π=(0.2,0.4,0.4)T

已知观测序列 O = ( 0 , 1 , 0 ) O=\left( 0, 1, 0 \right) O=(0,1,0),求最优状态序列。

解:
(1)在t=1时(初始化),对每一个状态,求观测为0的最大概率
? P ( s 1 , 1 ) = 0.2 × 0.5 = 0.1 P(s_{1,1})=0.2\times0.5=0.1 P(s1,1?)=0.2×0.5=0.1 P r e ( s 1 , 1 ) = N o n e Pre(s_{1,1})=None Pre(s1,1?)=None
? P ( s 1 , 2 ) = 0.4 × 0.4 = 0.16 P(s_{1,2})=0.4\times0.4=0.16 P(s1,2?)=0.4×0.4=0.16 P r e ( s 1 , 2 ) = N o n e Pre(s_{1,2})=None Pre(s1,2?)=None
? P ( s 1 , 3 ) = 0.4 × 0.7 = 0.28 P(s_{1,3})=0.4\times0.7=0.28 P(s1,3?)=0.4×0.7=0.28 P r e ( s 1 , 3 ) = N o n e Pre(s_{1,3})=None Pre(s1,3?)=None

(2)在t=2时,对每一个状态,求观测为1的
?最大概率 P ( s 2 , j ) = max ? 1 ≤ k ≤ 3 [ P ( s 1 , k ) a k j ] b j ( 1 ) P(s_{2,j})=\max_{1 \leq k \leq 3}{\left[ P(s_{1,k})a_{kj} \right]b_{j}(1)} P(s2,j?)=1k3max?[P(s1,k?)akj?]bj?(1)
?当前最优的前一个状态 P r e ( s 2 , j ) = a r g max ? 1 ≤ k ≤ 3 [ P ( s 1 , k ) a k j ] Pre(s_{2,j})=arg\max_{1 \leq k \leq 3}{\left[ P(s_{1,k})a_{kj} \right]} Pre(s2,j?)=arg1k3max?[P(s1,k?)akj?] j = 1 , 2 , 3. j=1,2,3. j=1,2,3.
P ( s 2 , 1 ) = m a x { 0.1 × 0.5 × 0.5 , 0.16 × 0.3 × 0.5 , 0.28 × 0.2 × 0.5 } P(s_{2,1})=max\left\{ 0.1\times0.5\times0.5, 0.16\times0.3\times0.5, 0.28\times0.2\times0.5 \right\} P(s2,1?)=max{0.1×0.5×0.5,0.16×0.3×0.5,0.28×0.2×0.5} = 0.028 =0.028 =0.028

P r e ( s 2 , 1 ) = s 1 , 3 = q 3 Pre(s_{2,1})=s_{1,3}=q_3 Pre(s2,1?)=s1,3?=q3?

P ( s 2 , 2 ) = m a x { 0.1 × 0.2 × 0.6 , 0.16 × 0.5 × 0.6 , 0.28 × 0.3 × 0.6 } P(s_{2,2})=max\left\{ 0.1\times0.2\times0.6,0.16\times0.5\times0.6,0.28\times0.3\times0.6 \right\} P(s2,2?)=max{0.1×0.2×0.6,0.16×0.5×0.6,0.28×0.3×0.6} = 0.0504 =0.0504 =0.0504

P r e ( s 2 , 2 ) = s 1 , 3 = q 3 Pre(s_{2,2})=s_{1,3}=q_3 Pre(s2,2?)=s1,3?=q3?

P ( s 2 , 3 ) = m a x { 0.1 × 0.3 × 0.3 , 0.16 × 0.2 × 0.3 , 0.28 × 0.5 × 0.3 } P(s_{2,3})=max\left\{ 0.1\times0.3\times0.3, 0.16\times0.2\times0.3,0.28\times0.5\times0.3 \right\} P(s2,3?)=max{0.1×0.3×0.3,0.16×0.2×0.3,0.28×0.5×0.3} = 0.042 =0.042 =0.042

P r e ( s 2 , 3 ) = s 1 , 3 = q 3 Pre(s_{2,3})=s_{1,3}=q_3 Pre(s2,3?)=s1,3?=q3?

(3)在t=3时,对每一个状态,求观测为0的
?最大概率 P ( s 3 , j ) = max ? 1 ≤ k ≤ 3 [ P ( s 2 , k ) a k j ] b j ( 0 ) P(s_{3,j})=\max_{1 \leq k \leq 3}{\left[ P(s_{2,k})a_{kj} \right]b_{j}(0)} P(s3,j?)=1k3max?[P(s2,k?)akj?]bj?(0)
?当前最优的前一个状态 P r e ( s 3 , j ) = a r g max ? 1 ≤ k ≤ 3 [ P ( s 2 , k ) a k j ] Pre(s_{3,j})=arg\max_{1 \leq k \leq 3}\left[ P(s_{2,k})a_{kj} \right] Pre(s3,j?)=arg1k3max?[P(s2,k?)akj?] j = 1 , 2 , 3. j=1,2,3. j=1,2,3.

P ( s 3 , 1 ) = m a x { 0.028 × 0.5 × 0.5 , 0.0504 × 0.3 × 0.5 , 0.042 × 0.2 × 0.5 } P(s_{3,1})=max\left\{ 0.028\times0.5\times0.5, 0.0504\times0.3\times0.5,0.042\times0.2\times0.5 \right\} P(s3,1?)=max{0.028×0.5×0.5,0.0504×0.3×0.5,0.042×0.2×0.5} = 0.00756 =0.00756 =0.00756

P r e ( s 3 , 1 ) = s 2 , 2 = q 2 Pre(s_{3,1})=s_{2,2}=q_2 Pre(s3,1?)=s2,2?=q2?

P ( s 3 , 2 ) = m a x { 0.028 × 0.2 × 0.4 , 0.0504 × 0.5 × 0.4 , 0.042 × 0.3 × 0.4 } P(s_{3,2})=max\left\{ 0.028\times0.2\times0.4, 0.0504\times0.5\times0.4, 0.042\times0.3\times0.4 \right\} P(s3,2?)=max{0.028×0.2×0.4,0.0504×0.5×0.4,0.042×0.3×0.4} = 0.01008 =0.01008 =0.01008

P r e ( s 3 , 2 ) = s 2 , 2 = q 2 Pre(s_{3,2})=s_{2,2}=q_2 Pre(s3,2?)=s2,2?=q2?

P ( s 3 , 3 ) = m a x { 0.028 × 0.3 × 0.7 , 0.0504 × 0.2 × 0.7 , 0.042 × 0.5 × 0.7 } P(s_{3,3})=max\left\{ 0.028\times0.3\times0.7,0.0504\times0.2\times0.7,0.042\times0.5\times0.7 \right\} P(s3,3?)=max{0.028×0.3×0.7,0.0504×0.2×0.7,0.042×0.5×0.7} = 0.0147 =0.0147 =0.0147

P r e ( s 3 , 3 ) = s 2 , 3 = q 3 Pre(s_{3,3})=s_{2,3}=q_3 Pre(s3,3?)=s2,3?=q3?

(4)得到结果.
?最大概率
?? P ? = max ? 1 ≤ j ≤ 3 P ( s 3 , j ) P^{\ast}=\max_{1 \leq j \leq 3}P\left( s_{3,j} \right) P?=max1j3?P(s3,j?)
??? = m a x { 0.00756 , 0.01008 , 0.0147 } =max\left\{ 0.00756,0.01008,0.0147 \right\} =max{0.00756,0.01008,0.0147}
??? = 0.0147 =0.0147 =0.0147
?最优状态序列
?? S ? = ( P r e ( s 2 ? ) t , P r e ( s 3 ? ) , s 3 ? ) S^{\ast}=\left( Pre(s_{2}^{\ast})t,Pre(s_{3}^{\ast}),s_{3}^{\ast} \right) S?=(Pre(s2??)t,Pre(s3??),s3??)
??? = ( s 1 , 3 , s 2 , 3 , s 3 , 3 ) =\left( s_{1,3},s_{2,3},s_{3,3} \right) =(s1,3?,s2,3?,s3,3?)
??? = ( q 3 , q 3 , q 3 ) =\left( q_3,q_3,q_3 \right) =(q3?,q3?,q3?)


4.python实现

对上述HMM维特比解码示例的python实现程序为

import numpy as np

def viterbi(pi, A, B, Q, V, obs_seq):
    '''
    :param pi:HMM初始状态概率向量,list类型
    :param A:HMM状态转移概率矩阵,list类型
    :param B:HMM观测生成概率矩阵,list类型
    :param Q:状态集合,list类型
    :param V:观测集合,list类型
    :param obs_seq:观测序列,list类型
    :return:最优状态序列的概率sta_pro,float类型;最优状态序列sta_seq,list类型
    '''

    # HMM模型参数转换为array类型
    pi = np.array(pi)
    A = np.array(A)
    B = np.array(B)

    # 1.定义动态计算结果存储矩阵
    rowNum = len(Q)  # 行数,状态数
    colNum = len(obs_seq)  # 列数,生成的观测数,即时刻数

    # 存储节点当前最大概率的矩阵
    probaMatrix = np.zeros((rowNum,colNum))

    # 存储当前最优路径下的前一个节点的矩阵
    preNodeMatrix = np.zeros((rowNum,colNum))

    # 2.初始化(第1时刻)
    probaMatrix[:,0] = pi*np.transpose(B[:,obs_seq[0]])
    preNodeMatrix[:,0] = [-1]*rowNum  # 第1时刻节点的前一个节点不存在,置为-1

    # 3.递推,第2时刻至最后
    for t in range(1, colNum):
        list_pre_max_proba = []  # 节点最大前置概率列表
        list_pre_node = []  # 节点当前最优路径中前一个节点列表
        for j in range(rowNum):
            pre_proba_list = list(np.array(probaMatrix[:,t-1])*np.transpose(A[:,j]))  # 前置概率列表,前一时刻的节点最大概率与到当前节点转移概率的乘积
            '''
            注:因为计算机的二进制机制对小数的表达是有限的,所以对小数作运算将产生一定的误差。
            在使用函数获取pre_proba_list中的最大值和对应的索引时,为有效降低这种误差,将数据放大后再进行操作。
            '''
            pre_proba_list = [x*pow(10,5) for x in pre_proba_list]  # 放大100000倍
            prePro = max(pre_proba_list)/pow(10,5)  # 最大前置概率
            preNodeIndexNum = pre_proba_list.index(max(pre_proba_list))  # 前置节点的索引号
            list_pre_max_proba.append(prePro)  # 最大前置概率加入列表
            list_pre_node.append(preNodeIndexNum)  # 前置节点的索引号加入列表

        probaMatrix[:,t] = np.array(list_pre_max_proba)*np.transpose(B[:,obs_seq[t]])  # 最大前置概率乘上观测概率,即为当前最大概率
        preNodeMatrix[:,t] = list_pre_node  # 将该列前置节点索引号加入矩阵

    # 此时,得到了完整的probaMatrix和preNodeMatrix,对这两个矩阵进行操作便可得到需要的结果
    # 4.得到最大概率
    maxPro = np.max(probaMatrix[:, colNum-1])  # 全局最大概率(即最后一列的最大值)

    # 5.得到最优状态序列的状态索引号列表
    lastStateIndexNum = np.argmax(probaMatrix[:, colNum-1])  # 最优状态序列中最后一个状态的索引号
    stateIndexList = []  # 定义最优状态的索引号列表
    stateIndexList.append(lastStateIndexNum)

    # 回溯,完成状态索引号列表
    currentIndex = lastStateIndexNum;
    for t in range(colNum-1, 0, -1):
        fls = preNodeMatrix[:, t].tolist()  # 矩阵中的数值是浮点型
        ls = list(map(int, fls))  # 转为整型
        currentIndex = ls[currentIndex]
        stateIndexList.append(currentIndex)

    stateIndexList.reverse()  # 反转列表

    # 6.由索引号序列得到最优状态序列
    stateSeq = [Q[i] for i in stateIndexList]

    return maxPro,stateSeq

if __name__=='__main__':
    # 状态集合
    Q = ["q1", "q2", "q3"]

    # 观测集合
    V = [0, 1]

    # 初始状态概率向量
    pi = [0.2, 0.4, 0.4]

    # 状态转移概率矩阵
    A = [[0.5, 0.2, 0.3],
         [0.3, 0.5, 0.2],
         [0.2, 0.3, 0.5]]

    # 观测概率矩阵
    B = [[0.5, 0.5],
         [0.4, 0.6],
         [0.7, 0.3]]

    # 观测序列
    obs_seq = [0, 1, 0]

    maxPro, stateSeq = viterbi(pi, A, B, Q, V, obs_seq)

    print("最大概率为:", maxPro)
    print("最优状态序列为:", stateSeq)

在这里插入图片描述
End.


参考

  1. 吴军. 数学之美(第二版). 人民邮电出版社.
  2. 李航. 统计学习方法. 清华大学出版社.
  3. https://www.cnblogs.com/zhibei/p/9391014.html
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-10-29 13:18:32  更:2021-10-29 13:18:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:50:38-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码