基于matlab实现的弹簧振动系统模型程序(动态模型)

完整代码:

clear all; 

%System data 
m=1.0; zeta=0.01; omega0=1.0; Dt=1.0; f0=1.0; 
x0=0.0; dotx0=0.0; 
xmax=sqrt(x0^2+(dotx0/omega0)^2)+min([0.5*abs(f0)*Dt/(m*omega0) f0/omega0^2]); 
omegad=omega0*sqrt(1-zeta^2); 
dt0=0.1*pi/omega0; nstep=500; 

a=0.70; b=0.70; r=0.35*a; fact=0.50/xmax; 

xf0=0.5*[0 -a   0   a     0]'; 
yf0=[0  -b/4 -b/2 -3*b/4 -b]'; 
xd1=0.5*[-a   -a   a     a]'; 
yd1=[-6*b    0   0    -6*b]'; 
xd2=0.5*[-0.8*a 0.8*a]'; 
yd2=[-3*b   -3*b]'; 
xf0=[xf0 
    xf0 
    xf0 
    xf0 
    xf0 
    xf0]; 
yf0=[yf0 
   -b+yf0 
   -2*b+yf0 
   -3*b+yf0 
   -4*b+yf0 
   -5*b+yf0]; 
xf=[0 
   xf0 
   0]; 
xSQ=[-a 5*a 5*a -a -a]'; 
ySQ=[0       0      -2*r   -2*r 0]'; 
xH=[-2000 2000]'; yH=[0 0]'; 

xx=x0; 
tt=0; 

set(gcf,'DoubleBuffer','on'); 

i=1; 
t=i*dt0; 
t0=min([t Dt]); 
t1=t-t0; 
h=exp(-zeta*omega0*t)*sin(omegad*t)/(m*omegad); 
doth=exp(-zeta*omega0*t)*(cos(omegad*t)-zeta*omega0/omegad*sin(omegad*t))/m; 
H=(1/m-doth-2*zeta*omega0*h)/omega0^2; 
h1=exp(-zeta*omega0*t1)*sin(omegad*t1)/(m*omegad); 
doth1=exp(-zeta*omega0*t1)*(cos(omegad*t1)-zeta*omega0/omegad*sin(omegad*t1))/m; 
H1=(1/m-doth1-2*zeta*omega0*h1)/omega0^2; 
if t>Dt 
  t2=t-Dt; 
  h2=exp(-zeta*omega0*t2)*sin(omegad*t2)/(m*omegad); 
  doth2=exp(-zeta*omega0*t2)*(cos(omegad*t2)-zeta*omega0/omegad*sin(omegad*t2))/m; 
  H2=(1/m-doth2-2*zeta*omega0*h2)/omega0^2; 
else 
  H2=0; 
end 
x=-f0*H2+f0*(t0/m+h1-h+2*zeta*omega0*(H1-H))/(Dt*omega0^2); 
x=x+exp(-zeta*omega0*t)*(x0*cos(omegad*t)+(dotx0+zeta*omega0*x0)*sin(omegad*t)/omegad); 
tt=[tt 
  t]; 
xx=[xx 
  x]; 
x=fact*x; 
yf=[0 
   -2*b+(1+x)*yf0 
   -6*b+(1+x)*yf0(size(yf0,1))]; 
clf; 
figure(1); 
subplot(2,1,1) 
h1=plot(xH,yH,'r'); 
hold on 
h2=plot(xH,yH-6*b+yf0(size(yf0,1))-r,'k'); 
h3=plot(xf,yf,'r'); 
h4=plot(4*a+xd1,-3*b+yd1,'r'); 
h5=plot(4*a*[1 1]',-3*b*[0 1]','r'); 
hej=yf(size(yf,1)); 
h6=plot(4*a+xd2,(-7*b+yf(size(yf,1))-hej)*ones(2,1),'r'); 
h7=plot(4*a*[1 1]',[-7*b+yf(size(yf,1))-hej yf(size(yf,1))]','r'); 
h8=plot(xSQ,yf(size(yf,1))+ySQ,'r'); 
hold off 
axis([-2 5 -10*b+(1+fact*x0)*yf0(size(yf0,1))-2*r r]); 
subplot(2,1,2) 
h9=plot(xH,yH,'k'); 
hold on; 
h10=plot(tt,-xx,'r'); 
hold off; 
axis([ 0 nstep*dt0  -xmax xmax]) 

% start loop 
for i=1:nstep 

t=i*dt0; 
t0=min([t Dt]); 
t1=t-t0; 
h=exp(-zeta*omega0*t)*sin(omegad*t)/(m*omegad); 
doth=exp(-zeta*omega0*t)*(cos(omegad*t)-zeta*omega0/omegad*sin(omegad*t))/m; 
H=(1/m-doth-2*zeta*omega0*h)/omega0^2; 
h1=exp(-zeta*omega0*t1)*sin(omegad*t1)/(m*omegad); 
doth1=exp(-zeta*omega0*t1)*(cos(omegad*t1)-zeta*omega0/omegad*sin(omegad*t1))/m; 
H1=(1/m-doth1-2*zeta*omega0*h1)/omega0^2; 
if t>Dt 
  t2=t-Dt; 
  h2=exp(-zeta*omega0*t2)*sin(omegad*t2)/(m*omegad); 
  doth2=exp(-zeta*omega0*t2)*(cos(omegad*t2)-zeta*omega0/omegad*sin(omegad*t2))/m; 
  H2=(1/m-doth2-2*zeta*omega0*h2)/omega0^2; 
else 
  H2=0; 
end 
x=-f0*H2+f0*(t0/m+h1-h+2*zeta*omega0*(H1-H))/(Dt*omega0^2); 
x=x+exp(-zeta*omega0*t)*(x0*cos(omegad*t)+(dotx0+zeta*omega0*x0)*sin(omegad*t)/omegad); 

tt=[tt 
  t]; 
xx=[xx 
  x]; 
x=fact*x; 
yf=[0 
   -2*b+(1+x)*yf0 
   -6*b+(1+x)*yf0(size(yf0,1))]; 
set(h3,'Xdata',xf); 
set(h3,'Ydata',yf); 
set(h4,'Xdata',4*a+xd1); 
set(h4,'Ydata',-3*b+yd1); 
set(h5,'Xdata',4*a*[1 1]'); 
set(h5,'Ydata',-3*b*[0 1]'); 
set(h6,'Xdata',4*a+xd2); 
set(h6,'Ydata',(-7*b+yf(size(yf,1))-hej)*ones(2,1)); 
set(h7,'Xdata',4*a*[1 1]'); 
set(h7,'Ydata',[-7*b+yf(size(yf,1))-hej yf(size(yf,1))]'); 


set(h8,'Xdata',xSQ); 
set(h8,'Ydata',yf(size(yf,1))+ySQ); 
set(h10,'Xdata',tt); 
set(h10,'Ydata',-xx); 

pause(0.1) 
end;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/109808.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

postgresql-视图

postgresql-视图 视图概述使用视图的好处 创建视图修改视图删除视图递归视图可更新视图WITH CHECK OPTION 视图概述 视图(View)本质上是一个存储在数据库中的查询语句。视图本身不包含数据,也被称为 虚拟表。我们在创建视图时给它指定了一个…

腾讯云镜像TencentOS Server操作系统介绍、性能稳定性测评

腾讯云TencentOS Server镜像是腾讯云推出的Linux操作系统,完全兼容CentOS生态和操作方式,TencentOS Server操作系统为云上运行的应用程序提供稳定、安全和高性能的执行环境,TencentOS可以运行在腾讯云CVM全规格实例上,包括黑石物理…

天翎知识管理系统:智能化搜索引擎,快速定位知识资源

关键词:知识管理系统、全文检索 编者按:在当今知识经济时代,企业所面临的知识资源越来越丰富,如何高效地管理和利用这些资源成为了一个重要的问题。天翎知识管理系统凭借其智能化搜索引擎,可以帮助企业快速定位知识资源…

Windows11系统下配置JAVA环境变量

一、环境变量的配置 1、右键开始菜单按钮,点击【系统➡高级系统设置】 2、在弹出的系统属性界面点击环境变量 3、在弹出的“环境变量”框,中选择下方的系统变量,点击新建 4、在弹出的“新建系统变量”框中,输入变量名和变量值&am…

数据预处理-分箱(Binning)和 WOE编码

数据预处理-分箱(Binning)和 WOE编码 1. 分箱 1.1 理论 1.1.1 定义 分箱就是将连续的特征离散化,以某种方式将特征值映射到几个箱(bin)中。 1.1.2 为什么要进行分箱? 引入非线性变换,增强模型性能。因为原始值和目…

【2023集创赛】加速科技杯作品:高光响应的二硫化铼光电探测器

本文为2023年第七届全国大学生集成电路创新创业大赛(“集创赛”)加速科技杯西北赛区二等奖作品分享,参加极术社区的【有奖征集】分享你的2023集创赛作品,秀出作品风采,分享2023集创赛作品扩大影响力,更有丰…

【Flowable】任务监听器(五)

前言 之前有需要使用到Flowable,鉴于网上的资料不是很多也不是很全也是捣鼓了半天,因此争取能在这里简单分享一下经验,帮助有需要的朋友,也非常欢迎大家指出不足的地方。 一、监听器 在Flowable中,我们可以使用监听…

C++(day4)

思维导图 封装Mystring #include <iostream> #include<cstring>using namespace std;class Mystring{ public://无参构造函数Mystring():size(10){strnew char[size];strcpy(str,"");cout<<"无参构造函数"<<endl;}//有参构造函数…

中小企业建设数字化工厂,选择集成还是重构

随着科技的飞速发展和市场竞争的日益激烈&#xff0c;数字化工厂管理系统已成为中小企业未来发展的必经之路。然而&#xff0c;对于许多中小企业来说&#xff0c;建设数字化工厂并非易事。在建设数字化工厂的过程中&#xff0c;企业需要面对许多问题&#xff0c;其中最关键的问…

Zynq UltraScale+ XCZU3EG 纯VHDL解码 IMX214 MIPI 视频,2路视频拼接输出,提供vivado工程源码和技术支持

目录 1、前言免责声明 2、我这里已有的 MIPI 编解码方案3、本 MIPI CSI2 模块性能及其优越性4、详细设计方案设计原理框图IMX214 摄像头及其配置D-PHY 模块CSI-2-RX 模块Bayer转RGB模块伽马矫正模块VDMA图像缓存Video Scaler 图像缓存DP 输出 5、vivado工程详解PL端FPGA硬件设计…

【栈与队列面试题】有效的括号(动图演示)

leetcode20.括号匹配问题 前言&#xff1a; &#x1f4a5;&#x1f388;个人主页:​​​​​​Dream_Chaser&#xff5e; &#x1f388;&#x1f4a5; ✨✨刷题专栏:http://t.csdn.cn/UlvTc ⛳⛳本篇内容:力扣上栈与队列的面试OJ题目 目录 leetcode20.括号匹配问题 1.问题描…

jmeter接口测试及详细步骤以及项目实战教程

在接口测试项目实战中&#xff0c;JMeter是一款非常强大和流行的自动化测试工具&#xff0c;它可以测试各种类型的应用程序&#xff0c;并通过采样和报告来识别性能瓶颈和API的问题。本文将为你提供一个基于实际项目的JMeter接口测试项目实战教程&#xff0c;指导你如何使用JMe…