handling point based data enabled
This commit is contained in:
parent
6bffb91951
commit
c3c4b05c01
|
@ -104,7 +104,7 @@ class ConfigMaterial(Config):
|
||||||
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def load_from_Dream3D(fname,base_group,grain_data,phase_name,phase_id):
|
def load_from_Dream3D(fname,base_group,data_group,ori_data,phase_id,phase_name):
|
||||||
r"""
|
r"""
|
||||||
Load material data from DREAM3D file.
|
Load material data from DREAM3D file.
|
||||||
|
|
||||||
|
@ -116,35 +116,66 @@ class ConfigMaterial(Config):
|
||||||
path to the DREAM3D file.
|
path to the DREAM3D file.
|
||||||
base_group : str
|
base_group : str
|
||||||
Name of the group (folder) below 'DataContainers',
|
Name of the group (folder) below 'DataContainers',
|
||||||
for example 'SyntheticVolumeDataContainer/Grain Data'.
|
for example 'SyntheticVolumeDataContainer'.
|
||||||
grain_data : str
|
data_group : str
|
||||||
Name of the dataset having grain based data for conversion,
|
Name of the group (folder) having relevant data for conversion,
|
||||||
for example 'EulerAngles'.
|
for example 'Grain Data' or 'CellData'.
|
||||||
phase_name : list
|
ori_data : str
|
||||||
List with name of the phases.
|
Name of the dataset having orientation data (working with Euler Angles in dream3D file),
|
||||||
|
For example 'EulerAngles'.
|
||||||
phase_id : str
|
phase_id : str
|
||||||
Name of the dataset containing phase IDs for each grain,
|
Name of the dataset containing phase IDs for each grain,
|
||||||
for example 'Phases'.
|
for example 'Phases'.
|
||||||
|
phase_name : list
|
||||||
|
List with name of the phases.
|
||||||
|
|
||||||
Examples
|
Examples
|
||||||
--------
|
--------
|
||||||
|
for grain based data with single phase
|
||||||
>>> import damask
|
>>> import damask
|
||||||
>>> import damask.ConfigMaterial as cm
|
>>> import damask.ConfigMaterial as cm
|
||||||
>>> cm.load_from_Dream3D('20grains16x16x16.dream3D','SyntheticVolumeDataContainer/Grain Data',\
|
>>> cm.load_from_Dream3D('20grains16x16x16.dream3D','SyntheticVolumeDataContainer', 'Grain Data'\
|
||||||
'EulerAngles',['Ferrite'],'Phases')
|
'EulerAngles','Phases',['Ferrite'])
|
||||||
|
|
||||||
|
for point based data with single phase
|
||||||
|
>>> import damask
|
||||||
|
>>> import damask.ConfigMaterial as cm
|
||||||
|
>>> cm.load_from_Dream3D('20grains16x16x16.dream3D','SyntheticVolumeDataContainer', 'CellData'\
|
||||||
|
'EulerAngles','Phases',['Ferrite'])
|
||||||
|
|
||||||
|
for grain based data with dual phase
|
||||||
|
>>> import damask
|
||||||
|
>>> import damask.ConfigMaterial as cm
|
||||||
|
>>> cm.load_from_Dream3D('20grains16x16x16.dream3D','SyntheticVolumeDataContainer', 'Grain Data'\
|
||||||
|
'EulerAngles','Phases',['Ferrite','Martensite'])
|
||||||
|
|
||||||
|
for point based data with dual phase
|
||||||
|
>>> import damask
|
||||||
|
>>> import damask.ConfigMaterial as cm
|
||||||
|
>>> cm.load_from_Dream3D('20grains16x16x16.dream3D','SyntheticVolumeDataContainer', 'CellData'\
|
||||||
|
'EulerAngles','Phases',['Ferrite','Martensite'])
|
||||||
|
|
||||||
"""
|
"""
|
||||||
root_dir = 'DataContainers'
|
root_dir = 'DataContainers'
|
||||||
hdf = h5py.File(fname,'r')
|
hdf = h5py.File(fname,'r')
|
||||||
|
cells = hdf[path.join(root_dir,base_group,'_SIMPL_GEOMETRY/DIMENSIONS')][()]
|
||||||
|
|
||||||
config_info = ConfigMaterial() # empty yaml dictionary
|
config_info = ConfigMaterial() # empty yaml dictionary
|
||||||
|
|
||||||
orientation_path = path.join(root_dir,base_group,grain_data)
|
orientation_path = path.join(root_dir,base_group,data_group,ori_data)
|
||||||
|
if hdf[orientation_path].attrs['TupleDimensions'].shape == (3,):
|
||||||
|
grain_orientations = np.array(hdf[orientation_path]).reshape(cells.prod(),3,order='F')
|
||||||
|
else:
|
||||||
grain_orientations = np.array(hdf[orientation_path])[1:]
|
grain_orientations = np.array(hdf[orientation_path])[1:]
|
||||||
|
|
||||||
grain_quats = Rotation.from_Euler_angles(grain_orientations).as_quaternion()
|
grain_quats = Rotation.from_Euler_angles(grain_orientations).as_quaternion()
|
||||||
|
|
||||||
phase_path = path.join(root_dir,base_group,phase_id)
|
phase_path = path.join(root_dir,base_group,data_group,phase_id)
|
||||||
|
if hdf[phase_path].attrs['TupleDimensions'].shape == (3,):
|
||||||
|
grain_phase = np.array(hdf[phase_path]).reshape(cells.prod(),order='F')
|
||||||
|
else:
|
||||||
grain_phase = np.array(hdf[phase_path])[1:]
|
grain_phase = np.array(hdf[phase_path])[1:]
|
||||||
|
|
||||||
grain_phase = grain_phase.reshape(len(grain_phase),)
|
grain_phase = grain_phase.reshape(len(grain_phase),)
|
||||||
phase_name_list = [phase_name[i - 1] for i in grain_phase]
|
phase_name_list = [phase_name[i - 1] for i in grain_phase]
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue