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
  • asp之家 网络编程 m.aspxhome.com