Simulate a set of pole figures for the SantaFe standard ODF, estimate an ODF and compare it to the inital SantaFe ODF.
Simulate pole figures
CS = crystalSymmetry('m-3m');
% crystal directions
h = [Miller(1,0,0,CS),Miller(1,1,0,CS),Miller(1,1,1,CS),Miller(2,1,1,CS)];
% specimen directions
r = equispacedS2Grid('resolution',5*degree,'antipodal');
% pole figures
pf = calcPoleFigure(SantaFe,h,r);
% add some noise
pf = noisepf(pf,100);
% plot them
plot(pf,'MarkerSize',5)
mtexColorMap LaboTeX
data:image/s3,"s3://crabby-images/e7090/e7090f87030091e3a7829d9ab556a78fa9f02ce7" alt=""
ODF Estimation with Ghost Correction
rec = calcODF(pf)
rec = SO3FunRBF (m-3m → xyz (222))
uniform component
weight: 0.59
multimodal components
kernel: de la Vallee Poussin, halfwidth 5°
center: 1232 orientations, resolution: 5°
weight: 0.41
ODF Estimation without Ghost Correction
rec2 = calcODF(pf,'NoGhostCorrection')
rec2 = SO3FunRBF (m-3m → xyz (222))
multimodal components
kernel: de la Vallee Poussin, halfwidth 5°
center: 1232 orientations, resolution: 5°
weight: 1
Error analysis
% calculate RP error
calcError(rec,SantaFe)
% difference plot between meassured and recalculated pole figures
plotDiff(pf,rec)
ans =
0.0446
data:image/s3,"s3://crabby-images/7cf1b/7cf1b3f78696df1ac2a8f267803b0b0c64f29f3e" alt=""
Plot estimated pole figures
plotPDF(rec,pf.h,'antipodal')
data:image/s3,"s3://crabby-images/8325a/8325a9eceff05b58a66e911a7362dd8c4be39f5d" alt=""
Plot estimated ODF (Ghost Corrected)
plot(rec,'sections',18,'resolution',5*degree,...
'contourf','FontSize',10,'silent','figSize','large','minmax')
mtexColorMap white2black
data:image/s3,"s3://crabby-images/8d4e4/8d4e4f32e213eb3e1dcb250dbd2a74450d579493" alt=""
Plot odf
plot(SantaFe,'sections',18,'contourf','FontSize',10,'silent',...
'figSize','large','minmax')
mtexColorMap white2black
data:image/s3,"s3://crabby-images/ade25/ade25b0db3a408553a57753b3e1efda42e149c4f" alt=""
Plot Fourier Coefficients
close all;
% true ODF
plotSpektra(SantaFe,'bandwidth',32,'linewidth',2)
% keep plot for adding the next plots
hold all
% With ghost correction:
plotSpektra(rec,'bandwidth',32,'linewidth',2)
% Without ghost correction:
plotSpektra(rec2,'bandwidth',32,'linewidth',2)
legend({'true ODF','with ghost correction','without ghost correction'})
% next plot command overwrites plot
hold off
data:image/s3,"s3://crabby-images/bb742/bb742b2e3c129a8ac38c61eca705e1adbd819b54" alt=""