⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 thbai.m

📁 利用matlab进行动力学仿真之三
💻 M
字号:
global a
a=1;
L0=1;
theta0=pi/6;
tmax=100;
step=0.01;
%%%%%%%%%%求解微分方程
[t,y]=ode45('fthbai',[0:step:tmax],[0,theta0,0,0]);
%%%%%%%%%%调用绘图子程序绘图
huitu(tmax,t,y,step);

%%%%%%%%%%坐标转换为实际坐标
y(:,1)=y(:,1)+ones(size([0:step:tmax]),1);
[y1,x1]=pol2cart(y(:,2),y(:,1));
y1=-y1;
%%%%%%%%%%初始化动画界面
figure(2)
text(-0.2,0.1,'弹簧摆');
ymax=max(abs(y1));
xmax=max(abs(x1));
axis([-1*xmax xmax -1*ymax 0.2]);
axis equal
%%%%%%%%%%%画初始位置
R=0.05;
yy=-y(1,1):0.01:0;
xx=R*sin(yy./1*30*pi);
[a,r]=cart2pol(xx,yy);
a=a+theta0;
[xx,yy]=pol2cart(a,r);
line([-0.5 0.5],[0 0],'color','r','linewidth',2)
ball=line(xx(1),yy(1),'color','r','marker','.',...
    'markersize',70,'erasemode','xor');
ball2=line(xx(1),yy(1),'color',[0.5 0.51 0.6],...
  'linestyle','-','linewidth',1.3,'erasemode','none');
spring=line(xx,yy,'color','g','linewidth',2,'erasemode','xor');
pause(1.5);
%%%%%%%%%%做动画
for i=1:length(t)
    yy=-y(i,1):0.01:0;
    xx=R*sin(yy./y(i,1)*30*pi);
    [a,r]=cart2pol(xx,yy);
    a=a+y(i,2);
    [xx,yy]=pol2cart(a,r);
    set(ball,'XData',x1(i),'YData',y1(i));
    set(ball2,'XData',x1(i),'YData',y1(i),...
        'color',[i/length(t),i/length(t),1-i/length(t)]);
    set(spring,'XData',xx,'YData',yy);
    drawnow;
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -