ROOT logo
HYDRA - THE HADES ANALYSIS PACKAGE » (UNKNOWN) » HBeam

class HBeam: public TObject


 Beam line transport

 Author:  T. Hennino (core), J. Biernat , J.Markert
          Pluto implementation by IF
 Written: 14.11.2013


Function Members (Methods)

public:
HBeam()
HBeam(const HBeam&)
virtual~HBeam()
voidTObject::AbstractMethod(const char* method) const
Int_taddDetector(TString name, Double_t distance, Int_t cutType, Double_t xcut = 50, Double_t ycut = 50)
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) const
voidcreateBeam(HBeamParticle& part)
Bool_tcreateDetectorHits(HBeamParticle& part)
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
vector<HBeamElement>&getDetectors()
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
vector<HBeamElement>&getElements()
vector<HBeamParticle>&getHistory()
virtual const char*TObject::GetIconName() const
virtual const char*TObject::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
Bool_tinitBeamLine(TString filename, Int_t targetElementNum, Bool_t debug = kFALSE)
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
vector<HBeamParticle>&newParticle()
virtual Bool_tTObject::Notify()
voidTObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
HBeam&operator=(const HBeam&)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
voidprintBeamLine(Bool_t trans = kFALSE)
voidprintBeamProfile()
voidprintDetectors()
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(ostream& out, Option_t* option = "")
voidsetBeam(Int_t id, Double_t p, Double_t dbeamtube_size_x, Double_t dbeamtube_size_y, Double_t xoff = 0, Double_t yoff = 0)
voidsetBeamProfile(Double_t sigma_beam = 0.05, Double_t flat_radius = 0)
voidsetBeamResolution(Double_t dpx = 0.001, Double_t dpy = 0.005, Double_t dpz = 0.06)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
voidsetTargetElementOnly(Int_t id)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
Bool_ttransport(HBeamParticle& part)
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()

Data Members

private:
HBeamParticlefBeambeam particle
TF1*fProfile-> beam profile
vector<HBeamElement>fdetectorsvector of all detectors
vector<HBeamElement>felementsvector of all beam elements
Double_tffromPluto[5]units -> Pluto ->transport
vector<HBeamParticle>fhistory! vector of beam particle at all detectors
Int_tfnum_targetindex of elemnt target
Double_tftoPluto[5]units -> transport ->Pluto

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

Double_t profile(Double_t* x, Double_t* par)
Bool_t setTargetElement(UInt_t n)
HBeam()
setBeamProfile(Double_t sigma_beam = 0.05, Double_t flat_radius = 0)
setBeamResolution(Double_t dpx = 0.001, Double_t dpy = 0.005, Double_t dpz = 0.06)
~HBeam()
vector<HBeamElement>& getDetectors()
{ return fdetectors ; }
vector<HBeamElement>& getElements()
{ return felements ; }
vector<HBeamParticle>& getHistory()
{ return fhistory ; }
void setTargetElementOnly(Int_t id)
{ fnum_target=id; }
Int_t addDetector(TString name, Double_t distance, Int_t cutType, Double_t xcut = 50, Double_t ycut = 50)
 adds a detector "name" at place "distance" [in mm]
 (distance must be negative if placed before the target)
 cutType (0,1,2)(no,radial,square) xcut/ycut [mm]
void setBeam(Int_t id, Double_t p, Double_t dbeamtube_size_x, Double_t dbeamtube_size_y, Double_t xoff = 0, Double_t yoff = 0)
void createBeam(HBeamParticle& part)
 beam profile
 x-y symmetric profile
Bool_t transport(HBeamParticle& part)
Bool_t createDetectorHits(HBeamParticle& part)
calc particles at detector places
vector <HBeamParticle>& newParticle()
void printBeamLine(Bool_t trans = kFALSE)
void printBeamProfile()
void printDetectors()
Bool_t initBeamLine(TString filename, Int_t targetElementNum, Bool_t debug = kFALSE)
opens the ASCII description of the beam line