Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/parameterisations/channeling/include/G4ChannelingFastSimInterpolation.hh

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /parameterisations/channeling/include/G4ChannelingFastSimInterpolation.hh (Version 11.3.0) and /parameterisations/channeling/include/G4ChannelingFastSimInterpolation.hh (Version 11.2.2)


  1 //                                                  1 //
  2 // *******************************************      2 // ********************************************************************
  3 // * License and Disclaimer                         3 // * License and Disclaimer                                           *
  4 // *                                                4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of th      5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided      6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License      7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/      8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.           9 // * include a list of copyright holders.                             *
 10 // *                                               10 // *                                                                  *
 11 // * Neither the authors of this software syst     11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing fin     12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warran     13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assum     14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file      15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitatio     16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                               17 // *                                                                  *
 18 // * This  code  implementation is the result      18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboratio     19 // * technical work of the GEANT4 collaboration.                      *
 20 // * By using,  copying,  modifying or  distri     20 // * By using,  copying,  modifying or  distributing the software (or *
 21 // * any work based  on the software)  you  ag     21 // * any work based  on the software)  you  agree  to acknowledge its *
 22 // * use  in  resulting  scientific  publicati     22 // * use  in  resulting  scientific  publications,  and indicate your *
 23 // * acceptance of all terms of the Geant4 Sof     23 // * acceptance of all terms of the Geant4 Software license.          *
 24 // *******************************************     24 // ********************************************************************
 25 //                                                 25 //
 26 // Author:      Alexei Sytov                   << 
 27                                                    26 
 28 #ifndef G4ChannelingFastSimInterpolation_h         27 #ifndef G4ChannelingFastSimInterpolation_h
 29 #define G4ChannelingFastSimInterpolation_h         28 #define G4ChannelingFastSimInterpolation_h
 30                                                    29 
 31 #include "G4PhysicsVector.hh"                      30 #include "G4PhysicsVector.hh"
 32 #include "G4Physics2DVector.hh"                    31 #include "G4Physics2DVector.hh"
 33 #include "G4ThreeVector.hh"                        32 #include "G4ThreeVector.hh"
 34 #include "G4PhysicsLinearVector.hh"                33 #include "G4PhysicsLinearVector.hh"
 35                                                    34 
 36 /** \file G4ChannelingFastSimInterpolation.hh      35 /** \file G4ChannelingFastSimInterpolation.hh
 37 * \brief Definition of the G4ChannelingFastSim     36 * \brief Definition of the G4ChannelingFastSimInterpolation class
 38 * The class includes spline interpolation coef     37 * The class includes spline interpolation coefficients for the important functions
 39 * needed in Channeling FastSimulation model, i     38 * needed in Channeling FastSimulation model, i.e. electric fields, nuclear and
 40 * electron densities and minimum energy of ion     39 * electron densities and minimum energy of ionization. All the functions have
 41 * transverse coordinates as arguments (x for c     40 * transverse coordinates as arguments (x for crystal planes, x and y for crystal axes).
 42 * All the functions are calculated in the co-r     41 * All the functions are calculated in the co-rotating reference system (along crystal
 43 * planes/axes).                                    42 * planes/axes).
 44 */                                                 43 */
 45                                                    44 
 46 class G4ChannelingFastSimInterpolation {           45 class G4ChannelingFastSimInterpolation {
 47                                                    46 
 48 public:                                            47 public:
 49     G4ChannelingFastSimInterpolation(G4double      48     G4ChannelingFastSimInterpolation(G4double dx0,
 50                                    G4double dy     49                                    G4double dy0,
 51                                    G4int nPoin     50                                    G4int nPointsx0,
 52                                    G4int nPoin     51                                    G4int nPointsy0,
 53                                    G4int iMode     52                                    G4int iModel0);
 54     ~G4ChannelingFastSimInterpolation() = defa     53     ~G4ChannelingFastSimInterpolation() = default;
 55                                                    54 
 56     ///Get Spline Function                         55     ///Get Spline Function
 57     G4double GetIF(G4double xx, G4double yy);      56     G4double GetIF(G4double xx, G4double yy);
 58                                                    57 
 59     ///Set spline coefficients                     58     ///Set spline coefficients
 60     void SetCoefficients1D(G4double AI0,           59     void SetCoefficients1D(G4double AI0,
 61                            G4double BI0,           60                            G4double BI0,
 62                            G4double CI0,           61                            G4double CI0,
 63                            G4double DI0,           62                            G4double DI0,
 64                            G4int i);               63                            G4int i);
 65     void SetCoefficients2D(G4double AI3D0,         64     void SetCoefficients2D(G4double AI3D0,
 66                            G4double BI3D0,         65                            G4double BI3D0,
 67                            G4double CI3D0,         66                            G4double CI3D0,
 68                            G4int i,                67                            G4int i,
 69                            G4int j,                68                            G4int j,
 70                            G4int k);               69                            G4int k);
 71                                                    70 
 72 private:                                           71 private:
 73     G4double Spline1D(G4double xx);                72     G4double Spline1D(G4double xx);
 74     G4double Spline2D(G4double xx, G4double yy     73     G4double Spline2D(G4double xx, G4double yy);// cubic spline of 2-variable function
 75                                                    74 
 76     G4double fDx=0., fDy=0.; //channel width a     75     G4double fDx=0., fDy=0.; //channel width and height
 77     G4double fStepi=0., fStepj=0.; //interpola     76     G4double fStepi=0., fStepj=0.; //interpolation steps in x and y, respectively
 78     G4double fStepi2=0.; //=fStepi*fStepi          77     G4double fStepi2=0.; //=fStepi*fStepi
 79     G4int nPointsx=0, nPointsy=0; //number of      78     G4int nPointsx=0, nPointsy=0; //number of interpolation nodes in x and y, respectively
 80                                                    79 
 81     std::vector <G4double> fAI;                    80     std::vector <G4double> fAI;
 82     std::vector <G4double> fBI;                    81     std::vector <G4double> fBI;
 83     std::vector <G4double> fCI;                    82     std::vector <G4double> fCI;
 84     std::vector <G4double> fDI;                    83     std::vector <G4double> fDI;
 85                                                    84 
 86     std::vector<std::vector<G4double>> fAI3D;      85     std::vector<std::vector<G4double>> fAI3D;
 87     std::vector<std::vector<G4double>> fBI3D;      86     std::vector<std::vector<G4double>> fBI3D;
 88     std::vector<std::vector<G4double>> fCI3D;      87     std::vector<std::vector<G4double>> fCI3D;
 89     std::vector<std::vector<G4double>> fAI3D3;     88     std::vector<std::vector<G4double>> fAI3D3;
 90     std::vector<std::vector<G4double>> fBI3D3;     89     std::vector<std::vector<G4double>> fBI3D3;
 91     std::vector<std::vector<G4double>> fCI3D3;     90     std::vector<std::vector<G4double>> fCI3D3;
 92                                                    91 
 93     G4int iModel=1;                                92     G4int iModel=1;
 94                                                    93 
 95 };                                                 94 };
 96                                                    95 
 97 #endif                                             96 #endif
 98                                                    97