HMM 隐马尔科夫 Python 代码
import numpy as np
# -*- codeing:utf-8 -*-
__author__ = 'youfei' # 隐状态
hidden_state = ['sunny', 'rainy'] # 观测序列
obsevition = ['walk', 'shop', 'clean'] # 根据观测序列、发射概率、状态转移矩阵、发射概率
# 返回最佳路径
def compute(obs, states, start_p, trans_p, emit_p):
# max_p(3*2)每一列存储第一列不同隐状态的最大概率
max_p = np.zeros((len(obs), len(states))) # path(2*3)每一行存储上max_p对应列的路径
path = np.zeros((len(states), len(obs))) # 初始化
for i in range(len(states)):
max_p[0][i] = start_p[i] * emit_p[i][obs[0]]
path[i][0] = i for t in range(1, len(obs)):
newpath = np.zeros((len(states), len(obs)))
for y in range(len(states)):
prob = -1
for y0 in range(len(states)):
nprob = max_p[t-1][y0] * trans_p[y0][y] * emit_p[y][obs[t]]
if nprob > prob:
prob = nprob
state = y0
# 记录路径
max_p[t][y] = prob
for m in range(t):
newpath[y][m] = path[state][m]
newpath[y][t] = y path = newpath max_prob = -1
path_state = 0
# 返回最大概率的路径
for y in range(len(states)):
if max_p[len(obs)-1][y] > max_prob:
max_prob = max_p[len(obs)-1][y]
path_state = y return path[path_state] state_s = [0, 1]
obser = [0, 1, 2] # 初始状态,测试集中,0.6概率观测序列以sunny开始
start_probability = [0.6, 0.4] # 转移概率,0.7:sunny下一天sunny的概率
transititon_probability = np.array([[0.7, 0.3], [0.4, 0.6]]) # 发射概率,0.4:sunny在0.4概率下为shop
emission_probability = np.array([[0.1, 0.4, 0.5], [0.6, 0.3, 0.1]]) result = compute(obser, state_s, start_probability, transititon_probability, emission_probability) for k in range(len(result)):
print(hidden_state[int(result[k])])
HMM 隐马尔科夫 Python 代码的更多相关文章
- Atitit 马尔可夫过程(Markov process) hmm隐马尔科夫。 马尔可夫链,的原理attilax总结
		Atitit 马尔可夫过程(Markov process) hmm隐马尔科夫. 马尔可夫链,的原理attilax总结 1. 马尔可夫过程1 1.1. 马尔科夫的应用 生成一篇"看起来像文章的 ... 
- HMM隐马尔科夫模型
		这是一个非常重要的模型,凡是学统计学.机器学习.数据挖掘的人都应该彻底搞懂. python包: hmmlearn 0.2.0 https://github.com/hmmlearn/hmmlearn ... 
- HMM隐马尔科夫算法(Hidden Markov Algorithm)初探
		1. HMM背景 0x1:概率模型 - 用概率分布的方式抽象事物的规律 机器学习最重要的任务,是根据一些已观察到的证据(例如训练样本)来对感兴趣的未知变量(例如类别标记)进行估计和推测. 概率模型(p ... 
- 自然语言处理(1)-HMM隐马尔科夫模型基础概念(一)
		隐马尔科夫模型HMM 序言 文本序列标注是自然语言处理中非常重要的一环,我先接触到的是CRF(条件随机场模型)用于解决相关问题,因此希望能够对CRF有一个全面的理解,但是由于在学习过程中发现一个算法像 ... 
- HMM 隐马尔科夫模型
		参考如下博客: http://www.52nlp.cn/itenyh%E7%89%88-%E7%94%A8hmm%E5%81%9A%E4%B8%AD%E6%96%87%E5%88%86%E8%AF%8 ... 
- 隐马尔科夫模型,第三种问题解法,维比特算法(biterbi) algorithm python代码
		上篇介绍了隐马尔科夫模型 本文给出关于问题3解决方法,并给出一个例子的python代码 回顾上文,问题3是什么, 下面给出,维比特算法(biterbi) algorithm 下面通过一个具体例子,来说 ... 
- 用hmmlearn学习隐马尔科夫模型HMM
		在之前的HMM系列中,我们对隐马尔科夫模型HMM的原理以及三个问题的求解方法做了总结.本文我们就从实践的角度用Python的hmmlearn库来学习HMM的使用.关于hmmlearn的更多资料在官方文 ... 
- HMM基本原理及其实现(隐马尔科夫模型)
		HMM(隐马尔科夫模型)基本原理及其实现 HMM基本原理 Markov链:如果一个过程的“将来”仅依赖“现在”而不依赖“过去”,则此过程具有马尔可夫性,或称此过程为马尔可夫过程.马尔可夫链是时间和状态 ... 
- 隐马尔科夫模型的Python3实现代码
		下面给出计算隐马尔科夫模型的编程代码: from hmmlearn.hmm import GaussianHMM import datetime import numpy as np from mat ... 
随机推荐
- S03_CH02_AXI_DMA PL发送数据到PS
			S03_CH02_AXI_DMA PL发送数据到PS 1.1概述 本课程的设计原理分析. 本课程循序渐进,承接<S03_CH01_AXI_DMA_LOOP 环路测试>这一课程,在DATA ... 
- java统计字符串中每个字符出现的次数
			package MapTest; import java.util.HashMap; public class MapTest { public static void Count(String st ... 
- Iedis - Redis 在IDEA中的可视化工具破解
			2.如何破解 // 如果你没有改动IDEA的话,IDEA的插件库在这个目录下C:\Users\Administrator\.IntelliJIdea2017.3\config\plugins\Iedi ... 
- poj 1224
			题意:有一个5 * 6的矩阵,每个位置表示灯,1表示灯亮,0表示灯灭. 然后如果选定位置i,j点击,则位置i,j和其上下左右的灯的状态都会反转. 现在要你求出一个5 * 6的矩阵,1表示这个灯被点击过 ... 
- [Vue]vue-router的push和replace的区别
			1.this.$router.push() 描述:跳转到不同的url,但这个方法会向history栈添加一个记录,点击后退会返回到上一个页面. 2.this.$router.replace() 描述: ... 
- js页面内容只读,不可复制
			// document.oncontextmenu=new Function("event.returnValue=false"); // document.onselectsta ... 
- Java在常见的spring面试问题TOP50
			1. 一般问题 1.1. 不同版本的 Spring Framework 有哪些主要功能? Version Feature Spring 2.5 发布于 2007 年.这是第一个支持注解的版本. Spr ... 
- Jenkins服务器安装与配置
			Jenkins是一个非常出色的持续集成服务器,本文主要介绍在CentOS系统中Jenkins的基本安装配置方法,供参考. 一. 软件包: 1. 下载apache-maven-2.2.1-bin.tar ... 
- Srping事物的隔离策略
			spring事务: 什么是事务: 事务逻辑上的一组操作,组成这组操作的各个逻辑单元,要么一起成功,要么一起失败. 事务特性(4种): 原子性 (atomicity):强调事务的不可分割. 一致性 (c ... 
- GOLANG接口编程的最佳实践一 (sort.Sort(data Interface ) )
			package main import( "fmt" "sort" "math/rand" ) //定义一个武当派的结构体 type Wud ... 
