no scaling of the output by size (seeds files are within 0..1)

plus some polishing here and there
This commit is contained in:
Philip Eisenlohr 2014-06-08 12:48:32 +00:00
parent b0ab048d7b
commit 31aded8311
1 changed files with 16 additions and 9 deletions

View File

@ -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