热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HMM算法之维特比算法

参考李航《统计学习基础的》的公式推导PInp.array([0.2,0.4,0.4])Anp.array([[0.5,0.2,0.3],[0.3,0.5,

参考李航《统计学习基础的》的公式推导

PI = np.array([0.2, 0.4, 0.4])
A = np.array([[0.5, 0.2, 0.3], [0.3, 0.5, 0.2], [0.2, 0.3, 0.5]])
B = np.array([[0.5, 0.5], [0.4, 0.6], [0.7, 0.3]])
O = [1, 2, 1] # 观测序列



def viterbi(PI, A, B, O):  # 维特比算法
    T = len(O)  # 观测序列的数目
    N = len(PI)  # 所有可能的状态个数
    deta = PI * B[:, O[0] - 1]  # 初始
    pusai = np.zeros((T, N))
    seq = np.zeros(T) # 最优状态序列
    print deta, pusai[0]
    for t in range(1, T):
        tmp = [(deta * A[:, i]).tolist() for i in range(3)]
        pusai[t] = np.argmax(tmp, axis=1).tolist()
        deta = [max(deta * A[:, i]) for i in range(N)] * B[:, O[t] - 1]
        print deta, pusai[t]
    i = np.argmax(deta)  # 从最后一个开始回溯
    seq[-1] = int(i)
    pusai = np.mat(pusai)
    for t in range(T - 1, 0, -1):
        i = pusai[t, i]
        seq[t - 1] = i
    return seq



推荐阅读
  • 本文探讨了K近邻(KNN)算法中K值的选择对模型复杂度的影响,通过实验分析不同K值下的模型表现,旨在为KNN算法的应用提供指导。 ... [详细]
  • ipvsadm命令简介:ipvsadm是LVS在应用层的管理命令,我们可以通过这个命令去管理LVS的配置。在fedora14、Linux6.0之后系统中 ... [详细]
  • 必知必会13条importosos.environ.setdefault(DJANGO_SETTINGS_MODULE,orm_practice.settings)impo ... [详细]
  • 前端监控系列2 | 深入探讨JS错误监控的重要性与实践
    作者:彭莉,火山引擎APM研发工程师,专注于前端监控技术的研发。本文将深入讨论JS错误监控的必要性及其实现方法,帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 深入解析Java设计模式之责任链模式
    责任链模式通过将处理请求的对象链接成一条链,确保每个请求能够沿着这条链传递,直至找到合适的处理者。本文将详细介绍责任链模式的原理、优势、局限及实际应用案例。 ... [详细]
  • VSCode中使用Clang-Format进行C/C++代码格式化配置
    本文介绍了如何在VSCode中配置Clang-Format以实现C/C++代码的自动格式化,包括安装必要的扩展、配置文件的创建以及常用设置的解释。建议阅读官方文档以获取更多详细信息。 ... [详细]
  • [TOC]Process的几个用法和守护进程一、Process的join用法话不多说,直接上代码二、Process的pid和ppid用法需要先导入os模块站在当前进程的角度:os. ... [详细]
  • NumPy 学习指南:深入理解 ndarray 索引机制
    本文详细介绍了 NumPy 的核心概念——N 维数组对象 (ndarray),并深入探讨了其索引机制,包括基本索引、切片以及高级索引等。 ... [详细]
  • 深入解析Pytest Fixture与Conftest的高级应用
    本文详细探讨了Pytest中的Fixture机制及其在conftest.py文件中的全局配置应用,涵盖Fixture的基本概念、定义、多种使用场景以及作用域等内容,适合希望深入了解Pytest测试框架的开发者。 ... [详细]
  • 本文介绍了 Python 中 *args 和 **kwargs 的使用方法,以及如何通过 lambda 表达式、map 和 filter 函数处理数据。同时,探讨了 enumerate 和 zip 函数的应用,并展示了如何使用生成器函数处理大数据集。 ... [详细]
  • 本文通过一个实际案例,详细介绍了如何使用Excel VBA和FSO(FileSystemObject)对象来提取指定文件夹中的所有文件名称,并将其以超链接的形式添加到Excel表格中。 ... [详细]
  • 本文详细介绍了如何在Unity中使用贝塞尔曲线来实现物体的平滑移动。通过定义一个辅助工具类和一个移动控制类,可以轻松地让物体沿着预设的贝塞尔曲线路径移动。 ... [详细]
  • 本文介绍了如何在 Linux 系统上构建网络路由器,特别关注于使用 Zebra 软件实现动态路由功能。通过具体的案例,展示了如何配置 RIP 和 OSPF 协议,以及如何利用多路由器查看工具(MRLG)监控网络状态。 ... [详细]
  • 学习目的:1.了解android线程的使用2.了解主线程与子线程区别3.解析异步处理机制主线程与子线程:所谓主线程,在Windows窗体应用程序中一般指UI线程,这个是程序启动的时 ... [详细]
  • Flutter入门指南:实现自动关闭的对话框与提示
    本文为Flutter系列教程的一部分,专注于讲解如何在Flutter应用中实现自动关闭的对话框和提示。通过具体的代码示例,帮助开发者掌握SnackBar、BottomSheet和Dialog的使用方法。 ... [详细]
author-avatar
wgol992015
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有