added help description.

fixed bug for grain index (+1).
renamed some variables and added a few comments.
This commit is contained in:
Philip Eisenlohr 2013-06-21 19:08:20 +00:00
parent 7b2e48df68
commit 5d15f68914
1 changed files with 22 additions and 13 deletions

View File

@ -69,17 +69,20 @@ mappings = {
} }
parser = OptionParser(option_class=extendedOption, usage='%prog options [file[s]]', description = """ parser = OptionParser(option_class=extendedOption, usage='%prog options [file[s]]', description = """
Smoothens out interface roughness. Smoothens out interface roughness by simulated curvature flow.
This is achieved by the diffusion of each initially sharply bounded grain volume within the periodic domain for a given time,
i.e. up to a diffusion distance of sqrt(t) voxels.
The final geometry is assembled by selecting at each voxel that grain index for which the concentration is largest.
""" + string.replace('$Id$','\n','\\n') """ + string.replace('$Id$','\n','\\n')
) )
parser.add_option('-N', '--iterations', dest='N', type='int', \ parser.add_option('-t', '--time', dest='t', type='int', \
help='number of iterations to apply smoothing [%default]') help='time for curvature flow [%default]')
parser.add_option('-2', '--twodimensional', dest='twoD', action='store_true', \ parser.add_option('-2', '--twodimensional', dest='twoD', action='store_true', \
help='output geom file with two-dimensional data arrangement [%default]') help='output geom file with two-dimensional data arrangement [%default]')
parser.set_defaults(twoD = False) parser.set_defaults(twoD = False)
parser.set_defaults(N = 1) parser.set_defaults(t = 1)
(options, filenames) = parser.parse_args() (options, filenames) = parser.parse_args()
@ -161,18 +164,24 @@ for file in files:
i/info['grid'][0] /info['grid'][1]] = item i/info['grid'][0] /info['grid'][1]] = item
i += 1 i += 1
maxMicro = numpy.zeros(info['grid']) #--- initialize helper data -----------------------------------------------------------------------
microstructureNew = numpy.zeros(info['grid'],'i') winner = numpy.zeros(info['grid'],'i')
for i in range(numpy.amax(microstructure)): diffusedMax = numpy.zeros(info['grid'])
diffusedMicro = ndimage.filters.gaussian_filter((microstructure == i).astype(float),numpy.sqrt(options.N))
microstructureNew = numpy.where(diffusedMicro > maxMicro,i,microstructureNew)
maxMicro = numpy.where(diffusedMicro > maxMicro,diffusedMicro,maxMicro)
microstructure = microstructureNew #--- diffuse each grain separately ----------------------------------------------------------------
formatwidth = int(math.floor(math.log10(microstructure.max())+1)) for theGrain in xrange(1,1+numpy.amax(microstructure)):
diffused = ndimage.filters.gaussian_filter((microstructure == theGrain).astype(float),\
numpy.sqrt(options.t),\
mode='wrap')
winner = numpy.where(diffused > diffusedMax, theGrain, winner)
diffusedMax = numpy.where(diffused > diffusedMax, diffused, diffusedMax)
microstructure = winner
# --- assemble header ----------------------------------------------------------------------------- # --- assemble header -----------------------------------------------------------------------------
formatwidth = int(math.floor(math.log10(microstructure.max())+1))
new_header.append('$Id$\n') new_header.append('$Id$\n')
new_header.append("grid\ta %i\tb %i\tc %i\n"%( new_header.append("grid\ta %i\tb %i\tc %i\n"%(
info['grid'][0],info['grid'][1],info['grid'][2])) info['grid'][0],info['grid'][1],info['grid'][2]))