43 "Interface to Range dE/dx and range library (Ricardo Yanez)")
64 DataFilePaths.
Begin(
" ");
67 while (!DataFilePaths.
End()) {
68 nextPath = DataFilePaths.
Next();
69 if (nextPath == lastPath)
break;
145 printf(
"\nEnergy loss & range tables loaded for 0 materials.\n");
229 Error(
"AddElementalMaterial",
230 "Nuclear data tables have not been initialised");
235 Error(
"AddElementalMaterial",
236 "No element found in ElementDensity NDT-table with Z=%d", z);
240 if (ed->
IsGas()) state =
"gas";
280 if (density > 0) state =
"solid";
283 for (
int i = 0; i <
nelem; i++) {
323 if (density > 0) state =
"solid";
326 for (
int i = 0; i <
nelem; i++) {
360 Error(
"MakeNaturallyOccuringElementMixture",
361 "Nuclear data tables have not been initialised");
366 Error(
"AddElementalMaterial",
367 "No element found in ElementDensity NDT-table with Z=%d", z);
374 while (!isotopes.
End()) {
383 if (ed->
IsGas()) state =
"gas";
390 while (!isotopes.
End()) {
408 TString DataFilePath = filename;
412 Error(
"ReadPredefinedMaterials",
"Cannot open %s for reading", DataFilePath.
Data());
415 Info(
"ReadPredefinedMaterials",
"Reading materials in file : %s", filename);
423 while (filestream.good()) {
424 line.ReadLine(filestream);
425 if (filestream.good()) {
426 if (
line.BeginsWith(
"//"))
continue;
427 if (
line.BeginsWith(
"COMPOUND")) {
431 else if (
line.BeginsWith(
"MIXTURE")) {
435 else if (
line.BeginsWith(
"ELEMENT")) {
447 line.ReadLine(filestream);
448 while (filestream.good() && !
line.IsWhitespace() &&
line !=
"\n") {
451 if (next ==
"name") name =
line.Next();
452 else if (next ==
"symbol") symbol =
line.Next();
453 else if (next ==
"state") state =
line.Next();
454 else if (next ==
"density") density =
line.Next().Atof();
455 else if (next ==
"nelem") {
457 for (
int i = 0; i <
nelem; i++) {
458 line.ReadLine(filestream);
460 element[i] =
line.Next();
465 natoms[i] =
line.Next().Atoi();
466 if (mixture) proportion[i] =
line.Next().Atof();
478 line.ReadLine(filestream);
479 while (filestream.good() && !
line.IsWhitespace() &&
line !=
"\n") {
482 if (next ==
"name") name =
line.Next();
483 else if (next ==
"symbol") symbol =
line.Next();
484 else if (next ==
"state") state =
line.Next();
521 matfilename +=
".dat";
KVIonRangeTableMaterial * M
KVNDTManager * gNDTManager
ClassImp(KVPartitionList) void KVPartitionList
Initialisation.
char * Form(const char *fmt,...)
R__EXTERN TSystem * gSystem
virtual const Char_t * GetType() const
static const Char_t * GetWORKDIRFilePath(const Char_t *namefile="")
static Bool_t SearchAndOpenKVFile(const Char_t *name, KVSQLite::database &dbfile, const Char_t *kvsubdir="")
virtual void Copy(TObject &) const
Make a copy of this object.
Atomic element with name, symbol and density.
const Char_t * GetElementName() const
const Char_t * GetElementSymbol() const
Extended version of ROOT THashList.
Material for use in energy loss & range calculations.
void AddCompoundElement(Int_t Z, Int_t A, Int_t Natoms)
void AddMixtureElement(Int_t Z, Int_t A, Int_t Natoms, Double_t Proportion)
virtual void Initialize()
Abstract base class for calculation of range & energy loss of charged particles in matter.
KVNuclData * GetData(Int_t zz, Int_t aa, const Char_t *name) const
Double_t GetValue() const
Description of properties and kinematics of atomic nuclei.
static Int_t IsMassGiven(const Char_t *)
KVNumberList GetKnownARange(Int_t z=-1, Double_t tmin=0) const
Double_t GetAbundance(Int_t z=-1, Int_t a=-1) const
Int_t GetZ() const
Return the number of proton / atomic number.
Strings used to represent a set of ranges of values.
Description of absorber for the Range dE/dx and range library.
Interface to Range dE/dx and range library.
virtual KVIonRangeTableMaterial * AddMixedMaterial(const Char_t *name, const Char_t *symbol, Int_t nelem, Int_t *z, Int_t *a, Int_t *natoms, Double_t *weight, Double_t density=-1.0) const
Bool_t fDoNotSaveMaterials
TString fLocalMaterialsDirectory
static KVHashList * fMaterials
static list of all currently defined materials
void SaveMaterial(KVIonRangeTableMaterial *mat) const
TObjArray * GetListOfMaterials()
KVIonRangeTableMaterial * GetMaterialWithNameOrType(const Char_t *material) const
void Print(Option_t *="") const
void Copy(TObject &) const
Make a copy of this object.
Bool_t ReadMaterials(const Char_t *filename) const
Read materials from file whose name is given.
virtual KVIonRangeTableMaterial * AddCompoundMaterial(const Char_t *name, const Char_t *symbol, Int_t nelem, Int_t *z, Int_t *a, Int_t *natoms, Double_t density=-1.0) const
KVIonRangeTableMaterial * MakeNaturallyOccuringElementMixture(Int_t z, Int_t &a) const
virtual KVIonRangeTableMaterial * AddElementalMaterial(Int_t z, Int_t a=0) const
void CheckMaterialsList() const
virtual void SetOwner(Bool_t enable=kTRUE)
virtual TObject * FindObjectByType(const Char_t *) const
virtual void Add(TObject *obj)
virtual TObject * FindObject(const char *name) const
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
void Begin(TString delim) const
KVString Next(Bool_t strip_whitespace=kFALSE) const
Extension of ROOT TSystemDirectory class, handling browsing directories on disk.
virtual TList * GetListOfFiles() const
Extended ROOT TSystemFile with added info on file size etc.
const Char_t * GetFullPath() const
virtual void Print(Option_t *option, const char *wildcard, Int_t recurse=1) const
void SetName(const char *name)
virtual Int_t GetEntries() const
virtual void SetOwner(Bool_t enable=kTRUE)
virtual const char * GetValue(const char *name, const char *dflt) const
virtual const char * GetName() const
virtual const char * GetTitle() const
virtual void Error(const char *method, const char *msgfmt,...) const
virtual void Info(const char *method, const char *msgfmt,...) const
const char * Data() const
TString & ReplaceAll(const char *s1, const char *s2)
virtual int Chmod(const char *file, UInt_t mode)
virtual int mkdir(const char *name, Bool_t recursive=kFALSE)
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)