前言

本文主要给大家介绍了关于利用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求解物理学中的双弹簧质能系统详解相关推荐

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

    前言 本文主要给大家介绍了关于利用python求解物理学中双弹簧质能系统的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 物理的模型如下: 在这个系统里有两个物体,它们的质 ...

  2. python的sort方法是哪种_python中的sort方法使用详解

    Python中的sort()方法用于数组排序,本文以实例形式对此加以详细说明: 一.基本形式列表有自己的sort方法,其对列表进行原址排序,既然是原址排序,那显然元组不可能拥有这种方法,因为元组是不可 ...

  3. python2与python3性能对比_对Python2与Python3中__bool__方法的差异详解

    对Python2与Python3中__bool__方法的差异详解 发布时间:2020-08-28 00:08:58 来源:脚本之家 阅读:74 作者:grey_csdn 学习Python面向对象编程的 ...

  4. python照片墙地图_利用python生成照片墙的示例代码

    PIL(Python Image Library)是python的第三方图像处理库,但是由于其强大的功能与众多的使用人数,几乎已经被认为是python官方图像处理库了.其官方主页为:PIL. PIL历 ...

  5. python爬虫背景_利用Python代码实现一键抠背景功能

    前言 又是一个逛csdn发现的一个有趣的小项目,可以一键抠背景,需要用到removebg模块及其API,API可从其官网免费获取,网址如下https://www.remove.bg/zh ps:加上/ ...

  6. python计算器程序_利用Python代码编写计算器小程序

    1 importtkinter2 importtkinter.messagebox3 importmath4 classJSQ:5 6 7 def __init__(self):8 #创建主界面 9 ...

  7. python做积分_利用python求积分的实例

    python的numpy库集成了很多的函数.利用其中的函数可以很方便的解决一些数学问题.本篇介绍如何使用python的numpy来求解积分. 代码如下: # -*- coding: utf-8 -*- ...

  8. python图色检测_利用python打开摄像头及颜色检测方法

    最近两周由于忙于个人项目,一直未发言了,实在是太荒凉了....,上周由于项目,见到Python的应用极为广泛,用起来也特别顺手,于是小编也开始着手学习Python,-下面我就汇报下今天的学习成果吧 小 ...

  9. python音频聚类_利用python的KMeans和PCA包实现聚类算法

    题目: 通过给出的驾驶员行为数据(trip.csv),对驾驶员不同时段的驾驶类型进行聚类,聚成普通驾驶类型,激进类型和超冷静型3类 . 利用Python的scikit-learn包中的Kmeans算法 ...

最新文章

  1. 25%的游戏通过Steam支持Linux系统
  2. 一个http请求的整个流程
  3. javascript操作html元素CSS属性
  4. IIS安装与MVC程序部署
  5. #HTTP协议学习# (七)cookie
  6. 从底层重学 Java 之两大浮点类型 GitChat链接
  7. jquery插件dataTables(dataTables在显示表格的时候,果然是个好东西,支持排序/搜索/分页/...)
  8. 为Eureka Server添加用户认证
  9. 中国大陆省市区县三级、四级菜单数据整理
  10. 【矢量分析】工科矢量分析公式大全
  11. 【AIOT】手表调研
  12. 在开发版上用C语言写实心圆,MFC利用CPen与CBrush绘制实心圆
  13. 将matlab代码转换成C代码
  14. 磁盘列阵(RAID)
  15. 检查网络端口是否正常
  16. 第十九章:如何组建团队
  17. 设置OpenWrt连接外网
  18. NAGVIS安装详解
  19. 发布java包运行提示找不到配置文件
  20. 归因分析指南v1.0

热门文章

  1. 英特尔Optane固态硬盘年内问世 性能暴增
  2. 海南电网全力支持新能源发展
  3. web04--cookie
  4. Android--近来学习总结(2017/3/27)
  5. Apache Storm 官方文档 —— 源码组织结构
  6. 挖掘频繁模式、关联和相关
  7. WPF的ProgressBar进度条
  8. nagios监控告警之网络流量监控(附pnp模板)
  9. BCP utility in Sybase(Unix Environment)
  10. 在表空间有足够free space的情况下出现ORA-1652