全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

利用python求解物理学中的双弹簧质能系统详解

前言

本文主要给大家介绍了关于利用python求解物理学中双弹簧质能系统的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

物理的模型如下:

在这个系统里有两个物体,它们的质量分别是m1和m2,被两个弹簧连接在一起,伸缩系统为k1和k2,左端固定。假定没有外力时,两个弹簧的长度为L1和L2。

由于两物体有重力,那么在平面上形成摩擦力,那么摩擦系数分别为b1和b2。所以可以把微分方程写成这样:

这是一个二阶的微分方程,为了使用python来求解,需要把它转换为一阶微分方程。所以引入下面两个变量:

这两个相当于运动的速度。通过运算可以改为这样:

这时可以线性方程改为向量数组的方式,就可以使用python定义了

代码如下:

# Use ODEINT to solve the differential equations defined by the vector field 
from scipy.integrate import odeint 
 
def vectorfield(w, t, p): 
 """ 
 Defines the differential equations for the coupled spring-mass system. 
 
 Arguments: 
  w : vector of the state variables: 
     w = [x1,y1,x2,y2] 
  t : time 
  p : vector of the parameters: 
     p = [m1,m2,k1,k2,L1,L2,b1,b2] 
 """ 
 x1, y1, x2, y2 = w 
 m1, m2, k1, k2, L1, L2, b1, b2 = p 
 
 # Create f = (x1',y1',x2',y2'): 
 f = [y1, 
   (-b1 * y1 - k1 * (x1 - L1) + k2 * (x2 - x1 - L2)) / m1, 
   y2, 
   (-b2 * y2 - k2 * (x2 - x1 - L2)) / m2] 
 return f 
 
# Parameter values 
# Masses: 
m1 = 1.0 
m2 = 1.5 
# Spring constants 
k1 = 8.0 
k2 = 40.0 
# Natural lengths 
L1 = 0.5 
L2 = 1.0 
# Friction coefficients 
b1 = 0.8 
b2 = 0.5 
 
# Initial conditions 
# x1 and x2 are the initial displacements; y1 and y2 are the initial velocities 
x1 = 0.5 
y1 = 0.0 
x2 = 2.25 
y2 = 0.0 
 
# ODE solver parameters 
abserr = 1.0e-8 
relerr = 1.0e-6 
stoptime = 10.0 
numpoints = 250 
 
# Create the time samples for the output of the ODE solver. 
# I use a large number of points, only because I want to make 
# a plot of the solution that looks nice. 
t = [stoptime * float(i) / (numpoints - 1) for i in range(numpoints)] 
 
# Pack up the parameters and initial conditions: 
p = [m1, m2, k1, k2, L1, L2, b1, b2] 
w0 = [x1, y1, x2, y2] 
 
# Call the ODE solver. 
wsol = odeint(vectorfield, w0, t, args=(p,), 
    atol=abserr, rtol=relerr) 
 
with open('two_springs.dat', 'w') as f: 
 # Print & save the solution. 
 for t1, w1 in zip(t, wsol):   
  out = '{0} {1} {2} {3} {4}\n'.format(t1, w1[0], w1[1], w1[2], w1[3]); 
  print(out) 
  f.write(out); 

在这里把结果输出到文件two_springs.dat,接着写一个程序来把数据显示成图片,就可以发表论文了,代码如下:

# Plot the solution that was generated 
 
from numpy import loadtxt 
from pylab import figure, plot, xlabel, grid, hold, legend, title, savefig 
from matplotlib.font_manager import FontProperties 
 
t, x1, xy, x2, y2 = loadtxt('two_springs.dat', unpack=True) 
 
figure(1, figsize=(6, 4.5)) 
 
xlabel('t') 
grid(True) 
lw = 1 
 
plot(t, x1, 'b', linewidth=lw) 
plot(t, x2, 'g', linewidth=lw) 
 
legend((r'$x_1$', r'$x_2$'), prop=FontProperties(size=16)) 
title('Mass Displacements for the\nCoupled Spring-Mass System') 
savefig('two_springs.png', dpi=100) 

最后来查看一下输出的png图片如下:


总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。


# 实验物理  # python  # python计算物理  # python物理引擎  # Python实现3行代码解简单的一元一次方程  # Python编程实现数学运算求一元二次方程的实根算法示例  # python计算方程式根的方法  # Python基于高斯消元法计算线性方程组示例  # 使用Python求解最大公约数的实现方法  # python求解水仙花数的方法  # Python求解平方根的方法  # Python实现高效求解素数代码实例  # python使用分治法实现求解最大值的方法  # Python编程求解二叉树中和为某一值的路径代码示例  # Python实现简单的四则运算计算器  # Python线性方程组求解运算示例  # 微分方程  # 就可以  # 左端  # 在这里  # 相关内容  # 在这个  # 线性方程  # 说了  # 不多  # 有一定  # 把它  # 这是一个  # 这两个  # 给大家  # 分别为  # 这篇文章  # 谢谢大家  # 转换为  # 发表论文  # 长度为 


相关文章: 详解jQuery停止动画——stop()方法的使用  图册素材网站设计制作软件,图册的导出方式有几种?  宝塔面板创建网站无法访问?如何快速排查修复?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  建站之星导航如何优化提升用户体验?  如何快速生成ASP一键建站模板并优化安全性?  北京网站制作网页,网站升级改版需要多久?  网站制作话术技巧,网站推广做的好怎么话术?  临沂网站制作公司有哪些,临沂第四中学官网?  建站主机如何选?性能与价格怎样平衡?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  魔毅自助建站系统:模板定制与SEO优化一键生成指南  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  Python文件管理规范_工程实践说明【指导】  建站主机如何选?高性价比方案全解析  小程序网站制作需要准备什么资料,如何制作小程序?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何高效搭建专业期货交易平台网站?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  简单实现Android验证码  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  寿县云建站:智能SEO优化与多行业模板快速上线指南  如何选择最佳自助建站系统?快速指南解析优劣  建站之星微信建站一键生成小程序+多端营销系统  开源网站制作软件,开源网站什么意思?  如何挑选最适合建站的高性能VPS主机?  如何选择可靠的免备案建站服务器?  建站主机是否属于云主机类型?  道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?  如何在橙子建站上传落地页?操作指南详解  网站制作模板下载什么软件,ppt模板免费下载网站?  如何快速搭建二级域名独立网站?  如何获取免费开源的自助建站系统源码?  宝塔建站助手安装配置与建站模板使用全流程解析  建站168自助建站系统:快速模板定制与SEO优化指南  建站ABC备案流程中有哪些关键注意事项?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  C#如何序列化对象为XML XmlSerializer用法  b2c电商网站制作流程,b2c水平综合的电商平台?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  如何用景安虚拟主机手机版绑定域名建站?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  如何在阿里云部署织梦网站?  建站主机服务器选型指南与性能优化方案解析  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  Thinkphp 中 distinct 的用法解析  如何在Windows虚拟主机上快速搭建网站?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  建站之星后台搭建步骤解析:模板选择与产品管理实操指南 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。