This section gives you an overview of the functionality MTEX offers to visualize spatial orientation data. Let us first import some sample EBSD data.
close all; plotx2east
mtexdata forsterite
csFo = ebsd('Forsterite').CS;
ebsd = EBSD
Phase Orientations Mineral Color Symmetry Crystal reference frame
0 58485 (24%) notIndexed
1 152345 (62%) Forsterite LightSkyBlue mmm
2 26058 (11%) Enstatite DarkSeaGreen mmm
3 9064 (3.7%) Diopside Goldenrod 12/m1 X||a*, Y||b*, Z||c
Properties: bands, bc, bs, error, mad
Scan unit : um
X x Y x Z : [0 36550] x [0 16750] x [0 0]
Normal vector: (0,0,1)
Phase Plots
By default, MTEX plots a phase map for EBSD data.
plot(ebsd)
data:image/s3,"s3://crabby-images/698fd/698fd7689945a0c3df54b4c6ae57fcfdaf132f04" alt=""
You can access the color of each phase by
ebsd('Diopside').color
ans =
0.8549 0.6471 0.1255
These values are RGB values which can be altered to any other RGB triple. A more convinient way for changing the color is the function str2rgb which converts color names into RGB triplets
ebsd('Diopside').color = str2rgb('salmon');
plot(ebsd('indexed'))
data:image/s3,"s3://crabby-images/322a8/322a82b5115cec5f9425a35648339e77a927c30b" alt=""
By default, not indexed phases are plotted as white and it is impossible to assign a different color as we did it for real phases. Instead we need to use option FaceColor
to specify the color directly in the plotting command.
hold on
plot(ebsd('notIndexed'),'FaceColor','Gray')
hold off
data:image/s3,"s3://crabby-images/c3521/c35212a94ba723775422daa52de4c73c29fe0cf1" alt=""
Visualizing arbitrary properties
Apart from the phase information, we can use any other property to colorize the EBSD data. As an example, we may plot the band contrast
plot(ebsd,ebsd.bc)
colormap gray % make the image grayscale
mtexColorbar
data:image/s3,"s3://crabby-images/bac21/bac21ced7958cc792cfa4992b480f51f55bafe32" alt=""
Visualizing orientations
Actually, we can pass any list of numbers or colors as a second input argument to be visualized together with the ebsd data. In order to visualize orientations in an EBSD map, we have first to compute a color for each orientation. The most simple way is to assign to each orientation its rotational angle. This is done by the command
plot(ebsd('Forsterite'),ebsd('Forsterite').orientations.angle./degree)
mtexColorbar
data:image/s3,"s3://crabby-images/66316/6631617a2ab0f0b7816f5af52863241f5e101514" alt=""
Obviously, the rotational angle is not a very distintive representative for orientations. A more common approach is to define a colorization of the fundamental secor of the inverse pole figure, a so called ipf color key, and to colorize orientations according to their position in a fixed inverse pole figure. Let's consider the following standard key.
% this defines an ipf color key for the Forsterite phase
ipfKey = ipfColorKey(ebsd('Forsterite'));
ipfKey.inversePoleFigureDirection = vector3d.Z;
% this is the colored fundamental sector
plot(ipfKey)
data:image/s3,"s3://crabby-images/a6831/a6831c5e763f44c6097a34d2233175e64efde1fd" alt=""
Next we may utilize this key to turn the orientations into colors, which are than passed to the plot command.
colors = ipfKey.orientation2color(ebsd('Forsterite').orientations);
plot(ebsd('Forsterite'),colors)
data:image/s3,"s3://crabby-images/5b4b2/5b4b20ede8c1e0457719531fe74f3f705a811c07" alt=""
The above ipf color key can be largely customizied. This is explained in more detail in IPF Maps. Beside IPF maps there are also more specific ways to colorize orientations as they are discussed in Advanced Plotting.
Superposing different plots
Combining different plots can be done either by plotting only subsets of the EBSD data or via the option 'faceAlpha'
. Note that the option 'faceAlpha'
requires the renderer of the figure to be set to 'opengl'
.
close all;
plot(ebsd,ebsd.bc)
mtexColorMap black2white
hold on
plot(ebsd('fo'),'FaceAlpha',0.5)
hold off
Warning: You asked me to make a phase plot of single
phase map. This might not what you are looking for. In
order to colorize the map according to the
orientations you should do
plot(ebsd,ebsd.orientations)
data:image/s3,"s3://crabby-images/aa141/aa141345aa19c8aeec6c01e09f805f182a4001e2" alt=""