forked from MJ0706/HCM-project
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreateLV_refine.py
71 lines (50 loc) · 2.04 KB
/
createLV_refine.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import sys
sys.path.append("/mnt/home/mojumder/HPCC_HCM")
import dolfin as dolfin
import vtk_py as vtk_py
import vtk
import os
import numpy as np
#from pyquaternion import Quaternion
######################################################################################
###################################################################
Laxis = np.array([0,0,1])
###################################################################
refinemesh= 0.3
isepiflip = False
isendoflip = True
zoffset = 22.0
angle = np.arccos(Laxis[2])
raxis = Laxis
raxis = raxis / np.linalg.norm(raxis)
#volumedatadir = './'
endostr = "Endo_time_19_3_5"
epistr = "Epi_time_19_2_14"
#endofilename = volumedatadir + endostr + '.stl'
endofilename = endostr + '.stl'
endopdata = vtk_py.readSTL(endofilename)
#epifilename = volumedatadir + epistr + '.stl'
epifilename = epistr + '.stl'
epipdata = vtk_py.readSTL(epifilename)
rotatedepipdata = vtk_py.rotatePData_w_axis(epipdata, angle, raxis)
rotatedendopdata = vtk_py.rotatePData_w_axis(endopdata, angle, raxis)
height = min(rotatedendopdata.GetBounds()[5], rotatedepipdata.GetBounds()[5]) - zoffset
clipped_endo, clipped_epi = vtk_py.clipSurfacesForCutLVMesh(rotatedendopdata, rotatedepipdata, height, verbose=True)
vtk_py.writeSTL(clipped_epi, "clipped_epi_tmp.stl")
vtk_py.writeSTL(clipped_endo, "clipped_endo_tmp.stl")
filename = './case_P2'
vtk_py.createLVmesh(filename, refinemesh, "clipped_epi_tmp.stl", "clipped_endo_tmp.stl")
#os.remove("clipped_epi_tmp.stl")
#os.remove("clipped_endo_tmp.stl")
os.remove("LVtemp.geo.bak")
ugrid = vtk_py.readUGrid(filename + '.vtk')
rotmat = vtk.vtkMatrix4x4()
rotmat.SetElement(0,0,1)
rotmat.SetElement(1,1,1)
rotmat.SetElement(2,2,1)
rotmat.SetElement(2,3,-ugrid.GetBounds()[5]*1)
rotmat.SetElement(3,3,1)
#rotmat = np.array([[0.1, 0, 0, 0], [0, 0.1, 0, 0], [0, 0, 0.1, 0], [0, 0, 0, 1]])
ugrid_transform = vtk_py.transform_mesh_w_4x4mat(filename + '.vtk', filename + '_rot.vtk', rotmat)
#ugrid_transform = vtk_py.readUGrid(filename + '_rot.vtk')
print "ugrid=trans", ugrid_transform