Finding a centre and plotting a sphere
2 views (last 30 days)
Show older comments
Hi, I'm new to matlab and completely lost on this one. I have to make a function which evaluates Euclidean distances between two sets of points, finds a sphere with centre at the middle-point between two most distant points and calculate its radius.
Basically I have 2 sets of points, from which I form the distance matrix D by using
D = sqrt( bsxfun(@plus,sum(P.^2,2),sum(R.^2,2)') - 2*(P*R') )
centre of the sphere should be between the 2 points with the largest distance between them. How to find that point?
0 Comments
Accepted Answer
David Hill
on 22 Mar 2021
M=0;%point sets p and q assumed to be in matrix form, for example [1 2 3;4 5 6]
for k=1:size(q,1)
[m,idx]=max(sqrt(sum((p-q(k,:)).^2,2)));
if m>M
M=m;
points=[p(idx,:);q(k,:)];
end
end
radius=M/2;
center=sum(points)/2;
See Also
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!