TVTK庫可視化實(shí)例

實(shí)例1:標(biāo)量數(shù)據(jù)可視化

tvtk.ContourFilter() 等值面過濾器

方法 說明
generate_values(n, grid.point_data.scalars.range) 設(shè)定n條等值線的值嘱么,一般用于重新繪制等值線
set_value() 設(shè)定一條等值線的值,一般用于覆蓋某條等值線或者新增加一條等值線
#數(shù)據(jù)讀取
from tvtk.api import tvtk
from tvtkfunc import ivtk_scene, event_loop
 
plot3d = tvtk.MultiBlockPLOT3DReader(
        xyz_file_name="combxyz.bin",
        q_file_name="combq.bin",
        scalar_function_number=100, vector_function_number=200
    ) #讀入Plot3D數(shù)據(jù)
plot3d.update() #讓plot3D計(jì)算其輸出數(shù)據(jù)
grid = plot3d.output.get_block(0) #獲取讀入的數(shù)據(jù)集對象
 
#創(chuàng)建等值面
con = tvtk.ContourFilter()#創(chuàng)建等值面對象  
con.set_input_data(grid)
con.generate_values(10, grid.point_data.scalars.range)#指定輪廓數(shù)和數(shù)據(jù)范圍
 
#繪制數(shù)據(jù)
#設(shè)定映射器的變量范圍屬性
m = tvtk.PolyDataMapper(scalar_range = grid.point_data.scalars.range,
                        input_connection=con.output_port)
a = tvtk.Actor(mapper = m)
a.property.opacity = 0.5 #設(shè)定透明度為0.5
#窗口繪制
win = ivtk_scene(a)
win.scene.isometric_view()
event_loop()

tvtkfunc.py文件百度云鏈接
combxyz.bin和combq.bin文件百度云鏈接

實(shí)例2:矢量數(shù)據(jù)可視化

tvtk.Glyph3D() 符號化技術(shù)

tvtk.MaskPoints() 降采樣

from tvtk.api import tvtk
from tvtkfunc import ivtk_scene, event_loop
 
#讀入PLot3D數(shù)據(jù)
plot3d = tvtk.MultiBlockPLOT3DReader(
        xyz_file_name="combxyz.bin",
        q_file_name="combq.bin",
        scalar_function_number=100, vector_function_number=200
    )
plot3d.update()
grid = plot3d.output.get_block(0)
 
#對數(shù)據(jù)集中的數(shù)據(jù)進(jìn)行隨機(jī)選取,每50個點(diǎn)選擇一個點(diǎn)
mask = tvtk.MaskPoints(random_mode=True, on_ratio=50)
mask.set_input_data(grid)
#創(chuàng)建表示箭頭的PolyData數(shù)據(jù)集
glyph_source = tvtk.ConeSource()
#在Mask采樣后的PolyData數(shù)據(jù)集每個點(diǎn)上放置一個箭頭
#箭頭的方向仁讨、長度和顏色由于點(diǎn)對應(yīng)的矢量和標(biāo)量數(shù)據(jù)決定
glyph = tvtk.Glyph3D(input_connection=mask.output_port,
                      scale_factor=2)
glyph.set_source_connection(glyph_source.output_port)
m = tvtk.PolyDataMapper(scalar_range=grid.point_data.scalars.range,
                        input_connection=glyph.output_port)
a = tvtk.Actor(mapper=m)
 
#窗口繪制
win = ivtk_scene(a)
win.scene.isometric_view()
event_loop()

實(shí)例3:空間輪廓線可視化

tvtk.StructuredGridOutlineFilter()
計(jì)算PolyData對象的外邊框尚卫。

from tvtk.api import tvtk
from tvtk.common import configure_input
from tvtkfunc import ivtk_scene, event_loop
 
plot3d = tvtk.MultiBlockPLOT3DReader(
        xyz_file_name="combxyz.bin",
        q_file_name="combq.bin",
        scalar_function_number=100, vector_function_number=200
    )#讀入Plot3D數(shù)據(jù)
plot3d.update()#讓plot3D計(jì)算其輸出數(shù)據(jù)
grid = plot3d.output.get_block(0)#獲取讀入的數(shù)據(jù)集對象
 
outline = tvtk.StructuredGridOutlineFilter()#計(jì)算表示外邊框的PolyData對象
configure_input(outline, grid)#調(diào)用tvtk.common.configure_input()
m = tvtk.PolyDataMapper(input_connection=outline.output_port)
a = tvtk.Actor(mapper=m)
a.property.color = 0.3, 0.3, 0.3
 
#窗口繪制
win = ivtk_scene(a)
win.scene.isometric_view()
event_loop()

Reference :
中國大學(xué)MOOC北京理工大學(xué)Python科學(xué)計(jì)算三維可視化黃天羽妖爷、嵩天老師課件
課程主頁

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末乌奇,一起剝皮案震驚了整個濱河市掂骏,隨后出現(xiàn)的幾起案子轰驳,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件级解,死亡現(xiàn)場離奇詭異冒黑,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)勤哗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進(jìn)店門抡爹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人芒划,你說我怎么就攤上這事冬竟。” “怎么了民逼?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵泵殴,是天一觀的道長。 經(jīng)常有香客問我拼苍,道長笑诅,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任疮鲫,我火速辦了婚禮吆你,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘俊犯。我一直安慰自己妇多,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布燕侠。 她就那樣靜靜地躺著者祖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪贬循。 梳的紋絲不亂的頭發(fā)上咸包,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天桃序,我揣著相機(jī)與錄音杖虾,去河邊找鬼。 笑死媒熊,一個胖子當(dāng)著我的面吹牛奇适,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播芦鳍,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼嚷往,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了柠衅?” 一聲冷哼從身側(cè)響起皮仁,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后贷祈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體趋急,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年势誊,在試婚紗的時候發(fā)現(xiàn)自己被綠了呜达。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡粟耻,死狀恐怖查近,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情挤忙,我是刑警寧澤霜威,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站饭玲,受9級特大地震影響侥祭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜茄厘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一矮冬、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧次哈,春花似錦胎署、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至哀卫,卻和暖如春巨坊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背此改。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工趾撵, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人共啃。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓占调,卻偏偏與公主長得像,于是被迫代替她去往敵國和親移剪。 傳聞我的和親對象是個殘疾皇子究珊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,520評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)纵苛,斷路器剿涮,智...
    卡卡羅2017閱讀 134,600評論 18 139
  • 此原創(chuàng)文章已獲得大數(shù)據(jù)文摘(微信公眾號)采用言津,并于2017年4月29日發(fā)布(閱讀量近5K):前沿 | 國際可視化盛...
    Kayyyy閱讀 8,106評論 0 43
  • 地樁連著繩子, 繩子的那頭 牽著一頭牛取试。 它低著頭纺念,從來不看天, 也忘記了 月色想括。 頂著陷谱,迎著烈陽,日復(fù)一日...
    腎毒閱讀 309評論 10 11
  • 是因?yàn)樽陨淼臈l件優(yōu)越瑟蜈?還是因?yàn)閷Ψ綄ψ约旱年P(guān)心愛護(hù)太多烟逊? 人類在愛情中總有一種很大的問題,就是受傷害的永遠(yuǎn)是投入最...
    小小話嘮子閱讀 98評論 0 0