add option to output double, triple, and quadruple scalars

This commit is contained in:
Philip Eisenlohr 2012-06-19 15:30:16 +00:00
parent 481268c8c2
commit 376ec2cd94
1 changed files with 48 additions and 12 deletions

View File

@ -115,6 +115,14 @@ def unravel(item):
def vtk_writeASCII_mesh(mesh,data,res): def vtk_writeASCII_mesh(mesh,data,res):
# ++++++++++++++++++++++++++++++++++++++++++++++++++++ # ++++++++++++++++++++++++++++++++++++++++++++++++++++
""" function writes data array defined on a hexahedral mesh (geometry) """ """ function writes data array defined on a hexahedral mesh (geometry) """
info = {\
'tensor': {'name':'tensor','len':9},\
'vector': {'name':'vector','len':3},\
'scalar': {'name':'scalar','len':1},\
'double': {'name':'scalar','len':2},\
'triple': {'name':'scalar','len':3},\
'quadruple': {'name':'scalar','len':4},\
}
N1 = (res[0]+1)*(res[1]+1)*(res[2]+1) N1 = (res[0]+1)*(res[1]+1)*(res[2]+1)
N = res[0]*res[1]*res[2] N = res[0]*res[1]*res[2]
@ -153,8 +161,8 @@ def vtk_writeASCII_mesh(mesh,data,res):
plural = {True:'',False:'S'}[type.lower().endswith('s')] plural = {True:'',False:'S'}[type.lower().endswith('s')]
for item in data[type]: for item in data[type]:
cmds += [\ cmds += [\
'%s %s float'%(type.upper()+plural,item), '%s %s float %i'%(info[type]['name'].upper()+plural,item,info[type]['len']),
{True:'LOOKUP_TABLE default',False:''}[type.lower()[:3]=='sca'], {True:'LOOKUP_TABLE default',False:''}[info[type]['name'][:3]=='sca'],
[[['\t'.join(map(unravel,data[type][item][:,j,k]))] for j in range(res[1])] for k in range(res[2])], [[['\t'.join(map(unravel,data[type][item][:,j,k]))] for j in range(res[1])] for k in range(res[2])],
] ]
@ -164,6 +172,14 @@ def vtk_writeASCII_mesh(mesh,data,res):
def gmsh_writeASCII_mesh(mesh,data,res): def gmsh_writeASCII_mesh(mesh,data,res):
# ++++++++++++++++++++++++++++++++++++++++++++++++++++ # ++++++++++++++++++++++++++++++++++++++++++++++++++++
""" function writes data array defined on a hexahedral mesh (geometry) """ """ function writes data array defined on a hexahedral mesh (geometry) """
info = {\
'tensor': {'name':'tensor','len':9},\
'vector': {'name':'vector','len':3},\
'scalar': {'name':'scalar','len':1},\
'double': {'name':'scalar','len':2},\
'triple': {'name':'scalar','len':3},\
'quadruple': {'name':'scalar','len':4},\
}
N1 = (res[0]+1)*(res[1]+1)*(res[2]+1) N1 = (res[0]+1)*(res[1]+1)*(res[2]+1)
N = res[0]*res[1]*res[2] N = res[0]*res[1]*res[2]
@ -214,7 +230,7 @@ def gmsh_writeASCII_mesh(mesh,data,res):
plural = {True:'',False:'S'}[type.lower().endswith('s')] plural = {True:'',False:'S'}[type.lower().endswith('s')]
for item in data[type]: for item in data[type]:
cmds += [\ cmds += [\
'%s %s float'%(type.upper()+plural,item), '%s %s float %i'%(info[type]['name'].upper()+plural,item,info[type]['len']),
'LOOKUP_TABLE default', 'LOOKUP_TABLE default',
[[['\t'.join(map(str,data[type][item][:,j,k]))] for j in range(res[1])] for k in range(res[2])], [[['\t'.join(map(str,data[type][item][:,j,k]))] for j in range(res[1])] for k in range(res[2])],
] ]
@ -294,6 +310,12 @@ Produce VTK file from data field. Coordinates are taken from (consecutive) x, y,
parser.add_option('-s', '--scalar', action='extend', dest='scalar', type='string', \ parser.add_option('-s', '--scalar', action='extend', dest='scalar', type='string', \
help='list of scalars to visualize') help='list of scalars to visualize')
parser.add_option( '--double', action='extend', dest='double', type='string', \
help='list of scalars to visualize')
parser.add_option( '--triple', action='extend', dest='triple', type='string', \
help='list of scalars to visualize')
parser.add_option( '--quadruple', action='extend', dest='quadruple', type='string', \
help='list of scalars to visualize')
parser.add_option('-v', '--vector', action='extend', dest='vector', type='string', \ parser.add_option('-v', '--vector', action='extend', dest='vector', type='string', \
help='list of vectors to visualize') help='list of vectors to visualize')
parser.add_option('-d', '--deformation', dest='defgrad', type='string', \ parser.add_option('-d', '--deformation', dest='defgrad', type='string', \
@ -322,6 +344,9 @@ parser.add_option('-u', '--unitlength', dest='unitlength', type='float', \
help='set unit length for 2D model [%default]') help='set unit length for 2D model [%default]')
parser.set_defaults(defgrad = 'f') parser.set_defaults(defgrad = 'f')
parser.set_defaults(scalar = []) parser.set_defaults(scalar = [])
parser.set_defaults(double = [])
parser.set_defaults(triple = [])
parser.set_defaults(quadruple = [])
parser.set_defaults(vector = []) parser.set_defaults(vector = [])
parser.set_defaults(tensor = []) parser.set_defaults(tensor = [])
parser.set_defaults(output_mesh = True) parser.set_defaults(output_mesh = True)
@ -370,7 +395,7 @@ for filename in args:
maxcol = max(maxcol,col+9) maxcol = max(maxcol,col+9)
break break
if column['tensor'][options.defgrad] < 0: if not options.undeformed and column['tensor'][options.defgrad] < 0:
print 'missing deformation gradient "%s"..!'%options.defgrad print 'missing deformation gradient "%s"..!'%options.defgrad
continue continue
@ -383,15 +408,17 @@ for filename in args:
maxcol = max(maxcol,col+3) maxcol = max(maxcol,col+3)
break break
column['scalar'] = {} for length,what in enumerate(['scalar','double','triple','quadruple']):
for label in options.scalar: column[what] = {}
column['scalar'][label] = -1 for label in eval('options.%s'%what):
column[what][label] = -1
for col,head in enumerate(headings): for col,head in enumerate(headings):
if head == label: if head == label or head == '1_%s'%label:
column['scalar'][label] = col column[what][label] = col
maxcol = max(maxcol,col+1) maxcol = max(maxcol,col+1+length)
break break
values = numpy.array(sorted([map(transliterateToFloat,line.split()[:maxcol]) for line in content[headrow+1:]], values = numpy.array(sorted([map(transliterateToFloat,line.split()[:maxcol]) for line in content[headrow+1:]],
key=lambda x:(x[locol+0],x[locol+1],x[locol+2])), # sort with z as fastest and x as slowest index key=lambda x:(x[locol+0],x[locol+1],x[locol+2])), # sort with z as fastest and x as slowest index
'd') 'd')
@ -434,16 +461,25 @@ for filename in args:
'tensor': {},\ 'tensor': {},\
'vector': {},\ 'vector': {},\
'scalar': {},\ 'scalar': {},\
'double': {},\
'triple': {},\
'quadruple': {},\
} }
reshape = {\ reshape = {\
'tensor': [3,3],\ 'tensor': [3,3],\
'vector': [3],\ 'vector': [3],\
'scalar': [],\ 'scalar': [],\
'double': [2],\
'triple': [3],\
'quadruple': [4],\
} }
length = {\ length = {\
'tensor': 9,\ 'tensor': 9,\
'vector': 3,\ 'vector': 3,\
'scalar': 1,\ 'scalar': 1,\
'double': 2,\
'triple': 3,\
'quadruple': 4,\
} }
for datatype in fields.keys(): for datatype in fields.keys():