Fitting spline to outline
2 ビュー (過去 30 日間)
古いコメントを表示
I have been trying to write a code (shown below) that will identify the outline of an object and then fit a spline to it.
I can identify the edge (using a ball for example below, image 1), but it picks up multiple points around the edge for each x and y value (image 2). So, I've tried to clean it up be removing some of the points.
However, the final spline doubles back on itself (image 4). How do I stop that from happening and just plot a smooth line connecting all the points?
% Get outline
BW = edge(Image, 'Canny', 0.6);
B = bwboundaries(BW);
J = num2cell(cell2mat(B),1);
F(:,1) = J{1,1};
F(:,2) = J{1,2};
%Show image and outline points
figure
imshow(I)
hold on
scatter(F(:,1),F(:,2), 'r0')
%Reduce number of points
for q = 20:20:(numel(F)/2)
F1((q/20),:) = F(q,:);
end
% Fit spline
x = F1(:,1);
y = F1(:,2);
pointspline = [x'; y'];
values = cscvn(pointspline);
sp = fn2fm(values,'B-')
%Show reduced points and spline
figure
scatter(F1(:,1),F1(:,2), 'r')
hold on
fnplt(sp)
1.
data:image/s3,"s3://crabby-images/dea78/dea7868a23b6cf3922a4b8e2698e3f05630d859e" alt="Sphere_Edge.png"
2.
data:image/s3,"s3://crabby-images/e6e50/e6e503b12bb0836318883f210f4ff2e0b7127273" alt="Sphere_Edge_Close.png"
3.
data:image/s3,"s3://crabby-images/b802f/b802f5df7cfdf133ae8e5c92703fbbab832a0589" alt="Ball_Spline.png"
4.
data:image/s3,"s3://crabby-images/914b8/914b88399e5deba50ed89546c7496b4d4c399cfa" alt="Spline_Close.png"
2 件のコメント
darova
2019 年 8 月 8 日
If the curve double back can you just use a half of data?
%Reduce number of points
% for q = 20:20:(numel(F)/2)
% F1((q/20),:) = F(q,:);
% end
% can be written as:
F1 = F(1:20:end/2,:);
Mehri Mehrnia
2022 年 6 月 20 日
something is wrong with this code, I used it for a boundary of image. it shifts it 90 degrees.
回答 (1 件)
参考
カテゴリ
Help Center および File Exchange で Splines についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!