In previous chapters we have discussed how to select EBSD data by properties. In this chapter we discus the ordering of EBSD pixels within MTEX. Lets start by importing some sample data
mtexdata twins
ebsd = EBSD
Phase Orientations Mineral Color Symmetry Crystal reference frame
0 46 (0.2%) notIndexed
1 22833 (100%) Magnesium LightSkyBlue 6/mmm X||a*, Y||b, Z||c*
Properties: bands, bc, bs, error, mad
Scan unit : um
X x Y x Z : [0 50] x [0 41] x [0 0]
Normal vector: (0,0,1)
and restricting it to very small rectangular subset
poly = [44 0 4 2];
ebsd = ebsd(inpolygon(ebsd,poly));
plot(ebsd,ebsd.orientations,'micronbar','off','edgecolor','k')
data:image/s3,"s3://crabby-images/5d223/5d223d7c9823d71863de9edc2ff5683ea10ceb34" alt=""
In the above plot each square corresponds to one entry in the variable ebsd
which as an index from 1 to 98. Let us visualize this index
text(ebsd,1:length(ebsd))
data:image/s3,"s3://crabby-images/feacd/feacd0ad81e0462faefe8472829f729884db086d" alt=""
We may easily select specific pixels by specifying their indices
hold on
plot(ebsd(16:18),'edgeColor','red','facecolor','none','linewidth',4)
legend off
hold off
data:image/s3,"s3://crabby-images/9e498/9e49847c2471e44778bcd66f4cbfce27ea175120" alt=""
Whether lines or columns run first is not related to MTEX but inherits from the ordering of the imported EBSD data. Since, we have restricted our large EBSD map to the small subset the indices of restricted data does not coincide with the indices of the imported data anymore. However, the original indices are still stored in ebsd.id
. Lets visualize those
plot(ebsd,ebsd.orientations,'micronbar','off','edgecolor','k')
text(ebsd,ebsd.id)
data:image/s3,"s3://crabby-images/c073f/c073fc700473b51f4b17855c2321d259c3c1bd18" alt=""
In order to select EBSD data according to their original id
use the option 'id'
, i.e.,
hold on
plot(ebsd('id',316:318),'edgeColor','red','facecolor','none','linewidth',4)
legend off
hold off
data:image/s3,"s3://crabby-images/9258f/9258f793bd9c461a0fa6ff9942269b6ec83903ec" alt=""
Square Grids
In the cases of gridded data it is often useful to convert them into a matrix form.
ebsd = ebsd.gridify;
plot(ebsd,ebsd.orientations,'micronbar','off')
[i,j] = ndgrid(1:size(ebsd,1),1:size(ebsd,2));
str = arrayfun(@(a,b) ['(' int2str(a) ',' int2str(b) ')'],i,j,'UniformOutput',false);
text(ebsd,str)
data:image/s3,"s3://crabby-images/153a1/153a1e3e847c3feb830119f7f64233119072ff74" alt=""
This allows to select EBSD data simply by their coordinates within the grid, e.g., by
hold on
plot(ebsd(2,2:4),'edgeColor','red','facecolor','none','linewidth',4)
legend off
hold off
data:image/s3,"s3://crabby-images/d582d/d582d8fd4b54520a285957becd27d537d7b18230" alt=""
Note that the gridify
command changes the order of measurements. They are now sorted such that rows runs first and columns second, as this is the default convention how Matlab indexes matrices.
plot(ebsd,ebsd.orientations,'micronbar','off')
text(ebsd,1:length(ebsd))
data:image/s3,"s3://crabby-images/75685/75685639c93e8cd328d21b9424a5769e3ea8cab6" alt=""
Hexagonal Grid
The command gridify
may also be applied to EBSD data measured on a hexagonal grid.
mtexdata titanium silent
ebsd = ebsd.gridify
ebsd = EBSDhex
Phase Orientations Mineral Color Symmetry Crystal reference frame
0 8100 (99%) Titanium (Alpha) LightSkyBlue 622 X||a, Y||b*, Z||c*
Properties: ci, grainid, iq, sem_signal, oldId
Scan unit : um
X x Y x Z : [0 1002] x [0 998] x [0 0]
Normal vector: (0,0,1)
Hex grid :97 x 84
This rearranges the measurements in a matrix form which can be indexed similarly as in the square case.
ebsd = ebsd(10:16,68:79);
Lets visualize the matrix coordinates for the hexagonal grid
plot(ebsd,ebsd.orientations,'edgeColor','k','micronbar','off')
axis off
[i,j] = ndgrid(1:size(ebsd,1),1:size(ebsd,2));
str = arrayfun(@(a,b) ['(' int2str(a) ',' int2str(b) ')'],i,j,'UniformOutput',false);
text(ebsd,str)
data:image/s3,"s3://crabby-images/ce14e/ce14e16075d74b7da0d87880657c8b13d78583d3" alt=""
Cube Coordinates
In hexagonal grids it is sometimes advantageous to use three digit cube coordinates to index the cell. This can be done using the commands hex2cube
and cube2hex
. Much more details on indexing hex grids can be found at here.
plot(ebsd,ebsd.orientations,'edgeColor','k','micronbar','off')
axis off
[i,j] = ndgrid(1:size(ebsd,1),1:size(ebsd,2));
[x,y,z] = ebsd.hex2cube(i,j);
str = arrayfun(@(a,b,c) ['(' int2str(a) ',' int2str(b) ',' int2str(c) ')'],x,y,z,'UniformOutput',false);
text(ebsd,str)
data:image/s3,"s3://crabby-images/1dfb4/1dfb418ae3c9a361489738c047faf3517a6da22b" alt=""