Azzera filtri
Azzera filtri

Equally spaced points along a nonlinear path

10 visualizzazioni (ultimi 30 giorni)
I have a path linear by parts that I need to equally divide with points. How do I do that?

Risposta accettata

Manikanta Aditya
Manikanta Aditya il 26 Mag 2024
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)])
Total length of the path: 4.2426
% Number of divisions
num_divisions = 10;
% Calculate the spacing
spacing = total_length / num_divisions;
% Display the spacing
disp(['Spacing between points: ', num2str(spacing)])
Spacing between points: 0.42426
% 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;
points = [points; path(end, :)];
% Display the points
disp('Equally spaced points along the path:')
Equally spaced points along the path:
0 0 0.3000 0.3000 0.6000 0.6000 0.9000 0.9000 3.0000 1.0000
I hope this answers your question.
  2 Commenti
Kacper il 26 Mag 2024
Thanks. I thought there was a neat function to do it for me and I just coudn't find it, but as long as it works.

Accedi per commentare.

Più risposte (1)

John D'Errico
John D'Errico il 27 Mag 2024
Modificato: John D'Errico il 27 Mag 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');


Scopri di più su Startup and Shutdown in Help Center e File Exchange





Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by