最小二乘法拟合球面源代码(matlab)

转自:https://blog.csdn.net/zhuoyueljl/article/details/53675460

最小二乘法拟合球面源代码(matlab)

1、源代码

[html]  view plain  copy
  1. <span style="font-size:14px;">[x,y,z]=sphere(5);  
  2. x = [0,0,1,0,0,0.7].';   %自己的数据  
  3. y = [0,1,0,0,-1,0.7].';  %自己的数据  
  4. z = [1,0,0,-1,0,0].';    %自己的数据  
  5. % 拟合  
  6. x = x(:); y = y(:); z = z(:);  
  7. data=unique([x(:)-0.1,y(:)+0.2,z(:)],'rows');  
  8. f=@(p,data)(data(:,1)-p(1)).^2+(data(:,2)-p(2)).^2+(data(:,3)-p(3)).^2-p(4)^2;  
  9. p=nlinfit(data,zeros(size(data,1),1),f,[0 0 0 1]')%拟合的参数  
  10. hold on  
  11. plot3(data(:,1),data(:,2),data(:,3),'o')  
  12. [X,Y,Z]=meshgrid(linspace(-14,14));  
  13. V=(X-p(1)).^2+(Y-p(2)).^2+(Z-p(3)).^2-p(4)^2;  
  14. isosurface(X,Y,Z,V,0);  
  15. alpha .5;camlight;axis equal;grid on;view(3);  
  16. title(sprintf('(x-%f)^2+(y-%f)^2+(z-%f)^2=%f',p(1),p(2),p(3),p(4)^2))</span>  


在matlab的输入窗口输入源代码后按Enter键如下图所示



2、实验结果




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值