来自sympy.calculus.euler的euler_equation产生错误的导数

如何解决来自sympy.calculus.euler的euler_equation产生错误的导数

我一直在尝试获取依赖于函数phi的函数的第一个变体及其第一个和第二个梯度。我可能做错了事。

函数phi:

φ(x,y,t)

它的第一个渐变gradient_1_phi:

⎡∂               ∂             ⎤
⎢──(φ(x,t))  ──(φ(x,t))⎥
⎣∂x              ∂y            ⎦

第二个梯度gradient_2_phi:

⎡   2                  2             ⎤
⎢  ∂                  ∂              ⎥
⎢ ───(φ(x,t))   ─────(φ(x,t))⎥
⎢   2               ∂y ∂x            ⎥
⎢ ∂x                                 ⎥
⎢                                    ⎥
⎢   2                  2             ⎥
⎢  ∂                  ∂              ⎥
⎢─────(φ(x,t))   ───(φ(x,t)) ⎥
⎢∂y ∂x                 2             ⎥
⎣                    ∂y              ⎦

为简单起见,我将该函数分为三个部分,一个部分包含phi,另一个包含第一个渐变,最后一个包含第二个渐变。它们分别是potential_PFC,regularizers_PFC_1和regularizers_PFC_2。

问题:在计算正则化器_PFC_2的第一个变化和第二个梯度gradient_2_phi时,交叉导数消失。

在regularizers_PFC_2中,我希望得到

⎡        4                     4                        4                             ⎤
⎢       ∂                     ∂                       ∂                               ⎥
⎢- 1.0⋅───(φ(x,t)) - 1.0⋅───(φ(x,t)) - 2.0⋅ ──────(φ(x,t)) = 0,True,True⎥
⎢        4                     4                      2  2                            ⎥
⎣      ∂x                    ∂y                     ∂x ∂y                             ⎦

但我知道

⎡        4                     4                            ⎤
⎢       ∂                     ∂                             ⎥
⎢- 1.0⋅───(φ(x,True⎥
⎢        4                     4                            ⎥
⎣      ∂x                    ∂y                             ⎦

这是代码,我非常感谢和建议。

from sympy import Symbol,Function
from sympy.calculus.euler import euler_equations
from sympy import tensorcontraction,tensorproduct,eye
from sympy.tensor.array import derive_by_array
from sympy import init_printing
init_printing()

La = Lb = Lc = 1

t     = Symbol('t')
x     = Symbol('x')
y     = Symbol('y')

phi   = Function('phi')(x,t)
gradient_1_phi = Function('gradient_1_phi')(x,t)
gradient_2_phi = Function('gradient_2_phi')(x,t)

grad_1_phi = derive_by_array(phi,[x,y])
grad_2_phi = derive_by_array(grad_1_phi,y])
regularizers_PFC_1 = -Lb*tensorcontraction(tensorproduct(grad_1_phi,grad_1_phi),(0,1))
regularizers_PFC_2 = +0.5*Lc*tensorcontraction(tensorproduct(grad_2_phi,grad_2_phi),1,2,3))
potential_PFC = La*(0.5*(1.0-0.2)*phi**2 + 0.25*phi*phi*phi*phi)
d_regularizers_PFC_1 = euler_equations(regularizers_PFC_1,[phi,gradient_1_phi,gradient_2_phi],t])
d_regularizers_PFC_2 = euler_equations(-regularizers_PFC_2,t])

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?