Neutral Particle Spectrometer analysis code
Loading...
Searching...
No Matches
THcNPSApparatus Class Reference

A dummy spectrometer apparatus for testing detectors.

This class behaves as a spectrometer apparatus in that it holds detector classes, but it does no reconstruction. It is intended to provide an elegant way to setup a teststand for a detector or a set of detectors, without requiring some "needed" detectors or parameters.

Definition at line 13 of file THcNPSApparatus.h.

Public Types

enum  EStagesDone { kCoarseTrack = BIT(0) , kCoarseRecon = BIT(1) , kTracking = BIT(2) , kReconstruct = BIT(3) }
 
- Public Types inherited from THaAnalysisObject
enum  EMode
 
enum  EStatus
 
enum  EType
 
- Public Types inherited from TObject
enum  EDeprecatedStatusBits
 
enum  EStatusBits
 

Public Member Functions

virtual Int_t CoarseReconstruct ()
 
TString GetKwPrefix ()
 Returns prefix used for parameters in param files.
 
Double_t GetNPSAngle ()
 
virtual Int_t Reconstruct ()
 Does nothing and returns 0.
 
 THcNPSApparatus (const char *name, const char *description)
 A constructor.
 
virtual ~THcNPSApparatus ()
 A destructor.
 
- Public Member Functions inherited from THaApparatus
virtual Int_t AddDetector (THaDetector *det, Bool_t quiet=false, Bool_t first=false)
 
virtual Int_t Begin (THaRunBase *r=nullptr)
 
virtual void Clear (Option_t *opt="")
 
virtual Int_t Decode (const THaEvData &)
 
virtual Int_t End (THaRunBase *r=nullptr)
 
virtual THaDetectorGetDetector (const char *name)
 
TListGetDetectors ()
 
Int_t GetNumDets () const
 
virtual EStatus Init (const TDatime &run_time)
 
virtual void Print (Option_t *opt="") const
 
virtual void SetDebugAll (Int_t level)
 
virtual ~THaApparatus ()
 
- Public Member Functions inherited from THaAnalysisObject
const char * GetClassName () const
 
const char * GetConfig () const
 
virtual const char * GetDBFileName () const
 
Int_t GetDebug () const
 
TDatime GetInitDate () const
 
const char * GetPrefix () const
 
TString GetPrefixName () const
 
EStatus Init ()
 
virtual Int_t InitOutput (THaOutput *)
 
Bool_t IsInit () const
 
Bool_t IsOK () const
 
Bool_t IsOKOut () const
 
virtual FILE * OpenFile (const TDatime &date)
 
virtual FILE * OpenRunDBFile (const TDatime &date)
 
THaAnalysisObjectoperator= (const THaAnalysisObject &&)=delete
 
THaAnalysisObjectoperator= (const THaAnalysisObject &)=delete
 
void SetConfig (const char *label)
 
virtual void SetDebug (Int_t level)
 
virtual void SetName (const char *name)
 
virtual void SetNameTitle (const char *name, const char *title)
 
EStatus Status () const
 
 THaAnalysisObject ()
 
 THaAnalysisObject (const THaAnalysisObject &&)=delete
 
 THaAnalysisObject (const THaAnalysisObject &)=delete
 
virtual ~THaAnalysisObject ()
 
- Public Member Functions inherited from TNamed
void Clear (Option_t *option="") override
 
TObjectClone (const char *newname="") const override
 
Int_t Compare (const TObject *obj) const override
 
void Copy (TObject &named) const override
 
virtual void FillBuffer (char *&buffer)
 
const char * GetName () const override
 
const char * GetTitle () const override
 
ULong_t Hash () const override
 
TClassIsA () const override
 
Bool_t IsSortable () const override
 
void ls (Option_t *option="") const override
 
TNamedoperator= (const TNamed &rhs)
 
void Print (Option_t *option="") const override
 
virtual void SetTitle (const char *title="")
 
virtual Int_t Sizeof () const
 
void Streamer (TBuffer &) override
 
void StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b)
 
 TNamed ()
 
 TNamed (const char *name, const char *title)
 
 TNamed (const TNamed &named)
 
 TNamed (const TString &name, const TString &title)
 
virtual ~TNamed ()
 
- Public Member Functions inherited from 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 TObjectDrawClone (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=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 TObjectFindObject (const char *name) const
 
virtual TObjectFindObject (const TObject *obj) const
 
virtual Option_tGetDrawOption () const
 
virtual const char * GetIconName () const
 
virtual char * GetObjectInfo (Int_t px, Int_t py) const
 
virtual Option_tGetOption () 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)
 
voidoperator new (size_t sz)
 
voidoperator new (size_t sz, void *vp)
 
voidoperator new[] (size_t sz)
 
voidoperator new[] (size_t sz, void *vp)
 
TObjectoperator= (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
 
 TObject ()
 
 TObject (const TObject &object)
 
virtual void UseCurrentStyle ()
 
virtual void Warning (const char *method, const char *msgfmt,...) const
 
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
 
virtual ~TObject ()
 

Protected Member Functions

virtual Int_t DefineVariables (EMode mode=kDefine)
 
virtual Int_t ReadDatabase (const TDatime &date)
 
virtual Int_t ReadRunDatabase (const TDatime &date)
 
- Protected Member Functions inherited from THaApparatus
 THaApparatus ()
 
 THaApparatus (const char *name, const char *description)
 
- Protected Member Functions inherited from THaAnalysisObject
virtual const char * ClassNameHere (const char *) const
 
Int_t DefineVarsFromList (const RVarDef *list, EMode mode, const char *def_prefix="", const char *comment_subst="") const
 
Int_t DefineVarsFromList (const VarDef *list, EMode mode=kDefine, const char *def_prefix="", const char *comment_subst="") const
 
Int_t DefineVarsFromList (const void *list, EType type, EMode mode, const char *def_prefix="", const char *comment_subst="") const
 
virtual void DoError (int level, const char *location, const char *fmt, va_list va) const
 
THaAnalysisObjectFindModule (const char *name, const char *classname, bool do_error=true)
 
virtual const char * Here (const char *) const
 
Int_t LoadDB (FILE *f, const TDatime &date, const DBRequest *req, Int_t search=0) const
 
virtual void MakePrefix ()
 
void MakePrefix (const char *basename)
 
Int_t RemoveVariables ()
 
 THaAnalysisObject (const char *name, const char *description)
 
- Protected Member Functions inherited from TObject
void MakeZombie ()
 

Protected Attributes

std::string fKwPrefix
 
TListfNonTrackingDetectors
 
UInt_t fStagesDone
 
Double_t fTheta_lab
 
TClonesArrayfTracks
 
- Protected Attributes inherited from THaApparatus
TListfDetectors
 
- Protected Attributes inherited from THaAnalysisObject
TString fConfig
 
Int_t fDebug
 
TObjectfExtra
 
TDatime fInitDate
 
Bool_t fIsInit
 
Bool_t fIsSetup
 
std::map< std::string, UInt_tfMessages
 
UInt_t fNEventsWithWarnings
 
Bool_t fOKOut
 
char * fPrefix
 
UInt_t fProperties
 
EStatus fStatus
 
 kConfigOverride
 
 kNeedsRunDB
 
- Protected Attributes inherited from TNamed
TString fName
 
TString fTitle
 
- Protected Attributes inherited from TObject
 kOnlyPrepStep
 

Private Member Functions

 ClassDef (THcNPSApparatus, 0)
 
void ListInit ()
 
 THcNPSApparatus ()
 

Private Attributes

Bool_t fListInit
 

Additional Inherited Members

- Static Public Member Functions inherited from THaAnalysisObject
static Int_t DefineVarsFromList (const void *list, EType type, EMode mode, const char *def_prefix, const TObject *obj, const char *prefix, const char *here, const char *comment_subst="")
 
static void GeoToSph (Double_t th_geo, Double_t ph_geo, Double_t &th_sph, Double_t &ph_sph)
 
static Bool_t IntersectPlaneWithRay (const TVector3 &xax, const TVector3 &yax, const TVector3 &org, const TVector3 &ray_start, const TVector3 &ray_vect, Double_t &length, TVector3 &intersect)
 
static Int_t LoadDB (FILE *file, const TDatime &date, const DBRequest *request, const char *prefix, Int_t search=0, const char *here="THaAnalysisObject::LoadDB")
 
static void PrintObjects (Option_t *opt="")
 
static void SphToGeo (Double_t th_sph, Double_t ph_sph, Double_t &th_geo, Double_t &ph_geo)
 
- Static Public Member Functions inherited from TNamed
static TClassClass ()
 
static const char * Class_Name ()
 
static constexpr Version_t Class_Version ()
 
static const char * DeclFileName ()
 
- Static Public Member Functions inherited from TObject
static TClassClass ()
 
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)
 
- Public Attributes inherited from THaAnalysisObject
 kDefine
 
 kDelete
 
 kFileError
 
 kInitError
 
 kNotinit
 
 kOK
 
 kRVarDef
 
 kVarDef
 
- Public Attributes inherited from TObject
 kBitMask
 
 kCanDelete
 
 kCannotPick
 
 kHasUUID
 
 kInconsistent
 
 kInvalidObject
 
 kIsOnHeap
 
 kIsReferenced
 
 kMustCleanup
 
 kNoContextMenu
 
 kNotDeleted
 
 kObjInCanvas
 
 kOverwrite
 
 kSingleKey
 
 kWriteDelete
 
 kZombie
 
- Protected Types inherited from THaAnalysisObject
enum  EProperties
 

#include <THcNPSApparatus.h>

Inheritance diagram for THcNPSApparatus:

Member Enumeration Documentation

◆ EStagesDone

Enumerator
kCoarseTrack 
kCoarseRecon 
kTracking 
kReconstruct 

Definition at line 24 of file THcNPSApparatus.h.

Constructor & Destructor Documentation

◆ THcNPSApparatus() [1/2]

THcNPSApparatus::THcNPSApparatus ( const char *  name,
const char *  description 
)

A constructor.

Parameters
[in]nameName of the apparatus. Is typically "H", "P" or "S" for HMS, SHMS and SOS, respectively.
[in]descriptionDescription of the apparatus.

Definition at line 60 of file THcNPSApparatus.cxx.

◆ ~THcNPSApparatus()

THcNPSApparatus::~THcNPSApparatus ( )
virtual

A destructor.

Definition at line 78 of file THcNPSApparatus.cxx.

◆ THcNPSApparatus() [2/2]

THcNPSApparatus::THcNPSApparatus ( )
private

Definition at line 249 of file THcNPSApparatus.cxx.

Member Function Documentation

◆ ClassDef()

THcNPSApparatus::ClassDef ( THcNPSApparatus  ,
 
)
private

◆ CoarseReconstruct()

Int_t THcNPSApparatus::CoarseReconstruct ( )
virtual

Reimplemented from THaApparatus.

Definition at line 114 of file THcNPSApparatus.cxx.

◆ DefineVariables()

Int_t THcNPSApparatus::DefineVariables ( THaAnalysisObject::EMode  mode = kDefine)
protectedvirtual

Reimplemented from THaAnalysisObject.

Definition at line 236 of file THcNPSApparatus.cxx.

◆ GetKwPrefix()

TString THcNPSApparatus::GetKwPrefix ( )

Returns prefix used for parameters in param files.

All the parameters read by this apparatus are prefixed with the returned string.

Definition at line 204 of file THcNPSApparatus.cxx.

◆ GetNPSAngle()

Double_t THcNPSApparatus::GetNPSAngle ( )
inline

Definition at line 20 of file THcNPSApparatus.h.

◆ ListInit()

void THcNPSApparatus::ListInit ( )
private

Definition at line 81 of file THcNPSApparatus.cxx.

◆ ReadDatabase()

Int_t THcNPSApparatus::ReadDatabase ( const TDatime date)
protectedvirtual

Reimplemented from THaAnalysisObject.

Definition at line 214 of file THcNPSApparatus.cxx.

◆ ReadRunDatabase()

Int_t THcNPSApparatus::ReadRunDatabase ( const TDatime date)
protectedvirtual

Reimplemented from THaAnalysisObject.

Definition at line 208 of file THcNPSApparatus.cxx.

◆ Reconstruct()

Int_t THcNPSApparatus::Reconstruct ( )
virtual

Does nothing and returns 0.

This function is usually responsible for reconstructing the event from the detectors in the spectrometer. Since this is a dummy apparatus, we have a dummy reconstruction.

Implements THaApparatus.

Definition at line 146 of file THcNPSApparatus.cxx.

Member Data Documentation

◆ fKwPrefix

std::string THcNPSApparatus::fKwPrefix
protected

Definition at line 42 of file THcNPSApparatus.h.

◆ fListInit

Bool_t THcNPSApparatus::fListInit
private

Definition at line 47 of file THcNPSApparatus.h.

◆ fNonTrackingDetectors

TList* THcNPSApparatus::fNonTrackingDetectors
protected

Definition at line 38 of file THcNPSApparatus.h.

◆ fStagesDone

UInt_t THcNPSApparatus::fStagesDone
protected

Definition at line 44 of file THcNPSApparatus.h.

◆ fTheta_lab

Double_t THcNPSApparatus::fTheta_lab
protected

Definition at line 40 of file THcNPSApparatus.h.

◆ fTracks

TClonesArray* THcNPSApparatus::fTracks
protected

Definition at line 32 of file THcNPSApparatus.h.

Collaboration diagram for THcNPSApparatus:

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