Error using sym/coeffs. First argument must be a scalar.

16 vues (au cours des 30 derniers jours)
Mustafa Duran
Mustafa Duran le 12 Jan 2023
Modifié(e) : Mustafa Duran le 12 Jan 2023
syms q1(t) q2(t) q3(t) q4(t) q5(t) q6(t) q1_hiz(t) q2_hiz(t) q3_hiz(t) q4_hiz(t) q5_hiz(t) q6_hiz(t) q1_ivme(t) q2_ivme(t) q3_ivme(t) q4_ivme(t) q5_ivme(t) q6_ivme(t) t
After various transactions, i get for example that equation:
VG1_O =
-0.4250*cos(q1(t))*q1_hiz(t)
-0.4250*sin(q1(t))*q1_hiz(t)
0
When i take the coefficients of that matrix as q2_hiz(t); it is expected that solution will be 0 however the solution is like this:
ff=coeffs(VG1_O(1,1),[q2_hiz(t)]);
ff=
-0.4250*cos(q1(t))*q1_hiz(t)
How can i solve this problem?

Réponse acceptée

Torsten
Torsten le 12 Jan 2023
Modifié(e) : Torsten le 12 Jan 2023
My guess is that VG1_0(1,1) is interpreted as a polynomial in the variable q2_hiz(t).
Since your expression does not contain q2_hiz(t), -0.4250*cos(q1(t))*q1_hiz(t) is the constant term of the polynomial
-0.4250*cos(q1(t))*q1_hiz(t) + 0*q2_hiz(t) + 0*q2_hiz(t)^2 + ...
and is thus returned by "coeffs".
  5 commentaires
Torsten
Torsten le 12 Jan 2023
That's what the diff command does - if a variable does not appear in an expression, the derivative with respect to this variable is 0. And if you want the coefficient of q1_hiz(t), the command will give you -0.4250*cos(q1(t)).
syms t q1(t) q1_hiz(t) q2_hiz(t) q3_hiz(t)
expr = -0.4250*cos(q1(t))*q1_hiz(t);
ff1 = diff(expr,q1_hiz(t))
ff1 = 
ff2 = diff(expr,q2_hiz(t))
ff2 = 
0
ff3 = diff(expr,q3_hiz(t))
ff3 = 
0
Mustafa Duran
Mustafa Duran le 12 Jan 2023
Modifié(e) : Mustafa Duran le 12 Jan 2023
You're right. Solution is so basic however i didn't think it is that much simple even if i know derivative. Sometimes it is better to take opinions of others. Thanks so much for responding my questions.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Mathematics dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by