calculate distance using the below equation
3 次查看(过去 30 天)
显示 更早的评论
i have 2 variables, dataMatrix and queryMatrix..... dataMatrix contains 245 rows and 38 column values...... and queryMatrix contains 1 row and 38 column values...... i calculate the euclidean distance and sort the distances in ascending order as below.....
for w=1:245
dist = sum((repmat(queryMatrix(w,:),245,1)-dataMatrix).^2,2);
[sortval sortpos] = sort(dist,'ascend');
neighborIds(w,:) = sortpos(1:k);
neighborDistances(w,:) = sqrt(sortval(1:k));
end
instead of euclidean distance i want to use the distance formula in the below link.....
but i dont know to write the equation in matlab...... please can someone convert that equation to matlab..... it would be great help to me..... please do reply......
1 个评论
采纳的回答
Matt J
2013-4-11
Assuming queryMatrix and dataMatrix are both 245x38, the whole thing can be done without loops,
d=permute(dataMatrix,[1,3,2]);
q=permute(queryMatrix,[3,1,2]);
num = abs(bsxfun(@minus,d,q));
den = bsxfun(@plus,abs(d),abs(q));
dist=sum(num./den,3);
[sortval sortpos] = sort(dist);
neighborIds = sortpos(1:k,:);
neighborDistances = sqrt(sortval(1:k,:));
更多回答(1 个)
Andrei Bobrov
2013-4-11
编辑:Andrei Bobrov
2013-4-11
dataMatrix = randi([-10,10],10,5);
queryMatrix = randi([-10 10],1,5);
d = bsxfun(@(x,y)abs(x - y)./(abs(x) + abs(y)),...
dataMatrix,permute(queryMatrix,[3 2 1]));
d = sort(squeeze(sum(d,2)));
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Expression Analysis 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!