def compute(init_mat,trans_mat,emit_mat): init_sum = sum(init_mat.values()) for key,value in init_mat.items(): init_mat[key] = round(value/init_sum,3) for key,value in trans_mat.items(): cur_sum = sum(value.values()) if(cur_sum==0): continue for i,j in value.items(): trans_mat[key][i] = round(j/cur_sum,3) emit_list = emit_mat.values.tolist() for i in range(len(emit_list)): cur_sum = sum(emit_list[i]) if (cur_sum == 0): continue for j in range(len(emit_list[i])): emit_mat.iloc[i,j] = round(emit_list[i][j]/cur_sum,3)
时间: 2024-04-26 15:22:58 浏览: 97
compute_mapping.rar_compute_mapping_dts_writero5t_降维_非线性降维
5星 · 资源好评率100%
这段代码是用来计算HMM模型的初始概率矩阵、转移概率矩阵和发射概率矩阵的。其中,init_mat表示初始概率矩阵,trans_mat表示转移概率矩阵,emit_mat表示发射概率矩阵。这段代码的具体实现是将每个矩阵中的概率值除以对应行或列的总和,从而得到标准化后的概率值。其中,round函数用于保留小数点后三位。
阅读全文