5 #include "KVDetector.h"
8 #include "KVNameValueList.h"
35 fReconstructedNuclei = 0;
37 SetOwnsDaughters(kFALSE);
38 fReconTraj.SetOwner();
48 if (fReconstructedNuclei && fReconstructedNuclei->TestBit(kNotDeleted)) {
49 fReconstructedNuclei->Clear();
50 delete fReconstructedNuclei;
51 fReconstructedNuclei = 0;
53 fReconstructedNuclei = 0;
54 fTrajectories.Clear();
71 TIter next(GetDetectors());
95 TList* dets =
new TList;
96 TIter next(GetDetectors());
121 if (fReconstructedNuclei && fReconstructedNuclei->GetSize()) {
122 fReconstructedNuclei->Clear();
136 if (!fReconstructedNuclei) {
137 fReconstructedNuclei =
new KVList(kFALSE);
138 fReconstructedNuclei->SetCleanup();
140 fReconstructedNuclei->Add(kvd);
154 if (fReconstructedNuclei) {
155 fReconstructedNuclei->Remove(kvd);
156 if (fReconstructedNuclei->GetSize() == 0) {
157 delete fReconstructedNuclei;
158 fReconstructedNuclei = 0;
162 Warning(
"RemoveHit",
"No reconstructed nuclei in this group");
187 TList* tmp =
new TList;
194 if (infront->GetEntries() > 1) {
195 Warning(
"GetAlignedDetectors",
196 "No unique solution. There are %d detectors in front of %s.",
197 infront->GetEntries(), det->GetName());
203 if (dir == kForwards) {
204 TIter next(tmp, kIterBackward);
205 TList* tmp2 =
new TList;
206 while ((det = (
KVDetector*)next())) tmp2->Add(det);
245 TIter next_traj(GetTrajectories());
264 fReconTrajMap.Clear();
265 TIter nxtRT(GetReconTrajectories());
269 TNamed* n =
new TNamed(rnt->GetTitle(), rnt->GetName());
270 unique_trajectories.
Add(n);
273 orig = (TNamed*)unique_trajectories.
FindObject(rnt->GetTitle());
278 fReconTrajMap.SetValue(rnt->GetName(), orig->GetTitle());
283 TIter nxtDel(&toRemove);
285 fReconTraj.Remove(rnt);
289 return fReconTraj.GetEntries();
301 TIter it(GetDetectors());
Base class for detector geometry description.
virtual TList * GetAlignedDetectors(UInt_t direction=1)
KVGeoDetectorNode * GetNode()
virtual void Print(Option_t *option="") const
Path taken by particles through multidetector geometry.
KVGeoDetectorNode * GetNextNode() const
static KVGeoDNTrajectory * Factory(const char *plugin, const KVGeoDNTrajectory *, const KVGeoDetectorNode *)
Instantiate & return object of class corresponding to plugin.
void IterateFrom(const KVGeoDetectorNode *node0=nullptr) const
Information on relative positions of detectors & particle trajectories.
KVSeqCollection * GetDetectorsInFront() const
Group of detectors which can be treated independently of all others in array.
void Reset(Option_t *opt="")
virtual TList * GetAlignedDetectors(KVDetector *, UChar_t dir=kBackwards)
virtual TList * GetDetectorsInLayer(UInt_t lay)
virtual UInt_t GetNumberOfDetectorLayers()
void AddHit(KVNucleus *kvd)
void RemoveHit(KVNucleus *kvd)
void PrintData() const
list detectors of group with any data they contain
Int_t CalculateReconstructionTrajectories()
Extended TList class which owns its objects by default.
Description of properties and kinematics of atomic nuclei.
KaliVeda extensions to ROOT collection classes.
virtual void SetOwner(Bool_t enable=kTRUE)
virtual TObject * First() const
virtual TObject * FindObject(const char *name) const
Optimised list in which named objects can only be placed once.
Bool_t ObjectAdded() const
virtual void Add(TObject *obj)