I writing program for rung kutta th4 now i have a problem who can help me?
4 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
% clear;
clc;
%% precision of work
n=100; %steps
dr=1/n; %minimum step radius
r=1/n:dr:1+1/n; %0=<r=<1 radius
%%
vdc=2.4; %max voltage(v)
dv=0.001; %step voltage(v)
%% capasitor properties
R=500e-6; %max radius plate(m)
h=1e-6; %thickness plate(m)
g=2e-6; %Initial gap capasitor(m)
%% material properties
E=150e9; %Young’s modulus (pa)
e0=8.854e-12; %Electrical permittivity of air
nu=0.06; %Poisson ratio
rho=2300; %Density (kg/m^3)
%% Fixed functions
D=(E*h^3)/(12*(1-nu^2)); %flexural strength
%tstar=R^2*sqrt((rho*h)/D);
%betha2=(c*R^4)/(D/tstar);
alpha=(e0*R^4)/(2*D*g^3);
%% mode shape
phi=cos((pi*r)/2).^2;
phi1=-cos(pi.*r/2).*pi.*sin(pi.*r/2);
phi2=((pi^2*sin(pi*r/2).^2)/2)-((cos(pi.*r/2).^2*pi^2)/2);
phi3=pi^3*sin(pi.*r/2).*cos(pi.*r/2);
phi4=((pi^4*cos(pi*r/2).^2)/2)-((pi^4*sin(pi*r/2).^2)/2);
%%
ws=zeros(1,n+1); %zeros matrix for ws
wprim=zeros(1,n+1);
V=0; %first voltage
zita=0.01; %Damping ratio=C/C(critical) %C(critical)=2*sqrt(k*m)
%% time option
T=1;
dt=0.01; %step time
t=0; %first time
y1=zeros(1,(T/dt)+1); y1=0;
y2=zeros(1,(T/dt)+1); y2=0;
%% loop
for i=1:vdc/dv
%% static
Tstr=((E*h)/2*R*(1-nu^2)).*sum((wprim.^2)*dr); %stretching force
betha1=Tstr.*(g^2*R)/D;
Fs=sum(((2*alpha.*V.*dv.*phi)./(1-ws).^2)*dr);
kelec=sum(((2*alpha.*V.^2.*phi.^2)./((1-ws).^3))*dr);
kmech=sum(((phi).*(phi4+(2./r).*phi3-((1./r.^2).*phi2)+((1./r.^3).*phi1)+...
(betha1.*(phi2+((1./r).*phi1))))).*dr);
keq=kmech-kelec;
as=Fs/keq;
psi=as*phi;
ws=ws+psi;
for j=1:n
wprim=(ws(j+1)-ws(j))/dr; %dw
end
V=V+dv;
wss(i)=ws(1);
VV(i)=V;
%% dynamic
m=sum((phi.^2)*dr);
k=sum(((phi).*(phi4+(2./r).*phi3-((1./r.^2).*phi2)+((1./r.^3).*phi1)+...
(betha1.*(phi2+((1./r).*phi1))))).*dr);
c=2*zita*sqrt(k*m);
end
%% runge kutta loop
for a=1:T/dt
% first
F=sum(((alpha.*(V.^2).*phi)./(1-(y1.*phi)).^2)*dr);
s1=y2;
p1=(1/m)*(F-(c*y2)-(k*y1));
% second
F=sum(((alpha.*(V.^2).*phi)./(1-((y1+(dt/2)*s1).*phi)).^2)*dr);
s2=y2+(dt/2)*p1;
p2=(1/m)*(F-(c*(y2+(dt/2)*p1))-(k*(y1+(dt/2)*s1)));
% third
F=sum(((alpha.*(V.^2).*phi)./(1-((y1+(dt/2)*s2).*phi)).^2)*dr);
s3=y2+(dt/2)*p2;
p3=(1/m)*(F-(c*(y2+(dt/2)*p2))-(k*(y1+(dt/2)*s2)));
% fourth
F=sum(((alpha.*(V.^2).*phi)./(1-((y1+(dt*s3)).*phi)).^2)*dr);
s4=y2+(dt*p3);
p4=(1/m)*(F-(c*(y2+(dt*p3)))-(k*(y1+(dt*s3))));
y1=y1+(dt/6)*(s1+(2*s2)+(2*s3)+s4);
y2=y2+(dt/6)*(p1+(2*p2)+(2*p3)+p4);
t=t+dt;
tt(a)=t;
y1(a)=y1;
y2(a)=y2;
end
%%
%plot(tt,y1.*phi)
%plot(tt,y2.*phi)
plot(y1.*phi,y2.*phi)
%plot(VV,1-wss)
grid on
1 Commento
Walter Roberson
il 4 Feb 2021
for j=1:n
wprim=(ws(j+1)-ws(j))/dr; %dw
end
That overwrites all of wprim each iteration of the loop.
Risposte (0)
Vedere anche
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!