Solving symbolic third order polynomial
9 views (last 30 days)
Show older comments
Hey need help finding the a0, ... a3 coefficients of a third order polynomial with constraints.
In the picture below (blue) are the constraints. This is a polynomial for trajectory, where on time t0 the function equals the starting position and on time t1 the end position. Also the derivative of the formula resembles the speed of the trajectory.
I tried it in Matlab but the answers I get don't match the (picture red) solution.
Could you help me?
syms q(t) a0 a1 a2 a3 q0 q1 dq0 dq1 t0 t1;
% formules
q(t) = a0 + a1*t + a2*t^2 + a3*t^3
dq = diff(q,t)
% solving
eqn = [q(t0)==q0, q(t1)==q1, dq(t0) == dq0, dq(t1) == dq1];
S = solve(eqn, [a0 a1 a2 a3]);
S.a0
If I solve the eqution with self chosen parameters and then it works, but I the symbolic answer.
% solving
t0 = 0;
t1 = 2;
q0 = 0;
q1 = 150;
dq0 = 0;
dq1 = 0;
eqn = [q(t0)==q0, q(t1)==q1, dq(t0) == dq0, dq(t1) == dq1];
S = solve(eqn, [a0 a1 a2 a3]);
q(t) = subs(q, [a0 a1 a2 a3], [S.a0, S.a1, S.a2, S.a3])
fplot(q, [0 2])
0 Comments
Answers (3)
Torsten
on 16 Sep 2023
Edited: Torsten
on 16 Sep 2023
syms t t0 t1 q0 q1 q0dot q1dot a0 a1 a2 a3
f(t) = a0 + a1*(t-t0) + a2*(t-t0)^2 + a3*(t-t0)^3;
df = diff(f,t);
S = solve([f(t0)==q0,df(t0) == q0dot,f(t1)==q1,df(t1)==q1dot],[a0 a1 a2 a3])
S.a0
S.a1
S.a2
S.a3
2 Comments
Torsten
on 17 Sep 2023
Edited: Torsten
on 17 Sep 2023
The coefficients a0 = q0 and a1 = q0dot in your screenshot clearly indicate that q is Taylor-expanded around t = t0, not t = 0. And this is usual practise because if the conditions are prescribed at t0 and t1, the form of the coefficients is much simpler.
The last contribution to a2 (-2*q0dot/(t1-t0)^2) is wrong in any case: it must have unit [q]/s^2, but it has unit [q]/s^3 (s is time unit, e.g. seconds).
Paul
on 16 Sep 2023
Hi Axel,
What is the source for the equations in red?
Here is Matlab's solution:
syms q(t) a0 a1 a2 a3 q0 q1 dq0 dq1 t0 t1;
% formules
q(t) = a0 + a1*t + a2*t^2 + a3*t^3;
dq = diff(q,t);
% solving
eqn = [q(t0)==q0, q(t1)==q1, dq(t0) == dq0, dq(t1) == dq1];
S = solve(eqn, [a0 a1 a2 a3]);
simplify(S.a0,100)
simplify(S.a1,100)
simplify(S.a2,100)
simplify(S.a3,100)
It looks like a3 is the same as the equation in red, but the others aren't (I tried various ways to simplify them further without success).
Verify the solution
qq(t) = simplify(subs(q,S));
dqq(t) = diff(qq(t));
simplify([qq(t0) qq(t1) dqq(t0) dqq(t1)])
Now implement the red equations (double check this as I had to keep scrolling back and forth)
a0 = q0;
a1 = dq1;
a2 = 3/(t1-t0)^2*(q1-q0) - 1/(t1-t0)*dq1 - 2/(t1-t0)^2*dq0
a3 = -2/(t1-t0)^3*(q1-q0) + 1/(t1-t0)^2*(dq1 + dq0)
qqq(t) = a1 + a1*t + a2*t^2 + a3*t^3;
simplify([qqq(t0); qqq(t1)])
Doesn't satisfy the first two blue constraints (or at least doesn't appear that way, I tried some simplifcations w/o success).
4 Comments
Paul
on 17 Sep 2023
The red answers are definitely wrong for the form of the cubic polynomial posed in your code. They are probably, i.e., I didn't verify myself, correct for the form of cubic polynmial posed by Torsten.
Sam Chak
on 17 Sep 2023
The trajectory position is chosen to be a cubic polynomial. From this cubic polynomial, the velocity can be obtained:
Since there are four unknowns, namely the initial position q0, initial velocity dq0, final position q1, and final velocity dq1, we can construct four equations with four constraints as follows:
These equations can then be expressed in a compact matrix form, as a single matrix equation of the form :
This system of four linear equations can be solved using the Inverse Matrix Method. See also: linsolve().
syms t1 t0 q(t)
t0 = sym('0'); % initial time
t1 = sym('2'); % final time
q0 = sym('0'); % initial position
dq0 = sym('0'); % initial velocity
q1 = sym('150'); % final position
dq1 = sym('0'); % final velocity
A = [1 t0 t0^2 t0^3;
0 1 2*t0 3*t0^2;
1 t1 t1^2 t1^3;
0 1 2*t1 3*t1^2]
B = [q0; dq0; q1; dq1]
% x = linsolve(A, B)
x = A\B
% Cubic Polynomial Trajectory
q(t) = x(1) + x(2)*t + x(3)*t^2 + x(4)*t^3
dq(t)= x(2) + 2*x(3)*t + 3*x(4)*t^2
% Plot the trajectory
t0 = double(t0); % convert the symbolic value of t0 to double precision
t1 = double(t1); % convert the symbolic value of t1 to double precision
q0 = double(q0); % convert the symbolic value of q0 to double precision
q1 = double(q1); % convert the symbolic value of q1 to double precision
fplot( q, [t0 t1], 'LineWidth', 3, 'Color', '#528AFA'), hold on % Sky palette
fplot(dq, [t0 t1], 'LineWidth', 3, 'Color', '#ffb7c5'), hold off % Sakura palette
% Labels
grid on
axis([-0.5 2.5 -50 200])
xlabel('Time (seconds)')
ylabel('Amount')
title('Cubic Trajectory, q(t) = '+string(q))
legend({'$q(t)$', '$\dot{q}(t)$'}, 'Interpreter', 'LaTeX', 'AutoUpdate', 'off', 'Location', 'South', 'FontSize', 12)
xline([t0 t1], '--', {sprintf('t0: %.0f s', t0) sprintf('t1: %.0f s', t1)}, 'color', '#7F7F7F');
yline([q0 q1], '--', {sprintf('q0: %.0f m', q0) sprintf('q1: %.0f m', q1)}, 'color', '#7F7F7F', 'LabelVerticalAlignment', 'bottom');
4 Comments
Sam Chak
on 18 Sep 2023
Edited: Sam Chak
on 18 Sep 2023
This is the symbolic approach. The linsolve() command can also return the symbolic results for the coefficients {}. Because the cubic trajectory function connects a point at a specific time to another point at time via a 3rd-degree polynomial, the mathematical function can be expressed relative to the point at a specific time , and it looks like this:
In the program, we can assign the starting point to be at the initial time :
syms f(t) t0 t1 a0 a1 a2 a3 q0 dq0 q1 dq1
f(t) = a0 + a1*(t - t0) + a2*(t - t0)^2 + a3*(t - t0)^3
g(t) = diff(f)
A = [1 t0-t0 (t0-t0)^2 (t0-t0)^3;
0 1 2*(t0-t0) 3*(t0-t0)^2;
1 t1-t0 (t1-t0)^2 (t1-t0)^3;
0 1 2*(t1-t0) 3*(t1-t0)^2]
B = [q0; dq0; q1; dq1]
x = linsolve(A, B);
a = simplify(x, 100) % [a0; a1; a2; a3]
Update: I think I have found the typo in the formula (see green circle). It is good that you double-check before applying the formulas blindly.
See Also
Categories
Find more on Numbers and Precision in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!