和欧拉用 python 养鱼

简介: 20条鱼每天能生殖14条小鱼每条鱼每天平均产出0.7条鱼照料的很好,死亡率 = 0简化模型,刚出生的小鱼就能生殖小鱼鱼缸最大环境承受值750条越接近环境承受值,小鱼的生育力越低(暗含死亡率)每天卖出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的变化-微分和导数

13.jpg


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

14.jpg


python实现

函数和初始值
  • 欧拉方法解微分方程的关键点在于Δt的选取,Δt越接近0,函数图像越准确
  • 在这里我们将Δt作为预测函数的参数
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 ,代表着一共做多少次欧拉方法来绘制函数图像

引入数学分析工具
import numpy as np #矩阵
import matplotlib.pyplot as plt #绘图
建立自变量和因变量矩阵
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
# 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矩阵,帮助我们描述函数了

在不同变化量下调用函数

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

p1,t1 = fish_predict(1)
p2,t2 = fish_predict(0.5)
p3,t3 = fish_predict(0.25)
绘图 - 曲线
fig = plt.figure() #创建图像                      
plt.plot(t1, p1, linewidth = 4) #绘制曲线  
plt.plot(t2, p2, linewidth = 4)
plt.plot(t3, p3, linewidth = 4)
绘图 - 标签、轴、网格
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]) #坐标轴范围
图像展示
plt.show()


15.jpg


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


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

总结

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

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

相关文章
|
2月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
2月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
2月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
126 80
|
21天前
|
存储 缓存 Java
Python高性能编程:五种核心优化技术的原理与Python代码
Python在高性能应用场景中常因执行速度不及C、C++等编译型语言而受质疑,但通过合理利用标准库的优化特性,如`__slots__`机制、列表推导式、`@lru_cache`装饰器和生成器等,可以显著提升代码效率。本文详细介绍了这些实用的性能优化技术,帮助开发者在不牺牲代码质量的前提下提高程序性能。实验数据表明,这些优化方法能在内存使用和计算效率方面带来显著改进,适用于大规模数据处理、递归计算等场景。
58 5
Python高性能编程:五种核心优化技术的原理与Python代码
|
3月前
|
存储 索引 Python
Python编程数据结构的深入理解
深入理解 Python 中的数据结构是提高编程能力的重要途径。通过合理选择和使用数据结构,可以提高程序的效率和质量
171 59
|
2月前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
51 14
|
2月前
|
分布式计算 大数据 数据处理
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
110 2
|
2月前
|
小程序 开发者 Python
探索Python编程:从基础到实战
本文将引导你走进Python编程的世界,从基础语法开始,逐步深入到实战项目。我们将一起探讨如何在编程中发挥创意,解决问题,并分享一些实用的技巧和心得。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的参考。让我们一起开启Python编程的探索之旅吧!
64 10
|
2月前
|
机器学习/深度学习 人工智能 Java
Python 语言:强大、灵活与高效的编程之选
本文全面介绍了 Python 编程语言,涵盖其历史、特点、应用领域及核心概念。从 1989 年由 Guido van Rossum 创立至今,Python 凭借简洁的语法和强大的功能,成为数据科学、AI、Web 开发等领域的首选语言。文章还详细探讨了 Python 的语法基础、数据结构、面向对象编程等内容,旨在帮助读者深入了解并有效利用 Python 进行编程。
|
2月前
|
机器学习/深度学习 人工智能 数据挖掘
探索Python编程的奥秘
在数字世界的海洋中,Python如同一艘灵活的帆船,引领着无数探险者穿梭于数据的波涛之中。本文将带你领略Python编程的魅力,从基础语法到实际应用,一步步揭开Python的神秘面纱。
57 12

热门文章

最新文章

相关实验场景

更多