MATLAB -- how to create a parabolic arc?
32 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Dominic
am 15 Apr. 2013
Beantwortet: Melek Cavlak
am 4 Dez. 2022
Example, I have three points x1, x2, and x3.
x1 is the start point of the arc; x3 is the end point of the arc; x2 is the critical point of the arc (where the tangent slope is zero).
If x2<x1, then the arc is a U-shaped (smiley); If x2>x1, then the arc is a upside-down-U-shaped (upside smiley).
Any ideas?
1 Kommentar
Youssef Khmou
am 15 Apr. 2013
Bearbeitet: Youssef Khmou
am 15 Apr. 2013
that condition is done automatically by the equation ax²+bx+c
Akzeptierte Antwort
Youssef Khmou
am 15 Apr. 2013
Bearbeitet: Youssef Khmou
am 15 Apr. 2013
hi,
The parabola's equation is defined y=ax²+bx+c, you need to set the coefficients a,b,and c so as the line passes through the three points x1,x2 and x3 :
x1=[0,0];
x2=[5,5];
x3=[10,0];
Y=[x1(2);x2(2);x3(2)]
A=[x1(1)^2 x1(1) 1;x2(1)^2 x2(1) 1;x3(1)^2 x3(1) 1]
X=inv(A)*Y
x=x1(1):0.1:x3(1);
Y=X(1)*x.^2+X(2)*x;
figure, plot(x,Y), grid on,
hold on
text(x1(1),x1(2), ' POINT X1')
text(x2(1),x2(2), ' POINT X2')
text(x3(1),x3(2), ' POINT X3')
hold off
5 Kommentare
Tyler Clausen
am 15 Feb. 2018
how would you do this with the points (-15,2), (1,4), and (3,5)? I keep getting wrong y coordinates when I plot.
Weitere Antworten (3)
Jim Riggs
am 15 Feb. 2018
Bearbeitet: Jim Riggs
am 15 Feb. 2018
This is a simple polynomial curve fit problem. If you have the curve fitting toolbox, the problem is solved by:
x = [0 5 10];
y = [0 5 0];
fit(x,y,'poly2');
This will give the coefficients for the second order polynomial. With only 3 point, the fitted curve will pass exactly through all three points. This function will work for any three points, as long as they are no colinear.
If you do not have the curve fitting toolbox, its not too hard to build a function which will perform polynomial curve fitting. If you are interested, I will help you work out the equations.
0 Kommentare
Siehe auch
Kategorien
Mehr zu Interpolation finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!