How do I get the matrix p
古いコメントを表示
Hello,
I am trying to solve the a matrix using solve function, not able to figure it out.
clear all
clc
syms x1 x2 M k L dx1 dx2 p
% Displacement of the bar
xg=(x1+x2)/2;
% Rotation of the bar
thi=(x2-x1)/L;
%moment of inertia
J=M*L^2/12;
dxg=(dx1+dx2)/2;
dthi=(dx2-dx1)/L;
% Kinetic energy
KE=0.5*((M*dxg^2)+(J*dthi^2));
% Potenial Engergy
PE=0.5*(2*k*x1^2+3*k*x2^2);
u=[x1 x2];
du=[dx1;dx2];
s=solve(KE==0.5.*transpose(du)*p*du);
3 件のコメント
Walter Roberson
2019 年 3 月 17 日
s = solve(EXPRESSION, p)
LOKESH UDATHA
2019 年 3 月 18 日
Walter Roberson
2019 年 3 月 18 日
No it isn't . u is 1 x 2 so transpose of u is 2 x 1. You cannot do 2 x 1 * 2 x 2 * 1 x 2 because none of the inner dimensions match. Your u would have to be 2 x 1 to fix that .
There is not enough information to isolate 2 x 2 p.
回答 (1 件)
Sajeer Modavan
2019 年 3 月 17 日
Since you are solving with for p, result of 's' equal to 'p'
to confirm this, you can use following code (which is same as yours, but forcefully solving for 'p')
P = solve(KE==0.5.*transpose(du)*p*du,p);
カテゴリ
ヘルプ センター および File Exchange で Mathematics and Optimization についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!