45theSpaceGroup(spacegroup),
59 cosa=std::cos(alpha), cosb=std::cos(beta), cosg=std::cos(gamma);
60 sina=std::sin(alpha), sinb=std::sin(beta), sing=std::sin(gamma);
62 cosar = (cosb*cosg-cosa)/(sinb*sing);
63 cosbr = (cosa*cosg-cosb)/(sina*sing);
64 cosgr = (cosa*cosb-cosg)/(sina*sinb);
67 theRecVolume = 1. / theVolume;
69 theRecSize[0] = sizeB * sizeC * sina / theVolume;
70 theRecSize[1] = sizeC * sizeA * sinb / theVolume;
71 theRecSize[2] = sizeA * sizeB * sing / theVolume;
92 x3=cosa, y3=(cosb-cosa*cosg)/sing, z3=std::sqrt(1.-x3*x3-y3*y3);
102 x3=cosa, y3=(cosb-cosa*cosg)/sing, z3=std::sqrt(1.-x3*x3-y3*y3);
151 if( aGroup >= 1 && aGroup <= 2 ) {
return Triclinic;}
152 else if(aGroup >= 3 && aGroup <= 15 ) {
return Monoclinic;}
153 else if(aGroup >= 16 && aGroup <= 74 ) {
return Orthorhombic;}
154 else if(aGroup >= 75 && aGroup <= 142) {
return Tetragonal;}
155 else if(aGroup == 146 || aGroup == 148 ||
156 aGroup == 155 || aGroup == 160 ||
157 aGroup == 161 || aGroup == 166 ||
159 else if(aGroup >= 143 && aGroup <= 167) {
return Hexagonal;}
160 else if(aGroup >= 168 && aGroup <= 194) {
return Hexagonal;}
161 else if(aGroup >= 195 && aGroup <= 230) {
return Cubic;}
201 G4double x3=cosa, y3=(cosb-cosa*cosg)/sing, z3=std::sqrt(1.-x3*x3-y3*y3);
210 vecout.push_back(aaa);
211 vecout.emplace_back(2., 5., 3.);
219 for(
auto &vec:vecout){
232 return FillAmorphous(Cij);
235 return FillCubic(Cij);
238 return FillTetragonal(Cij);
241 return FillOrthorhombic(Cij);
244 return FillRhombohedral(Cij);
247 return FillMonoclinic(Cij);
250 return FillTriclinic(Cij);
253 return FillHexagonal(Cij);
264G4bool G4CrystalUnitCell::FillAmorphous(
G4double Cij[6][6])
const {
265 Cij[3][3] = 0.5*(Cij[0][0]-Cij[0][1]);
272 G4double C11=Cij[0][0], C12=Cij[0][1], C44=Cij[3][3];
274 for (
size_t i=0; i<6; i++) {
275 for (
size_t j=i; j<6; j++) {
278 Cij[i][j] = (i == j) ? C11 : C12;
280 else if(i == j && i >= 3)
291 ReflectElReduced(Cij);
293 return (C11!=0. && C12!=0. && C44!=0.);
298G4bool G4CrystalUnitCell::FillTetragonal(
G4double Cij[6][6])
const {
299 G4double C11=Cij[0][0], C12=Cij[0][1], C13=Cij[0][2], C16=Cij[0][5];
300 G4double C33=Cij[2][2], C44=Cij[3][3], C66=Cij[5][5];
307 ReflectElReduced(Cij);
310 return (C11!=0. && C12!=0. && C13!=0. && C33!=0. && C44!=0. && C66!=0.);
315G4bool G4CrystalUnitCell::FillOrthorhombic(
G4double Cij[6][6])
const {
317 ReflectElReduced(Cij);
320 for (
size_t i=0; i<6; i++) {
321 for(
size_t j = i + 1; j < 3; j++)
323 good &= (Cij[i][j] != 0);
332G4bool G4CrystalUnitCell::FillRhombohedral(
G4double Cij[6][6])
const {
333 G4double C11=Cij[0][0], C12=Cij[0][1], C13=Cij[0][2], C14=Cij[0][3];
334 G4double C15=Cij[0][4], C33=Cij[2][2], C44=Cij[3][3], C66=0.5*(C11-C12);
345 return (C11!=0 && C12!=0 && C13!=0 && C14!=0. &&
346 C33!=0. && C44!=0. && C66!=0.);
351G4bool G4CrystalUnitCell::FillMonoclinic(
G4double Cij[6][6])
const {
355 return (FillOrthorhombic(Cij) && Cij[0][5]!=0. && Cij[1][5]!=0. &&
356 Cij[2][5] != 0. && Cij[3][4]!=0.);
361G4bool G4CrystalUnitCell::FillTriclinic(
G4double Cij[6][6])
const {
364 ReflectElReduced(Cij);
367 for (
size_t i=0; i<6; i++) {
368 for(
size_t j = i; j < 6; j++)
370 good &= (Cij[i][j] != 0);
380G4bool G4CrystalUnitCell::FillHexagonal(
G4double Cij[6][6])
const {
382 Cij[4][5] = 0.5*(Cij[0][0] - Cij[0][1]);
389G4bool G4CrystalUnitCell::ReflectElReduced(
G4double Cij[6][6])
const {
390 for (
size_t i=1; i<6; i++) {
391 for (
size_t j=i+1; j<6; j++) {
392 Cij[j][i] = Cij[i][j];
418 return a*a*a*std::sqrt(1.-3.*cosa*cosa+2.*cosa*cosa*cosa);
424 return a*b*c*std::sqrt(1.-cosa*cosa-cosb*cosb-cosg*cosg*2.*cosa*cosb*cosg);
427 return std::sqrt(3.0)/2.*a*a*c;
460 G4double a2 = a*a, b2 = b*b, c2 = c*c;
461 G4double h2 = h*h, k2 = k*k, l2 = l*l;
472 return a2 / ( h2+k2+l2 );
475 return 1.0 / ( (h2 + k2)/a2 + l2/c2 );
478 return 1.0 / ( h2/a2 + k2/b2 + l2/c2 );
481 cos2a=cosa*cosa; sin2a=sina*sina;
482 T = h2+k2+l2+2.*(h*k+k*l+h*l) * ((cos2a-cosa)/sin2a);
483 R = sin2a / (1. - 3*cos2a + 2.*cos2a*cosa);
488 return 1./(1./sin2b * (h2/a2+l2/c2-2*h*l*cosb/(a*c)) + k2/b2);
494 return 1. / ( (4.*(h2+k2+h*k) / (3.*a2)) + l2/c2 );
526 G4double a2 = a*a, b2 = b*b, c2 = c*c;
527 G4double h2 = h*h, k2 = k*k, l2 = l*l;
535 return a2 * (h2+k2+l2);
538 return (h2+k2)*a2 + l2*c2 ;
541 return h2*a2 + k2+b2 + h2*c2;
544 return (h2+k2+l2+2.*(h*k+k*l+h*l) * cosar)*a2;
547 return h2*a2+k2*b2+l2*c2+2.*h*l*a*c*cosbr;
550 return h2*a2+k2*b2+l2*c2+2.*k*l*b*c*cosar+2.*l*h*c*a*cosbr+2.*h*k*a*b*cosgr;
553 return (h2+k2+h*k)*a2 + l2*c2;
587 G4double a2 = a*a, b2 = b*b, c2 = c*c;
595 return (h1*h2 + k1*k2 + l1+l2) / (std::sqrt(h1*h1 + k1*k1 + l1*l1) * std::sqrt(h2*h2 + k2*k2 + l2*l2));
603 return dsp1dsp2 * (h1*h2*a2 + k1*k2*a2 + l1*l2*c2);
607 return dsp1dsp2 * (h1*h2*a2 + k1*k2*b2 + l1*l2*c2+
608 (k1*l2+k2*l1)*b*c*cosar+
609 (h1*l2+h2*l1)*a*c*cosbr+
610 (h1*k2+h2*k1)*a*b*cosgr);
614 return dsp1dsp2 * (h1*h2*a2 + k1*k2*b2 + l1*l2*c2+
615 (k1*l2+k2*l1)*b*c*cosar+
616 (h1*l2+h2*l1)*a*c*cosbr+
617 (h1*k2+h2*k1)*a*b*cosgr);
621 return dsp1dsp2 * (h1*h2*a2 + k1*k2*b2 + l1*l2*c2+
622 (k1*l2+k2*l1)*b*c*cosar+
623 (h1*l2+h2*l1)*a*c*cosbr+
624 (h1*k2+h2*k1)*a*b*cosgr);
628 return dsp1dsp2 *( (h1*h2 + k1*k2 + 0.5*(h1*k2+k1*h2))*a2 + l1*l2*c2);
CLHEP::Hep3Vector G4ThreeVector
Hep3Vector & rotateX(double)
Hep3Vector & rotateZ(double)
G4ThreeVector theBasis[3]
const G4ThreeVector & GetRecUnitBasis(G4int idx) const
G4ThreeVector GetUnitBasisTrigonal()
const G4ThreeVector & GetRecBasis(G4int idx) const
G4double GetIntSp2(G4int h, G4int k, G4int l)
G4bool FillElReduced(G4double Cij[6][6])
G4CrystalUnitCell(G4double sizeA, G4double sizeB, G4double sizeC, G4double alpha, G4double beta, G4double gamma, G4int spacegroup)
G4bool FillAtomicPos(G4ThreeVector &pos, std::vector< G4ThreeVector > &vecout)
const G4ThreeVector & GetUnitBasis(G4int idx) const
G4ThreeVector theRecUnitBasis[3]
G4double GetRecIntSp2(G4int h, G4int k, G4int l)
G4ThreeVector theRecBasis[3]
G4bool FillAtomicUnitPos(G4ThreeVector &pos, std::vector< G4ThreeVector > &vecout)
G4ThreeVector theUnitBasis[3]
virtual ~G4CrystalUnitCell()
G4double ComputeCellVolume()
G4ThreeVector theRecAngle
theLatticeSystemType GetLatticeSystem()
const G4ThreeVector & GetBasis(G4int idx) const
G4double GetIntCosAng(G4int h1, G4int k1, G4int l1, G4int h2, G4int k2, G4int l2)
DLL_API const Hep3Vector HepZHat
DLL_API const Hep3Vector HepXHat
DLL_API const Hep3Vector HepYHat