fixed small bugs.

modernized file treatment.
improved Laguerre speed by a factor of 2 due to precalculating the squared weights.
This commit is contained in:
Philip Eisenlohr 2015-06-27 08:41:08 +00:00
parent 50bcfe6e0d
commit 129026662c
1 changed files with 73 additions and 77 deletions

View File

@ -31,44 +31,50 @@ def meshgrid2(*arrs):
return tuple(ans) return tuple(ans)
def laguerreTessellation(undeformed, coords, weights): def laguerreTessellation(undeformed, coords, weights):
bestdist = np.ones(len(undeformed)) * np.finfo('d').max
bestseed = np.zeros(len(undeformed))
for i,seed in enumerate(coords):
for copy in np.array([[1, 0, 0, ],
[0, 1, 0, ],
[0, 0, 1, ],
[-1, 0, 0, ],
[0, -1, 0, ],
[0, 0, -1, ],
[1, 1, 0, ],
[1, 0, 1, ],
[0, 1, 1, ],
[-1, 1, 0, ],
[-1, 0, 1, ],
[0, -1, 1, ],
[-1, -1, 0, ],
[-1, 0, -1, ],
[0, -1, -1, ],
[1, -1, 0, ],
[1, 0, -1, ],
[0, 1, -1, ],
[1, 1, 1, ],
[-1, 1, 1, ],
[1, -1, 1, ],
[1, 1, -1, ],
[-1, -1, -1, ],
[1, -1, -1, ],
[-1, 1, -1, ],
[-1, -1, 1, ]]).astype(float):
diff = undeformed - np.repeat((seed+info['size']*copy).reshape(3,1),len(undeformed),axis=1).T
dist = np.sum(diff*diff,axis=1) - weights[i]
bestseed = np.where(dist < bestdist, np.ones(len(undeformed))*(i+1),bestseed)
bestdist = np.where(dist < bestdist, dist,bestdist)
return bestseed
weight = np.power(np.tile(weights, 27),2) # Laguerre weights (squared)
micro = np.zeros(undeformed.shape[0])
N = coords.shape[0] # Number of seeds points
periodic = np.array([
[ -1,-1,-1 ],
[ 0,-1,-1 ],
[ 1,-1,-1 ],
[ -1, 0,-1 ],
[ 0, 0,-1 ],
[ 1, 0,-1 ],
[ -1, 1,-1 ],
[ 0, 1,-1 ],
[ 1, 1,-1 ],
[ -1,-1, 0 ],
[ 0,-1, 0 ],
[ 1,-1, 0 ],
[ -1, 0, 0 ],
[ 0, 0, 0 ],
[ 1, 0, 0 ],
[ -1, 1, 0 ],
[ 0, 1, 0 ],
[ 1, 1, 0 ],
[ -1,-1, 1 ],
[ 0,-1, 1 ],
[ 1,-1, 1 ],
[ -1, 0, 1 ],
[ 0, 0, 1 ],
[ 1, 0, 1 ],
[ -1, 1, 1 ],
[ 0, 1, 1 ],
[ 1, 1, 1 ],
]).astype(float)
for i,vec in enumerate(periodic):
seeds = np.append(seeds, coords+vec, axis=0) if i > 0 else coords+vec
for i,point in enumerate(undeformed):
tmp = np.repeat(point.reshape(3,1), N*27, axis=1).T
dist = np.sum((tmp - seeds)*(tmp - seeds),axis=1) - weight
micro[i] = np.argmin(dist)%N
return micro
# -------------------------------------------------------------------- # --------------------------------------------------------------------
# MAIN # MAIN
@ -109,48 +115,39 @@ parser.add_option('-r', '--rnd', dest='randomSeed', type='int', metavar='int',
help='seed of random number generator for second phase distribution [%default]') help='seed of random number generator for second phase distribution [%default]')
parser.add_option('--secondphase', type='float', dest='secondphase', metavar= 'float', parser.add_option('--secondphase', type='float', dest='secondphase', metavar= 'float',
help='volume fraction of randomly distribute second phase [%default]') help='volume fraction of randomly distribute second phase [%default]')
parser.add_option('--laguerre', dest='laguerre', action='store_true', parser.add_option('-l', '--laguerre', dest='laguerre', action='store_true',
help='for weighted voronoi (Laguerre) tessellation [%default]') help='use Laguerre (weighted Voronoi) tessellation [%default]')
parser.set_defaults(grid = (0,0,0)) parser.set_defaults(grid = (0,0,0),
parser.set_defaults(size = (0.0,0.0,0.0)) size = (0.0,0.0,0.0),
parser.set_defaults(origin = (0.0,0.0,0.0)) origin = (0.0,0.0,0.0),
parser.set_defaults(homogenization = 1) homogenization = 1,
parser.set_defaults(phase = 1) phase = 1,
parser.set_defaults(crystallite = 1) crystallite = 1,
parser.set_defaults(secondphase = 0.0) secondphase = 0.0,
parser.set_defaults(config = False) config = False,
parser.set_defaults(laguerre = False) laguerre = False,
parser.set_defaults(randomSeed = None) randomSeed = None,
)
(options,filenames) = parser.parse_args() (options,filenames) = parser.parse_args()
if options.secondphase > 1.0 or options.secondphase < 0.0: if options.secondphase > 1.0 or options.secondphase < 0.0:
parser.error('volume fraction of second phase (%f) out of bounds...'%options.secondphase) parser.error('volume fraction of second phase (%f) out of bounds...'%options.secondphase)
#--- setup file handles --------------------------------------------------------------------------- # --- loop over input files -------------------------------------------------------------------------
files = []
if filenames == []: if filenames == []:
files.append({'name': 'STDIN', filenames = ['STDIN']
'input': sys.stdin,
'output': sys.stdout,
'croak': sys.stderr,
})
else:
for name in filenames:
if os.path.exists(name):
files.append({'name': name,
'input': open(name),
'output': open(name+'_tmp','w'),
'croak': sys.stdout,
})
for name in filenames:
if name == 'STDIN':
file = {'name':'STDIN', 'input':sys.stdin, 'output':sys.stdout, 'croak':sys.stderr}
file['croak'].write('\033[1m'+scriptName+'\033[0m\n')
else:
if not os.path.exists(name): continue
file = {'name':name, 'input':open(name), 'output':open(name+'_tmp','w'), 'croak':sys.stderr}
file['croak'].write('\033[1m'+scriptName+'\033[0m: '+file['name']+'\n')
#--- loop over input files ------------------------------------------------------------------------ table = damask.ASCIItable(file['input'],file['output'],buffered=False) # make unbuffered ASCII_table
for file in files: table.head_read() # read ASCII header info
file['croak'].write('\033[1m' + scriptName + '\033[0m: ' + (file['name'] if file['name'] != 'STDIN' else '') + '\n')
table = damask.ASCIItable(file['input'],file['output'],buffered = False)
table.head_read()
labels = [] labels = []
if np.all(table.label_index(['1_coords','2_coords','3_coords']) != -1): if np.all(table.label_index(['1_coords','2_coords','3_coords']) != -1):
@ -241,7 +238,7 @@ for file in files:
#--- switch according to task --------------------------------------------------------------------- #--- switch according to task ---------------------------------------------------------------------
if options.config: # write config file if options.config: # write config file
phase=np.empty(info['microstructures'],'i') phase = np.empty(info['microstructures'],'i')
phase.fill(options.phase) phase.fill(options.phase)
phase[0:int(float(info['microstructures'])*options.secondphase)] = options.phase+1 phase[0:int(float(info['microstructures'])*options.secondphase)] = options.phase+1
randomSeed = int(os.urandom(4).encode('hex'), 16) if options.randomSeed == None else options.randomSeed # radom seed per file for second phase randomSeed = int(os.urandom(4).encode('hex'), 16) if options.randomSeed == None else options.randomSeed # radom seed per file for second phase
@ -286,10 +283,10 @@ for file in files:
newInfo['microstructures'] = info['microstructures'] newInfo['microstructures'] = info['microstructures']
for i in grainIDs: for i in grainIDs:
if i not in indices: newInfo['microstructures'] -= 1 if i not in indices: newInfo['microstructures'] -= 1
file['croak'].write('all' if [newInfo['microstructures'] == info['microstructures'] ] else 'only' + file['croak'].write(('all' if newInfo['microstructures'] == info['microstructures'] else 'only') +
' %i'%newInfo['microstructures'] + ' %i'%newInfo['microstructures'] +
'' if [newInfo['microstructures'] == info['microstructures']] else \ ('' if newInfo['microstructures'] == info['microstructures'] else \
'out of %i'%info['microstructures'] + ' out of %i'%info['microstructures']) +
' grains mapped.\n') ' grains mapped.\n')
#--- write header --------------------------------------------------------------------------------- #--- write header ---------------------------------------------------------------------------------
@ -312,8 +309,7 @@ for file in files:
#--- output finalization -------------------------------------------------------------------------- #--- output finalization --------------------------------------------------------------------------
table.close()
if file['name'] != 'STDIN': if file['name'] != 'STDIN':
table.input_close()
table.output_close()
os.rename(file['name']+'_tmp', os.rename(file['name']+'_tmp',
os.path.splitext(file['name'])[0] +'%s'%('_material.config' if options.config else '.geom')) os.path.splitext(file['name'])[0] +'%s'%('_material.config' if options.config else '.geom'))