利用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 =


  

 # 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求解物理学中的双弹簧质能系统详解的更多相关文章

  1. python装饰器中functools.wraps的作用详解

    直接上代码看效果: # 定义一个最简单的装饰器 def user_login_data(f): def wrapper(*args, **kwargs): return f(*args, **kwar ...

  2. Java中的IO流系统详解(转载)

    摘要: Java 流在处理上分为字符流和字节流.字符流处理的单元为 2 个字节的 Unicode 字符,分别操作字符.字符数组或字符串,而字节流处理单元为 1 个字节,操作字节和字节数组. Java ...

  3. Java中的IO流系统详解

    Java 流在处理上分为字符流和字节流.字符流处理的单元为 2 个字节的 Unicode 字符,分别操作字符.字符数组或字符串,而字节流处理单元为 1 个字节,操作字节和字节数组. Java 内用 U ...

  4. python中argparse模块用法实例详解

    python中argparse模块用法实例详解 这篇文章主要介绍了python中argparse模块用法,以实例形式较为详细的分析了argparse模块解析命令行参数的使用技巧,需要的朋友可以参考下 ...

  5. **Python中的深拷贝和浅拷贝详解

    Python中的深拷贝和浅拷贝详解   这篇文章主要介绍了Python中的深拷贝和浅拷贝详解,本文讲解了变量-对象-引用.可变对象-不可变对象.拷贝等内容.   要说清楚Python中的深浅拷贝,需要 ...

  6. Python中random模块生成随机数详解

    Python中random模块生成随机数详解 本文给大家汇总了一下在Python中random模块中最常用的生成随机数的方法,有需要的小伙伴可以参考下 Python中的random模块用于生成随机数. ...

  7. python中requests库使用方法详解

    目录 python中requests库使用方法详解 官方文档 什么是Requests 安装Requests库 基本的GET请求 带参数的GET请求 解析json 添加headers 基本POST请求 ...

  8. Python中的变量和作用域详解

    Python中的变量和作用域详解 python中的作用域分4种情况: L:local,局部作用域,即函数中定义的变量: E:enclosing,嵌套的父级函数的局部作用域,即包含此函数的上级函数的局部 ...

  9. Python中%r和%s的详解及区别_python_脚本之家

    Python中%r和%s的详解及区别_python_脚本之家 https://www.jb51.net/article/108589.htm

随机推荐

  1. SecureCRT中解决乱码的问题

    SecureCRT中文乱码的问题,解决方法如下: 打开Option菜单,点击Session Options-     在Appearance外观这里,选择编码--UTF-8     一定要记得先保存! ...

  2. Nginx入门(三)——正向代理

    server { resolver 114.114.114.114; #指定DNS服务器IP地址 listen 443; location / { proxy_pass https://$host$r ...

  3. 并发编程大师系列之:Synchronized的类锁和对象锁

    说到并发编程,感觉跟大多数人一样,谈之色变,说它简单把,其实很有内容,说难吧,用起来也挺容易,最近我硬着头皮,决心要把并发编程好好的搞一遍.以前,面试的时候,面试官问,并发编程会吗?嗯,接触过,就加一 ...

  4. java中使用redis --- List列表的简单应用

    1.Dos中启动server端 2.idea中启动client端 public class RedisTest01 { public static void main(String[] args){ ...

  5. xld特征

    halcon中什么是xld? xld(eXtended Line Descriptions) 扩展的线性描述,它不是基于像素的,人们称它是亚像素,只不过比像素更精确罢了,可以精确到像素内部的一种描述. ...

  6. Redis vs kafka

    kafka的订阅可以重复消费,但redis的不行,只能收到订阅之后发布的数据 redis无法实现消息堆积和回溯 1 Redis是个数据库,可以改.查,而KFAKA 不能改查2 redis是内存数据库, ...

  7. 编写一个c程序来计算整数中的设置位数?

    回答: unsigned int NumberSetBits(unsigned int n) { ; while (n) { ; ; } return CountSetBits; } 本质上就是计算n ...

  8. 深入理解JavaScript之实现继承的7种方式

    1.原型链继承 核心:将父类的实例作为子类的原型 首先,要知道构造函数.原型和实例之间的关系:构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个原型对象的指针. func ...

  9. Codeforces 380E Sereja and Dividing

    题面 洛谷传送门 题解 博客 有精度要求所以只用求几十次就差不多了 CODE #include <bits/stdc++.h> using namespace std; typedef l ...

  10. 代码 | 自适应大邻域搜索系列之(7) - 局部搜索LocalSearch的代码解析

    前言 好了小伙伴们我们又见面了,咳咳没错还是我.不知道你萌接连被这么多篇代码文章刷屏是什么感受,不过,酸爽归酸爽.今天咱们依然讲代码哈~不过今天讲的依然很简单,关于局部搜索LocalSearch的代码 ...