no scaling of the output by size (seeds files are within 0..1)
plus some polishing here and there
This commit is contained in:
parent
b0ab048d7b
commit
31aded8311
|
@ -57,9 +57,9 @@ Examples:
|
|||
|
||||
|
||||
parser.add_option('-w','--white', dest='whitelist', action='extend', type='string', \
|
||||
help='white list of column labels (a,b,c,...)', metavar='<LIST>')
|
||||
help='white list of grain IDs', metavar='<LIST>')
|
||||
parser.add_option('-b','--black', dest='blacklist', action='extend', type='string', \
|
||||
help='black list of column labels (a,b,c,...)', metavar='<LIST>')
|
||||
help='black list of grain IDs', metavar='<LIST>')
|
||||
|
||||
parser.set_defaults(whitelist = [])
|
||||
parser.set_defaults(blacklist = [])
|
||||
|
@ -136,11 +136,12 @@ for file in files:
|
|||
if numpy.any(info['size'] <= 0.0):
|
||||
file['croak'].write('invalid size x y z.\n')
|
||||
continue
|
||||
if 'origin' not in info:
|
||||
info['origin'] = numpy.zeros(3)
|
||||
|
||||
#--- read data ------------------------------------------------------------------------------------
|
||||
microstructure = numpy.zeros(info['grid'].prod(),'i') # initialize as flat array
|
||||
i = 0
|
||||
theTable.data_rewind()
|
||||
while theTable.data_read():
|
||||
items = theTable.data
|
||||
if len(items) > 2:
|
||||
|
@ -159,6 +160,8 @@ for file in files:
|
|||
theTable.info = [
|
||||
scriptID,
|
||||
"grid\ta %i\tb %i\tc %i"%(info['grid'][0],info['grid'][1],info['grid'][2],),
|
||||
"size\tx %i\ty %i\tz %i"%(info['size'][0],info['size'][1],info['size'][2],),
|
||||
"origin\tx %i\ty %i\tz %i"%(info['origin'][0],info['origin'][1],info['origin'][2],),
|
||||
]
|
||||
theTable.labels_clear()
|
||||
theTable.labels_append(['x','y','z','microstructure']) # implicitly switching label processing/writing on
|
||||
|
@ -167,7 +170,7 @@ for file in files:
|
|||
#--- filtering of grain voxels ------------------------------------------------------------------------------------
|
||||
theTable.data_clear()
|
||||
i = 0
|
||||
|
||||
outputDead = False
|
||||
coord = numpy.zeros(3,'d')
|
||||
for coord[2] in xrange(info['grid'][2]):
|
||||
for coord[1] in xrange(info['grid'][1]):
|
||||
|
@ -175,13 +178,17 @@ for file in files:
|
|||
if (options.whitelist == [] and options.blacklist == []) or \
|
||||
(options.whitelist != [] and microstructure[i] in options.whitelist) or \
|
||||
(options.blacklist != [] and microstructure[i] not in options.blacklist):
|
||||
theTable.data = list((coord+0.5)/info['grid']*info['size'])+[microstructure[i]]
|
||||
theTable.data_write()
|
||||
theTable.data = list((coord+0.5)/info['grid'])+[microstructure[i]]
|
||||
outputDead = not theTable.data_write()
|
||||
i += 1
|
||||
if outputDead: break
|
||||
if outputDead: break
|
||||
if outputDead: break
|
||||
|
||||
# ------------------------------------------ output result ---------------------------------------
|
||||
|
||||
outputDead or theTable.output_flush() # just in case of buffered ASCII table
|
||||
|
||||
file['input'].close() # close input ASCII table
|
||||
theTable.input_close() # close input ASCII table
|
||||
if file['name'] != 'STDIN':
|
||||
file['output'].close() # close output ASCII table
|
||||
theTable.output_close() # close output ASCII table
|
||||
|
|
Loading…
Reference in New Issue