【人工智能】动态时间规整 DTW

动态时间规整 DTW

How DTW (Dynamic Time Warping) algorithm works

def dtw(seq_a: List, seq_b: List):
    match_table = [[0 for _ in range(len(seq_a))] for _ in range(len(seq_b))]
    for i in range(len(seq_b)):
        for j in range(len(seq_a)):
            if i == 0 and j == 0:
                match_table[i][j] = abs(seq_b[i] - seq_a[j])
            elif i == 0:
                match_table[i][j] = abs(seq_b[i] - seq_a[j]) + match_table[i][j-1]
            elif j == 0:
                match_table[i][j] = abs(seq_b[i] - seq_a[j]) + match_table[i-1][j]
            else:
                match_table[i][j] = abs(seq_b[i] - seq_a[j]) + min(match_table[i-1][j], match_table[i][j-1], match_table[i-1][j-1])
    return match_table
posted @   杨谖之  阅读(21)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
历史上的今天:
2019-02-16 sqli-labs学习笔记 DAY1
点击右上角即可分享
微信分享提示
主题色彩