- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我尝试在 sympy 中求解 4 个微分方程组。我收到“NotImplementedError”。有解决办法吗?
我试图解决的颂歌集是:
![ODE]: /image/2U4BR.jpg
我尝试用数值替换 R12 到 R45 符号。我继续收到同样的错误。
import sympy as sp
import numpy as np
import matplotlib.pyplot as plt
# Define symbols
m1, m2, m3, m4 = sp.symbols('m1 m2 m3 m4', real = True, positive=True)
c1, c2, c3, c4 = sp.symbols('c1 c2 c3 c4', real = True, positive=True)
R12, R25, R23, R34, R45 = sp.symbols('R12 R25 R23 R34 R45', real = True, positive=True) #0.2, 0.1, 2.7, 0.5, .6
T1, T2, T3, T4 = sp.symbols('T1 T2 T3 T4', cls=sp.Function)
qp, qel = sp.symbols('qp qel')
T5 = 25 # ambient temperature
# Define equations
eq1 = -sp.Eq(sp.Derivative(T1(t), t)) + - (T1(t)-T2(t)) / (R12 * m1 * c1)
eq2 = -sp.Eq(sp.Derivative(T2(t), t)) + 1 / (m2 * c2) * ((T1(t) - T2(t))/R12 + (T5-T2(t))/R25 - (T2(t)-T3(t))/R23)
eq3 = -sp.Eq(sp.Derivative(T3(t), t)) + 1 / (m3 * c3) * ((T2(t) - T3(t))/R23 + (T4(t)-T3(t))/R34 - qp)
eq4 = -sp.Eq(sp.Derivative(T4(t), t)) + 1 / (m4 * c4) * (qp - (T4(t) - T3(t))/R34 + (T4(t)-T5)/R45)
eq = (eq1, eq2, eq3, eq4)
funct = (T1(t), T2(t), T3(t), T4(t))
# Solve
sp.dsolve(eq, funct)
我期望收到这组微分方程的符号解。结果是“NotImplementedError”
最佳答案
您创建方程的语法不正确。 Eq
需要接受两个参数,左侧和右侧。
eq1 = sp.Eq(sp.Derivative(T1(t), t), + - (T1(t)-T2(t)) / (R12 * m1 * c1))
eq2 = sp.Eq(sp.Derivative(T2(t), t), + 1 / (m2 * c2) * ((T1(t) - T2(t))/R12 + (T5-T2(t))/R25 - (T2(t)-T3(t))/R23))
eq3 = sp.Eq(sp.Derivative(T3(t), t), + 1 / (m3 * c3) * ((T2(t) - T3(t))/R23 + (T4(t)-T3(t))/R34 - qp))
eq4 = sp.Eq(sp.Derivative(T4(t), t), + 1 / (m4 * c4) * (qp - (T4(t) - T3(t))/R34 + (T4(t)-T5)/R45))
我这样做了,dsolve 需要一段时间来计算解决方案。它必须对 4x4 符号矩阵求幂,这涉及到查找符号特征值,即求解四次方程,即 very complicated in the general case .
SymPy 可能可以在这里改进。用数字参数替换符号参数应该会使速度更快。
关于python - 如何修复/解决 sympy dsolve 函数中的 NotImplemented 错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55516346/
我有以下功能: def __eq__(self, other: object) -> Union[bool, NotImplemented]: try:
我正在编写一个新的扩展类型,但我在设置数字运算(例如加法/减法/乘法)时遇到了问题。我已经设法设置了一些就地操作,而没有调用正常操作。 例如,我有这个功能: static PyObject * MyT
查看decimal.py,它在很多特殊的方法中使用了NotImplemented。例如 class A(object): def __lt__(self, a): return
我正在尝试使用 HippoMock 模拟接口(interface),以便在使用所述接口(interface)的类中使用。我构建了一个模拟对象并设置了 ExceptCallOverload,一切都可以正
我有一个用于一些插件式东西的基类,并且有一些方法是绝对需要实现的。 例如,我目前将基类中的那些声明为虚拟的 public virtual void Save { throw new NotIm
Python 有一个名为 NotImplemented 的单例。 . 为什么有人想要返回 NotImplemented 而不是引发 NotImplementedError异常(exception)?这
假设我定义了一个类 A 并且我不希望任何人在不逃避的情况下编写该类的不等式。 class A(): def __ne__(self, other): return NotImp
我最近偶然发现了 Python 的 NotImplemented 内置函数。经过一些阅读后,我现在确实明白了它的目的,但我不明白为什么它会评估为 True 作为 bool 值。下面的例子让我觉得这是一
从 python 3 中的 __eq__ 特殊方法返回 NotImplemented 的结果是什么(如果重要,则为 3.5)? 文档不清晰; only relevant text I found仅含糊
不要把苹果和橙子混在一起 问题 我正在使用 __eq__ 运算符和 NotImplemented 值。 我试图了解当 obj1.__eq__(obj2) 返回 NotImplemented 并且 ob
Python 有一个名为 NotImplemented 的单例。 . 为什么有人想要返回 NotImplemented 而不是提高 NotImplementedError异常(exception)?会
我正在使用我知道可以工作的存储帐户和帐户 key /信用:我有一个使用完全相同的连接字符串的 blob 容器,可以正常工作。 我正在有效地这样做: CloudStorageAccount.Parse(
为了回答另一个问题,我一直在研究 pandas 中的列乘法运算。 A = pd.DataFrame({'Col1' : [1, 2, 3], 'Col2' : [2, 3, 4]}) B = pd.D
我惊讶地发现 python(版本 3.2.2)拒绝 pickle 一个对象,因为它的字典包含对 Ellipsis 的引用。其他built-in constants , pickle 很高兴与 Fals
我正在尝试让一个非常简单的 Scrapy 爬虫工作。我从解析中收到 NotImplemented 错误 - 本质上与此相同的问题:Why does scrapy throw an error for
我有一个代数对象的类层次结构,它实现了特殊方法,例如 __mul__ 和 __add__ ,并使用多重继承。我以某种方式假设 Python (>= 3.5) 会遍历方法解析顺序 (mro) 来查找第一
这个问题是从 this question 的回答和讨论中提出来的.以下片段显示了问题的关键: >>> bool(NotImplemented) True 我的问题如下: 为什么决定 NotImplem
如果我有两个对象 A 和 B,我可以为 A 的 返回 NotImplemented >__iadd__ 方法,并让 B 使用它的 __radd__ 方法修改 A。 >>> class A(): ...
我尝试在 sympy 中求解 4 个微分方程组。我收到“NotImplementedError”。有解决办法吗? 我试图解决的颂歌集是: ![ODE]: /image/2U4BR.jpg 我尝试用数值
我正在尝试设置一个端点以将文件上传到 AWS S3 存储桶。我正在使用 Node.JS、Express、AWS S3 SDK 和 Multer 库。 这是我目前用于上传中间件的代码: export c
我是一名优秀的程序员,十分优秀!