Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >和欧拉用 python 养鱼

和欧拉用 python 养鱼

作者头像
小小詹同学
发布于 2018-09-25 09:55:59
发布于 2018-09-25 09:55:59
78900
代码可运行
举报
文章被收录于专栏:小詹同学小詹同学
运行总次数:0
代码可运行

宠物鱼店主戴夫最近引进了一批彩虹鱼,打算捞一笔,他引进了30条彩虹鱼,每天要卖出20条,未来会发生什么呢?让我们和欧拉预测一波

已知
  • 20条鱼每天能生殖14条小鱼
  • 每条鱼每天平均产出0.7条鱼
  • 照料的很好,死亡率 = 0
  • 简化模型,刚出生的小鱼就能生殖小鱼
  • 鱼缸最大环境承受值750条
  • 越接近环境承受值,小鱼的生育力越低(暗含死亡率)
  • 每天卖出20条小鱼
建模
  1. P(0) = 30 第0天的小鱼数量 P_init = 30
  2. P(1) = P(0) + 0.7 * P(0) - 20 第1天的小鱼的数量
  3. P(t+Δt) = P(t) +0.7 * P(t) * Δt -20 * Δt 第t+Δt天相对第t天的小鱼数量
  4. P(t+Δt) = P(t) +0.7 *(1 - P(t)/750) * P(t) * Δt -20 * Δt 加入环境承受值对于生育率的影响(简单模型)
简单的分析一下P的变化-微分和导数

这是一个P的导数,相关与P函数本身的一个微分方程,Autonomous differential equations 自控微分方程 。看上去是不是很复杂,这个时候我们就要呼唤欧拉了 :欧拉方法,命名自它的发明者莱昂哈德·欧拉(),是一种一阶数值方法,用以对给定初值的常微分方程(即初值问题)求解。它是一种解决数值常微分方程的最基本的一类显型方法(Explicit method)。

python实现
函数和初始值
  • 欧拉方法解微分方程的关键点在于Δt的选取,Δt越接近0,函数图像越准确
  • 在这里我们将Δt作为预测函数的参数
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def fish_predict(Dt):  #Δt
    t_init = 0 #第0天开始
    t_end = 30 #第30天结束
    P_init = 30 #初始数量30
    n_steps = int(round((t_end-t_init)/Dt)) 

在这里n_steps = (30-0)/Δt ,代表着一共做多少次欧拉方法来绘制函数图像

引入数学分析工具
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import numpy as np #矩阵
import matplotlib.pyplot as plt #绘图
建立自变量和因变量矩阵
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    t_arr = np.zeros(n_steps + 1) #创建一维矩阵t,记录自变量变化(初始为零) 
    P_arr = np.zeros(n_steps + 1) #创建一维矩阵P,记录因变量变化(初始为零) 
    t_arr[0] = t_init #默认值                      
    P_arr[0] = P_init #默认值   
欧拉方法-步进,得到函数离散值
  • 当前节点函数值 = 前一个节点函数值 + 前一个节点的导数 * 自变量变化量
  • P_arr[i] = P + Dt*dPdt
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# Euler's method
    for i in range (1, n_steps + 1):
        P = P_arr[i-1]
        t = t_arr[i-1]
        dPdt = 0.7*P*(1-P/750)-20 #导数                       
        P_arr[i] = P + Dt*dPdt #求当前节点函数值              
        t_arr[i] = t + Dt #自变量步进变化
    return P_arr,t_arr

这样的循环下来,我们就将欧拉方法融入python中,返回两个离散的P_arr、t_arr矩阵,帮助我们描述函数了

在不同变化量下调用函数

为了更加深刻的理解欧拉法求解微分方程,我在这里使用三个不同的变化量使用欧拉方法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
p1,t1 = fish_predict(1)
p2,t2 = fish_predict(0.5)
p3,t3 = fish_predict(0.25)
绘图 - 曲线
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
fig = plt.figure() #创建图像                      
plt.plot(t1, p1, linewidth = 4) #绘制曲线  
plt.plot(t2, p2, linewidth = 4)
plt.plot(t3, p3, linewidth = 4)
绘图 - 标签、轴、网格
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
plt.title('fish', fontsize = 25) #标签
plt.xlabel('t', fontsize = 20)
plt.ylabel('P(t)', fontsize = 20)
plt.legend(['Dt = 1','Dt = 2','Dt = 3']) #图例
plt.xticks(fontsize = 15) #字体
plt.yticks(fontsize = 15) 
plt.grid(True) #网格                          
plt.axis([0, 25, 0, 800]) #坐标轴范围
图像展示
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
plt.show()  

通过这么多我们可以分析得出,小店店主可以快乐的天天卖鱼捞金了。不过我才不会告诉他,小鱼要长几个月才能有生育能力。。。

如果对于鱼群的年龄和数量分布再进行分析,增加一个复杂的多为矩阵表示鱼群,也不成问题~

总结

本文对于一个鱼缸进行简单的数学建模、欧拉方法求解,数学转换代码,连续图像离散化,离散点构建图像,numpy构建矩阵,matplotlib.pyplot绘图,python实现。

这个鱼缸的最简模型从来不是python和数学的终点。仅仅是本文,和作者的一个暂时的节点。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-09-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 小詹学Python 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向后Euler)【理论到程序】
是一个关键参数,它决定了离散化的程度,选择合适的步长对于数值解的准确性和稳定性非常重要。
Qomolangma
2024/07/30
2920
【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向后Euler)【理论到程序】
【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向前Euler)【理论到程序】
是一个关键参数,它决定了离散化的程度,选择合适的步长对于数值解的准确性和稳定性非常重要。
Qomolangma
2024/07/30
2500
【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向前Euler)【理论到程序】
欧拉法与梯形法求解微分方程【含matlab源代码】
感谢Miracle向公众号投稿!欢迎更多爱好、喜欢matlab编程的朋友来稿,在公众号回复“投稿”了解投稿详情。
巴山学长
2021/07/30
3.2K0
Python NumPy学习指南:从入门到精通
NumPy,即Numerical Python,是Python中最为常用的科学计算库之一。它提供了强大的多维数组对象ndarray,并支持大量的数学函数和操作。与Python内置的列表相比,NumPy数组的计算速度更快,占用内存更少,非常适合处理大量的数据。
半截诗
2025/01/11
4840
Python 数学应用(一)
Python 是一种功能强大、灵活且易于学习的编程语言。它是许多专业人士、爱好者和科学家的首选编程语言。Python 的强大之处来自其庞大的软件包生态系统和友好的社区,以及其与编译扩展模块无缝通信的能力。这意味着 Python 非常适合解决各种问题,特别是数学问题。
ApacheCN_飞龙
2024/05/24
3360
Python 数学应用(一)
Newmark方法解运动方程
时刻的运动方程,因此是一种显式格式。欧拉法由前一步的已知值可求下一步的值,故为一步法,可以自起步(self-starting)。但是欧拉法在位移表达式中只保留了
fem178
2023/01/30
8610
Newmark方法解运动方程
【机器学习】因微知著,穷数通灵:微积分与机器学习的量化之美
在机器学习的学习旅程中,微积分不仅是理解单变量变化的工具,更是处理多变量和复杂系统的关键。上一篇文章中,我们详细讲解了积分的基本概念与计算方法,并通过实战项目展示了积分在概率与统计中的应用。本篇文章将进一步探讨多重积分与微分方程,这两者在机器学习中的应用广泛且重要。通过理论与实践相结合的方式,你将能够更好地理解和运用这些高级微积分概念。
半截诗
2025/01/09
2200
【机器学习】因微知著,穷数通灵:微积分与机器学习的量化之美
【Python篇】深度探索NumPy(下篇):从科学计算到机器学习的高效实战技巧
接上篇【Python篇】NumPy完整指南(上篇):掌握数组、矩阵与高效计算的核心技巧
半截诗
2024/10/09
3490
【GAN优化】从动力学视角看GAN是一种什么感觉?
今天讲述的内容是GAN与动力学,这是一个非常好玩、非常新鲜的视角。考虑到很多人微积分和线性代数等知识的涉猎不多,我将会对涉及的内容都做出基本说明,也并不会涉及过深入的东西,然后争取串成一个故事,扩展一下大家的视野。
用户1508658
2019/08/29
1.5K1
微分方程与欧拉法
本文介绍了如何利用数值求解方法解决微分方程,包括欧拉法、龙格-库塔方法等,并给出了具体的MATLAB代码示例。
用户1147754
2018/01/03
1.1K0
微分方程与欧拉法
扒一扒那些叫欧拉的定理们(八)——欧拉公式和自然对数的底e
从今天开始,我们开始进入一个新的领域,也是欧拉他老爷子开创的,来看看复数领域的欧拉定理,以及欧拉公式里有着怎样的智慧。
magic2728
2021/07/14
1.5K0
第六部分:NumPy在科学计算中的应用
在科学计算中,数值积分是一个常见的问题。NumPy提供了一些函数来进行数值积分,结合scipy库可以实现更加复杂的积分计算。
半截诗
2024/10/14
2410
Python实现随机性操作的多种方法
在编程中,我们经常会遇到需要根据一定的概率来做出选择的情况,比如在游戏中随机生成事件、在机器学习中采样数据等。Python提供了多种方法来实现这种基于概率的选择,本文将介绍其中的几种方法,并给出相应的代码示例。
一键难忘
2024/06/21
3870
硬核NeruIPS 2018最佳论文,一个神经了的常微分方程
在最近结束的 NeruIPS 2018 中,来自多伦多大学的陈天琦等研究者成为最佳论文的获得者。他们提出了一种名为神经常微分方程的模型,这是新一类的深度神经网络。神经常微分方程不拘于对已有架构的修修补补,它完全从另外一个角度考虑如何以连续的方式借助神经网络对数据建模。在陈天琦的讲解下,机器之心将向各位读者介绍这一令人兴奋的神经网络新家族。
机器之心
2019/01/02
1K0
有限元法(FEM)
空间和时间相关问题的物理定律通常用偏微分方程(PDE)来描述。对于绝大多数的几何结构和所面对的问题来说,可能无法求出这些偏微分方程的解析解。不过,在通常的情况下,可以根据不同的离散化 类型来构造出近似的方程,得出与这些偏微分方程近似的数值模型方程,并可以用数值方法求解。如此,这些数值模型方程的解就是相应的偏微分方程真实解的近似解。有限元法(FEM)就是用来计算出这些近似解的。
技术客
2022/05/19
2K0
天生一对,硬核微分方程与深度学习的「联姻」之路
近日,北京智源人工智能研究院开展了第一次论坛,其以「人工智能的数理基础」这一重大研究方向为主题,从数学、统计和计算等角度讨论了智能系统应该怎样融合数学系统。
机器之心
2019/05/22
1.4K0
【机器学习】穷理至极,观微知著:微积分的哲思之旅与算法之道
在前几篇文章中,我们详细讲解了多重积分与微分方程的基本概念与计算方法,并通过实战项目展示了它们在机器学习中的应用。本篇文章将进一步探讨这些高级微积分工具的更多应用场景,并介绍数值解法,以应对复杂的实际问题。通过理论与实践相结合的方式,你将能够更深入地理解和运用这些高级微积分概念,提升在机器学习领域的分析与建模能力。
半截诗
2025/01/09
1170
【机器学习】穷理至极,观微知著:微积分的哲思之旅与算法之道
22届考研模拟卷(公共数学二)汇总
现在是 2022-1-1,我简单的点评一下今年各位老师的出卷,如果读者想刷这一年的,可以作为参考
一只野生彩色铅笔
2022/09/20
3.5K0
22届考研模拟卷(公共数学二)汇总
泰勒公式和Gamma函数
泰勒公式,也称泰勒展开式。是用一个函数在某点的信息,描述其附近取值的公式。如果函数足够平滑,在已知函数在某一点的各阶导数值的情况下,泰勒公式可以利用这些导数值来做系数,构建一个多项式近似函数,求得在这一点的邻域中的值。
润森
2019/08/29
2.7K0
泰勒公式和Gamma函数
详解SLAM中的李群和李代数(上)
最近阅读高翔大神的《视觉SLAM十四讲》这本书,感觉整本书写的非常的平实,用非常接地气的语言毫无保留的介绍了视觉SLAM的相关知识,非常值得一读。不过,在第4章出现的李群和李代数的相关概念就有点令人难以费解了。其实这段不是这本书的作者故意写的晦涩难懂,而是这部分知识属于数学或者物理专业才会学习的知识,普通的理工科专业的读者没有接触过这方面的知识。笔者也是在这个地方卡了壳,因此在本文中将李群和李代数相关的知识总结一下。
charlee44
2025/05/03
1380
推荐阅读
相关推荐
【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向后Euler)【理论到程序】
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档