Python Sympy计算梯度、散度和旋度的实例
作者:落叶_小唱 时间:2023-03-11 05:14:10
sympy有个vector 模块,里面提供了求解标量场、向量场的梯度、散度、旋度等计算,官方参考连接:
http://docs.sympy.org/latest/modules/vector/index.html
sympy中计算梯度、散度和旋度主要有两种方式:
一个是使用∇∇算子,sympy提供了类Del(),该类的方法有:cross、dot和gradient,cross就是叉乘,计算旋度的,dot是点乘,用于计算散度,gradient自然就是计算梯度的。
另一种方法就是直接调用相关的API:curl、divergence和gradient,这些函数都在模块sympy.vector 下面。
使用sympy计算梯度、散度和旋度之前,首先要确定坐标系,sympy.vector模块里提供了构建坐标系的类,常见的是笛卡尔坐标系, CoordSys3D,根据下面的例子可以了解到相应应用。
(1)计算梯度
## 1 gradient
C = CoordSys3D('C')
delop = Del() # nabla算子
# 标量场 f = x**2*y-xy
f = C.x**2*C.y - C.x*C.y
res = delop.gradient(f, doit=True) # 使用nabla算子
# res = delop(f).doit()
res = gradient(f) # 直接使用gradient
print(res) # (2*C.x*C.y - C.y)*C.i + (C.x**2 - C.x)*C.j
(2)计算散度
## divergence
C = CoordSys3D('C')
delop = Del() # nabla算子
# 向量场 f = x**2*y*i-xy*j
f = C.x**2*C.y*C.i - C.x*C.y*C.j
res = delop.dot(f, doit=True)
# res = divergence(f)
print(res) # 2*C.x*C.y - C.x,即2xy-x,向量场的散度是标量
(3)计算旋度
## curl
C = CoordSys3D('C')
delop = Del() # nabla算子
# 向量场 f = x**2*y*i-xy*j
f = C.x**2*C.y*C.i - C.x*C.y*C.j
res = delop.cross(f, doit=True)
# res = curl(f)
print(res) # (-C.x**2 - C.y)*C.k,即(-x**2-y)*k,向量场的旋度是向量
来源:https://blog.csdn.net/ouening/article/details/80712269
标签:Python,Sympy,梯度,散度,旋度
0
投稿
猜你喜欢
js实现微信聊天效果
2024-04-16 09:14:33
Flask中jinja2的继承实现方法及实例
2022-09-24 12:31:09
python3操作mysql数据库的方法
2023-07-28 15:48:27
python实现串口通信的示例代码
2023-08-04 03:44:24
apache+mysql+php+ssl服务器之完全安装攻略
2023-11-16 07:34:16
Python如何脚本过滤文件中的注释
2021-10-03 15:24:52
Doctype之谜
2009-07-22 20:48:00
Opencv实现倾斜图片转正示例
2022-05-02 14:28:08
基于asyncio 异步协程框架实现收集B站直播弹幕
2021-07-14 19:34:40
python实现PID算法及测试的例子
2021-08-30 00:57:33
js实现带有介绍的Select列表菜单实例
2024-04-19 10:26:22
python实现csdn全部博文下载并转PDF
2023-08-13 05:26:41
Python中random函数的用法整理大全
2023-05-08 15:15:52
详解vscode使用git所遇到的坑
2023-12-25 11:17:48
快速了解Python相对导入
2023-07-29 18:35:30
Oracle数据库快照的使用
2010-07-28 13:32:00
MySQL性能全面优化方法参考,从CPU,文件系统选择到mysql.cnf参数优化
2024-01-22 16:37:20
JS获取当前时间的实例代码(昨天、今天、明天)
2024-04-23 09:28:36
python中format函数与round函数的区别
2021-03-31 03:33:29
layerUI下的绑定事件实例代码
2024-04-16 09:38:08