1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

解题思路

题目要求对每条观测序列,求:

  1. 最优隐藏状态序列
  2. 该最优路径对应的对数概率 logP(q^,o)log P(q̂, o)logP(q^​,o)

这正是经典的ViterbiViterbiViterbi 算法问题。

P4588.第2题-离散型隐马尔可夫模型预测

    1000ms Tried: 27 Accepted: 6 Difficulty: 5 所属公司 : 蚂蚁
    算法与标签>动态规划

题目内容

请在仅使用 numpynumpynumpy 的前提下,实现离散型隐马尔可夫模型 (HMMHMMHMM) 的 ViterbiViterbiViterbi 动态规划。

给定:

  • 初始分布 π∈RN\pi \in \mathbb{R}^{N}π∈RN

  • 状态转移矩阵 A∈RN×NA \in \mathbb{R}^{N \times N}A∈RN×N

  • 观测概率矩阵 B∈RN×MB \in \mathbb{R}^{N \times M}B∈RN×M (列索引=观测符号)

  • 多条离散观测序列 {o(s)}s=1S\left\{\mathbf{o}^{(s)}\right\}_{s=1}^{S}{o(s)}s=1S​ ,符号取值 0...M−10...M-10...M−1

请为每条序列计算

1.最优隐藏状态序列 q^(s)=(q1,…,qT)\hat{\mathbf{q}}^{(s)}=\left(q_{1}, \ldots, q_{T}\right)q^​(s)=(q1​,…,qT​)

2.该序列的对数概率 log⁡P(q^,o)\log P(\hat{\mathbf{q}}, \mathbf{o})logP(q^​,o)

实现要求

  • 对数域计算,避免下溢:所有乘法用 log+log+log+,求和用 logsumexplogsumexplogsumexp 或 np.logaddexp.reducenp.logaddexp.reducenp.logaddexp.reduce

  • 只需前向传递 +++ 回溯,无需 forward/backwardforward/backwardforward/backward 或 EMEMEM 训练

  • 所有浮点以 float64float64float64 计算;输出对数概率保留 666 位小数(四舍五入)

输入描述

单行 JSON:

{

"pi":[0.6,0.4],                        //长度N

"A": [[0.7,0.3],[0.4,0.6]],         // N×N

"B": [[0.5,0.4,0.1],[0.1,0.3,0.6]], // N×M

"obs":[[0.0],[2.2]...]          //S条序列,符号整数

}
  • N≤4,M≤4N≤4,M≤4N≤4,M≤4,序列长度 T≤6,S≤10T≤6,S≤10T≤6,S≤10

  • 所有概率矩阵行各自已归一化;不必检验

输出描述

仅一行 JSON:

{

"paths":[[q11,q12,...],[q21,...],...],         //每条序列最优路径

"logp":[-2.253795,-2.448768,...]         //对应对数概率,使用 round(x,6) 保留小数位

}

次序须与输入 obsobsobs 保持一致。

补充说明

为确保通过测试用例,仅允许使用 numpynumpynumpy 。

样例1

输入

{"pi":[0.6,0.4],"A":[[0.7,0.3],[0.4,0.6]],"B":[[0.5,0.4,0.1],[0.1,0.3,0.6]],"obs":[[0,0]]}

输出

{"paths": [[0, 0]], "logp": [-2.253795]}

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 0, 57ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?