DTW算法程序最终输出的D(n,m)是一个距离还是一个矩阵?DTW的一般算法实现DTW算法的函数Dtw.mfunction dist = dtw(t,r)n = size(t,1);m = size(r,1);% 帧匹配距离矩阵d = zeros(n,m);for i = 1:nfor j = 1:md(i,j) = sum((t(i
来源:学生作业帮助网 编辑:作业帮 时间:2024/11/17 18:49:26
DTW算法程序最终输出的D(n,m)是一个距离还是一个矩阵?DTW的一般算法实现DTW算法的函数Dtw.mfunction dist = dtw(t,r)n = size(t,1);m = size(r,1);% 帧匹配距离矩阵d = zeros(n,m);for i = 1:nfor j = 1:md(i,j) = sum((t(i
DTW算法程序最终输出的D(n,m)是一个距离还是一个矩阵?
DTW的一般算法
实现DTW算法的函数Dtw.m
function dist = dtw(t,r)
n = size(t,1);
m = size(r,1);
% 帧匹配距离矩阵
d = zeros(n,m);
for i = 1:n
for j = 1:m
d(i,j) = sum((t(i,:)-r(j,:)).^2);
end
end
% 累积距离矩阵
D = ones(n,m) *realmax;
D(1,1) = d(1,1);
% 动态规划
for i = 2:n
for j = 1:m
D1 = D(i-1,j);
if j>1
D2 = D(i-1,j-1);
else
D2 =realmax;
end
if j>2
D3 = D(i-1,j-2);
else
D3 =realmax;
end
D(i,j) = d(i,j) + min([D1,D2,D3]);
end
end
dist = D(n,m);
如题,最后输出的是距离还是矩阵?利用这个程序,最开始的t和r并没有定义,那么我需要输入的是两个n维和m维矩阵吗?
DTW算法程序最终输出的D(n,m)是一个距离还是一个矩阵?DTW的一般算法实现DTW算法的函数Dtw.mfunction dist = dtw(t,r)n = size(t,1);m = size(r,1);% 帧匹配距离矩阵d = zeros(n,m);for i = 1:nfor j = 1:md(i,j) = sum((t(i
是一个方阵