推文:科学计算三维可视化---TVTK库可视化实例

使用相关函数:科学计算三维可视化---Mlab基础(管线控制函数)

一:mlab.pipeline中标量数据可视化

通过持续实例,来感受mlab对数据可视化的方便性

(一)生成标量数据

等值面:(外层会覆盖内层)

import numpy as np
from mayavi import mlab x,y,z = np.ogrid[-::20j,-::20j,-::20j]
s = np.sin(x*y*z)/(x*y*z) mlab.contour3d(s)  #等值面绘制
mlab.show()

切平面:

import numpy as np
from mayavi import mlab x,y,z = np.ogrid[-::20j,-::20j,-::20j]
s = np.sin(x*y*z)/(x*y*z) #绘制两个方向的切平面
mlab.pipeline.image_plane_widget(mlab.pipeline.scalar_field(s), #scalar_field获得数据的标量数据场
plane_orientation="x_axes", #设置切平面的方向
slice_index=
) mlab.pipeline.image_plane_widget(mlab.pipeline.scalar_field(s),
plane_orientation="y_axes",
slice_index=
) #为这个数据绘制外框
mlab.outline()
mlab.show()

复合观测方法

import numpy as np
from mayavi import mlab x,y,z = np.ogrid[-::20j,-::20j,-::20j]
s = np.sin(x*y*z)/(x*y*z) src = mlab.pipeline.scalar_field(s) #建立标量场数据 mlab.pipeline.iso_surface(src,contours=[s.min()+0.1*s.ptp(),],opacity=0.1) #iso_surface对输入体绘制其等值面,记得设置透明度,否则内部数据将被外部遮挡
mlab.pipeline.iso_surface(src,contours=[s.max()-0.1*s.ptp(),]) #也可以使用等值面iso_surface,来观察一定范围内的数据 #绘制切平面
mlab.pipeline.image_plane_widget(src, #使用切平面来观察某一平面的数据细节
plane_orientation="z_axes", #设置切平面的方向
slice_index=
) mlab.show()

二:mlab.pipeline中矢量数据可视化

import numpy as np
from mayavi import mlab x,y,z = np.mgrid[::20j,::20j,::20j] #u,v,w是在点x,y,z处的矢量数据
u = np.sin(np.pi*x)*np.cos(np.pi*z)
v = -*np.sin(np.pi*x)*np.cos(*np.pi*z)
w = np.cos(np.pi*x)*np.sin(np.pi*z) + np.cos(np.pi*y)*np.sin(*np.pi*z) mlab.quiver3d(u,v,w) #quiver3d可以在数据点处画出箭头
mlab.outline() mlab.show()

上面数据过于密集:可以使用降采样:科学计算三维可视化---TVTK库可视化实例 

import numpy as np
from mayavi import mlab x,y,z = np.mgrid[::20j,::20j,::20j] #u,v,w是在点x,y,z处的矢量数据
u = np.sin(np.pi*x)*np.cos(np.pi*z)
v = -*np.sin(np.pi*x)*np.cos(*np.pi*z)
w = np.cos(np.pi*x)*np.sin(np.pi*z) + np.cos(np.pi*y)*np.sin(*np.pi*z) src = mlab.pipeline.vector_field(u,v,w)
#pipeline的vectors构建了矢量域
mlab.pipeline.vectors(src,mask_points=10,scale_factor=2.0) #mask_points没10个数据点选取一个,scale_factor放缩比率2.0
mlab.show()

切面观察矢量数据

import numpy as np
from mayavi import mlab x,y,z = np.mgrid[::20j,::20j,::20j] #u,v,w是在点x,y,z处的矢量数据
u = np.sin(np.pi*x)*np.cos(np.pi*z)
v = -*np.sin(np.pi*x)*np.cos(*np.pi*z)
w = np.cos(np.pi*x)*np.sin(np.pi*z) + np.cos(np.pi*y)*np.sin(*np.pi*z) src = mlab.pipeline.vector_field(u,v,w)
#pipeline的vectors构建了矢量域
mlab.pipeline.vector_cut_plane(src,mask_points=10,scale_factor=2.0) #mask_points没10个数据点选取一个,scale_factor放缩比率2.0 mlab.show()

另一个矢量数据重要显示方法:级数的等值面

级数是矢量域中的重要参数,他可以显示数量的法线等值面,我们通过计算矢量法向得到一个标量域
import numpy as np
from mayavi import mlab x,y,z = np.mgrid[::20j,::20j,::20j] #u,v,w是在点x,y,z处的矢量数据
u = np.sin(np.pi*x)*np.cos(np.pi*z)
v = -*np.sin(np.pi*x)*np.cos(*np.pi*z)
w = np.cos(np.pi*x)*np.sin(np.pi*z) + np.cos(np.pi*y)*np.sin(*np.pi*z) src = mlab.pipeline.vector_field(u,v,w)
magnitude = mlab.pipeline.extract_vector_norm(src) #extract_vector_norm通过计算矢量法向得到一个标量域
mlab.pipeline.iso_surface(magnitude,contours=[2.0,0.5
]) #构建等值面 mlab.outline()
mlab.show()

流线的可视化对矢量数据也非常有意义,在很多应用中,他可以表示流体力学的轨迹,有可以表示电磁场线

import numpy as np
from mayavi import mlab x,y,z = np.mgrid[::20j,::20j,::20j] #u,v,w是在点x,y,z处的矢量数据
u = np.sin(np.pi*x)*np.cos(np.pi*z)
v = -*np.sin(np.pi*x)*np.cos(*np.pi*z)
w = np.cos(np.pi*x)*np.sin(np.pi*z) + np.cos(np.pi*y)*np.sin(*np.pi*z) flow = mlab.flow(u,v,w,seed_scale=,
seed_resolution=,
integration_direction="both") mlab.outline()
mlab.show()

复合观测方法

为矢量场数据给出有意义的矢量观测是比较有困难的工作,因此通常我们需要使用不同的根据,对矢量数据进行可视化
#等值面
iso = mlab.pipeline.iso_surface(magnitude,contours=[2.0,],opacity=0.3) #构建等值面
#矢量场
vec = mlab.pipeline.vectors(magnitude,mask_points=,line_width=,
color=(0.8,0.8,0.8),
scale_factor=.)
#矢量场流线
flow = mlab.pipeline.streamline(magnitude,seedtype="plane",
seed_visible=False,
seed_scale=0.5,
seed_resolution=,
linetype="ribbon")
#矢量场切平面
vcp = mlab.pipeline.vector_cut_plane(magnitude,mask_points=,
scale_factor=,
colormap="jet",
plane_orientation="x_axes")

科学计算三维可视化---Mlab基础(数据可视化)的更多相关文章

  1. 科学计算三维可视化---Mlab基础(管线控制函数)

    科学计算三维可视化---TVTK管线与数据加载(可视化管线和图像管线了解) 科学计算三维可视化---Mayavi入门(Mayavi管线) Mlab管线控制函数的调用 Sources:数据源 Filte ...

  2. 科学计算三维可视化---Mlab基础(鼠标选取交互操作)

    一:鼠标选取介绍 二:选取红色小球分析 相关方法:科学计算三维可视化---Mlab基础(基于Numpy数组的绘图函数) 1.小球场景初始化建立 import numpy as np from maya ...

  3. Python科学计算三维可视化(整理完结)

    中国MOOC<Pyhton计算计算三维可视化>总结 课程url:here ,教师:黄天宇,嵩天 下文的图片和问题,答案都是从eclipse和上完课后总结的,转载请声明. Python数据三 ...

  4. 科学计算三维可视化---TVTK库可视化实例

    一:TVTK库可视化实例 Plot3D文件知识:PLOT3D 数据格式 PLOT3D文件分为网格文件(XYZ 文件), 空气动力学结果文件 (Q 文件)和通用结果文件(函数文件 + 函数名称文件).网 ...

  5. 科学计算三维可视化---Mlab基础(基于Numpy数组的绘图函数)

    Mlab了解 Mlab是Mayavi提供的面向脚本的api,他可以实现快速的三维可视化,Mayavi可以通过Mlab的绘图函数对Numpy数组建立可视化. 过程为: .建立数据源 .使用Filter( ...

  6. 科学计算三维可视化---Mlab基础(改变物体的外观颜色)

    import numpy as np from mayavi import mlab #建立数据 x,y = np.mgrid[-::200j,-::200j] z = *np.sin(x*y)/(x ...

  7. 科学计算三维可视化---TVTK管线与数据加载(可视化管线和图像管线了解)

    一:TVTK的管线 使用管线技术将TVTK中各个对象穿连起来,几乎所有渲染引擎都会提到管线技术 在TVTK中,每个对象只需要实现相对简单的任务,整个管线则能根据用户的需求,实现复杂的数据可视化处理. ...

  8. 科学计算三维可视化---TVTK入门(数据加载)

    一:数据加载 大多数可视化应用的数据并非是在TVTK库中构建的,很多都是通过接口读取外部数据文件 (一)使用vtkSTLReader来读取外部文件 .stl 文件是在计算机图形应用系统中,用于表示三角 ...

  9. 科学计算三维可视化---Traits介绍

    简介 Traits是开源扩展库,Traits本身与科学计算可视化没有直接关联,但他其实TVTK,Mayavi,TraitsUI基础 安装: pip3 install traits--cp36-cp36 ...

随机推荐

  1. mysql非安装包安装教程

    设置mysql的环境变量 本人设置安装的路径是:E:\WebApplication\webMySQL\mysql-5.7.13-winx64 我的电脑 ---> 高级系统配置 ---> 环 ...

  2. js如何判断一个值是不是Array类型

    本来判断一个对象类型用typeof是最好的,不过对于Array类型是不适用的可以使用 instanceof操作符var arrayStr=new Array("1","2 ...

  3. CASE (Transact-SQL)

    A. 使用带有 CASE 简单表达式的 SELECT 语句Using a SELECT statement with a simple CASE expression在 SELECT 语句中,CASE ...

  4. Cannot open the disk 'D:\win7-ie8\Windows 7 x64.vmdk' or one of the snapshot

    使用机子过程中断电,开机后使用虚拟机提示[Cannot open the disk 'D:\win7-ie8\Windows 7 x64.vmdk' or one of the snapshot],找 ...

  5. webservice(一) 概念

    Web service:是一个平台独立的,低耦合的,自包含的.基于可编程的web的应用程序,可使用开放的XML(标准通用标记语言下的一个子集)标准来描述.发布.发现.协调和配置这些应用程序,用于开发分 ...

  6. 探秘SpringAop(一)_介绍以及使用详解

    常用的编程范式 AOP 是什么 是一种编程方式,不是编程语言 解决特定问题,不能解决所有的问题 OOP的补充,不是代替 AOP 初衷 DRY: Don't repeat yourself(代码重复) ...

  7. 深入理解JAVA虚拟机阅读笔记2——垃圾回收

    线程私有的程序计数器.虚拟机栈和本地方法栈随线程而生,随线程而灭.栈中的栈帧随方法的进入和退出有条不紊的入栈和出栈. 而Java堆和方法区因为需要多大内存.创建多少对象都是不确定的,因此这两个区域是垃 ...

  8. Memcache服务器端+Redis服务器端+PHP Memcache扩展+PHP Memcached扩展+PHP Redis扩展+MemAdmin Memcache管理工具+一些概念(更新中)

    Memcache和Redis因为操作简单,是我们常用的服务器数据缓存系统,以下文字仅作备忘记录,部份转载至网络. 一.定义 1.Memcache Memcache是一个高性能的分布式的内存对象缓存系统 ...

  9. static关键字的总结

    C++的static有两种用法:面向过程程序设计中的static和面向对象程序设计中的static.前者应用于普通变量和函数,不涉及类:后者主要说明static在类中的作用. 1.面向过程设计中的st ...

  10. 【bzoj4712】洪水 树链剖分+线段树维护树形动态dp

    题目描述 给出一棵树,点有点权.多次增加某个点的点权,并在某一棵子树中询问:选出若干个节点,使得每个叶子节点到根节点的路径上至少有一个节点被选择,求选出的点的点权和的最小值. 输入 输入文件第一行包含 ...