Equally spaced points along a nonlinear path
9 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Kacper
am 26 Mai 2024
Bearbeitet: John D'Errico
am 27 Mai 2024
I have a path linear by parts that I need to equally divide with points. How do I do that?
0 Kommentare
Akzeptierte Antwort
Manikanta Aditya
am 26 Mai 2024
Hi @Kacper
To equally divide a path that is linear by parts, you can follow these steps:
Calculate the total length of the path and determine the spacing between the points and place the points along the path.
Check the following code as a example for your understanding:
% Define the path as a list of points
path = [0, 0; 1, 1; 2, 0; 3, 1];
% Calculate the total length of the path
lengths = sqrt(sum(diff(path).^2, 2));
total_length = sum(lengths);
% Display the total length of the path
disp(['Total length of the path: ', num2str(total_length)])
% Number of divisions
num_divisions = 10;
% Calculate the spacing
spacing = total_length / num_divisions;
% Display the spacing
disp(['Spacing between points: ', num2str(spacing)])
% Place the points
points = [];
current_length = 0;
for i = 1:size(path, 1)-1
while current_length < lengths(i)
points = [points; path(i, :) + (path(i+1, :) - path(i, :)) * current_length / lengths(i)];
current_length = current_length + spacing;
end
end
points = [points; path(end, :)];
% Display the points
disp('Equally spaced points along the path:')
disp(points)
I hope this answers your question.
2 Kommentare
Weitere Antworten (1)
John D'Errico
am 27 Mai 2024
Bearbeitet: John D'Errico
am 27 Mai 2024
Simpler yet, just download my interparc from the file exchange. It allows you to do the operation in a variety of ways, using several variations of spline interpolant, or assuming piecewise linear segments.
It does all the work for you, and it is free.
x = randn(6,1);
y = randn(6,1);
% 500 points, equally spaced along the curve in arclength
Pspline = interparc(500,x,y,'spline');
plot(x,y,'ro',Pspline(:,1),Pspline(:,2),'-')
0 Kommentare
Siehe auch
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!