adding material.config to header
This commit is contained in:
parent
367134d793
commit
f693ead989
|
@ -29,24 +29,22 @@ parser.add_option('--phase', dest='phase', type='int', nargs = 2,
|
||||||
help='phase indices for <microstructure> configuration %default')
|
help='phase indices for <microstructure> configuration %default')
|
||||||
parser.add_option('--crystallite', dest='crystallite', type='int', metavar = 'int',
|
parser.add_option('--crystallite', dest='crystallite', type='int', metavar = 'int',
|
||||||
help='crystallite index for <microstructure> configuration [%default]')
|
help='crystallite index for <microstructure> configuration [%default]')
|
||||||
parser.add_option('-c', '--configuration', dest='config', action='store_true',
|
parser.add_option('-c','--compress', dest='compress', action='store_true',
|
||||||
help='output material configuration [%default]')
|
|
||||||
parser.add_option('--compress', dest='compress', action='store_true',
|
|
||||||
help='lump identical microstructure and texture information [%default]')
|
help='lump identical microstructure and texture information [%default]')
|
||||||
parser.add_option('-a', '--axes', dest='axes', nargs = 3, metavar = 'string string string',
|
parser.add_option('-a', '--axes', dest='axes', nargs = 3, metavar = 'string string string',
|
||||||
help='Euler angle coordinate system for <texture> configuration x,y,z = %default')
|
help='Euler angle coordinate system for <texture> configuration x,y,z = %default')
|
||||||
parser.add_option('-p', '--precision', dest='precision', choices=['0','1','2','3'], metavar = 'int',
|
parser.add_option('-p', '--precision', dest='precision', choices=['0','1','2','3'], metavar = 'int',
|
||||||
help = 'euler angles decimal places for output format and compressing (0,1,2,3) [2]')
|
help = 'euler angles decimal places for output format and compressing (0,1,2,3) [2]')
|
||||||
|
|
||||||
parser.set_defaults(column = 11)
|
parser.set_defaults(column = 11,
|
||||||
parser.set_defaults(threshold = 0.5)
|
threshold = 0.5,
|
||||||
parser.set_defaults(homogenization = 1)
|
homogenization = 1,
|
||||||
parser.set_defaults(phase = [1,2])
|
phase = [1,2],
|
||||||
parser.set_defaults(crystallite = 1)
|
crystallite = 1,
|
||||||
parser.set_defaults(config = False)
|
compress = False,
|
||||||
parser.set_defaults(compress = False)
|
axes = ['y','x','-z'],
|
||||||
parser.set_defaults(axes = ['y','x','-z'])
|
precision = '2',
|
||||||
parser.set_defaults(precision = '2')
|
)
|
||||||
(options,filenames) = parser.parse_args()
|
(options,filenames) = parser.parse_args()
|
||||||
|
|
||||||
|
|
||||||
|
@ -60,8 +58,9 @@ if filenames == []: filenames = [None]
|
||||||
|
|
||||||
for name in filenames:
|
for name in filenames:
|
||||||
try:
|
try:
|
||||||
table = damask.ASCIItable(name = name, outname = os.path.splitext(name)[0] +'%s'%('_material.config' if options.config else '.geom'),
|
table = damask.ASCIItable(name = name,
|
||||||
buffered = False, labeled = False, readonly=True)
|
outname = os.path.splitext(name)[-2]+'.geom' if name else name,
|
||||||
|
buffered = False, labeled = False)
|
||||||
except: continue
|
except: continue
|
||||||
damask.util.report(scriptName,name)
|
damask.util.report(scriptName,name)
|
||||||
|
|
||||||
|
@ -142,21 +141,21 @@ for name in filenames:
|
||||||
texture = np.arange(info['grid'].prod())
|
texture = np.arange(info['grid'].prod())
|
||||||
microstructure = np.hstack( zip(texture,phase) ).reshape(info['grid'].prod(),2) # create texture/phase pairs
|
microstructure = np.hstack( zip(texture,phase) ).reshape(info['grid'].prod(),2) # create texture/phase pairs
|
||||||
formatOut = 1+int(math.log10(len(texture)))
|
formatOut = 1+int(math.log10(len(texture)))
|
||||||
textureOut =['\n\n<texture>']
|
textureOut =['<texture>']
|
||||||
|
|
||||||
eulerFormatOut='%%%i.%if'%(int(options.precision)+4,int(options.precision))
|
eulerFormatOut='%%%i.%if'%(int(options.precision)+4,int(options.precision))
|
||||||
outStringAngles='(gauss) phi1 '+eulerFormatOut+' Phi '+eulerFormatOut+' phi2 '+eulerFormatOut+' scatter 0.0 fraction 1.0\n'
|
outStringAngles='(gauss) phi1 '+eulerFormatOut+' Phi '+eulerFormatOut+' phi2 '+eulerFormatOut+' scatter 0.0 fraction 1.0'
|
||||||
for i in xrange(len(texture)):
|
for i in xrange(len(texture)):
|
||||||
textureOut += ['[Texture%s]\n'%str(i+1).zfill(formatOut) +
|
textureOut += ['[Texture%s]'%str(i+1).zfill(formatOut),
|
||||||
'axes %s %s %s\n'%(options.axes[0],options.axes[1],options.axes[2]) +
|
'axes %s %s %s'%(options.axes[0],options.axes[1],options.axes[2]),
|
||||||
outStringAngles%tuple(eulerangles[texture[i],...])
|
outStringAngles%tuple(eulerangles[texture[i],...])
|
||||||
]
|
]
|
||||||
formatOut = 1+int(math.log10(len(microstructure)))
|
formatOut = 1+int(math.log10(len(microstructure)))
|
||||||
microstructureOut =['<microstructure>']
|
microstructureOut =['<microstructure>']
|
||||||
for i in xrange(len(microstructure)):
|
for i in xrange(len(microstructure)):
|
||||||
microstructureOut += ['[Grain%s]\n'%str(i+1).zfill(formatOut) +
|
microstructureOut += ['[Grain%s]'%str(i+1).zfill(formatOut),
|
||||||
'crystallite\t%i\n'%options.crystallite +
|
'crystallite\t%i'%options.crystallite,
|
||||||
'(constituent)\tphase %i\ttexture %i\tfraction 1.0\n'%(microstructure[i,1],microstructure[i,0]+1)
|
'(constituent)\tphase %i\ttexture %i\tfraction 1.0'%(microstructure[i,1],microstructure[i,0]+1)
|
||||||
]
|
]
|
||||||
|
|
||||||
info['microstructures'] = len(microstructure)
|
info['microstructures'] = len(microstructure)
|
||||||
|
@ -178,16 +177,15 @@ for name in filenames:
|
||||||
|
|
||||||
#--- write data/header --------------------------------------------------------------------------------
|
#--- write data/header --------------------------------------------------------------------------------
|
||||||
table.info_clear()
|
table.info_clear()
|
||||||
if options.config:
|
|
||||||
table.output_write(line for line in microstructureOut+ textureOut)
|
|
||||||
else:
|
|
||||||
table.info_append([' '.join([scriptID] + sys.argv[1:]),
|
table.info_append([' '.join([scriptID] + sys.argv[1:]),
|
||||||
"grid\ta %i\tb %i\tc %i"%(info['grid'][0],info['grid'][1],info['grid'][2],),
|
"grid\ta %i\tb %i\tc %i"%(info['grid'][0],info['grid'][1],info['grid'][2],),
|
||||||
"size\tx %f\ty %f\tz %f"%(info['size'][0],info['size'][1],info['size'][2],),
|
"size\tx %f\ty %f\tz %f"%(info['size'][0],info['size'][1],info['size'][2],),
|
||||||
"origin\tx %f\ty %f\tz %f"%(info['origin'][0],info['origin'][1],info['origin'][2],),
|
"origin\tx %f\ty %f\tz %f"%(info['origin'][0],info['origin'][1],info['origin'][2],),
|
||||||
"microstructures\t%i"%info['microstructures'],
|
"microstructures\t%i"%info['microstructures'],
|
||||||
"homogenization\t%i"%info['homogenization'],
|
"homogenization\t%i"%info['homogenization'],
|
||||||
])
|
] +
|
||||||
|
[line for line in microstructureOut + textureOut]
|
||||||
|
)
|
||||||
table.head_write()
|
table.head_write()
|
||||||
if options.compress:
|
if options.compress:
|
||||||
matPoints = matPoints.reshape((info['grid'][1],info['grid'][0]))
|
matPoints = matPoints.reshape((info['grid'][1],info['grid'][0]))
|
||||||
|
|
Loading…
Reference in New Issue