首页 > 其他 > 详细

[Matlab] LS(least squares)拟合3D平面

时间:2018-10-28 21:23:14      阅读:241      评论:0      收藏:0      [点我收藏+]
function [a,b,c,d]=get_LS_plane(data)
% a*x + b*y + c*z + d = 0
planeData=data;
% 协方差矩阵的SVD变换中,最小奇异值对应的奇异向量就是平面的方向
xyz0=mean(planeData,1);
centeredPlane=bsxfun(@minus,planeData,xyz0);
[~,~,V]=svd(centeredPlane);
a=V(1,3);
b=V(2,3);
c=V(3,3);
d=-dot([a b c],xyz0);

end

  

[Matlab] LS(least squares)拟合3D平面

原文:https://www.cnblogs.com/LoveBuzz/p/9867130.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!