forked from jasonfleming/pputils
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathply2adcirc.py
executable file
·100 lines (86 loc) · 2.92 KB
/
ply2adcirc.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#!/usr/bin/env python3
#
#+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!
# #
# ply2adcirc.py #
# #
#+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!
#
# Author: Pat Prodanovic, Ph.D., P.Eng.
#
# Date: Nov 2, 2016
#
# Modified: Nov 9, 2016
# Adjusted so that it takes the coordinate shift into account in the
# conversion process. See adcirc2ply.py script for how this file is
# created.
#
# Purpose: Script designed to open a *.ply file, and output it to an
# adcirc *.grd file. This script is useful for taking geometry modifed
# by MeshLab and then bringing it back to pputils.
#
# Works for Python 2 or Python 3
#
# Uses: Python 2 or 3, Numpy
#
# Example:
#
# when extracting 1 variable
# python ply2adcirc.py -i out.ply -o out.grd
# where:
# -i MeshLab *.ply mesh file
# -o Adcirc *.grd file
#
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# Global Imports
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
import os,sys
import numpy as np
from ppmodules.readMesh import * # to get all readMesh functions
#
#+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# MAIN
#+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
#
# I/O
if len(sys.argv) != 5 :
print('Wrong number of Arguments, stopping now...')
print('Usage:')
print('python adcirc2ply.py -i out.grd -o out.ply')
sys.exit()
ply_file = sys.argv[2]
adcirc_file = sys.argv[4]
# to create the output files
fout = open(adcirc_file,'w')
# read the ply file
n,e,x,y,z,ikle = readPly(ply_file)
# to read the ply_shift_coordinates.txt file
if (os.path.isfile('ply_shift_coordinates.txt') == False):
print('File ply_shift_coordinates.txt does not exist!')
print('Re-run adcirc2ply.py to generate this file.')
print('Exiting ...')
sys.exit()
coords = list()
with open('ply_shift_coordinates.txt','r') as f:
for i in f:
coords.append(i)
f.close()
# now remove the shift file
os.remove('ply_shift_coordinates.txt')
# the coords are stored as a list with one record, the record being a
# string; split this string into xref and yref
xref = float(coords[0].split()[0])
yref = float(coords[0].split()[1])
# now to write the adcirc mesh file with the corrext coordinates
fout.write("ADCIRC" + "\n")
# writes the number of elements and number of nodes in the header file
fout.write(str(e) + " " + str(n) + "\n")
# writes the nodes
for i in range(n):
fout.write(str(i+1) + " " + str("{:.3f}".format(x[i]+xref)) + " " +
str("{:.3f}".format(y[i]+yref)) + " " + str("{:.3f}".format(z[i])) + "\n")
# writes the elements
for i in range(e):
fout.write(str(i+1) + " 3 " + str(ikle[i,0]) + " " + str(ikle[i,1]) + " " +
str(ikle[i,2]) + "\n")
print("All Done!")