Added explicit option to force geom input format.
Added option to output legacy format. Possible bug in VTK presently prevents XML output to STDOUT... (Have filed issue to VTK developers.)
This commit is contained in:
parent
57acaba63e
commit
dffa119724
|
@ -19,16 +19,31 @@ Create regular voxel grid from points in an ASCIItable (or geom file).
|
||||||
|
|
||||||
""", version = scriptID)
|
""", version = scriptID)
|
||||||
|
|
||||||
parser.add_option('-m', '--mode',
|
parser.add_option('-m',
|
||||||
|
'--mode',
|
||||||
dest = 'mode',
|
dest = 'mode',
|
||||||
type = 'choice', choices = ['cell','point'],
|
type = 'choice', choices = ['cell','point'],
|
||||||
help = 'cell-centered or point-centered coordinates ')
|
help = 'cell-centered or point-centered coordinates ')
|
||||||
parser.add_option('-c', '--coordinates',
|
parser.add_option('-p',
|
||||||
dest = 'coords',
|
'--pos', '--position',
|
||||||
|
dest = 'pos',
|
||||||
type = 'string', metavar = 'string',
|
type = 'string', metavar = 'string',
|
||||||
help = 'coordinate label [%default]')
|
help = 'coordinate label [%default]')
|
||||||
parser.set_defaults(coords = 'pos',
|
parser.add_option('-g',
|
||||||
mode = 'cell'
|
'--geom',
|
||||||
|
dest = 'geom',
|
||||||
|
action = 'store_true',
|
||||||
|
help = 'geom input format')
|
||||||
|
parser.add_option('-l',
|
||||||
|
'--legacy',
|
||||||
|
dest = 'legacy',
|
||||||
|
action = 'store_true',
|
||||||
|
help = 'force legacy VTK output')
|
||||||
|
|
||||||
|
parser.set_defaults(mode = 'cell',
|
||||||
|
pos = 'pos',
|
||||||
|
geom = False,
|
||||||
|
legacy = False,
|
||||||
)
|
)
|
||||||
|
|
||||||
(options, filenames) = parser.parse_args()
|
(options, filenames) = parser.parse_args()
|
||||||
|
@ -38,7 +53,7 @@ parser.set_defaults(coords = 'pos',
|
||||||
if filenames == []: filenames = [None]
|
if filenames == []: filenames = [None]
|
||||||
|
|
||||||
for name in filenames:
|
for name in filenames:
|
||||||
isGeom = name is not None and name.endswith('.geom')
|
isGeom = options.geom or (name is not None and name.endswith('.geom'))
|
||||||
try: table = damask.ASCIItable(name = name,
|
try: table = damask.ASCIItable(name = name,
|
||||||
buffered = False,
|
buffered = False,
|
||||||
labeled = not isGeom,
|
labeled = not isGeom,
|
||||||
|
@ -53,9 +68,9 @@ for name in filenames:
|
||||||
|
|
||||||
remarks = []
|
remarks = []
|
||||||
errors = []
|
errors = []
|
||||||
coordDim = 3 if isGeom else table.label_dimension(options.coords)
|
coordDim = 3 if isGeom else table.label_dimension(options.pos)
|
||||||
if not 3 >= coordDim >= 1: errors.append('coordinates "{}" need to have one, two, or three dimensions.'.format(options.coords))
|
if not 3 >= coordDim >= 1: errors.append('coordinates "{}" need to have one, two, or three dimensions.'.format(options.pos))
|
||||||
elif coordDim < 3: remarks.append('appending {} dimensions to coordinates "{}"...'.format(3-coordDim,options.coords))
|
elif coordDim < 3: remarks.append('appending {} dimensions to coordinates "{}"...'.format(3-coordDim,options.pos))
|
||||||
|
|
||||||
if remarks != []: damask.util.croak(remarks)
|
if remarks != []: damask.util.croak(remarks)
|
||||||
if errors != []:
|
if errors != []:
|
||||||
|
@ -73,7 +88,7 @@ for name in filenames:
|
||||||
endpoint = True,
|
endpoint = True,
|
||||||
) for i in xrange(3)]
|
) for i in xrange(3)]
|
||||||
else:
|
else:
|
||||||
table.data_readArray(options.coords)
|
table.data_readArray(options.pos)
|
||||||
if len(table.data.shape) < 2: table.data.shape += (1,) # expand to 2D shape
|
if len(table.data.shape) < 2: table.data.shape += (1,) # expand to 2D shape
|
||||||
if table.data.shape[1] < 3:
|
if table.data.shape[1] < 3:
|
||||||
table.data = np.hstack((table.data,
|
table.data = np.hstack((table.data,
|
||||||
|
@ -117,22 +132,27 @@ for name in filenames:
|
||||||
|
|
||||||
# ------------------------------------------ output result ---------------------------------------
|
# ------------------------------------------ output result ---------------------------------------
|
||||||
|
|
||||||
if name:
|
if options.legacy:
|
||||||
|
writer = vtk.vtkDataSetWriter()
|
||||||
|
writer.SetHeader('# powered by '+scriptID)
|
||||||
|
else:
|
||||||
writer = vtk.vtkXMLRectilinearGridWriter()
|
writer = vtk.vtkXMLRectilinearGridWriter()
|
||||||
(directory,filename) = os.path.split(name)
|
|
||||||
writer.SetDataModeToBinary()
|
writer.SetDataModeToBinary()
|
||||||
writer.SetCompressorTypeToZLib()
|
writer.SetCompressorTypeToZLib()
|
||||||
writer.SetFileName(os.path.join(directory,os.path.splitext(filename)[0] +
|
|
||||||
('' if isGeom else '_{}({})'.format(options.coords, options.mode)) +
|
if name:
|
||||||
'.' + writer.GetDefaultFileExtension()))
|
writer.SetFileName(os.path.join(os.path.split(name)[0],
|
||||||
|
os.path.splitext(os.path.split(name)[1])[0] +
|
||||||
|
('' if isGeom else '_{}({})'.format(options.pos, options.mode)) +
|
||||||
|
'.' + ('vtk' if options.legacy else writer.GetDefaultFileExtension())))
|
||||||
else:
|
else:
|
||||||
writer = vtk.vtkDataSetWriter()
|
|
||||||
writer.WriteToOutputStringOn()
|
writer.WriteToOutputStringOn()
|
||||||
writer.SetHeader('# powered by '+scriptID)
|
|
||||||
|
|
||||||
if vtk.VTK_MAJOR_VERSION <= 5: writer.SetInput(rGrid)
|
if vtk.VTK_MAJOR_VERSION <= 5: writer.SetInput(rGrid)
|
||||||
else: writer.SetInputData(rGrid)
|
else: writer.SetInputData(rGrid)
|
||||||
|
|
||||||
writer.Write()
|
writer.Write()
|
||||||
if name is None: sys.stdout.write(writer.GetOutputString()[0:writer.GetOutputStringLength()])
|
|
||||||
|
if name is None: sys.stdout.write(writer.GetOutputString())
|
||||||
|
|
||||||
table.close()
|
table.close()
|
||||||
|
|
Loading…
Reference in New Issue