dynamic time warping matlab,科学网—【科研速记】Dynamic time warping - 李冰的博文

DTW的作用

Dynamic time warping 简称DTW,用于计算两个时间序列之间的相似性的算法,也可以理解找到两个时间序列之间的最佳匹配。DTW最著名的用途应该是用于语音识别。

36fb1b319f27596c2ddc93396f221d5c.png

Figure 1

DTW为什么会出现呢?

在计算两个序列相似性时,传统的度量方法如欧式距离、曼哈顿距离都会失效,或者说无法真正度量两个序列相似性。其原因是,这些距离度量方式是用一一对应的距离度量。

035a5f99e35707bc415560e049f86e6a.png

Figure 2 欧式距离

那么有没有一种根据序列的走势来计算相似性呢,比如序列A上某个点可能和序列B上多个点进行匹配。DTW就可以达到这种效果,如下图:

7ad1cfa454c9dc5bbde3b8ea073a06c4.png

Figure 3  DTW

DTW算法形式

int DTWDistance(s: array [1..n], t: array [1..m]) {

DTW := array [0..n, 0..m]

for i := 1 to n

DTW[i, 0] := infinity

for i := 1 to m

DTW[0, i] := infinity

DTW[0, 0] := 0

for i := 1 to n

for j := 1 to m

cost:= d(s[i], t[j])

DTW[i, j] := cost + minimum(DTW[i-1, j  ],    // insertion

DTW[i  , j-1],    // deletion

DTW[i-1, j-1])    // match

return DTW[n, m]

}

注意,

(1)这个问题是一个动态规划问题,并且算法中经典问题——求字符串匹配的编辑距离——类似。

(2)找两个序列的匹配路径,要从最末尾的dtw(n,m)往回找,而不是从dtw(1,1)往前搜。

Reference:

Distance Functions for Sequence Data and Time Series

https://en.wikipedia.org/wiki/Dynamic_time_warping

转载本文请联系原作者获取授权,同时请注明本文来自李冰科学网博客。

链接地址:http://blog.sciencenet.cn/blog-212252-701037.html

上一篇:小白鼠成长日记2013年0213——缺乏讨论导致科研进度慢

下一篇:小白鼠成长日记20130621——听南洋理工大学的Xu dong的讲座

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值