Theory
The Bingham distribution has the density function
\[ f(g;K,U) = _1\!F_1 \left(\frac{1}{2},2,K \right)^{-1} \exp \left\{ g^T UKU g \right\},\qquad g\in S^3, \]
where \(U\) is an \(4 \times 4\) orthogonal matrix with unit quaternions \(u_{1,..,4}\in S^3\) in the columns and \(K\) is a \(4 \times 4\) diagonal matrix with the entries \(k_1,..,k_4\) describing the shape of the distribution. \(_1F_1(\cdot,\cdot,\cdot)\) is the hypergeometric function with matrix argument normalizing the density.
The shape parameters \(k_1 \ge k_2 \ge k_3 \ge k_4\) give
- a bipolar distribution, if \(k_1 + k_4 > k_2 + k_3\),
- a circular distribution, if \(k_1 + k_4 = k_2 + k_3\),
- a spherical distribution, if \(k_1 + k_4 < k_2 + k_3\),
- a uniform distribution, if \(k_1 = k_2 = k_3 = k_4\),
The general setup of the Bingham distribution in MTEX is done as follows
cs = crystalSymmetry('1');
kappa = [100 90 80 0]; % shape parameters
U = eye(4); % orthogonal matrix
odf = BinghamODF(kappa,U,cs)
odf = SO3FunBingham (1 → xyz)
kappa: 100 90 80 0
weight: 1
Lets visualize the ODF as pole figures
h = [Miller(0,0,1,cs) Miller(1,0,0,cs) Miller(1,1,1,cs)];
plotzOutOfPlane
plotPDF(odf,h,'antipodal','silent','layout',[1 3]);
data:image/s3,"s3://crabby-images/82aa2/82aa26f003e46cf2042f7c4935f5670ae0a7170e" alt=""
plot(odf,'sections',6)
data:image/s3,"s3://crabby-images/b3934/b3934a4c008b3553e99c14d270f4b227186a76e6" alt=""
The bipolar case and unimodal distribution
First, we define some unimodal odf
odf_spherical = unimodalODF(orientation.rand(cs),'halfwidth',20*degree)
odf_spherical = SO3FunRBF (1 → xyz)
unimodal component
kernel: de la Vallee Poussin, halfwidth 20°
center: 1 orientations
Bunge Euler angles in degree
phi1 Phi phi2 weight
156.958 161.468 197.878 1
plotPDF(odf_spherical,h,'antipodal','silent')
data:image/s3,"s3://crabby-images/fb6c6/fb6c643c30411e7f52f9b45685e7880ba9c757ea" alt=""
Next, we simulate individual orientations from this odf, in a scattered axis/angle plot in which the simulated data looks like a sphere
ori_spherical = discreteSample(odf_spherical,1000);
close all
scatter(ori_spherical)
data:image/s3,"s3://crabby-images/50675/50675ef683b4850443cf59775800e93706bb5b19" alt=""
From this simulated EBSD data, we can estimate the parameters of the Bingham distribution,
odf_est = calcBinghamODF(ori_spherical)
plotPDF(odf_est,h,'antipodal','silent')
odf_est = SO3FunBingham (1 → xyz)
kappa: 0 1.9 3 25
weight: 1
data:image/s3,"s3://crabby-images/babe3/babe347e4b09bf58965b139fee0bf3aa4dd3699d" alt=""
TODO
where U
is the orthogonal matrix of eigenvectors of the orientation tensor and kappa
the shape parameters associated with the U
.
next, we test the different cases of the distribution on rejection
%T_spherical = bingham_test(ori_spherical,'spherical','approximated');
%T_oblate = bingham_test(ori_spherical,'prolate', 'approximated');
%T_prolate = bingham_test(ori_spherical,'oblate', 'approximated');
%t = [T_spherical T_oblate T_prolate]
The spherical test case failed to reject for some level of significance, hence we would dismiss the hypothesis prolate and oblate.
%df_spherical = BinghamODF(kappa,U,crystalSymmetry,specimenSymmetry)
%plotPDF(odf_spherical,h,'antipodal','silent')
Prolate case and fiber distribution
The prolate case corresponds to a fiber.
odf_prolate = fibreODF(Miller(0,0,1,crystalSymmetry('1')),zvector,...
'halfwidth',20*degree)
odf_prolate = SO3FunCBF (1 → xyz)
kernel: de la Vallee Poussin, halfwidth 20°
fibre : (001) || 0,0,1
weight: 1
plotPDF(odf_prolate,h,'upper','silent')
data:image/s3,"s3://crabby-images/2bd93/2bd933ec94f4bd00c5db1b30d1174f62f4bb26c3" alt=""
As before, we generate some random orientations from a model odf. The shape in an axis/angle scatter plot reminds of a cigar
ori_prolate = discreteSample(odf_prolate,1000);
close all
scatter(ori_prolate)
data:image/s3,"s3://crabby-images/5d898/5d89876b1c016c5ebc80608a2f940f76f870d2f1" alt=""
We estimate the parameters of the Bingham distribution
calcBinghamODF(ori_prolate)
ans = SO3FunBingham (1 → xyz)
kappa: 0 4.5 47 49
weight: 1
and test on the three cases
%T_spherical = bingham_test(ori_prolate,'spherical','approximated');
%T_oblate = bingham_test(ori_prolate,'prolate', 'approximated');
%T_prolate = bingham_test(ori_prolate,'oblate', 'approximated');
%t = [T_spherical T_oblate T_prolate]
The test clearly rejects the spherical and prolate case, but not the prolate. We construct the Bingham distribution from the parameters, it might show some skewness
odf_prolate = BinghamODF(kappa,U,crystalSymmetry,specimenSymmetry)
odf_prolate = SO3FunBingham (1 → xyz)
kappa: 100 90 80 0
weight: 1
plotPDF(odf_prolate,h,'antipodal','silent')
data:image/s3,"s3://crabby-images/5c5a4/5c5a412deb56e27746958c827f7764ac4f0d2f2d" alt=""
Oblate case
The oblate case of the Bingham distribution has no direct counterpart in terms of texture components, thus we can construct it straightforward
odf_oblate = BinghamODF([50 50 50 0],eye(4),crystalSymmetry,specimenSymmetry)
odf_oblate = SO3FunBingham (1 → xyz)
kappa: 50 50 50 0
weight: 1
plotPDF(odf_oblate,h,'antipodal','silent')
data:image/s3,"s3://crabby-images/4c2ef/4c2effb3e8bfac7b674540e11cc92e081153e046" alt=""
The oblate cases in axis/angle space remind on a disk
ori_oblate = discreteSample(odf_oblate,1000);
close all
scatter(ori_oblate)
data:image/s3,"s3://crabby-images/c2f07/c2f076d56ed0ac53597219d31e67ff5f2ac5eedc" alt=""
We estimate the parameters again
calcBinghamODF(ori_oblate)
ans = SO3FunBingham (1 → xyz)
kappa: 0 45 46 47
weight: 1
and do the tests
%T_spherical = bingham_test(ori_oblate,'spherical','approximated');
%T_oblate = bingham_test(ori_oblate,'prolate', 'approximated');
%T_prolate = bingham_test(ori_oblate,'oblate', 'approximated');
%t = [T_spherical T_oblate T_prolate]
the spherical and oblate case are clearly rejected, the prolate case failed to reject for some level of significance
odf_oblate = BinghamODF(kappa, U,crystalSymmetry,specimenSymmetry)
odf_oblate = SO3FunBingham (1 → xyz)
kappa: 100 90 80 0
weight: 1
plotPDF(odf_oblate,h,'antipodal','silent')
data:image/s3,"s3://crabby-images/006e6/006e61d061a1fea0c02f256c3d32835b01925e86" alt=""
Bingham unimodal ODF
% a modal orientation
cs = crystalSymmetry('-3m');
mod = orientation.byEuler(45*degree,0*degree,0*degree,cs);
% the corresponding Bingham ODF
odf = BinghamODF(20,mod)
plot(odf,'sections',6,'silent','contourf','sigma')
odf = SO3FunBingham (-3m1 → xyz)
kappa: 20 0 0 0
weight: 1
data:image/s3,"s3://crabby-images/161c7/161c7a4416eabcfda9e5b7f271f4df9227b66ef9" alt=""
Bingham fibre ODF
odf = BinghamODF([-10,-10,10,10],quaternion(eye(4)),cs)
plot(odf,'sections',6,'silent','sigma')
odf = SO3FunBingham (-3m1 → xyz)
kappa: -10 -10 10 10
weight: 1
data:image/s3,"s3://crabby-images/3fb2b/3fb2bd13f7de8c7852ea540831afd658094f538d" alt=""
Bingham spherical ODF
odf = BinghamODF([-10,10,10,10],quaternion(eye(4)),cs)
plot(odf,'sections',6,'silent','sigma');
odf = SO3FunBingham (-3m1 → xyz)
kappa: -10 10 10 10
weight: 1
data:image/s3,"s3://crabby-images/6840a/6840a6692a9eff039d25446dcc2458df0d08fcf4" alt=""