对于我的作业,我应该计算最小的圆。第一部分要求我计算欧几里得距离,我使用以下代码进行管理:
function euclidean = center(x, y)
maximaldist = 0;
rng(0, 'twister')
A= randi([0 10],10,2)
for i=1:size(A,1)
euclidean=sqrt((x-A(i)).^2 + (y-A(i+size(A,1))).^2);
if euclidean > maximaldist
maximaldist = euclidean;
end
end
对于第二部分,我需要继续使用 fminsearch,但由于某种原因,我无法在代码中实现它(我可以从命令窗口使用它)。谁可以帮我这个事?
编辑:所以我尝试过...
基本上我能找到的一切。
for i=1:size(A,1)
fun=@(x) sqrt((x(1)-A(i)).^2 + (x(2)-A(i+size(A,1))).^2);
end
x0=[0 0];
fminsearch(fun, x0)
end
出于绝望,这是我对 fminsearch 部分的混乱。
然后我把代码改成了这个;所以我可以尝试如下一个;
function euclidean = denneme(x,y)
%point_x=point(1);
%point_y=point(2);
rng(0, 'twister')
a= randi([0 10],10,1);
b= randi([0 10],10,1);
distance=sqrt((x-a).^2 + (y-b).^2);
euclidean=max(distance);
f= @(x) denneme(x(1),x(2));
fminsearch(f, [0 0])
但它说没有足够的输入参数。我已经尝试了很多东西并删除了很多东西,所以我无法进行很多试验。