Info
この質問は閉じられています。 編集または回答するには再度開いてください。
Can anybody help me in simplifying the final solution of 'y' in terms of variable? It can be easily solve by hand and we can get values as a factor of '(1/l)*sqrt(T/rho)'.
1 回表示 (過去 30 日間)
古いコメントを表示
clc;
clear all;
close all;
syms T h l rho F1 F2 omega
mem=4 %number of elements
h=l/mem
%element k matrix
k=h\T*[1 -1;-1 1];
m=(rho*h/6)*[2 1;1 2]
% assembling global matrix
tightwire=importdata('TightWire.xlsx');
S=zeros(mem+1,'sym');
M=zeros(mem+1,'sym');
U=sym('U%d',[mem+1 1])
F=sym('F%d',[mem+1 1])
for t=2:mem
F(t)=tightwire(mem,t);
end
%elementnumbering
nod=[1:1:mem+1];
c=cell(mem,1);
for t=1:mem
c{t,1}=[nod(t) nod(t)+1];
end
for r=1:mem
l=c{r};
for i=1:mem+1
for j=1:mem+1
for o=1:2
for p=1:2
if i==l(o)
if j==l(p)
S(i,j)=S(i,j)+k(o,p);
M(i,j)=M(i,j)+m(o,p);
end
end
end
end
end
end
end
determinant=S(2:mem,2:mem)-omega^2*M(2:mem,2:mem)
y=solve(det(determinant),omega)
0 件のコメント
回答 (1 件)
Walter Roberson
2018 年 4 月 25 日
Change
syms T h l rho F1 F2 omega
to
syms T h l rho F1 F2 omega real
Change
y=solve(det(determinant),omega)
to
y = simplify(solve(det(determinant),omega))
6 件のコメント
Walter Roberson
2018 年 4 月 26 日
You should not use uniform 0 there unless you are using older MATLAB versions that do not permit you to create symbolic output from a cellfun. But if you are then
constants = [constants{:}]
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!