gpt4 book ai didi

gekko - 使用 Gekko 和 Python 拟合数据的数值 ODE 解

转载 作者:行者123 更新时间:2023-12-02 00:47:28 37 4
gpt4 key购买 nike

使用 Gekko 拟合数据的数值 ODE 解。

嗨,大家好!
我想知道是否可以使用 GEKKO 拟合 ODE 的系数。
我尝试复制 example given here 失败.

这是我想出的(但有缺陷——我或许应该提到,不幸的是,我的数学技能相当差):

import numpy as np
from gekko import GEKKO

tspan = [0, 0.1, 0.2, 0.4, 0.8, 1]
Ca_data = [2.0081, 1.5512, 1.1903, 0.7160, 0.2562, 0.1495]

m = GEKKO(remote=False)

t = m.Param(value=tspan)
m.time = t
Ca_m = m.Param(value=Ca_data)

Ca = m.Var()

k = m.FV(value=1.3)
k.STATUS = 1

m.Equation( Ca.dt() == -k * Ca)

m.Obj( ((Ca-Ca_m)**2)/Ca_m )

m.options.IMODE = 2
m.solve(disp=True)
print(k.value[0]) #2.58893455 is the solution

有人可以帮我吗?
非常感谢,
马丁

(这是我在这里的第一篇文章——如果我做了一些不恰当的事情,请保持温和。)

最佳答案

您的解决方案很接近,但您需要:

  • 更多节点(默认= 2)以提高准确性。 Gekko 只会添加您定义的点。见 additional information on collocation .
  • 定义 Cam.CV()使用内置错误模型代替 m.Var()m.Obj节点>=3。否则,每个搭配区间的内部节点也与测量值匹配,这给出了一个稍微错误的答案。
  • 套装EV_TYPE=2使用平方误差。绝对值目标EV_TYPE=1 (默认)给出正确但略有不同的答案。

  • import numpy as np
    from gekko import GEKKO

    m = GEKKO(remote=False)
    m.time = [0, 0.1, 0.2, 0.4, 0.8, 1]
    Ca_data = [2.0081, 1.5512, 1.1903, 0.7160, 0.2562, 0.1495]
    Ca = m.CV(value=Ca_data); Ca.FSTATUS = 1 # fit to measurement
    k = m.FV(value=1.3); k.STATUS = 1 # adjustable parameter
    m.Equation(Ca.dt()== -k * Ca) # differential equation

    m.options.IMODE = 5 # dynamic estimation
    m.options.NODES = 5 # collocation nodes
    m.options.EV_TYPE = 2 # squared error
    m.solve(disp=True) # display solver output
    print(k.value[0]) # 2.58893455 is the curve_fit solution

    解决方法是 k=2.5889717102 .绘图显示与测量值的匹配。

    import matplotlib.pyplot as plt  # plot solution
    plt.plot(m.time,Ca_data,'ro')
    plt.plot(m.time,Ca.value,'bx')
    plt.show()

    Parameter Estimation Solution

    additional tutorialscourse material使用微分和代数方程模型进行参数估计。

    关于gekko - 使用 Gekko 和 Python 拟合数据的数值 ODE 解,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60606528/

    37 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com