How to find the distance between two points along a curve?
조회 수: 18 (최근 30일)
이전 댓글 표시
I have a set of generated X and Y axis data, which have given a curved line. Now, I need to find the distance between two specified points along the curve, not the straight shortest distance between two points but along the curve path. Can someone help me finding this numerically?
댓글 수: 7
Mathieu NOE
2024년 4월 26일
dr represents only the increment of arc length (quite constant in this example)
now you need to do a sum of them - see my answer
답변 (2개)
Mathieu NOE
2024년 4월 26일
편집: Mathieu NOE
2024년 4월 26일
hello
try this
th = linspace(-pi/2, pi/2, 100);
R = 200;
X = R * sin(th) ; % X-coordinates
Y = R * cos(th) ; % Y-coordinates
dx = diff(X);
dy = diff(Y);
ds = sqrt(dx.^2+dy.^2); % increment of arc length
s = cumsum(ds); % integration => total arc length
s = [0 s]; % add first point : arc length = 0
% compute arc length between two points (defined by index position)
k1 = 25;
k2 = 59;
d = s(k2) - s(k1)
plot(X, Y, 'r.-',X(k1:k2), Y(k1:k2), 'db');
axis square
댓글 수: 4
Torsten
2024년 4월 27일
If you have an explicit equation of your curve, you can use the usual formula for arclength:
R = 200;
fun = @(t)sqrt((R*cos(t)).^2+(R*(-sin(t))).^2)
length_of_curve = integral(fun,-pi/2,pi/2)
2*pi*R/2
참고 항목
카테고리
Help Center 및 File Exchange에서 Interpolation에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!