-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathprobe.py
executable file
·128 lines (118 loc) · 4.15 KB
/
probe.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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#!/usr/bin/env python3
#
#+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!
# #
# probe.py #
# #
#+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!+!
#
# Author: Pat Prodanovic, Ph.D., P.Eng.
#
# Date: Feb 13, 2016
#
# Purpose: Probes the selafin file, and outputs file's metadata. Works for
# Python 2 or Python 3 as it uses selafin_io_pp class ppSELAFIN.
#
# Revised: Apr 30, 2016
# Added ability to probe 3d *.slf files.
#
# Uses: Python 2 or 3, Numpy
#
# Example: python probe2.py -i input.slf
#
# where:
# --> -i is the telemac *.slf file being probed
#
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# Global Imports
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# need future for backward compatibility with python2
from __future__ import absolute_import, division, print_function
import sys
import numpy as np
from ppmodules.selafin_io_pp import *
#+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# MAIN
#+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
#
if len(sys.argv) != 3:
print('Wrong number of Arguments, stopping now...')
print('Example usage:')
print('python probe.py -i input.slf')
sys.exit()
# I/O
input_file = sys.argv[2] # input *.slf file
print('#################################')
print("The input file being probed: " + input_file)
#
# constructor for pp_SELAFIN class
slf = ppSELAFIN(input_file)
slf.readHeader()
slf.readTimes()
times = slf.getTimes()
vnames = slf.getVarNames()
vunits = slf.getVarUnits()
ftype,fsize = slf.getPrecision()
nplan = slf.getNPLAN()
NELEM = slf.getNELEM()
NPOIN = slf.getNPOIN()
IPOBO = slf.getIPOBO()
DATE = slf.getDATE()
if (nplan > 1):
slf_type = '3d'
else:
slf_type = '2d'
if(ftype == 'f' and fsize == 4):
precision = 'single'
elif(ftype == 'd' and fsize == 8):
precision = 'double'
else:
precision = 'unknown'
# prints variable names
print('Precision: ' + precision )
print('File type: ' + slf_type )
if slf_type == '3d':
print('Number of planes: ' + str(nplan))
print('Number of elements: ' + str(NELEM))
print('Number of nodes: ' + str(NPOIN))
print('Date: ' + str(DATE[0]) + '-' + str(DATE[1]).zfill(2) + '-'
+ str(DATE[2]).zfill(2) + ' ' + str(DATE[3]).zfill(2) + ':'
+ str(DATE[4]).zfill(2) + ':' + str(DATE[5]).zfill(2) )
print(' ')
print('#################################')
print('Variables in '+input_file+' are: ')
print('---------------------------------')
print(' v variable unit' )
print('---------------------------------')
for i in range(len(vnames)):
print(' ',i, '-->', vnames[i] + ' [' + vunits[i].strip() + ']')
print(' ')
print('#################################')
# prints times
records = np.arange(len(times))
nrecs = len(times)
if (len(times) < 2):
print(" t time (s)")
print('---------------------------------')
print(str(records[0]) + " -->" + str("{:10.1f}".format(times[0])))
elif(len(times) < 3):
print(" t time (s)")
print('---------------------------------')
print(str(records[0]) + " -->" + str("{:10.1f}".format(times[0])))
print(str(records[1]) + " -->" + str("{:10.1f}".format(times[1])))
elif (len(times) < 4):
print(" t time (s)")
print('---------------------------------')
print(str(records[0]) + " -->" + str("{:10.1f}".format(times[0])))
print(str(records[1]) + " -->" + str("{:10.1f}".format(times[1])))
print(str(records[2]) + " -->" + str("{:10.1f}".format(times[2])))
else:
print("t time (s)")
print('---------------------------------')
print(str(records[0]) + " -->" + str("{:10.1f}".format(times[0])))
print(str(records[1]) + " -->" + str("{:10.1f}".format(times[1])))
print(str(records[2]) + " -->" + str("{:10.1f}".format(times[2])))
print(str(records[3]) + " -->" + str("{:10.1f}".format(times[3])))
print(' ......')
print(str(records[nrecs-1]) +"-->" + str("{:10.1f}".format(times[nrecs-1])))
print('#################################')