Colorbars
Unlike the common MATLAB command colorbar
the MTEX command mtexColorbar allows you to add a colorbar to all subplots in a figure.
% this defines some model ODFs
cs = crystalSymmetry('-3m');
mod1 = orientation.byEuler(110*degree,30*degree,80*degree,cs);
mod2 = orientation.byEuler(310*degree,70*degree,40*degree,cs);
odf = 0.7*unimodalODF(mod1) + 0.3*unimodalODF(mod2);
% plot some pole figures
plotPDF(odf,Miller({1,0,0},{1,1,1},cs))
% and add a colorbar to each pole figure
mtexColorbar
data:image/s3,"s3://crabby-images/e2f2b/e2f2bb052c9da5d11bb3d0b8a4d04113c0a99808" alt=""
Executing the command mtexColorbar
twice deletes the colorbar. You can also have a horizontal colorbar at the bottom of the figure by setting the option location
to southOutside
. Further, we can set a title to the colorbar to describe the unit.
% delete vertical colorbar
mtexColorbar
% add horizontal colorbars
mtexColorbar('location','southOutSide','title','mrd')
data:image/s3,"s3://crabby-images/4bf2e/4bf2e3c092853fdecffccaacb0d8377d812b9dac" alt=""
If color range is set to equal in an MTEX figure only one colorbar is added (see. Color Coding).
mtexColorbar % delete colorbar
setColorRange('equal'); % set equal color range to all plots
mtexColorbar % create a new colorbar
data:image/s3,"s3://crabby-images/75a67/75a6736fae3929eeaf037823c1bbd4805dc9981c" alt=""
Annotating Directions, Orientations, Fibers
Pole figures or inverse pole figures are much better readable if they include specimen or crystal directions. Using the MTEX command annotate one can easily add specimen coordinate axes to a pole figure plot.
annotate(vector3d(1,1,1),'label',{'(111)'},'BackgroundColor','w')
data:image/s3,"s3://crabby-images/f053e/f053e8a33e827157705f8efdc0ace448da9ae3fb" alt=""
The command annotate allows also to mark crystal directions in inverse pole figures.
plotIPDF(odf,[xvector,zvector],'antipodal','marginx',10)
mtexColorMap white2black
annotate(Miller({2,-1,-1,0},{2,-1,-1,1},cs), ...
'all','labeled','BackgroundColor','yellow')
data:image/s3,"s3://crabby-images/adeff/adeff3e4a3e8dd9fadbc95f60e9e688dafa01b79" alt=""
One can also mark specific orientations in pole figures or in inverse pole figures.
plotIPDF(odf,[xvector,zvector],'antipodal')
mtexColorMap white2black
annotate(mod1,...
'marker','s','MarkerSize',6,'MarkerFaceColor','r',...
'label','A','color','w')
annotate(mod2,...
'marker','s','MarkerSize',6,'MarkerFaceColor','g',...
'label','B')
drawNow(gcm,'figSize','normal')
data:image/s3,"s3://crabby-images/23c08/23c08613188c87b2b2beeaea2ec736d6d2230bda" alt=""
as well as in ODF plots
plot(odf,'sigma')
mtexColorMap white2black
annotate(mod1,'label','A','textColor','r',...
'MarkerSize',15,'MarkerEdgeColor','r','MarkerFaceColor','none')
annotate(mod2,'label','B','textColor','b',...
'MarkerSize',15,'MarkerEdgeColor','b','MarkerFaceColor','none')
data:image/s3,"s3://crabby-images/ec046/ec046295ebeaac70058cff00112a547818ea39c6" alt=""
or orientation scatter plots
ori = odf.discreteSample(200);
scatter(ori);
annotate(mod1,...
'MarkerSize',10,'MarkerEdgeColor','r','MarkerFaceColor','r')
annotate(mod2,...
'MarkerSize',10,'MarkerEdgeColor','g','MarkerFaceColor','g')
data:image/s3,"s3://crabby-images/bfa54/bfa54999546b3c20ccdb74496647ed53b17406d7" alt=""
Legends
If you have multiple data in one plot then it makes sense to add a legend saying which color / symbol correspond to which data set. The key is to use the option DisplayName available for all plotting commands to include the resulting graphical object into the legend and give it a name.
plotPDF(odf,Miller({1,0,0},{1,1,1},cs))
plot(ori,'MarkerFaceColor','k','MarkerEdgeColor','black','add2all',...
'DisplayName','randomSample')
f = fibre(Miller({1,1,-2,1},cs),vector3d.Y);
plot(f,'color','red','linewidth',2,'add2all','DisplayName','fibre')
legend show
data:image/s3,"s3://crabby-images/c66fc/c66fca990cda16886abeea84440c3a669b09181b" alt=""
The following example compares the Fourier coefficients of the fibre ODF with the Fourier coefficients of an unimodal ODF.
close all
plotSpektra(FourierODF(odf,32),'DisplayName','Unimodal ODF')
hold on
fodf = fibreODF(Miller(1,0,0,cs),zvector);
plotSpektra(FourierODF(fodf,32),'DisplayName','Fibre ODF');
hold off
legend show
data:image/s3,"s3://crabby-images/0bfe8/0bfe87ed547bb2549d14b034c5408a519856aaed" alt=""
Adding a Spherical Grid
Sometimes it is useful to have a spherical grid in your plot to make the projection easier to understand or if you need to know some angular relationships. For this reason, there is the option grid, which enables the grid and the option grid_res, which allows to specify the spacing of the grid lines.
plotPDF(odf,[Miller(1,0,0,cs),Miller(0,0,1,cs)],'grid','grid_res',15*degree,'antipodal');
mtexColorMap white2black
data:image/s3,"s3://crabby-images/e286b/e286b6bd3a8a2c58fc2f56395ae14112884f3d10" alt=""