In this section we discuss how MTEX aligns coordinate systems on the screen and how to change it. In MTEX it is possible to mix different alignment. At the same time MTEX tries to be as consistent as possible, e.g. by aligning EBSD maps and pole figures with respect to the same reference directions.
Different alignments are typically used when
- displaying directions in crystal vs. specimen reference frame
- displaying orthogonal 2d EBSD sections
In MTEX each plottable variable has a property how2plot
v1 = vector3d(1,1,1);
v2 = vector3d(-1,1,1);
v1.how2plot
ans = plottingConvention
outOfScreen: (0,0,1)
north : (0,1,0)
east : (1,0,0)
The property how2plot
is a handle class of type plottingConvention
and tells MTEX how to align the corresponding coordinate system on screen.
plot(v1,'label','v_1','figSize','small')
annotate([xvector,yvector,zvector],'labeled','backgroundcolor','w')
data:image/s3,"s3://crabby-images/15946/15946705db53db9bb151c417ca0ffe932f891eeb" alt=""
We can change it by setting north
, east
or outOfScreen
to other directions.
v1.how2plot.outOfScreen = yvector
plot(v1,'label','v_1','figSize','small')
annotate([xvector,yvector,zvector],'labeled','backgroundcolor','w')
v1 = vector3d
x y z
1 1 1
data:image/s3,"s3://crabby-images/50b7d/50b7d888bfce95b86c75f0d7b22fbd450eac079e" alt=""
Note that plottingConvention
is a handle class, i.e. changing v1.how2plot
changes also v2.how2plot
v2.how2plot
plot(v2,'label','v_2','figSize','small')
annotate([xvector,yvector,zvector],'labeled','backgroundcolor','w')
ans = plottingConvention
outOfScreen: (0,1,0)
north : (0,0,-1)
east : (1,0,0)
data:image/s3,"s3://crabby-images/2c9c5/2c9c59db8e0427b77229c2fcf3e36420762f657d" alt=""
In order to have different plotting axes alignments within one MTEX session we have to define a new plottingConvention
by
% instantiate a new plotting convention and sets it up
pC2 = plottingConvention; pC2.north = yvector
% assign this plottingConvention to v2
v2.how2plot = pC2;
% plot v1 and v2 in separate plots
plot(v1,'upper','label','v_1')
annotate([xvector,yvector,zvector],'labeled','backgroundcolor','w')
nextAxis
plot(v2,'upper','label','v_2')
annotate([xvector,yvector,zvector],'labeled','backgroundcolor','w')
pC2 = plottingConvention
outOfScreen: (0,0,1)
north : (0,1,0)
east : (1,0,0)
data:image/s3,"s3://crabby-images/edfd4/edfd4b3110e456d7b1217c2cdc2c1e9f98c0ca0a" alt=""
When initiating a new vector3d
MTEX uses plottingConvention.default
as default plotting convention. This default plotting convention can be changed by
plotx2north
plotzOutOfPlane
plot([xvector,yvector,zvector],'upper','labeled','backgroundcolor','w')
data:image/s3,"s3://crabby-images/e6b42/e6b428b432cd65df09a8c47b39df7186b5cbf0c0" alt=""
When importing data those might be associated with a plotting convention that is different to the default one
mtexdata dubna
pf.how2plot
plot(pf{1:4})
pf = PoleFigure (xyz)
crystal symmetry : Quartz (321, X||a*, Y||b, Z||c*)
h = (02-21), r = 72 x 19 points
h = (10-10), r = 72 x 19 points
h = (10-11)(01-11), r = 72 x 19 points
h = (10-12), r = 72 x 19 points
h = (11-20), r = 72 x 19 points
h = (11-21), r = 72 x 19 points
h = (11-22), r = 72 x 19 points
ans = plottingConvention
outOfScreen: (0,0,1)
north : (0,1,0)
east : (1,0,0)
data:image/s3,"s3://crabby-images/5419e/5419e44ae76f0bed72a10ceda28ca0880df4f2bc" alt=""
Note that all quantities derived from those data will inherit the stored plotting convention
odf = calcODF(pf,'silent');
plotPDF(odf,pf.allH{1:4})
data:image/s3,"s3://crabby-images/2beb4/2beb412b9ba641d9ae3766b4f13928b44f1ba99d" alt=""
We may also set the default plotting convention to the plotting convention of the imported data by
pf.how2plot.makeDefault
plottingConvention.default
ans = plottingConvention
outOfScreen: (0,0,1)
north : (0,1,0)
east : (1,0,0)