DTW算法代码(老外写的)

时间:2014-12-25 10:07:49
【文件属性】:
文件名称:DTW算法代码(老外写的)
文件大小:8KB
文件格式:C
更新时间:2014-12-25 10:07:49
dtw 在日常的生活中我们最经常使用的距离毫无疑问应该是欧式距离,但是对于一些特殊情况,欧氏距离存在着其很明显的缺陷,比如说时间序列,举个比较简单的例子,序列A:1,1,1,10,2,3,序列B:1,1,1,2,10,3,如果用欧氏距离,也就是distance[i][j]=(b[j]-a[i])*(b[j]-a[i])来计算的话,总的距离和应该是128,应该说这个距离是非常大的,而实际上这个序列的图像是十分相似的,这种情况下就有人开始考虑寻找新的时间序列距离的计算方法,然后提出了DTW算法,这种方法在语音识别,机器学习方便有着很重要的作用。 这个算法是基于动态规划(DP)的思想,解决了发音长短不一的模板匹配问题,简单来说,就是通过构建一个邻接矩阵,寻找最短路径和。 还以上面的2个序列作为例子,A中的10和B中的2对应以及A中的2和B中的10对应的时候,distance[3]以及distance[4]肯定是非常大的,这就直接导致了最后距离和的膨胀,这种时候,我们需要来调整下时间序列,如果我们让A中的10和B中的10 对应 ,A中的1和B中的2对应,那么最后的距离和就将大大缩短,这种方式可以看做是一种时间扭曲,看到这里的时候,我相信应该会有人提出来,为什么不能使用A中的2与B中的2对应的问题,那样的话距离和肯定是0了啊,距离应该是最小的吧,但这种情况是不允许的,因为A中的10是发生在2的前面,而B中的2则发生在10的前面,如果对应方式交叉的话会导致时间上的混乱,不符合因果关系。 接下来,以output[6][6](所有的记录下标从1开始,开始的时候全部置0)记录A,B之间的DTW距离,简单的介绍一下具体的算法,这个算法其实就是一个简单的DP,状态转移公式是output[i] [j]=Min(Min(output[i-1][j],output[i][j-1]),output[i-1][j-1])+distance[i] [j];最后得到的output[5][5]就是我们所需要的DTW距离.

网友评论

  • 没太看懂,不过代码不错
  • 好的源代码,值得学习借鉴
  • 测试通过,非常好用
  • 比较好的源代码,值得学习借鉴
  • 是vc的,确实是匹配的好算法
  • C语言版的DTW算法,可以运行起来
  • 怎么会有bug 啊?
  • 有代码,调试成功。
  • 是 C 写的 看不太懂,还是非常感谢
  • 要是用matlab写的就更好了。网上查到的基本都是不可执行。赞一个
  • 代码写的很清晰,很容易理解,很不错
  • 很好用,谢谢分享。
  • 很好用,多谢分享。
  • 经典算法!
  • 算法很经典 思路很清晰
  • 算法很经典
  • 很清楚,易读
  • 要是matlab就好了
  • 不错,比较经典的DTW算法,也很规范。
  • 最近要用语音识别,感觉很不错
  • 很经典的算法,代码写的很漂亮,谢谢楼主分享。
  • 老外就是厉害呀 简介 清晰
  • 好吧,dtw不是很懂
  • 经典算法,main函数写的有点问题,自己改改就行
  • 这个的确不错,非常清晰
  • 嗯,不错,很详细
  • 还可以,不错
  • 感觉很有用。
  • 还可以,就是C写的,不过这只是经典的dtw算法。
  • 简洁,有参考价值