ode45 Inputs must be floats, namely single or double.
    조회 수: 4 (최근 30일)
  
       이전 댓글 표시
    
I Have this code and I do not know where is the problem. I end up with:
Error in ode45 (line 115)
  odearguments(FcnHandlesUsed, solver_name, ode, tspan, y0, options, varargin);
Error in SixDOFSolutionOnlyFromMaple (line 7)
[t, D]=ode45(@SixDOF14March2019,range,IC);
This is the code (Matlab function) and I want to make it easy for you to follow:
1) I have 5 ODEs which are second order.
2) The 5 ODE varibles are (x, y , z, thx, thy) and their derivatives (xdot, ydot, zdot, thxdot, thydot)
3) I did the summation to calculate some forces.
4) I noticed some thing strang (not sure if it has any effect) that when I want to calculate (DelAL) and the 3 other varibles above it I end up with an expression includes cos(%1) and somethings like that! I do NOT know what is (%1)??!!
function der=SixDOF14March2019(t,D)
x=D(1);
xdot=D(2);
y=D(3);
ydot=D(4);
z=D(5);
zdot=D(6);
thx=D(7);
thxdot=D(8);
thy=D(9);
thydot=D(10);
%thz=D(11);
%thzdot=D(12);
%clear all; close all; clc; format long;
syms x y z thx thy thz xdot ydot zdot thxdot thydot thzdot t Fr Fa J
syms lR lL 
syms RjInR RjOutR RjInL RjOutL 
syms rIn rOut 
syms B
syms thj
syms thinitial 
syms alphaO alphaP 
syms Pr deltaP Zp 
syms omIn omOut omC omB n 
syms Nin Nout Nball 
syms AjInA AjInRad AjOutA AjOutRad 
syms AInA AInRad AOutA AOutRad 
syms Ainitial 
syms psi 
syms Ajb Ab 
syms RjOutRFinal RjInRFinal RjOutFinal RjInLFinal 
syms DeltajR DelatajAR DeltajRR DeltajL DelatajAL DeltajRL 
syms alphajR alphajL 
syms deltajR deltajL 
syms rgIn rgOut dIn dOut db dm m 
syms gamma fin fo SigRhoIn SigRhoOut FRhoIn FRhoOut
syms Ein Eout Eb newIn newOut newB DeltaStarIn DeltaStarOut 
syms gammaInitial SigRhoInInitial SigRhoOutInitial FRhoInInitial FRhoOutInitial DeltaStarInInitial DeltaStarOutInitial KInInitial KOutInitial 
syms DeltaStarInjR DeltaStarInjL DeltaStarOutjR DeltaStarOutjL 
syms M 
syms Ix Iy Iz 
syms C 
% GIVEN:
% ======
g=9.81;
lR=0.1275; lL=0.0875;
rgIn=0.00408;rgOut=0.00461;dIn=0.046; dOut=0.062;db=0.00794;dm=0.5*(dIn+dOut);m=6;
alphaO=15*pi/180;
Ein=(2.07*10^11);Eout=(2.07*10^11);Eb=(2.07*10^11);newIn=0.3;newOut=0.3;newB=0.3;
M=5.5;
Ix=0.05177; Iy=Ix; Iz=0.0044;
psi=0;thinitial=0;
AInA=0;AOutA=0;AInRad=0;AOutRad=0;Ab=0; 
Ainitial=0;
Nin=0;Nout=0;Nball=0;
Pr=50;
n=2500; 
omIn=(2*pi*n/60);omOut=0;
B=rgIn+rgOut-db; 
alphaP=.273932890990504;
Us = 0.217e-1; Ud = 1.3;
C=300; 
%INITIAL CALCULATIONS USING alphaO%
%==================================
gammaInitial=db*cos(alphaO)/dm;
fi=rgIn/db; fo=rgOut/db;
FRhoInInitial= ((1/fi)+(2*gammaInitial/(1-gammaInitial)))/((4)-(1/fi)+(2*gammaInitial/(1-gammaInitial)));
FRhoOutInitial= ((1/fo)-(2*gammaInitial/(1+gammaInitial)))/((4)-(1/fo)-(2*gammaInitial/(1+gammaInitial)));
SigRhoInInitial=(1/db)*((4)-(1/fi)+(2*gammaInitial/(1-gammaInitial)));
SigRhoOutInitial=(1/db)*((4)-(1/fo)-(2*gammaInitial/(1+gammaInitial)));
% DeltaStarInInitial
if (FRhoInInitial>=0)&&(FRhoInInitial<0.9) 
    DeltaStarInInitial=(-4.473235689079742*(FRhoInInitial^6))+(10.221093192616578*(FRhoInInitial^5))+(-9.137566232244472*(FRhoInInitial^4))+(3.727561235805512*(FRhoInInitial^3))+(-0.911658734913609*(FRhoInInitial^2))+(0.041760021004309*(FRhoInInitial))+(0.999977423957012);
elseif (FRhoInInitial>=0.9)&&(FRhoInInitial<=0.995)
    DeltaStarInInitial=(-0.178413900461346*(10^6)*(FRhoInInitial^5))+(0.836143462688479*(10^6)*(FRhoInInitial^4))+(-1.567353804615937*(10^6)*(FRhoInInitial^3))+(1.468900655521535*(10^6)*(FRhoInInitial^2))+(-0.688261350489303*(10^6)*(FRhoInInitial))+(0.128985184237206*(10^6));
elseif (FRhoInInitial>0.995)&&(FRhoInInitial<=1)
    DeltaStarInInitial=(-0.283909265667587*(10^12)*(FRhoInInitial^5))+(1.414016787576658*(10^12)*(FRhoInInitial^4))+(-2.817011913800072*(10^12)*(FRhoInInitial^3))+(2.806027557873945*(10^12)*(FRhoInInitial^2))+(-1.397540196512594*(10^12)*(FRhoInInitial))+(0.278417030529744*(10^12));
end
% DeltaStarOutInitial
if (FRhoOutInitial>=0)&&(FRhoOutInitial<0.9) 
    DeltaStarOutInitial=(-4.473235689079742*(FRhoOutInitial^6))+(10.221093192616578*(FRhoOutInitial^5))+(-9.137566232244472*(FRhoOutInitial^4))+(3.727561235805512*(FRhoOutInitial^3))+(-0.911658734913609*(FRhoOutInitial^2))+(0.041760021004309*(FRhoOutInitial))+(0.999977423957012);
elseif (FRhoOutInitial>=0.9)&&(FRhoOutInitial<=0.995)
    DeltaStarOutInitial=(-0.178413900461346*(10^6)*(FRhoOutInitial^5))+(0.836143462688479*(10^6)*(FRhoOutInitial^4))+(-1.567353804615937*(10^6)*(FRhoOutInitial^3))+(1.468900655521535*(10^6)*(FRhoOutInitial^2))+(-0.688261350489303*(10^6)*(FRhoOutInitial))+(0.128985184237206*(10^6));
elseif (FRhoOutInitial>0.995)&&(FRhoOutInitial<=1)
    DeltaStarOutInitial=(-0.283909265667587*(10^12)*(FRhoOutInitial^5))+(1.414016787576658*(10^12)*(FRhoOutInitial^4))+(-2.817011913800072*(10^12)*(FRhoOutInitial^3))+(2.806027557873945*(10^12)*(FRhoOutInitial^2))+(-1.397540196512594*(10^12)*(FRhoOutInitial))+(0.278417030529744*(10^12));
end
KInInitial=((4*2^0.5)/3)*(1/(SigRhoInInitial)^0.5)*((Ein*Eb)/(Ein+Eb-(Ein*newB^2)-(Eb*newIn^2)))*(1/DeltaStarInInitial)^1.5
KOutInitial=((4*2^0.5)/3)*(1/(SigRhoOutInitial)^0.5)*((Eout*Eb)/(Eout+Eb-(Eout*newB^2)-(Eb*newOut^2)))*(1/DeltaStarOutInitial)^1.5
KInitial=(1/(((1/KInInitial)^(2/3))+((1/KOutInitial)^(2/3))))^(3/2)
Zp=B*(sin(alphaP-alphaO)/cos(alphaP));
omB=(0.5*dm*db)*((omIn*(1-(db*cos(alphaO)/dm)^2))+(omOut*(1+(db*cos(alphaO)/dm)^2)));
omC=(0.5)*((omIn*(1-(db*cos(alphaO)/dm)))+(omOut*(1+(db*cos(alphaO)/dm))));
thj=(omC*t)+((2*pi*(J-1))/m)+thinitial;
AjInA=(AInA*sin(Nin*(psi+(omC-omIn)*t+(2*pi*(j-1)/m))))+Ainitial;
AjOutA=(AOutA*sin(Nout*(psi+(omC-omOut)*t+(2*pi*(j-1)/m))))+Ainitial;
AjInRad=(AInRad*sin(Nin*(psi+(omC-omIn)*t+(2*pi*(j-1)/m))))+Ainitial;
AjOutRad=(AOutRad*sin(Nout*(psi+(omC-omOut)*t+(2*pi*(j-1)/m))))+Ainitial;
Ajb=2*Ab*sin(Nball*omB*t);
DelRadR=B*cos(alphaO)+x*cos(thj)+y*sin(thj)-lR*thy*cos(thj)+lR*thx*cos(thy)*sin(thj)+(1/2)*dm*cos(thj)*(1-cos(thy))+(1/2)*dm*sin(thj)*(1-cos(thx));
DelRadL=B*cos(alphaO)+x*cos(thj)+y*sin(thj)-lL*thy*cos(thj)+lR*thx*cos(thy)*sin(thj)-(1/2)*dm*cos(thj)*(1-cos(thy))-(1/2)*dm*sin(thj)*(1-cos(thx));
DelAR=B*sin(alphaO)+Zp+z+lR*(1-cos(thy))*cos(thj)+lR*(1-cos(thx))*cos(thy)*sin(thj)-(1/2)*thy*dm*cos(thj)+(1/2)*thx*dm*sin(thj);
DelAL=B*sin(alphaO)+Zp-z+lL*(1-cos(thy))*cos(thj)+lL*(1-cos(thx))*cos(thy)*sin(thj)+(1/2)*thy*dm*cos(thj)-(1/2)*thx*dm*sin(thj);
alphajR = atan(DelAR/DelRadR);
alphajL = atan(DelAL/DelRadL);
deltajR = (DelAR^2+DelRadR^2)^.5+Ajb-B;
deltajL = (DelAL^2+DelRadL^2)^.5+Ajb-B;
% (Initial) Forces:
% =========================
QR = KInitial*deltajR^1.5;
FxR = QR*cos(alphajR)*cos(thj);
FyR = QR*cos(alphajR)*sin(thj);
FzR = QR*sin(alphajR);
MxR = FyR*lR+(1/2)*FzR*sin(thj)*dm;
MyR = FxR*lR+(1/2)*FzR*cos(thj)*dm;
FxxR = symsum(FxR, J, 1, m)
FyyR = symsum(FyR, J, 1, m)
FzzR = symsum(FzR, J, 1, m)
MxxR = symsum(MxR, J, 1, m)
MyyR = symsum(MyR, J, 1, m)
QL = KInitial*deltajL^1.5;
FxL = QL*cos(alphajL)*cos(thj);
FyL = QL*cos(alphajL)*sin(thj);
FzL = QL*sin(alphajL);
MxL = FyL*lL+(1/2)*FzL*sin(thj)*dm;
MyL = FxL*lL+(1/2)*FzL*cos(thj)*dm;
FxxL = symsum(FxL, J, 1, m)
FyyL = symsum(FyL, J, 1, m)
FzzL = symsum(FzL, J, 1, m)
MxxL = symsum(MxL, J, 1, m)
MyyL = symsum(MyL, J, 1, m)
% (Initial) Equations:
% ====================
der=[xdot;
    (-1/M)*(C*xdot+FxxR+FxxL-M*g-Us*omIn^2*cos(omIn*t));
    ydot;
    (-1/M)*(C*ydot+FyyR+FyyL-Us*omIn^2*sin(omIn*t));
    zdot;
    (-1/M)*(C*zdot+FzzR+FzzL);
    thxdot;
    (-1/Ix)*(Iz*thydot*omIn+MxxL-MxxR- Ud*omIn^2*cos(omIn*t));
    thydot;
    (-1/Iy)*(-Iz*thxdot*omIn+MyyL-MyyR- Ud*omIn^2*sin(omIn*t))];
This is the solution code:
clear all; close all; clc; format long;
range=[0 0.1];
IC=[10e-6 0 10e-7 0 10e-8 0 0 0 0 0];
[t, D]=ode45(@SixDOF14March2019,range,IC);
Your participation is greatly appreciated!
댓글 수: 6
  darova
      
      
 2019년 3월 15일
				All values you pass der must be numeric
xdot = D(2);        % first you assign xdot value from D(2)
syms xdot           % then you declare xdot as symbolic variable
der = [xdot];       % trying to pass symbolic variable
답변 (0개)
참고 항목
카테고리
				Help Center 및 File Exchange에서 Symbolic Math Toolbox에 대해 자세히 알아보기
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


