-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvisualizeMe.py
More file actions
50 lines (41 loc) · 1.61 KB
/
visualizeMe.py
File metadata and controls
50 lines (41 loc) · 1.61 KB
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
from __future__ import print_function
#from builtins import *
import sys
import floatingse.instance
import wisdem
import rotorse
from floatingse.instance.spar_instance import SparInstance
from floatingse.instance.semi_instance import SemiInstance
from wisdem.floating.turbine_spar_instance import TurbineSparInstance
from wisdem.floating.turbine_semi_instance import TurbineSemiInstance
mydtu = '10MW'
def name2obj(fstr):
if not (type(fstr) is type('') or type(fstr) == type(u'')):
raise ValueError(str(fstr)+' is not a valid string')
mystr = fstr.lower()
if mystr.find('turb') >= 0 and mystr.find('spar') >= 0:
myobj = TurbineSparInstance(mydtu)
elif mystr.find('turb') >= 0 and (mystr.find('semi') >= 0 or mystr.find('tlp') >= 0):
myobj = TurbineSemiInstance(mydtu)
elif mystr.find('turb') < 0 and mystr.find('spar') >= 0:
myobj = SparInstance()
elif mystr.find('turb') < 0 and (mystr.find('semi') >= 0 or mystr.find('tlp') >= 0):
myobj = SemiInstance()
else:
raise ValueError('Unknown solution, '+fstr)
myobj.set_reference('10MW')
myobj.load(fstr)
myobj.evaluate()
try:
print('mass', 1e-6*myobj.prob['total_mass'])
print('cost', 1e-6*myobj.prob['total_cost'])
print('R_fairlead', myobj.prob['fairlead_radius'])
print('R_aux', myobj.params['radius_to_offset_column'])
print(myobj.constraint_report())
except:
pass
return myobj
if __name__ == '__main__':
if len(sys.argv) != 2: raise Exception('Must pass in save-file')
myobj = name2obj( sys.argv[1] )
myobj.visualize()