Geant4  10.03.p01
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4PhysicsLogVector Class Reference

#include <G4PhysicsLogVector.hh>

Inheritance diagram for G4PhysicsLogVector:
Collaboration diagram for G4PhysicsLogVector:

Public Member Functions

 G4PhysicsLogVector ()
 
 G4PhysicsLogVector (G4double theEmin, G4double theEmax, size_t theNbin)
 
virtual ~G4PhysicsLogVector ()
 
virtual G4bool Retrieve (std::ifstream &fIn, G4bool ascii) final
 
virtual void ScaleVector (G4double factorE, G4double factorV) final
 
- Public Member Functions inherited from G4PhysicsVector
 G4PhysicsVector (G4bool spline=false)
 
 G4PhysicsVector (const G4PhysicsVector &)
 
G4PhysicsVectoroperator= (const G4PhysicsVector &)
 
virtual ~G4PhysicsVector ()
 
G4double Value (G4double theEnergy, size_t &lastidx) const
 
G4double Value (G4double theEnergy) const
 
G4double GetValue (G4double theEnergy, G4bool &isOutRange) const
 
G4int operator== (const G4PhysicsVector &right) const
 
G4int operator!= (const G4PhysicsVector &right) const
 
G4double operator[] (const size_t index) const
 
G4double operator() (const size_t index) const
 
void PutValue (size_t index, G4double theValue)
 
G4double Energy (size_t index) const
 
G4double GetMaxEnergy () const
 
G4double GetLowEdgeEnergy (size_t binNumber) const
 
size_t GetVectorLength () const
 
size_t FindBin (G4double energy, size_t idx) const
 
void FillSecondDerivatives ()
 
void ComputeSecDerivatives ()
 
void ComputeSecondDerivatives (G4double firstPointDerivative, G4double endPointDerivative)
 
G4double FindLinearEnergy (G4double rand) const
 
G4bool IsFilledVectorExist () const
 
G4PhysicsVectorType GetType () const
 
void SetSpline (G4bool)
 
G4bool Store (std::ofstream &fOut, G4bool ascii=false) const
 
void DumpValues (G4double unitE=1.0, G4double unitV=1.0) const
 
void SetVerboseLevel (G4int value)
 

Additional Inherited Members

- Protected Member Functions inherited from G4PhysicsVector
void DeleteData ()
 
void CopyData (const G4PhysicsVector &vec)
 
void PrintPutValueError (size_t index)
 
- Protected Attributes inherited from G4PhysicsVector
G4PhysicsVectorType type
 
G4double edgeMin
 
G4double edgeMax
 
size_t numberOfNodes
 
G4PVDataVector dataVector
 
G4PVDataVector binVector
 
G4PVDataVector secDerivative
 
G4double dBin
 
G4double baseBin
 
G4int verboseLevel
 

Detailed Description

Definition at line 60 of file G4PhysicsLogVector.hh.

Constructor & Destructor Documentation

G4PhysicsLogVector::G4PhysicsLogVector ( )

Definition at line 51 of file G4PhysicsLogVector.cc.

52  : G4PhysicsVector()
53 {
55 }
G4PhysicsVector(G4bool spline=false)
G4PhysicsVectorType type
G4PhysicsLogVector::G4PhysicsLogVector ( G4double  theEmin,
G4double  theEmax,
size_t  theNbin 
)

Definition at line 57 of file G4PhysicsLogVector.cc.

59  : G4PhysicsVector()
60 {
62 
63  dBin = G4Log(theEmax/theEmin)/(G4double)theNbin;
64  baseBin = G4Log(theEmin)/dBin;
65 
66  numberOfNodes = theNbin + 1;
67  dataVector.reserve(numberOfNodes);
68  binVector.reserve(numberOfNodes);
69 
70  binVector.push_back(theEmin);
71  dataVector.push_back(0.0);
72 
73  for (size_t i=1; i<numberOfNodes-1; ++i)
74  {
75  binVector.push_back(G4Exp((baseBin+i)*dBin));
76  dataVector.push_back(0.0);
77  }
78  binVector.push_back(theEmax);
79  dataVector.push_back(0.0);
80 
81  edgeMin = binVector[0];
82  edgeMax = binVector[numberOfNodes-1];
83 }
G4PVDataVector dataVector
G4PhysicsVector(G4bool spline=false)
G4PVDataVector binVector
G4PhysicsVectorType type
G4double G4Log(G4double x)
Definition: G4Log.hh:230
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
Definition: G4Exp.hh:183
double G4double
Definition: G4Types.hh:76

Here is the call graph for this function:

G4PhysicsLogVector::~G4PhysicsLogVector ( )
virtual

Definition at line 85 of file G4PhysicsLogVector.cc.

86 {}

Member Function Documentation

G4bool G4PhysicsLogVector::Retrieve ( std::ifstream &  fIn,
G4bool  ascii 
)
finalvirtual

Reimplemented from G4PhysicsVector.

Definition at line 88 of file G4PhysicsLogVector.cc.

89 {
90  G4bool success = G4PhysicsVector::Retrieve(fIn, ascii);
91  if (success)
92  {
95  }
96  return success;
97 }
G4PVDataVector binVector
bool G4bool
Definition: G4Types.hh:79
G4double G4Log(G4double x)
Definition: G4Log.hh:230
virtual G4bool Retrieve(std::ifstream &fIn, G4bool ascii=false)

Here is the call graph for this function:

void G4PhysicsLogVector::ScaleVector ( G4double  factorE,
G4double  factorV 
)
finalvirtual

Reimplemented from G4PhysicsVector.

Definition at line 99 of file G4PhysicsLogVector.cc.

100 {
101  G4PhysicsVector::ScaleVector(factorE, factorV);
102  dBin = G4Log(binVector[1]/edgeMin);
104 }
G4PVDataVector binVector
virtual void ScaleVector(G4double factorE, G4double factorV)
G4double G4Log(G4double x)
Definition: G4Log.hh:230

Here is the call graph for this function:


The documentation for this class was generated from the following files: