Labfans是一个针对大学生、工程师和科研工作者的技术社区。 | 论坛首页 | 联系我们(Contact Us) |
![]() |
|
![]() |
#1 |
初级会员
注册日期: 2010-05-25
年龄: 37
帖子: 4
声望力: 0 ![]() |
![]()
要求一个平面Z=AX+BY+C, 给出了一些三维点,要求使点到这个平面的 最大值与最小值之差 为最小 时的A,B,C的值??
![]() ![]() 我编的算法如下,不行 x=[564.350 564.704 564.563 554.944 553.457 555.864 547.304 546.524 546.161 529.135 534.381 535.569 ] y=[487.186 497.095 510.358 489.682 499.659 508.552 489.794 499.659 512.507 493.103 502.950 511.496 ] z=[219.127 214.034 207.437 221.187 216.696 211.390 223.820 219.135 212.828 228.552 221.764 217.055 ] z=X(1)*x+X(2)*y+X(3); for j=1:length(x) r=(X(1)*x(j)+X(2)*y(j)-z(j)+X(3))/(sqrt(X(1)^2+X(2)^2+1^2)); end function F=myfun(X) F=max(r)-min(r); x0=[1,1,1] %起始点 [X,fval]=fminunc(@myfun,x0) set(handles.edit2,'string',num2str(fval)) 此帖于 2010-05-25 17:30 被 cyn3942637 编辑。 |
![]() |
![]() |