help now working if no mentat release present.
improved style
This commit is contained in:
parent
7ef5323f1e
commit
072be9c1bb
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
# -*- coding: UTF-8 no BOM -*-
|
# -*- coding: UTF-8 no BOM -*-
|
||||||
|
|
||||||
import sys,os,pwd,math,string
|
import sys,os,string
|
||||||
import numpy as np
|
import numpy as np
|
||||||
from optparse import OptionParser
|
from optparse import OptionParser
|
||||||
import damask
|
import damask
|
||||||
|
@ -11,13 +11,7 @@ scriptName = os.path.splitext(scriptID.split()[1])[0]
|
||||||
|
|
||||||
sys.path.append(damask.solver.Marc().libraryPath('../../'))
|
sys.path.append(damask.solver.Marc().libraryPath('../../'))
|
||||||
|
|
||||||
try:
|
active=[True,True,True] # directions on which to add PBC
|
||||||
from py_mentat import *
|
|
||||||
except:
|
|
||||||
print('error: no valid Mentat release found')
|
|
||||||
sys.exit(-1)
|
|
||||||
|
|
||||||
|
|
||||||
def outMentat(cmd,locals):
|
def outMentat(cmd,locals):
|
||||||
if cmd[0:3] == '(!)':
|
if cmd[0:3] == '(!)':
|
||||||
exec(cmd[3:])
|
exec(cmd[3:])
|
||||||
|
@ -28,26 +22,30 @@ def outMentat(cmd,locals):
|
||||||
py_send(cmd)
|
py_send(cmd)
|
||||||
return
|
return
|
||||||
|
|
||||||
def outStdout(cmd,locals):
|
#-------------------------------------------------------------------------------------------------
|
||||||
|
def outFile(cmd,locals,dest):
|
||||||
|
#-------------------------------------------------------------------------------------------------
|
||||||
if cmd[0:3] == '(!)':
|
if cmd[0:3] == '(!)':
|
||||||
exec(cmd[3:])
|
exec(cmd[3:])
|
||||||
elif cmd[0:3] == '(?)':
|
elif cmd[0:3] == '(?)':
|
||||||
cmd = eval(cmd[3:])
|
cmd = eval(cmd[3:])
|
||||||
sys.stdout.write(cmd+'\n')
|
dest.write(cmd+'\n')
|
||||||
else:
|
else:
|
||||||
sys.stdout.write(cmd+'\n')
|
dest.write(cmd+'\n')
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------------------------------
|
||||||
def output(cmds,locals,dest):
|
def output(cmds,locals,dest):
|
||||||
|
#-------------------------------------------------------------------------------------------------
|
||||||
for cmd in cmds:
|
for cmd in cmds:
|
||||||
if isinstance(cmd,list):
|
if isinstance(cmd,list):
|
||||||
output(cmd,locals,dest)
|
output(cmd,locals,dest)
|
||||||
else:
|
else:
|
||||||
{\
|
if dest == 'Mentat':
|
||||||
'Mentat': outMentat,\
|
outMentat(str(cmd),locals)
|
||||||
'Stdout': outStdout,\
|
else:
|
||||||
}[dest](cmd,locals)
|
outFile(str(cmd),locals,dest)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
|
@ -66,7 +64,6 @@ def servoLink():
|
||||||
NodeCoords[node,0] = py_get_float("node_x(%i)"%(node+1))
|
NodeCoords[node,0] = py_get_float("node_x(%i)"%(node+1))
|
||||||
NodeCoords[node,1] = py_get_float("node_y(%i)"%(node+1))
|
NodeCoords[node,1] = py_get_float("node_y(%i)"%(node+1))
|
||||||
NodeCoords[node,2] = py_get_float("node_z(%i)"%(node+1))
|
NodeCoords[node,2] = py_get_float("node_z(%i)"%(node+1))
|
||||||
|
|
||||||
box['min'] = NodeCoords.min(axis=0) # find the bounding box
|
box['min'] = NodeCoords.min(axis=0) # find the bounding box
|
||||||
box['max'] = NodeCoords.max(axis=0)
|
box['max'] = NodeCoords.max(axis=0)
|
||||||
box['delta'] = box['max']-box['min']
|
box['delta'] = box['max']-box['min']
|
||||||
|
@ -74,13 +71,14 @@ def servoLink():
|
||||||
if box['delta'][coord] != 0.0:
|
if box['delta'][coord] != 0.0:
|
||||||
for extremum in ['min','max']:
|
for extremum in ['min','max']:
|
||||||
rounded = round(box[extremum][coord]*1e+15/box['delta'][coord]) * \
|
rounded = round(box[extremum][coord]*1e+15/box['delta'][coord]) * \
|
||||||
1e-15*box['delta'][coord] # rounding to 1e-15 of dimension
|
1e-15*box['delta'][coord] # rounding to 1e-15 of dimension
|
||||||
box[extremum][coord] = {False: rounded,
|
box[extremum][coord] = 0.0 if rounded == 0.0 else rounded # get rid of -0.0 (negative zeros)
|
||||||
True: 0.0}[rounded == 0.0] # get rid of -0.0 (negative zeros)
|
|
||||||
baseNode = {}
|
baseNode = {}
|
||||||
linkNodes = []
|
linkNodes = []
|
||||||
|
|
||||||
for node in xrange(Nnodes): # loop over all nodes
|
#!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
|
# loop over all nodes
|
||||||
|
for node in xrange(Nnodes):
|
||||||
pos = {}
|
pos = {}
|
||||||
key = {}
|
key = {}
|
||||||
maxFlag = [False, False, False]
|
maxFlag = [False, False, False]
|
||||||
|
@ -89,17 +87,16 @@ def servoLink():
|
||||||
for coord in xrange(3): # for each direction
|
for coord in xrange(3): # for each direction
|
||||||
if box['delta'][coord] != 0.0:
|
if box['delta'][coord] != 0.0:
|
||||||
rounded = round(NodeCoords[node,coord]*1e+15/box['delta'][coord]) * \
|
rounded = round(NodeCoords[node,coord]*1e+15/box['delta'][coord]) * \
|
||||||
1e-15*box['delta'][coord] # rounding to 1e-15 of dimension
|
1e-15*box['delta'][coord] # rounding to 1e-15 of dimension
|
||||||
NodeCoords[node,coord] = {False: rounded,
|
NodeCoords[node,coord] = 0.0 if rounded == 0.0 else rounded # get rid of -0.0 (negative zeros)
|
||||||
True: 0.0}[rounded == 0.0] # get rid of -0.0 (negative zeros)
|
key[base[coord]] = "%.8e"%NodeCoords[node,coord] # translate position to string
|
||||||
key[base[coord]] = "%.8e"%NodeCoords[node,coord] # translate position to string
|
if (key[base[coord]] == "%.8e"%box['min'][coord]): # compare to min of bounding box (i.e. is on outer face?)
|
||||||
if (key[base[coord]] == "%.8e"%box['min'][coord]): # compare to min of bounding box (i.e. is on outer face?)
|
Nmin += 1 # count outer (back) face membership
|
||||||
Nmin += 1 # count outer (back) face membership
|
elif (key[base[coord]] == "%.8e"%box['max'][coord]): # compare to max of bounding box (i.e. is on outer face?)
|
||||||
elif (key[base[coord]] == "%.8e"%box['max'][coord]): # compare to max of bounding box (i.e. is on outer face?)
|
Nmax += 1 # count outer (front) face membership
|
||||||
Nmax += 1 # count outer (front) face membership
|
maxFlag[coord] = True # remember face membership (for linked nodes)
|
||||||
maxFlag[coord] = True # remember face membership (for linked nodes)
|
|
||||||
|
|
||||||
if Nmin > 0 and Nmin > Nmax: # node is on more back than front faces
|
if Nmin > 0: # node is on a back face
|
||||||
# prepare for any non-existing entries in the data structure
|
# prepare for any non-existing entries in the data structure
|
||||||
if key['x'] not in baseNode.keys():
|
if key['x'] not in baseNode.keys():
|
||||||
baseNode[key['x']] = {}
|
baseNode[key['x']] = {}
|
||||||
|
@ -110,24 +107,22 @@ def servoLink():
|
||||||
|
|
||||||
baseNode[key['x']][key['y']][key['z']] = node+1 # remember the base node id
|
baseNode[key['x']][key['y']][key['z']] = node+1 # remember the base node id
|
||||||
|
|
||||||
elif Nmax > 0 and Nmax >= Nmin: # node is on at least as many front than back faces
|
if Nmax > 0 and Nmax >= Nmin: # node is on at least as many front than back faces
|
||||||
linkNodes.append({'id': node+1,'coord': NodeCoords[node], 'onFaces': Nmax,'faceMember': maxFlag})
|
if any([maxFlag[i] and active[i] for i in xrange(3)]):
|
||||||
|
linkNodes.append({'id': node+1,'coord': NodeCoords[node], 'faceMember': [maxFlag[i] and active[i] for i in xrange(3)]})
|
||||||
|
|
||||||
|
baseCorner = baseNode["%.8e"%box['min'][0]]["%.8e"%box['min'][1]]["%.8e"%box['min'][2]] # detect ultimate base node
|
||||||
|
|
||||||
|
|
||||||
baseCorner = baseNode["%.8e"%box['min'][0]]["%.8e"%box['min'][1]]["%.8e"%box['min'][2]] # detect ultimate base node
|
for node in linkNodes: # loop over all linked nodes
|
||||||
|
linkCoord = [node['coord']] # start list of control node coords with my coords
|
||||||
|
for dir in xrange(3): # check for each direction
|
||||||
for node in linkNodes: # loop over all linked nodes
|
if node['faceMember'][dir]: # me on this front face
|
||||||
linkCoord = [node['coord']] # start list of control node coords with my coords
|
linkCoord[0][dir] = box['min'][dir] # project me onto rear face along dir
|
||||||
for dir in xrange(3): # check for each direction
|
linkCoord.append(np.array(box['min'])) # append base corner
|
||||||
if node['faceMember'][dir]: # me on this front face
|
linkCoord[-1][dir] = box['max'][dir] # stretch it to corresponding control leg of "dir"
|
||||||
linkCoord[0][dir] = box['min'][dir] # project me onto rear face along dir
|
|
||||||
linkCoord.append(np.array(box['min'])) # append base corner
|
|
||||||
|
|
||||||
linkCoord[-1][dir] = box['max'][dir] # stretch it to corresponding control leg of "dir"
|
|
||||||
|
|
||||||
nLinks = len(linkCoord)
|
nLinks = len(linkCoord)
|
||||||
|
|
||||||
for dof in [1,2,3]:
|
for dof in [1,2,3]:
|
||||||
cmds.append([
|
cmds.append([
|
||||||
"*new_link *link_class servo",
|
"*new_link *link_class servo",
|
||||||
|
@ -146,13 +141,6 @@ def servoLink():
|
||||||
"*link_class servo *servo_ret_dof %i %i"%(1+nLinks,dof),
|
"*link_class servo *servo_ret_dof %i %i"%(1+nLinks,dof),
|
||||||
"*link_class servo *servo_ret_coef %i -%i"%(1+nLinks,nLinks-1),
|
"*link_class servo *servo_ret_coef %i -%i"%(1+nLinks,nLinks-1),
|
||||||
])
|
])
|
||||||
|
|
||||||
cmds.append([
|
|
||||||
"*select_nodes",
|
|
||||||
["%i"%node['id'] for node in linkNodes],
|
|
||||||
"#",
|
|
||||||
])
|
|
||||||
|
|
||||||
return cmds
|
return cmds
|
||||||
|
|
||||||
#--------------------------------------------------------------------------------------------------
|
#--------------------------------------------------------------------------------------------------
|
||||||
|
@ -172,30 +160,38 @@ parser.set_defaults(verbose = False)
|
||||||
|
|
||||||
(options, args) = parser.parse_args()
|
(options, args) = parser.parse_args()
|
||||||
|
|
||||||
outputLocals = {}
|
|
||||||
if options.verbose:
|
if options.verbose:
|
||||||
file={'croak':sys.stderr}
|
file={'croak':sys.stderr}
|
||||||
else:
|
else:
|
||||||
file={'croak':sys.stdout}
|
file={'croak':sys.stdout}
|
||||||
|
|
||||||
|
try:
|
||||||
|
from py_mentat import *
|
||||||
|
except:
|
||||||
|
file['croak'].write('error: no valid Mentat release found')
|
||||||
|
sys.exit(-1)
|
||||||
|
|
||||||
|
outputLocals = {}
|
||||||
|
|
||||||
file['croak'].write('\033[1m'+scriptName+'\033[0m\n\n')
|
file['croak'].write('\033[1m'+scriptName+'\033[0m\n\n')
|
||||||
file['croak'].write( 'waiting to connect...\n')
|
file['croak'].write( 'waiting to connect...\n')
|
||||||
py_connect('',options.port)
|
try:
|
||||||
file['croak'].write('connected...\n')
|
py_connect('',options.port)
|
||||||
output([\
|
output(['*draw_manual'],outputLocals,'Mentat') # prevent redrawing in Mentat, should be much faster. Since py_connect has no return value, try this to determine if failed or not
|
||||||
'*draw_manual', # prevent redrawing in "new" Mentat, should be much faster
|
except:
|
||||||
'*remove_all_servos',
|
file['croak'].write('Could not connect. Set Tools/Python/"Run as Separate Process" & "Initiate"...\n')
|
||||||
|
sys.exit()
|
||||||
|
file['croak'].write( 'connected...\n')
|
||||||
|
|
||||||
|
output(['*remove_all_servos',
|
||||||
'*sweep_all',
|
'*sweep_all',
|
||||||
'*renumber_nodes',
|
'*renumber_nodes',
|
||||||
'*set_links off',
|
'*set_links off',
|
||||||
],outputLocals,'Mentat') # script depends on consecutive numbering of nodes
|
],outputLocals,'Mentat') # script depends on consecutive numbering of nodes
|
||||||
|
|
||||||
cmds = servoLink()
|
cmds = servoLink()
|
||||||
output(cmds,outputLocals,'Mentat')
|
output(cmds,outputLocals,'Mentat')
|
||||||
output([\
|
|
||||||
'*set_links on',
|
|
||||||
'*draw',
|
|
||||||
],outputLocals,'Mentat') # script depends on consecutive numbering of nodes
|
|
||||||
py_disconnect()
|
py_disconnect()
|
||||||
|
|
||||||
if options.verbose:
|
if options.verbose:
|
||||||
output(cmds,outputLocals,'Stdout')
|
output(cmds,outputLocals,sys.stdout)
|
||||||
|
|
Loading…
Reference in New Issue