流场可视化学习2

通过使用PyVista实现一个螺旋状三维流场。
代码如下

import numpy as np
import pyvista as pv

# 创建结构化网格数据集
x, y, z = np.meshgrid(np.linspace(-1, 1, 10), np.linspace(-1, 1, 10), np.linspace(-1, 1, 10))
vectors = np.zeros((x.size, 3))
vectors[:, 0] = np.sin(np.pi * x.ravel()) * np.cos(np.pi * y.ravel()) * np.cos(np.pi * z.ravel())
vectors[:, 1] = -np.cos(np.pi * x.ravel()) * np.sin(np.pi * y.ravel()) * np.cos(np.pi * z.ravel())
vectors[:, 2] = (np.sqrt(2.0 / 3.0) * np.cos(np.pi * x.ravel()) * np.cos(np.pi * y.ravel()) * np.sin(np.pi * z.ravel()))

# 将矢量数据添加到结构化网格中
grid = pv.StructuredGrid(x, y, z)
grid["vectors"] = vectors

# 计算流线
streamlines = grid.streamlines("vectors", integration_direction="both")

# 可视化流线
p = pv.Plotter()
p.add_mesh(streamlines, scalars="vectors", show_scalar_bar=False, line_width=2)
p.show()

实现效果如下:

在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值