KaliVeda
1.12/06
Heavy-Ion Analysis Toolkit
|
C++ implementation of VEDALOSS stopping power calculation.
See documentation here.
Normally all range, \(dE\), \(E_{res}\) functions are limited to range \(0\leq E\leq E_{max}\), where \(E_{max}\) is nominal maximum energy for which range tables are valid (usually 400MeV/u for \(Z<3\), 250MeV/u for \(Z>3\)).
If higher energies are required, call static method KVedaLoss::SetIgnoreEnergyLimits() BEFORE ANY MATERIALS ARE CREATED in order to recalculate the \(E_{max}\) limits in such a way that:
Then, at the most, the new limit will be 1 GeV/nucleon, or at the least, it will remain at the nominal (400 or 250 MeV/nucleon) level.
Definition at line 33 of file KVedaLoss.h.
Public Member Functions | |
KVedaLoss () | |
Default constructor. More... | |
virtual | ~KVedaLoss () |
Destructor. More... | |
KVIonRangeTableMaterial * | AddCompoundMaterial (const Char_t *, const Char_t *, Int_t, Int_t *, Int_t *, Int_t *, Double_t=-1.0) const |
Use the RANGE tables to generate a new compound material. More... | |
KVIonRangeTableMaterial * | AddElementalMaterial (Int_t Z, Int_t A=0) const |
KVIonRangeTableMaterial * | AddMixedMaterial (const Char_t *, const Char_t *, Int_t, Int_t *, Int_t *, Int_t *, Double_t *, Double_t=-1.0) const |
Use the RANGE tables to generate a new mixed material. More... | |
Bool_t | AddRANGEMaterial (const Char_t *name) const |
If the given material is defined in the RANGE tables, import it into VEDALOSS. More... | |
Bool_t | CheckIon (Int_t Z, Int_t A) const |
TObjArray * | GetListOfMaterials () |
void | Print (Option_t *="") const |
Bool_t | ReadMaterials (const Char_t *path) const |
Read and add range tables for materials in file. More... | |
![]() | |
KVIonRangeTable (const Char_t *name="", const Char_t *title="") | |
Default constructor. More... | |
virtual | ~KVIonRangeTable () |
Destructor. More... | |
virtual Double_t | GetAtomicMass (const Char_t *) |
Returns atomic mass of a material in the range tables. More... | |
virtual Double_t | GetDeltaEFromEResOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t ERes, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t E, Double_t r, Double_t Amat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetDensity (const Char_t *) |
Returns density (g/cm**3) of a material in the range tables. More... | |
virtual Double_t | GetEIncFromDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t DeltaE, Double_t e, enum SolType type=kEmax, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetEIncFromEResOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t Eres, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetEIncOfMaxDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetEmaxValid (const Char_t *material, Int_t Z, Int_t A) |
virtual Double_t | GetEResOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t E, Double_t r, Double_t Amat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearDeltaEFromEResOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t ERes, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t E, Double_t d, Double_t Amat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearEIncFromDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t DeltaE, Double_t e, enum SolType type=kEmax, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearEIncFromEResOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t Eres, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearEIncOfMaxDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearEResOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t E, Double_t d, Double_t Amat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearMaxDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearPunchThroughEnergy (const Char_t *mat, Int_t Z, Int_t A, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetLinearRangeOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t E, Double_t Amat=0., Double_t T=-1., Double_t P=-1.) |
KVIonRangeTableMaterial * | GetMaterial (const Char_t *material) const |
Returns pointer to material of given name or type. More... | |
KVIonRangeTableMaterial * | GetMaterial (TGeoMaterial *) const |
virtual const Char_t * | GetMaterialName (const Char_t *) |
Return name of material of given type or name if it is in range tables. More... | |
virtual Double_t | GetMaxDeltaEOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetPunchThroughEnergy (const Char_t *mat, Int_t Z, Int_t A, Double_t e, Double_t isoAmat=0., Double_t T=-1., Double_t P=-1.) |
virtual Double_t | GetRangeOfIon (const Char_t *mat, Int_t Z, Int_t A, Double_t E, Double_t Amat=0., Double_t T=-1., Double_t P=-1.) |
virtual TGeoMaterial * | GetTGeoMaterial (const Char_t *material) |
Create and return pointer to TGeoMaterial/Mixture corresponding to material. More... | |
virtual Double_t | GetZ (const Char_t *) |
Returns atomic number of a material in the range tables. More... | |
virtual Bool_t | IsMaterialGas (const Char_t *) |
Return kTRUE if material is gaseous. More... | |
virtual Bool_t | IsMaterialKnown (const Char_t *) |
Return kTRUE if material is in range tables. More... | |
virtual Bool_t | IsMaterialKnown (TGeoMaterial *) |
Returns kTRUE if material corresponding to TGeoMaterial name or type is in range table. More... | |
virtual void | SetTemperatureAndPressure (const Char_t *, Double_t temperature, Double_t pressure) |
![]() | |
KVBase () | |
Default constructor. More... | |
KVBase (const Char_t *name, const Char_t *title="") | |
Ctor for object with given name and type. More... | |
KVBase (const KVBase &) | |
copy ctor More... | |
virtual | ~ KVBase () |
virtual void | Clear (Option_t *opt="") |
Clear object properties : name, type/title, number, label. More... | |
virtual void | Copy (TObject &) const |
Make a copy of this object. More... | |
const Char_t * | GetLabel () const |
UInt_t | GetNumber () const |
UInt_t | GetNumberOfObjects () const |
virtual TObject * | GetObject () const |
const Char_t * | GetType () const |
Bool_t | HasLabel () const |
virtual Bool_t | IsCalled (const Char_t *name) const |
Bool_t | IsLabelled (const Char_t *l) const |
virtual Bool_t | IsType (const Char_t *typ) const |
virtual void | List () |
KVBase & | operator= (const KVBase &) |
copy assignment operator More... | |
Double_t | ProtectedGetX (const TF1 *func, Double_t val, int &status, Double_t xmin=0.0, Double_t xmax=0.0) const |
void | SetLabel (const Char_t *lab) |
virtual void | SetNumber (UInt_t num) |
virtual void | SetType (const Char_t *str) |
![]() | |
TNamed () | |
TNamed (const char *name, const char *title) | |
TNamed (const TNamed &named) | |
TNamed (const TString &name, const TString &title) | |
virtual | ~TNamed () |
virtual TObject * | Clone (const char *newname="") const |
virtual Int_t | Compare (const TObject *obj) const |
virtual void | FillBuffer (char *&buffer) |
virtual const char * | GetName () const |
virtual const char * | GetTitle () const |
virtual ULong_t | Hash () const |
virtual Bool_t | IsSortable () const |
virtual void | ls (Option_t *option="") const |
TNamed & | operator= (const TNamed &rhs) |
virtual void | SetName (const char *name) |
virtual void | SetNameTitle (const char *name, const char *title) |
virtual void | SetTitle (const char *title="") |
virtual Int_t | Sizeof () const |
![]() | |
TObject () | |
TObject (const TObject &object) | |
virtual | ~TObject () |
void | AbstractMethod (const char *method) const |
virtual void | AppendPad (Option_t *option="") |
virtual void | Browse (TBrowser *b) |
ULong_t | CheckedHash () |
virtual const char * | ClassName () const |
virtual void | Delete (Option_t *option="") |
virtual Int_t | DistancetoPrimitive (Int_t px, Int_t py) |
virtual void | Draw (Option_t *option="") |
virtual void | DrawClass () const |
virtual TObject * | DrawClone (Option_t *option="") const |
virtual void | Dump () const |
virtual void | Error (const char *method, const char *msgfmt,...) const |
virtual void | Execute (const char *method, const char *params, Int_t *error=0) |
virtual void | Execute (TMethod *method, TObjArray *params, Int_t *error=0) |
virtual void | ExecuteEvent (Int_t event, Int_t px, Int_t py) |
virtual void | Fatal (const char *method, const char *msgfmt,...) const |
virtual TObject * | FindObject (const char *name) const |
virtual TObject * | FindObject (const TObject *obj) const |
virtual Option_t * | GetDrawOption () const |
virtual const char * | GetIconName () const |
virtual char * | GetObjectInfo (Int_t px, Int_t py) const |
virtual Option_t * | GetOption () const |
virtual UInt_t | GetUniqueID () const |
virtual Bool_t | HandleTimer (TTimer *timer) |
Bool_t | HasInconsistentHash () const |
virtual void | Info (const char *method, const char *msgfmt,...) const |
virtual Bool_t | InheritsFrom (const char *classname) const |
virtual Bool_t | InheritsFrom (const TClass *cl) const |
virtual void | Inspect () const |
void | InvertBit (UInt_t f) |
virtual Bool_t | IsEqual (const TObject *obj) const |
virtual Bool_t | IsFolder () const |
R__ALWAYS_INLINE Bool_t | IsOnHeap () const |
R__ALWAYS_INLINE Bool_t | IsZombie () const |
void | MayNotUse (const char *method) const |
virtual Bool_t | Notify () |
void | Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const |
void | operator delete (void *ptr) |
void | operator delete[] (void *ptr) |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, void *vp) |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, void *vp) |
TObject & | operator= (const TObject &rhs) |
virtual void | Paint (Option_t *option="") |
virtual void | Pop () |
virtual Int_t | Read (const char *name) |
virtual void | RecursiveRemove (TObject *obj) |
void | ResetBit (UInt_t f) |
virtual void | SaveAs (const char *filename="", Option_t *option="") const |
virtual void | SavePrimitive (std::ostream &out, Option_t *option="") |
void | SetBit (UInt_t f) |
void | SetBit (UInt_t f, Bool_t set) |
virtual void | SetDrawOption (Option_t *option="") |
virtual void | SetUniqueID (UInt_t uid) |
virtual void | SysError (const char *method, const char *msgfmt,...) const |
R__ALWAYS_INLINE Bool_t | TestBit (UInt_t f) const |
Int_t | TestBits (UInt_t f) const |
virtual void | UseCurrentStyle () |
virtual void | Warning (const char *method, const char *msgfmt,...) const |
virtual Int_t | Write (const char *name=0, Int_t option=0, Int_t bufsize=0) |
virtual Int_t | Write (const char *name=0, Int_t option=0, Int_t bufsize=0) const |
Static Public Member Functions | |
static Bool_t | IsUseNewRangeInversion () |
static void | SetIgnoreEnergyLimits (Bool_t yes=kTRUE) |
static void | SetUseNewRangeInversion (Bool_t yes=kTRUE) |
![]() | |
static KVIonRangeTable * | GetRangeTable (const Char_t *name) |
Generates an instance of the KVIonRangeTable plugin class corresponding to given name. More... | |
![]() | |
static Bool_t | AreEqual (Double_t x, Double_t y, Long64_t maxdif=1) |
Comparison between two 64-bit floating-point values. More... | |
static void | BackupFileWithDate (const Char_t *path) |
static void | CombineFiles (const Char_t *file1, const Char_t *file2, const Char_t *newfilename, Bool_t keep=kTRUE) |
static void | Deprecated (const char *method, const char *advice) |
static Bool_t | FindClassSourceFiles (const Char_t *class_name, KVString &imp_file, KVString &dec_file, const Char_t *dir_name=".") |
static Bool_t | FindExecutable (TString &exec, const Char_t *path="$(PATH)") |
static const Char_t * | FindFile (const Char_t *search, TString &wfil) |
static const Char_t * | GetBINDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetDATABASEFilePath () |
static const Char_t * | GetDATADIRFilePath (const Char_t *namefile="") |
static Bool_t | GetDataSetEnv (const Char_t *dataset, const Char_t *type, Bool_t defval) |
static const Char_t * | GetDataSetEnv (const Char_t *dataset, const Char_t *type, const Char_t *defval) |
static Double_t | GetDataSetEnv (const Char_t *dataset, const Char_t *type, Double_t defval) |
static const Char_t * | GetETCDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetExampleFilePath (const Char_t *library, const Char_t *namefile) |
Return full path to example file for given library (="KVMultiDet", "BackTrack", etc.) More... | |
static const Char_t * | GetINCDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetKVBuildDate () |
Returns KaliVeda build date. More... | |
static const Char_t * | GetKVBuildDir () |
Returns top-level directory used for build. More... | |
static const Char_t * | GetKVBuildTime () |
Returns KaliVeda build date. More... | |
static const Char_t * | GetKVBuildType () |
Returns KaliVeda build type (cmake build: Release, Debug, RelWithDebInfo, ...) More... | |
static const Char_t * | GetKVBuildUser () |
Returns username of person who performed build. More... | |
static const Char_t * | GetKVSourceDir () |
Returns top-level directory of source tree used for build. More... | |
static const Char_t * | GetKVVersion () |
Returns KaliVeda version string. More... | |
static const Char_t * | GetLIBDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetListOfPlugins (const Char_t *base) |
static const Char_t * | GetListOfPluginURIs (const Char_t *base) |
static const Char_t * | GetPluginURI (const Char_t *base, const Char_t *plugin) |
static void | GetTempFileName (TString &base) |
static const Char_t * | GetTEMPLATEDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetWORKDIRFilePath (const Char_t *namefile="") |
static const Char_t * | gitBranch () |
Returns git branch of sources. More... | |
static const Char_t * | gitCommit () |
Returns last git commit of sources. More... | |
static void | InitEnvironment () |
static bool | is_gnuinstall () |
static Bool_t | IsThisAPlugin (const TString &uri, TString &base) |
static TPluginHandler * | LoadPlugin (const Char_t *base, const Char_t *uri="0") |
static Bool_t | OpenContextMenu (const char *method, TObject *obj, const char *alt_method_name="") |
static void | OpenTempFile (TString &base, std::ofstream &fp) |
static void | PrintSplashScreen () |
Prints welcome message and infos on version etc. More... | |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, std::ifstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0) |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, std::ofstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0) |
static Bool_t | SearchKVFile (const Char_t *name, TString &fullpath, const Char_t *kvsubdir="") |
static const Char_t * | WorkingDirectory () |
![]() | |
static Longptr_t | GetDtorOnly () |
static Bool_t | GetObjectStat () |
static void | SetDtorOnly (void *obj) |
static void | SetObjectStat (Bool_t stat) |
Private Member Functions | |
void | AddMaterial (KVIonRangeTableMaterial *) const |
Bool_t | CheckMaterialsList () const |
KVIonRangeTableMaterial * | GetMaterialWithNameOrType (const Char_t *material) const |
Returns pointer to material of given name or type. More... | |
Bool_t | init_materials () const |
Private Attributes | |
TString | fLocalMaterialsDirectory |
Static Private Attributes | |
static Bool_t | fgNewRangeInversion = kTRUE |
static flag for using new KVedaLossInverseRangeFunction More... | |
static KVHashList * | fMaterials = 0x0 |
static list of all known materials More... | |
Additional Inherited Members | |
![]() | |
enum | SolType { kEmax , kEmin } |
![]() | |
enum | EKaliVedaBits { kIsKaliVedaObject = BIT(23) } |
![]() | |
enum | EDeprecatedStatusBits |
enum | EStatusBits |
![]() | |
kBitMask | |
kCanDelete | |
kCannotPick | |
kHasUUID | |
kInconsistent | |
kInvalidObject | |
kIsOnHeap | |
kIsReferenced | |
kMustCleanup | |
kNoContextMenu | |
kNotDeleted | |
kObjInCanvas | |
kOverwrite | |
kSingleKey | |
kWriteDelete | |
kZombie | |
![]() | |
virtual KVIonRangeTableMaterial * | GetMaterialWithPointer (TGeoMaterial *) const |
![]() | |
virtual void | DoError (int level, const char *location, const char *fmt, va_list va) const |
void | MakeZombie () |
![]() | |
TString | fLabel |
label for the object More... | |
![]() | |
TString | fName |
TString | fTitle |
![]() | |
kOnlyPrepStep | |
#include <KVedaLoss.h>
KVedaLoss::KVedaLoss | ( | ) |
Default constructor.
Definition at line 69 of file KVedaLoss.cpp.
|
virtual |
Destructor.
Definition at line 86 of file KVedaLoss.cpp.
|
virtual |
Use the RANGE tables to generate a new compound material.
Reimplemented from KVIonRangeTable.
Definition at line 231 of file KVedaLoss.cpp.
|
virtual |
Use the RANGE tables to generate a new material of a given element. If A is given only one isotope will be used, by default the natural abundance of each isotope is used to generate a mixture
Reimplemented from KVIonRangeTable.
Definition at line 197 of file KVedaLoss.cpp.
|
private |
Add a material (taken from a different range table) to VEDALOSS This means fitting the ranges for Z=1-100 and writing the parameters in a file which will be stored in
/VEDALOSS/[name].dat
which will be read at each initialisation to include the new material
Definition at line 283 of file KVedaLoss.cpp.
|
virtual |
Use the RANGE tables to generate a new mixed material.
Reimplemented from KVIonRangeTable.
Definition at line 246 of file KVedaLoss.cpp.
If the given material is defined in the RANGE tables, import it into VEDALOSS.
Definition at line 214 of file KVedaLoss.cpp.
Reimplemented from KVIonRangeTable.
Definition at line 59 of file KVedaLoss.cpp.
|
inlineprivate |
Definition at line 38 of file KVedaLoss.h.
|
virtual |
Create and fill a list of all materials for which range tables exist. Each entry is a TNamed with the name and type (title) of the material. User's responsibility to delete list after use (it owns its objects).
Implements KVIonRangeTable.
Definition at line 325 of file KVedaLoss.cpp.
|
privatevirtual |
Returns pointer to material of given name or type.
Implements KVIonRangeTable.
Definition at line 262 of file KVedaLoss.cpp.
|
private |
PRIVATE method - called to initialize fMaterials list of all known materials properties, read from file given by TEnv variable KVedaLoss.RangeTables
any files in /vedaloss.dat will also be read, these contain materials added by the user(s)
Definition at line 100 of file KVedaLoss.cpp.
|
inlinestatic |
Definition at line 62 of file KVedaLoss.h.
Reimplemented from KVIonRangeTable.
Definition at line 311 of file KVedaLoss.cpp.
Read and add range tables for materials in file.
Implements KVIonRangeTable.
Definition at line 138 of file KVedaLoss.cpp.
Call this static method with yes=kTRUE in order to recalculate the nominal limits on incident ion energies for which the range tables are valid.
Normally all range, \(dE\), \(E_{res}\) functions are limited to range \(0\leq E\leq E_{max}\), where \(E_{max}\) is nominal maximum energy for which range tables are valid (usually 400MeV/u for \(Z<3\), 250MeV/u for \(Z>3\)).
If higher energies are required, call static method KVedaLoss::SetIgnoreEnergyLimits() BEFORE ANY MATERIALS ARE CREATED in order to recalculate the \(E_{max}\) limits in such a way that:
Then, at the most, the new limit will be 1 GeV/nucleon, or at the least, it will remain at the nominal (400 or 250 MeV/nucleon) level.
Definition at line 36 of file KVedaLoss.cpp.
Definition at line 58 of file KVedaLoss.h.
static flag for using new KVedaLossInverseRangeFunction
Definition at line 44 of file KVedaLoss.h.
|
private |
Definition at line 35 of file KVedaLoss.h.
|
staticprivate |
static list of all known materials
Definition at line 34 of file KVedaLoss.h.