![]() |
KaliVeda
Toolkit for HIC analysis
|
Base class for detector geometry description, interface to energy-loss calculations.
KVDetector is the base class for the description of all individual detectors in the KaliVeda framework. A detector is defined by the following characteristics:
A detector is created either with the constructor taking the material type as argument:
or using SetMaterial:
or it is created when a ROOT geometry is imported into a KVMultiDetArray object using KVGeoImport.
Two methods are available: one simply calculates the energy lost by the particle in the detector, but does not modify either the particle or the detector (GetELostByParticle); the other simulates the passage of the particle through the detector, the particle's energy is reduced by the amount lost in the detector's absorbers and the total energy lost in the detector is increased, e.g.:
For detector geometries based on the ROOT geometry package, the following methods refer to the surface of the first volume constituting the detector crossed from the target (referred to as the "entrance window"):
Definition at line 158 of file KVDetector.h.
#include <KVDetector.h>

Public Member Functions | |
| KVDetector () | |
| default ctor More... | |
| KVDetector (const Char_t *gas, const Double_t thick, const Double_t pressure, const Double_t temperature=19.0) | |
| KVDetector (const Char_t *type, const Float_t thick=0.0) | |
| Create a new detector of a given material and thickness in centimetres (default value = 0.0) More... | |
| KVDetector (const KVDetector &) | |
| copy ctor More... | |
| virtual | ~ KVDetector () |
| void | AddAbsorber (KVMaterial *) |
| Bool_t | AddCalibrator (KVCalibrator *cal, const KVNameValueList &opts="") |
| KVDetectorSignal * | AddDetectorSignal (const KVString &type) |
| Bool_t | AddDetectorSignalExpression (const KVString &type, const KVString &_expr) |
| virtual void | AddEnergyLossInSubDetector (int, double) |
| void | AddHit (KVNucleus *part) |
| void | AddParentStructure (KVGeoStrucElement *elem) |
| Bool_t | BelongsToIdentifiedParticle () const |
| Bool_t | BelongsToUnidentifiedParticle () const |
| void | Clear (Option_t *opt="") override |
| void | ClearHits () |
| void | Copy (TObject &obj) const override |
| void | DetectParticle (KVNucleus *, TVector3 *norm=0) override |
| virtual TGraph * | DrawPunchThroughEnergyVsZ (Int_t massform=KVNucleus::kBetaMass) |
| virtual TGraph * | DrawPunchThroughEsurAVsZ (Int_t massform=KVNucleus::kBetaMass) |
| virtual Int_t | FindZmin (Double_t ELOSS=-1., Char_t mass_formula=-1) |
| virtual Bool_t | Fired (Option_t *opt="any") const |
| KVMaterial * | GetAbsorber (const Char_t *name) const |
| KVMaterial * | GetAbsorber (Int_t i) const |
| Returns pointer to the i-th absorber in the detector (i=0 first absorber, i=1 second, etc.) More... | |
| KVMaterial * | GetActiveLayer () const override |
| TGeoHMatrix * | GetActiveLayerMatrix () const |
| TGeoBBox * | GetActiveLayerShape () const |
| TVector3 | GetActiveLayerSurfaceCentre () const |
| TVector3 | GetActiveLayerVolumeCentre () const |
| virtual Double_t | GetCalibratedEnergy () const |
| KVCalibrator * | GetCalibrator (const Char_t *name, const Char_t *type) const |
| KVCalibrator * | GetCalibrator (const Char_t *type) const |
| const TVector3 | GetCentreOfEntranceWindow () const |
| virtual Double_t | GetCorrectedEnergy (KVNucleus *, Double_t e=-1., Bool_t transmission=kTRUE) |
| Double_t | GetCosTheta () const override |
| Double_t | GetDeltaE (Int_t Z, Int_t A, Double_t Einc, Double_t=0.) override |
| Double_t | GetDeltaEFromERes (Int_t Z, Int_t A, Double_t Eres) override |
| virtual KVDetectorSignal * | GetDetectorSignal (const KVString &type) const |
| Double_t | GetDetectorSignalValue (const KVString &type, const KVNameValueList ¶ms="") const |
| TVector3 | GetDirection () override |
| Double_t | GetDistance () const override |
| Double_t | GetEIncOfMaxDeltaE (Int_t Z, Int_t A) override |
| virtual TF1 * | GetELossFunction (Int_t Z, Int_t A) |
| Double_t | GetELostByParticle (KVNucleus *, TVector3 *norm=0) override |
| virtual Double_t | GetEnergy () const |
| Double_t | GetEnergyLoss () const override |
| const KVPosition & | GetEntranceWindow () const |
| virtual Double_t | GetEntranceWindowSurfaceArea () |
| Return surface area of first layer of detector in cm2. More... | |
| Double_t | GetERes (Int_t Z, Int_t A, Double_t Einc, Double_t=0.) override |
| virtual Double_t | GetEResAfterDetector () const |
| virtual TF1 * | GetEResFunction (Int_t Z, Int_t A) |
| KVGroup * | GetGroup () const |
| UInt_t | GetGroupNumber () |
| KVList * | GetHits () const |
| Return the list of particles hitting this detector in an event. More... | |
| Double_t | GetIncidentEnergy (Int_t Z, Int_t A, Double_t delta_e=-1.0, enum SolType type=kEmax) override |
| Double_t | GetIncidentEnergyFromERes (Int_t Z, Int_t A, Double_t Eres) override |
| virtual Int_t | GetIndex () const |
| Double_t | GetInverseDetectorSignalValue (const KVString &output, Double_t value, const KVString &input, const KVNameValueList ¶ms="") const |
| Double_t | GetLinearRange (Int_t Z, Int_t A, Double_t Einc) override |
| const KVList * | GetListOfAbsorbers () const |
| KVList * | GetListOfCalibrators () const |
| const KVSeqCollection & | GetListOfDetectorSignals () const |
| const KVSeqCollection & | GetListOfDetectorSignalsForRawTree () const |
| const Char_t * | GetMaterialName () const |
| Double_t | GetMaxDeltaE (Int_t Z, Int_t A) override |
| const Char_t * | GetNameOfArray () const |
| Int_t | GetNHits () const |
| Return the number of particles hitting this detector in an event. More... | |
| KVGeoDetectorNode * | GetNode () |
| Int_t | GetNumberOfAbsorberLayers () const |
| KVGeoStrucElement * | GetParentStructure (const Char_t *type, const Char_t *name="") const |
| Double_t | GetParticleEIncFromERes (KVNucleus *, TVector3 *norm=0) override |
| Double_t | GetPhi () const override |
| Double_t | GetPunchThroughEnergy (Int_t Z, Int_t A) override |
| void | GetRandomAngles (Double_t &th, Double_t &ph, Option_t *t="isotropic") override |
| TVector3 | GetRandomDirection (Option_t *t="isotropic") override |
| Double_t | GetRange (Int_t Z, Int_t A, Double_t Einc) override |
| virtual TF1 * | GetRangeFunction (Int_t Z, Int_t A) |
| Double_t | GetSinTheta () const override |
| virtual Double_t | GetSmallestEmaxValid (Int_t Z, Int_t A) const |
| Double_t | GetSolidAngle () const override |
| Double_t | GetTheta () const override |
| virtual Double_t | GetTotalDeltaE (Int_t Z, Int_t A, Double_t Einc) |
| Double_t | GetTotalThicknessInCM () const |
| Bool_t | HasDetectorSignal (const KVString &type) const |
| Bool_t | HasSameStructureAs (const KVDetector *) const |
| void | IncrementIdentifiedParticles (Int_t n=1) |
| void | IncrementUnidentifiedParticles (Int_t n=1) |
| void | init () |
| default initialisations More... | |
| Bool_t | IsAnalysed () |
| Bool_t | IsCalibrated () const |
| Bool_t | IsCalibrated (const KVNameValueList ¶ms) const |
| virtual Bool_t | IsDetecting () const |
| Bool_t | IsGasDetector () const |
| Bool_t | IsMultiLayer () const |
| virtual Bool_t | IsOK () const |
| virtual Bool_t | IsPresent () const |
| virtual Bool_t | IsSegmented () const |
| virtual Bool_t | IsSimMode () const |
| Bool_t | IsSingleLayer () const |
| void | Print (Option_t *option="") const override |
| virtual void | ReadDefinitionFromFile (const Char_t *) |
| void | RemoveAllAbsorbers () |
| virtual void | RemoveCalibrators () |
| void | RemoveHit (KVNucleus *part) |
| void | RemoveParentStructure (KVGeoStrucElement *elem) |
| Bool_t | ReplaceCalibrator (const Char_t *type, KVCalibrator *cal, const KVNameValueList &opts="") |
| virtual void | Reset (Option_t *opt="") |
| void | SetActiveLayer (Int_t i) |
| void | SetActiveLayer (KVMaterial *actif) |
| void | SetActiveLayerMatrix (const TGeoHMatrix *) |
| Set ROOT geometry global matrix transformation to coordinate frame of active layer volume. More... | |
| void | SetActiveLayerShape (TGeoBBox *) |
| Set ROOT geometry shape of active layer volume. More... | |
| void | SetAnalysed (Bool_t b=kTRUE) |
| void | SetDetecting (Bool_t yes=kTRUE) |
| void | SetDetectorSignalValue (const KVString &type, Double_t val) const |
| virtual void | SetEnergy (Double_t e) const |
| void | SetEnergyLoss (Double_t e) const override |
| void | SetEntranceWindowMatrix (const TGeoHMatrix *) |
| Set ROOT geometry global matrix transformation to coordinate frame of entrance window. More... | |
| void | SetEntranceWindowShape (TGeoBBox *) |
| Set ROOT geometry shape of entrance window. More... | |
| virtual void | SetEResAfterDetector (Double_t e) |
| void | SetMaterial (const Char_t *type) override |
| void | SetNameOfArray (const TString &n) |
| void | SetPresent (Bool_t yes=kTRUE) |
| void | SetPressure (Double_t P) override |
| virtual void | SetSimMode (Bool_t on=kTRUE) |
| void | SetTemperature (Double_t T) override |
| void | SetThickness (Double_t thick) override |
Public Member Functions inherited from KVMaterial | |
| KVMaterial () | |
| default ctor More... | |
| KVMaterial (const Char_t *gas, const Double_t thick, const Double_t pressure, const Double_t temperature=19.0) | |
| KVMaterial (const Char_t *type, const Double_t thick=0.0) | |
| Create material with given type and linear thickness in cm. More... | |
| KVMaterial (const KVMaterial &) | |
| Copy ctor. More... | |
| KVMaterial (Double_t area_density, const Char_t *type) | |
| Create material with given area density in \(g/cm^{2}\) and given type. More... | |
| virtual | ~ KVMaterial () |
| void | Clear (Option_t *opt="") override |
| Reset absorber - set stored energy lost by particles in absorber to zero. More... | |
| void | Copy (TObject &obj) const override |
| Make a copy of this material object. More... | |
| virtual TGeoVolume * | GetAbsGeoVolume () const |
| Double_t | GetAreaDensity () const |
| Double_t | GetDensity () const |
| Double_t | GetEffectiveAreaDensity (TVector3 &norm, TVector3 &direction) |
| Double_t | GetEffectiveThickness (TVector3 &norm, TVector3 &direction) |
| Double_t | GetEmaxValid (Int_t Z, Int_t A) |
| virtual Double_t | GetEResFromDeltaE (Int_t Z, Int_t A, Double_t dE=-1.0, enum SolType type=kEmax) |
| virtual TGeoMedium * | GetGeoMedium (const Char_t *="") |
| virtual TGraph * | GetGraphOfDeltaEVsE (const KVNucleus &nuc, Int_t npts, Double_t Emin, Double_t Emax) |
| Double_t | GetMass () const |
| virtual Double_t | GetPressure () const |
| virtual Double_t | GetTemperature () const |
| virtual Double_t | GetThickness () const |
| Double_t | GetZ () const |
| void | init () |
| Bool_t | IsGas () const |
| Bool_t | IsIsotopic () const |
| Bool_t | IsNat () const |
| void | Print (Option_t *option="") const override |
| Show information on this material. More... | |
| virtual void | SetAbsGeoVolume (TGeoVolume *v) |
| void | SetAreaDensity (Double_t dens) |
| void | SetMass (Int_t a) |
Public Member Functions inherited from KVBase | |
| 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... | |
| void | Error (const char *method, const char *msgfmt,...) const override |
| const Char_t * | GetLabel () const |
| UInt_t | GetNumber () const |
| virtual TObject * | GetObject () const |
| virtual 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) |
| void | Warning (const char *method, const char *msgfmt,...) const override |
Public Member Functions inherited from TNamed | |
| TNamed () | |
| TNamed (const char *name, const char *title) | |
| TNamed (const TNamed &named) | |
| TNamed (const TString &name, const TString &title) | |
| virtual | ~TNamed () |
| TObject * | Clone (const char *newname="") const override |
| Int_t | Compare (const TObject *obj) const override |
| virtual void | FillBuffer (char *&buffer) |
| const char * | GetName () const override |
| const char * | GetTitle () const override |
| ULong_t | Hash () const override |
| TClass * | IsA () const override |
| Bool_t | IsSortable () const override |
| void | ls (Option_t *option="") const override |
| 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 |
| void | Streamer (TBuffer &) override |
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) |
Public Member Functions inherited from TObject | |
| 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 | Execute (const char *method, const char *params, Int_t *error=nullptr) |
| virtual void | Execute (TMethod *method, TObjArray *params, Int_t *error=nullptr) |
| 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) |
| Bool_t | IsDestructed () const |
| 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 *vp) |
| void | operator delete[] (void *ptr) |
| void | operator delete[] (void *ptr, void *vp) |
| 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) |
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) |
| 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 Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) |
| virtual Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) const |
Public Member Functions inherited from KVPosition | |
| KVPosition () | |
| KVPosition (Double_t thmin, Double_t thmax, Double_t phmin, Double_t phmax, Double_t dist=0.0) | |
| virtual | ~KVPosition () |
| Double_t | GetAzimuthalWidth (Double_t phmin=-1., Double_t phimax=-1.) const |
| void | GetCornerCoordinates (TVector3 *, Double_t=0) |
| void | GetCornerCoordinatesInOwnFrame (TVector3 *, Double_t=0) |
| Double_t | GetPhiMax () const |
| Double_t | GetPhiMin () const |
| TRotation | GetRandomIsotropicRotation () |
| Double_t | GetThetaMax () const |
| Double_t | GetThetaMin () const |
| void | GetWidthsFromDimension (Double_t lin_dim) |
| void | init () |
| default initialiser More... | |
| Bool_t | IsAlignedWith (KVPosition *pos) |
| kTRUE if one of the two solid angle elements is completely contained within the other. More... | |
| Bool_t | IsAzimuthallyWiderThan (KVPosition *pos) |
| Bool_t | IsInPhiRange (const Double_t phi) |
| Bool_t | IsInPolarRange (const Double_t theta) |
| kTRUE if given angle theta is within the polar range of this solid angle element More... | |
| Bool_t | IsOverlappingWith (KVPosition *pos) |
| kTRUE if there is at least partial overlap between two solid angle elements More... | |
| Bool_t | IsSmallerThan (KVPosition *pos) |
| kTRUE if "this" is entirely contained within "pos" More... | |
| virtual Bool_t | ROOTGeo () const |
| Returns kTRUE if ROOT geometry is used, kFALSE if not. More... | |
| virtual void | SetAzimuthalAngle (Double_t ph) |
| virtual void | SetAzimuthalMinMax (Double_t min, Double_t max) |
| Set min and max azimuthal angles and calculate (mean) phi. More... | |
| virtual void | SetAzimuthalWidth (Double_t aw) |
| void | SetDistance (Double_t d) |
| void | SetPhi (Double_t p) |
| void | SetPhiMinMax (Double_t min, Double_t max) |
| virtual void | SetPolarAngle (Double_t th) |
| virtual void | SetPolarMinMax (Double_t min, Double_t max) |
| Set min and max polar angles and calculate (mean) theta. More... | |
| virtual void | SetPolarWidth (Double_t pw) |
| void | SetTheta (Double_t t) |
Static Public Member Functions | |
| static KVDetector * | MakeDetector (const Char_t *name, Float_t thick) |
Static Public Member Functions inherited from KVMaterial | |
| static KVIonRangeTable * | ChangeRangeTable (const Char_t *name) |
| static KVIonRangeTable * | GetRangeTable () |
Static Public Member Functions inherited from KVBase | |
| 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 KVString &class_name, KVString &imp_file, KVString &dec_file, const KVString &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 KVString | GetDataSetEnv (const KVString &dataset, const KVString &type, const char *defval) |
| template<typename ValType > | |
| static ValType | GetDataSetEnv (const KVString &dataset, const KVString &type, const ValType &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 time. 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 int | GetKVMajorVersion () |
| static int | GetKVMinorVersion () |
| 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 | IsEnvInit () |
| 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, KVSQLite::database &dbfile, const Char_t *kvsubdir="") |
| 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 Public Member Functions inherited from TNamed | |
| static TClass * | Class () |
| static const char * | Class_Name () |
| static constexpr Version_t | Class_Version () |
| static const char * | DeclFileName () |
Static Public Member Functions inherited from TObject | |
| static TClass * | Class () |
| static const char * | Class_Name () |
| static constexpr Version_t | Class_Version () |
| static const char * | DeclFileName () |
| static Longptr_t | GetDtorOnly () |
| static Bool_t | GetObjectStat () |
| static void | SetDtorOnly (void *obj) |
| static void | SetObjectStat (Bool_t stat) |
Private Types | |
| enum | { kIsAnalysed = BIT(14) , kActiveSet = BIT(15) , kUnidentifiedParticle = BIT(16) , kIdentifiedParticle = BIT(17) } |
Private Member Functions | |
| void | AddDetectorSignal (KVDetectorSignal *ds) |
| Double_t | ELossActive (Double_t *x, Double_t *par) |
| Double_t | EResDet (Double_t *x, Double_t *par) |
| template<typename AbsorberStack > | |
| Double_t | get_corrected_energy (AbsorberStack *stack, KVNucleus *nuc, Double_t e, Bool_t transmission) |
| TGeoHMatrix * | GetMatrix () const override |
| Double_t | GetMisalignmentAngle () const override |
| TVector3 | GetRandomPointOnSurface () const override |
| TGeoBBox * | GetShape () const override |
| Double_t | GetSurfaceArea (int npoints=100000) const override |
| TVector3 | GetSurfaceCentre () const override |
| TVector3 | GetSurfaceNormal () const override |
| TVector3 | GetVolumeCentre () const override |
| Double_t | RangeDet (Double_t *x, Double_t *par) |
| void | remove_signal_for_calibrator (KVCalibrator *K) |
| void | SetMatrix (const TGeoHMatrix *m) override |
| void | SetShape (TGeoBBox *s) override |
| virtual Bool_t | use_signal_for_raw_data_tree (const TString &) const |
Private Attributes | |
| KVList | fAbsorbers |
| list of absorbers making up the detector More... | |
| KVMaterial * | fActiveLayer |
| The active absorber in the detector. More... | |
| KVList * | fCalibrators |
| list of associated calibrator objects More... | |
| Bool_t | fDetecting |
| =kTRUE if detector is "detecting", =kFALSE if not More... | |
| KVUniqueNameList | fDetSignals |
| list of signals associated with detector More... | |
| KVUniqueNameList | fDetSignalsForRawTree |
| list of signals used for raw data TTree More... | |
| TF1 * | fELossF |
| parametric function dE in active layer vs. incident energy More... | |
| TF1 * | fEResF |
| parametric function Eres residual energy after all layers of detector More... | |
| Double_t | fEResforEinc |
| used by GetIncidentEnergy & GetCorrectedEnergy More... | |
| KVPosition | fEWPosition |
| position of entrance window i.e. first volume in detector geometry More... | |
| TString | fFName |
| dynamically generated full name of detector More... | |
| Int_t | fIdentP |
| temporary counters, determine state of identified/unidentified particle flags More... | |
| TString | fNameOfArray |
| name of multidetector array this detector is part of More... | |
| KVGeoDetectorNode | fNode |
| positioning information relative to other detectors More... | |
| KVUniqueNameList | fParentStrucList |
| list of geometry structures which directly contain this detector More... | |
| KVList * | fParticles |
| list of particles hitting detector in an event More... | |
| Bool_t | fPresent |
| =kTRUE if detector is present, =kFALSE if it has been removed More... | |
| TF1 * | fRangeF |
| parametric function range of particles in detector More... | |
| Bool_t | fSimMode |
| =kTRUE when using to simulate detector response, =kFALSE when analysing data More... | |
| Bool_t | fSingleLayer |
| =kTRUE if detector has a single absorber layer More... | |
| Int_t | fUnidentP |
| temporary counters, determine state of identified/unidentified particle flags More... | |
Static Private Attributes | |
| static Int_t | fDetCounter = 0 |
Additional Inherited Members | |
Public Types inherited from KVMaterial | |
| enum | SolType { kEmax , kEmin } |
Public Types inherited from KVBase | |
| enum | EKaliVedaBits { kIsKaliVedaObject = BIT(23) } |
Public Types inherited from TObject | |
| enum | EDeprecatedStatusBits |
| enum | EStatusBits |
Public Attributes inherited from TObject | |
| kBitMask | |
| kCanDelete | |
| kCannotPick | |
| kHasUUID | |
| kInconsistent | |
| kInvalidObject | |
| kIsOnHeap | |
| kIsReferenced | |
| kMustCleanup | |
| kNoContextMenu | |
| kNotDeleted | |
| kObjInCanvas | |
| kOverwrite | |
| kSingleKey | |
| kWriteDelete | |
| kZombie | |
Protected Member Functions inherited from TObject | |
| virtual void | DoError (int level, const char *location, const char *fmt, va_list va) const |
| void | MakeZombie () |
Protected Attributes inherited from TNamed | |
| TString | fName |
| TString | fTitle |
Protected Attributes inherited from TObject | |
| kOnlyPrepStep | |
|
private |
| Enumerator | |
|---|---|
| kIsAnalysed | |
| kActiveSet | |
| kUnidentifiedParticle | |
| kIdentifiedParticle | |
Definition at line 168 of file KVDetector.h.
| KVDetector::KVDetector | ( | ) |
default ctor
Definition at line 58 of file KVDetector.cpp.
Create a new detector of a given material and thickness in centimetres (default value = 0.0)
Definition at line 71 of file KVDetector.cpp.
| KVDetector::KVDetector | ( | const Char_t * | gas, |
| const Double_t | thick, | ||
| const Double_t | pressure, | ||
| const Double_t | temperature = 19.0 |
||
| ) |
Create gaseous dteector with given type, linear thickness in cm, pressure in Torr, and temperature in degrees C (default value 19°C).
Definition at line 90 of file KVDetector.cpp.
| KVDetector::KVDetector | ( | const KVDetector & | obj | ) |
copy ctor
Definition at line 108 of file KVDetector.cpp.
|
virtual |
| void KVDetector::AddAbsorber | ( | KVMaterial * | mat | ) |
Add a layer of absorber material to the detector By default, the first layer added is set as the "Active" layer. Call SetActiveLayer to change this.
Definition at line 607 of file KVDetector.cpp.
| Bool_t KVDetector::AddCalibrator | ( | KVCalibrator * | cal, |
| const KVNameValueList & | opts = "" |
||
| ) |
Associate a calibration with this detector.
This will add a new signal to the list of the detector's signals.
Also sets calibrator's name to [detname]_[caltype] where caltype is the type of the KVCalibration object.
| [in] | cal | pointer to KVCalibrator object (must be on heap, i.e. created with new: detector handles deletion) |
| [in] | opts | can be used to pass any extra parameters/options needed by the calibrator. For example, if it contains a parameter ZRange=1-10
then the calibrator will be handled by a KVZDependentCalibratedSignal (handles several calibrators which provide the same output signal, each one is used for a specific range of atomic numbers) |
Definition at line 439 of file KVDetector.cpp.
|
inline |
Add a new signal to the list of detector's signals.
| [in] | type | define the name of the signal to add |
delete{.cpp} the signal object: the detector handles deletionDefinition at line 797 of file KVDetector.h.
|
inlineprivate |
Internal use only.
Add KVDetectorSignal object to list of detector's signals.
Definition at line 276 of file KVDetector.h.
Add a new KVDetectorSignalExpression to this detector
| [in] | type | the name/type of the new signal |
| [in] | _expr | mathematical expression using any of the known signals of the detector |
Definition at line 1802 of file KVDetector.cpp.
|
inlinevirtual |
Reimplemented in KVSegmentedDetector.
Definition at line 827 of file KVDetector.h.
Add to the list of particles hitting this detector in an event
Definition at line 419 of file KVDetector.h.
| void KVDetector::AddParentStructure | ( | KVGeoStrucElement * | elem | ) |
Definition at line 1630 of file KVDetector.cpp.
|
inline |
Definition at line 576 of file KVDetector.h.
|
inline |
Definition at line 572 of file KVDetector.h.
Set energy loss(es) etc. to zero
If opt="N":
Reimplemented from KVBase.
Reimplemented in KVFAZIADetector, and KVSegmentedDetector.
Definition at line 565 of file KVDetector.cpp.
|
inline |
clear the list of particles hitting this detector in an event
Definition at line 443 of file KVDetector.h.
copy 'this' to 'obj' The structure of the detector is copied, with new cloned objects for each absorber layer. The active layer is set in the new detector.
Reimplemented from KVBase.
Reimplemented in KVFAZIADetector.
Definition at line 129 of file KVDetector.cpp.
Calculate the energy loss of a charged particle traversing the detector, the particle is slowed down, it is added to the list of all particles hitting the detector. The apparent energy loss of the particle in the active layer of the detector is set. Do nothing if particle has zero (or -ve) energy.
If the optional argument 'norm' is given, it is supposed to be a vector normal to the detector, oriented from the origin towards the detector. In this case the effective thicknesses of the detector's absorbers 'seen' by the particle depending on its direction of motion is used for the calculation.
Reimplemented from KVMaterial.
Definition at line 195 of file KVDetector.cpp.
|
virtual |
Creates and fills a TGraph with the punch through energy in MeV vs. Z for the given detector, for Z=1-92. The mass of each nucleus is calculated according to the given mass formula (see KVNucleus).
Definition at line 1564 of file KVDetector.cpp.
|
virtual |
Creates and fills a TGraph with the punch through energy in MeV/nucleon vs. Z for the given detector, for Z=1-92. The mass of each nucleus is calculated according to the given mass formula (see KVNucleus).
Definition at line 1589 of file KVDetector.cpp.
Calculates energy loss (in MeV) in active layer of detector, taking into account preceding layers
Arguments are: x[0] is incident energy in MeV Parameters are: par[0] Z of ion par[1] A of ion
Definition at line 924 of file KVDetector.cpp.
Calculates residual energy (in MeV) of particle after traversing all layers of detector. Returned value is -1000 if particle stops in one of the layers of the detector.
Arguments are: x[0] is incident energy in MeV Parameters are: par[0] Z of ion par[1] A of ion
Definition at line 1018 of file KVDetector.cpp.
For particles which stop in the first stage of an identification telescope, we can at least estimate a minimum Z value based on the energy lost in this detector.
This is based on the KVMaterial::GetMaxDeltaE method, giving the maximum energy loss in the active layer of the detector for a given nucleus (A,Z).
The "Zmin" is the Z of the particle which gives a maximum energy loss just greater than that measured in the detector. Particles with Z<Zmin could not lose as much energy and so are excluded.
If ELOSS is not given, we use the current value of GetEnergy() Use 'mass_formula' to change the formula used to calculate the A of the nucleus from its Z. Default is valley of stability value. (see KVNucleus::GetAFromZ).
If the value of ELOSS or GetEnergy() is <=0 we return Zmin=0
Definition at line 850 of file KVDetector.cpp.
Returns kTRUE if detector was hit (fired) in an event
The actual meaning of hit/fired depends on the context and the option string opt.
If the detector is in "simulation mode", i.e. if SetSimMode(kTRUE) has been called, this method returns kTRUE if the calculated energy loss in the active layer is > 0.
In "experimental mode" (i.e. IsSimMode() returns kFALSE), depending on the option:
opt="any" (default): Returns true if ANY of the raw parameters associated with the detector were present in the last handled event opt="all" : Returns true if ALL of the raw parameters associated with the detector were present in the last handled event
Reimplemented in KVFAZIADetector.
Definition at line 462 of file KVDetector.h.
|
inlineprivate |
Definition at line 228 of file KVDetector.h.
|
inline |
Return absorber with given name
Definition at line 318 of file KVDetector.h.
| KVMaterial * KVDetector::GetAbsorber | ( | Int_t | i | ) | const |
Returns pointer to the i-th absorber in the detector (i=0 first absorber, i=1 second, etc.)
Definition at line 623 of file KVDetector.cpp.
|
inlineoverridevirtual |
Get pointer to the "active" layer in the detector, i.e. the one in which energy losses are measured
Reimplemented from KVMaterial.
Definition at line 312 of file KVDetector.h.
|
inline |
Return coordinate transformation matrix to active layer
Definition at line 600 of file KVDetector.h.
|
inline |
Return geometry of active layer
Definition at line 595 of file KVDetector.h.
|
inline |
Return centre of entrance surface of active layer [this is NOT necessarily the same as the entrance window]
Definition at line 584 of file KVDetector.h.
|
inline |
Return centre of the active layer volume
Definition at line 590 of file KVDetector.h.
|
inlinevirtual |
Returns energy loss in detector calculated using available calibration(s)
Definition at line 359 of file KVDetector.h.
|
inline |
Definition at line 832 of file KVDetector.h.
|
inline |
Definition at line 840 of file KVDetector.h.
|
inline |
This method does exactly the same as the method in previous versions of KaliVeda: it returns the vector position of the centre of the surface (entrance) of the "entrance window" of the detector i.e. the first volume encountered
Definition at line 700 of file KVDetector.h.
|
virtual |
Returns the total energy loss in the detector for a given nucleus including inactive absorber layers. e = energy loss in active layer (if not given, we use current value) transmission = kTRUE (default): the particle is assumed to emerge with a non-zero residual energy Eres after the detector. = kFALSE: the particle is assumed to stop in the detector.
WARNING: if transmission=kTRUE, and if the residual energy after the detector is known (i.e. measured in a detector placed after this one), you should first call SetEResAfterDetector(Eres); before calling this method. Otherwise, especially for heavy ions, the correction may be false for particles which are just above the punch-through energy.
WARNING 2: if measured energy loss in detector active layer is greater than maximum possible theoretical value for given nucleus' Z & A, this may be because the A was not measured but calculated from Z and hence could be false, or perhaps there was an (undetected) pile-up of two or more particles in the detector. In this case we return the corrected energy corresponding to the maximum theoretical energy loss in the active layer and we add the following parameters to the particle (in nuc->GetParameters()):
GetCorrectedEnergy.Warning = 1 GetCorrectedEnergy.Detector = [name] GetCorrectedEnergy.MeasuredDE = [value] GetCorrectedEnergy.MaxDE = [value] GetCorrectedEnergy.Transmission = 0 or 1 GetCorrectedEnergy.ERES = [value]
Reimplemented in KVCsI.
Definition at line 751 of file KVDetector.cpp.
|
inlineoverridevirtual |
cosinus of polar angle corresponding to centre of entrance window of detector
Reimplemented from KVPosition.
Definition at line 749 of file KVDetector.h.
Overrides KVMaterial::GetDeltaE Returns energy loss of given nucleus in the active layer of the detector. optimization for single-layer detectors
Reimplemented from KVMaterial.
Definition at line 1224 of file KVDetector.cpp.
Overrides KVMaterial::GetDeltaEFromERes
Calculate energy loss in active layer of detGetAlignedDetector for nucleus (Z,A) having a residual kinetic energy Eres (MeV)
Reimplemented from KVMaterial.
Definition at line 1368 of file KVDetector.cpp.
|
inlinevirtual |
| [in] | type | name/type of signal |
Reimplemented in KVCsI.
Definition at line 544 of file KVDetector.h.
|
inline |
| [in] | type | name/type of signal |
| [in] | params | list of extra parameters possibly required to calculate value of signal can be passed as a string of "param1=value,param2=value,..." parameter/value pairs |
Definition at line 504 of file KVDetector.h.
|
inlineoverridevirtual |
direction corresponding to centre of entrance window
Reimplemented from KVPosition.
Definition at line 725 of file KVDetector.h.
distance from target [cm] to entrance window of detector
Reimplemented from KVPosition.
Definition at line 731 of file KVDetector.h.
Overrides KVMaterial::GetEIncOfMaxDeltaE Returns incident energy corresponding to maximum energy loss in the active layer of the detector, for a given nucleus.
Reimplemented from KVMaterial.
Definition at line 1192 of file KVDetector.cpp.
Return pointer to TF1 giving energy loss in active layer of detector as function of incident energy, for a given nucleus (Z,A). The TF1::fNpx parameter is taken from environment variable KVDetector.EnergyLoss.Npx
Definition at line 1168 of file KVDetector.cpp.
Calculate the total energy loss of a charged particle traversing the detector. This does not affect the "stored" energy loss value of the detector, nor its ACQData, nor the energy of the particle.
If the optional argument 'norm' is given, it is supposed to be a vector normal to the detector, oriented from the origin towards the detector. In this case the effective thicknesses of the detector's absorbers 'seen' by the particle depending on its direction of motion is used for the calculation.
Reimplemented from KVMaterial.
Definition at line 268 of file KVDetector.cpp.
|
inlinevirtual |
Returns either the calibrated energy loss measured in the active layer of the detector, or (if IsSimMode()==kTRUE) the simulated energy losses
Reimplemented in KVPhoswich.
Definition at line 364 of file KVDetector.h.
|
inlineoverridevirtual |
Reimplemented from KVMaterial.
Definition at line 384 of file KVDetector.h.
|
inline |
Returns KVPosition object corresponding to the entrance window volume i.e. the first volume encountered in the detector
Definition at line 694 of file KVDetector.h.
|
virtual |
Return surface area of first layer of detector in cm2.
Definition at line 1099 of file KVDetector.cpp.
Overrides KVMaterial::GetERes Returns residual energy of given nucleus after the detector. Returns 0 if Einc<=0
Reimplemented from KVMaterial.
Definition at line 1257 of file KVDetector.cpp.
|
inlinevirtual |
Definition at line 632 of file KVDetector.h.
Return pointer toTF1 giving residual energy after detector as function of incident energy, for a given nucleus (Z,A). The TF1::fNpx parameter is taken from environment variable KVDetector.ResidualEnergy.Npx
Definition at line 1118 of file KVDetector.cpp.
| KVGroup * KVDetector::GetGroup | ( | ) | const |
Definition at line 1612 of file KVDetector.cpp.
| UInt_t KVDetector::GetGroupNumber | ( | ) |
Definition at line 1621 of file KVDetector.cpp.
|
inline |
Return the list of particles hitting this detector in an event.
Definition at line 439 of file KVDetector.h.
|
overridevirtual |
Overrides KVMaterial::GetIncidentEnergy Returns incident energy corresponding to energy loss delta_e in active layer of detector for a given nucleus. If delta_e is not given, the current energy loss in the active layer is used.
By default the solution corresponding to the highest incident energy is returned This is the solution found for Einc greater than the maximum of the dE(Einc) curve. If you want the low energy solution set SolType = KVIonRangeTable::kEmin.
WARNING: calculating the incident energy of a particle using only the dE in a detector is ambiguous, as in general (and especially for very heavy ions) the maximum of the dE curve occurs for Einc greater than the punch-through energy, therefore it is not always true to assume that if the particle does not stop in the detector the required solution is that for type=KVIonRangeTable::kEmax. For a range of energies between punch-through and dE_max, the required solution is still that for type=KVIonRangeTable::kEmin. If the residual energy of the particle is unknown, there is no way to know which is the correct solution.
WARNING 2 If the given energy loss in the active layer is greater than the maximum theoretical dE for given Z & A, (dE > GetMaxDeltaE(Z,A)) then we return a NEGATIVE incident energy corresponding to the maximum, GetEIncOfMaxDeltaE(Z,A)
Reimplemented from KVMaterial.
Definition at line 1296 of file KVDetector.cpp.
Overrides KVMaterial::GetIncidentEnergyFromERes
Calculate incident energy of nucleus from residual energy.
Returns -1 if Eres is out of defined range of values
Reimplemented from KVMaterial.
Definition at line 1390 of file KVDetector.cpp.
|
inlinevirtual |
Return a numerical identifier for the detector
Can be overridden in specialised detector classes
Reimplemented in KVINDRADetector, and KVFAZIADetector.
Definition at line 811 of file KVDetector.h.
|
inline |
| [in] | output | name/type of output signal |
| [in] | value | value of output signal |
| [in] | input | name/type of input signal |
| [in] | params | list of extra parameters possibly required to calculate value of signal can be passed as a string of "param1=value,param2=value,..." parameter/value pairs |
Calculate the value of the input signal for a given value of the output signal.
This uses the inverse calibrations of all intermediate signals.
Definition at line 528 of file KVDetector.h.
Returns range of ion in centimetres in this detector, taking into account all layers. Note that for Einc > punch through energy, this range is no longer correct (but still > total thickness of detector).
Reimplemented from KVMaterial.
Definition at line 1529 of file KVDetector.cpp.
|
inline |
Definition at line 323 of file KVDetector.h.
|
inline |
Definition at line 401 of file KVDetector.h.
|
inline |
Definition at line 789 of file KVDetector.h.
|
inline |
Definition at line 793 of file KVDetector.h.
|
inline |
Definition at line 349 of file KVDetector.h.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 189 of file KVDetector.h.
Overrides KVMaterial::GetMaxDeltaE Returns maximum energy loss in the active layer of the detector, for a given nucleus.
Reimplemented from KVMaterial.
Definition at line 1208 of file KVDetector.cpp.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 217 of file KVDetector.h.
|
inline |
Return name of multidetector array this detector belongs to
Definition at line 783 of file KVDetector.h.
|
inline |
Return the number of particles hitting this detector in an event.
Definition at line 449 of file KVDetector.h.
|
inline |
Definition at line 344 of file KVDetector.h.
|
inline |
Definition at line 327 of file KVDetector.h.
| KVGeoStrucElement * KVDetector::GetParentStructure | ( | const Char_t * | type, |
| const Char_t * | name = "" |
||
| ) | const |
Get parent geometry structure element of given type. Give unique name of structure if more than one element of same type is possible.
Definition at line 1650 of file KVDetector.cpp.
|
overridevirtual |
Calculate the energy of particle 'kvn' before its passage through the detector, based on the current kinetic energy, Z & A of nucleus 'kvn', supposed to be after passing through the detector.
If the optional argument 'norm' is given, it is supposed to be a vector normal to the detector, oriented from the origin towards the detector. In this case the effective thicknesses of the detector's absorbers 'seen' by the particle depending on its direction of motion is used for the calculation.
Reimplemented from KVMaterial.
Definition at line 320 of file KVDetector.cpp.
|
inlineoverridevirtual |
azimuthal angle [deg.] corresponding to centre of entrance window of detector
Reimplemented from KVPosition.
Definition at line 755 of file KVDetector.h.
Returns energy (in MeV) necessary for ion (Z,A) to punch through all layers of this detector
Reimplemented from KVMaterial.
Definition at line 1544 of file KVDetector.cpp.
|
inlineoverridevirtual |
random angles [deg.] corresponding to point on entrance window
Reimplemented from KVPosition.
Definition at line 719 of file KVDetector.h.
random direction corresponding to point on entrance window
Reimplemented from KVPosition.
Definition at line 713 of file KVDetector.h.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 197 of file KVDetector.h.
WARNING: SAME AS KVDetector::GetLinearRange Only linear range in centimetres is calculated for detectors!
Reimplemented from KVMaterial.
Definition at line 1514 of file KVDetector.cpp.
Return pointer toTF1 giving range (in centimetres) in detector as function of incident energy, for a given nucleus (Z,A). The TF1::fNpx parameter is taken from environment variable KVDetector.Range.Npx
Definition at line 1143 of file KVDetector.cpp.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 193 of file KVDetector.h.
|
inlineoverridevirtual |
sinus of polar angle corresponding to centre of entrance window of detector
Reimplemented from KVPosition.
Definition at line 743 of file KVDetector.h.
Returns the smallest maximum energy for which range tables are valid for all absorbers in the detector, and given ion (Z,A)
Definition at line 1415 of file KVDetector.cpp.
Return solid angle [msr] corresponding to the entrance window of the detector
Reimplemented from KVPosition.
Definition at line 707 of file KVDetector.h.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 213 of file KVDetector.h.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 201 of file KVDetector.h.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 209 of file KVDetector.h.
|
inlineoverridevirtual |
polar angle [deg.] corresponding to centre of entrance window of detector
Reimplemented from KVPosition.
Definition at line 737 of file KVDetector.h.
Returns calculated total energy loss of ion in ALL layers of the detector. This is just (Einc - GetERes(Z,A,Einc))
Definition at line 1242 of file KVDetector.cpp.
|
inline |
Calculate and return the total thickness in centimetres of ALL absorbers making up the detector, not just the active layer (value returned by GetThickness()).
Definition at line 333 of file KVDetector.h.
|
inlineoverrideprivatevirtual |
Reimplemented from KVPosition.
Definition at line 205 of file KVDetector.h.
| [in] | type | name/type of signal |
Definition at line 553 of file KVDetector.h.
| Bool_t KVDetector::HasSameStructureAs | ( | const KVDetector * | other | ) | const |
Return kTRUE if the two detectors have the same internal structure, i.e.
Definition at line 1771 of file KVDetector.cpp.
Definition at line 566 of file KVDetector.h.
Definition at line 560 of file KVDetector.h.
default initialisations
Definition at line 31 of file KVDetector.cpp.
|
inline |
Definition at line 454 of file KVDetector.h.
|
inline |
A detector is considered to be calibrated if it has a signal "Energy" available
Definition at line 405 of file KVDetector.h.
| Bool_t KVDetector::IsCalibrated | ( | const KVNameValueList & | params | ) | const |
A detector is considered to be calibrated if it has a signal "Energy" available and if depending on the supplied parameters this signal can be calculated
Definition at line 545 of file KVDetector.cpp.
|
inlinevirtual |
return if the detector is ready to detect or not
Definition at line 667 of file KVDetector.h.
|
inline |
Definition at line 773 of file KVDetector.h.
|
inline |
Returns kTRUE for detectors with several absorber layers
Definition at line 768 of file KVDetector.h.
|
inlinevirtual |
return kTRUE if detector is here and working
Definition at line 677 of file KVDetector.h.
|
inlinevirtual |
return the presence or not of the detector
Definition at line 658 of file KVDetector.h.
|
inlinevirtual |
Reimplemented in KVSegmentedDetector.
Definition at line 823 of file KVDetector.h.
|
inlinevirtual |
Returns simulation mode of detector: IsSimMode()=kTRUE : we are in simulation mode (calculation of energy losses etc.) IsSimMode()=kFALSE: we are analysing/reconstruction experimental data Changes behaviour of Fired(): in simulation mode, Fired() returns kTRUE whenever the energy loss in the active layer is >0
Definition at line 648 of file KVDetector.h.
|
inline |
Returns kTRUE for detectors with a single absorber layer
Definition at line 763 of file KVDetector.h.
|
static |
Static function which will create an instance of the KVDetector-derived class corresponding to 'name' These are defined as 'Plugin' objects in the file $KVROOT/KVFiles/.kvrootrc : [name_of_dataset].detector_type detector_type To use the dataset-dependent plugin, call this method with name = "[name_of_dataset].detector_type" If not, the default plugin will be used first we check if there is a special plugin for the DataSet if not we take the default one
'thickness' is passed as argument to the constructor for the detector plugin check and load plugin library
Definition at line 1059 of file KVDetector.cpp.
Print info on this detector if option="data" the energy loss and raw data are displayed
Reimplemented from KVBase.
Definition at line 356 of file KVDetector.cpp.
Calculates range (in centimetres) of ions in detector as a function of incident energy (in MeV), taking into account all layers of the detector.
Arguments are: x[0] = incident energy in MeV Parameters are: par[0] = Z of ion par[1] = A of ion
Definition at line 962 of file KVDetector.cpp.
Create detector from text file in 'TEnv' format.
Layer: Gold Gold.Material: Au Gold.AreaDensity: 200.*KVUnits::ug +Layer: Gas1 Gas1.Material: C3F8 Gas1.Thickness: 5.*KVUnitscm Gas1.Pressure: 50.*KVUnits::mbar Gas1.Active: yes +Layer: Si1 Si1.Material: Si Si1.Thickness: 300.*KVUnitsum
Definition at line 1452 of file KVDetector.cpp.
|
private |
Used when a calibrator object is removed or replaced We remove and delete the corresponding output signal from the list of detector signals
Definition at line 679 of file KVDetector.cpp.
| void KVDetector::RemoveAllAbsorbers | ( | ) |
Completely reset the KVDetector as if it had just been created by a call to the default constructor:
Definition at line 646 of file KVDetector.cpp.
|
virtual |
Removes all calibrations associated to this detector: in other words, we delete all the KVCalibrator objects in list fCalibrators.
We also destroy all signals provided by these calibrators
Reimplemented in KVCsI.
Definition at line 701 of file KVDetector.cpp.
Remove from list of particles hitting this detector in an event
Definition at line 430 of file KVDetector.h.
| void KVDetector::RemoveParentStructure | ( | KVGeoStrucElement * | elem | ) |
Definition at line 1639 of file KVDetector.cpp.
| Bool_t KVDetector::ReplaceCalibrator | ( | const Char_t * | type, |
| KVCalibrator * | cal, | ||
| const KVNameValueList & | opts = "" |
||
| ) |
Replace calibrator of given type with the given calibrator object The calibrator object should not be shared with any other detectors: it now belongs to this detector, which will delete it when necessary. If an exising calibrator with the same type is already defined, it will be deleted and removed from the detector's calibrator list
Returns kFALSE in case of problems.
The (optional) KVNameValueList argument can be used to pass any extra parameters/options.
Definition at line 517 of file KVDetector.cpp.
Definition at line 413 of file KVDetector.h.
Set active layer with index (=0, 1, ...)
Definition at line 307 of file KVDetector.h.
|
inline |
Definition at line 302 of file KVDetector.h.
| void KVDetector::SetActiveLayerMatrix | ( | const TGeoHMatrix * | m | ) |
Set ROOT geometry global matrix transformation to coordinate frame of active layer volume.
Definition at line 1670 of file KVDetector.cpp.
Set ROOT geometry shape of active layer volume.
Definition at line 1681 of file KVDetector.cpp.
Definition at line 458 of file KVDetector.h.
Definition at line 672 of file KVDetector.h.
| [in] | type | name/type of signal |
| [in] | val | value to set for signal |
Set value of signal of given type associated with detector
Definition at line 517 of file KVDetector.h.
Set value of energy lost in active layer
Reimplemented in KVPhoswich.
Definition at line 376 of file KVDetector.h.
Reimplemented from KVMaterial.
Definition at line 388 of file KVDetector.h.
| void KVDetector::SetEntranceWindowMatrix | ( | const TGeoHMatrix * | m | ) |
Set ROOT geometry global matrix transformation to coordinate frame of entrance window.
Definition at line 1692 of file KVDetector.cpp.
Set ROOT geometry shape of entrance window.
Definition at line 1703 of file KVDetector.cpp.
Definition at line 628 of file KVDetector.h.
Set material of active layer. If no absorbers have been added to the detector, create and add one (active layer by default)
Reimplemented from KVMaterial.
Definition at line 169 of file KVDetector.cpp.
|
inlineoverrideprivatevirtual |
Make KVPosition methods private to avoid misuse N.B. the inherited KVPosition part of KVDetector is used for the ACTIVE layer of the detector the entrance window is described by member KVPosition fEWPosition
Reimplemented from KVPosition.
Definition at line 181 of file KVDetector.h.
Definition at line 779 of file KVDetector.h.
Definition at line 663 of file KVDetector.h.
| [in] | P | pressure in [Torr] |
For a gaseous detector, set/change the pressure of the active gas layer.
For ROOT geometries, we change the medium/material of the corresponding node in the geometry in order to reflect the change in pressure (gases are represented by different media/materials for each pressure/temperature) so that it will be taken into account for example when filtering simulated data.
Reimplemented from KVMaterial.
Reimplemented in KVChIo.
Definition at line 1832 of file KVDetector.cpp.
Reimplemented from KVPosition.
Definition at line 185 of file KVDetector.h.
Set simulation mode of detector If on=kTRUE (default), we are in simulation mode (calculation of energy losses etc.) If on=kFALSE, we are analysing/reconstruction experimental data Changes behaviour of Fired(): in simulation mode, Fired() returns kTRUE whenever the energy loss in the active layer is >0
Definition at line 639 of file KVDetector.h.
| [in] | T | pressure in [deg. C] |
For a gaseous detector, set/change the temperature of the active gas layer.
For ROOT geometries, we change the medium/material of the corresponding node in the geometry in order to reflect the change in temperature (gases are represented by different media/materials for each pressure/temperature) so that it will be taken into account for example when filtering simulated data.
Reimplemented from KVMaterial.
Definition at line 1863 of file KVDetector.cpp.
Overrides KVMaterial::SetThickness
If ROOT geometry is defined, we modify the DZ thickness of the volume representing this detector in accordance with the new thickness.
This is only implemented for single-layer detectors with the following shapes:
Reimplemented from KVMaterial.
Reimplemented in KVSilicon.
Definition at line 1722 of file KVDetector.cpp.
|
inlineprivatevirtual |
Reimplemented in KVINDRADetector, and KVFAZIADetector.
Definition at line 285 of file KVDetector.h.
|
private |
list of absorbers making up the detector
Definition at line 258 of file KVDetector.h.
|
private |
The active absorber in the detector.
Definition at line 165 of file KVDetector.h.
|
private |
list of associated calibrator objects
Definition at line 256 of file KVDetector.h.
|
staticprivate |
Definition at line 164 of file KVDetector.h.
|
private |
=kTRUE if detector is "detecting", =kFALSE if not
Definition at line 272 of file KVDetector.h.
|
private |
list of signals associated with detector
Definition at line 222 of file KVDetector.h.
|
private |
list of signals used for raw data TTree
Definition at line 223 of file KVDetector.h.
|
private |
parametric function dE in active layer vs. incident energy
Definition at line 264 of file KVDetector.h.
|
private |
parametric function Eres residual energy after all layers of detector
Definition at line 265 of file KVDetector.h.
|
private |
used by GetIncidentEnergy & GetCorrectedEnergy
Definition at line 268 of file KVDetector.h.
|
private |
position of entrance window i.e. first volume in detector geometry
Definition at line 161 of file KVDetector.h.
|
private |
dynamically generated full name of detector
Definition at line 255 of file KVDetector.h.
|
private |
temporary counters, determine state of identified/unidentified particle flags
Definition at line 175 of file KVDetector.h.
|
private |
name of multidetector array this detector is part of
Definition at line 166 of file KVDetector.h.
|
private |
positioning information relative to other detectors
Definition at line 163 of file KVDetector.h.
|
private |
list of geometry structures which directly contain this detector
Definition at line 162 of file KVDetector.h.
|
private |
list of particles hitting detector in an event
Definition at line 257 of file KVDetector.h.
|
private |
=kTRUE if detector is present, =kFALSE if it has been removed
Definition at line 271 of file KVDetector.h.
|
private |
parametric function range of particles in detector
Definition at line 266 of file KVDetector.h.
|
private |
=kTRUE when using to simulate detector response, =kFALSE when analysing data
Definition at line 270 of file KVDetector.h.
|
private |
=kTRUE if detector has a single absorber layer
Definition at line 274 of file KVDetector.h.
|
private |
temporary counters, determine state of identified/unidentified particle flags
Definition at line 176 of file KVDetector.h.