12#include "TRestTrackReconnectionProcess.h"
18TRestTrackReconnectionProcess::TRestTrackReconnectionProcess() {
Initialize(); }
20TRestTrackReconnectionProcess::TRestTrackReconnectionProcess(
const char* configFilename) {
27TRestTrackReconnectionProcess::~TRestTrackReconnectionProcess() {
delete fOutputTrackEvent; }
29void TRestTrackReconnectionProcess::LoadDefaultConfig() {
30 SetName(
"trackReconnectionProcess");
31 SetTitle(
"Default config");
38 fInputTrackEvent =
nullptr;
44void TRestTrackReconnectionProcess::LoadConfig(
const string& configFilename,
const string& name) {
53 Int_t trackBranches = 0;
58 for (
int tck = 0; tck < fInputTrackEvent->GetNumberOfTracks(); tck++)
59 fOutputTrackEvent->AddTrack(fInputTrackEvent->GetTrack(tck));
61 for (
int tck = 0; tck < fInputTrackEvent->GetNumberOfTracks(); tck++) {
62 if (!fInputTrackEvent->isTopLevel(tck))
continue;
63 Int_t tckId = fInputTrackEvent->GetTrack(tck)->GetTrackID();
65 TRestVolumeHits* hits = fInputTrackEvent->GetTrack(tck)->GetVolumeHits();
69 cout <<
"TRestTrackReconnectionProcess. Input hits" << endl;
70 Int_t pId = fInputTrackEvent->GetTrack(tck)->GetParentID();
71 cout <<
"Track : " << tck <<
" TrackID : " << tckId <<
" ParentID : " << pId << endl;
72 cout <<
"-----------------" << endl;
76 SetDistanceMeanAndSigma((
TRestHits*)hits);
78 if (fMeanDistance == 0)
continue;
81 vector<TRestVolumeHits> subHitSets;
87 for (
int n = 0; n < 1; n++) {
90 BreakTracks(&initialHits, subHitSets, 1.5 * (n + 1));
91 ReconnectTracks(subHitSets);
94 SetDistanceMeanAndSigma(&resultHits);
95 tBranches = GetTrackBranches(resultHits, fNSigmas);
98 cout <<
"Break and reconnect finished" << endl;
99 cout <<
"Branches : " << tBranches << endl;
103 initialHits = resultHits;
108 if (tBranches > trackBranches) trackBranches = tBranches;
111 for (
unsigned int n = 0; n < subHitSets[0].GetNumberOfHits(); n++) {
112 if (n > 0 && n < subHitSets[0].GetNumberOfHits() - 1) {
115 subHitSets[0].SwapHits(n - 1, n);
117 Double_t distanceAfter = subHitSets[0].GetHitsPathLength(n - 2, n + 2);
119 if (distanceAfter < distance)
continue;
121 subHitSets[0].SwapHits(n - 1, n);
129 cout <<
" **** Splitting track : " << endl;
130 cout <<
"Number of subHitSets : " << subHitSets.size() << endl;
135 for (
unsigned int n = 0; n < subHitSets.size(); n++) {
138 aTrack.SetTrackID(fOutputTrackEvent->GetNumberOfTracks() + 1);
140 aTrack.SetParentID(tckId);
142 aTrack.SetVolumeHits(subHitSets[n]);
144 fOutputTrackEvent->AddTrack(&aTrack);
152 cout <<
"++++++++++++++++++++++++++++++++" << endl;
153 fOutputTrackEvent->PrintEvent();
154 cout <<
"++++++++++++++++++++++++++++++++" << endl;
158 return fOutputTrackEvent;
168 cout <<
"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
169 cout <<
"BreakTracks. Breaking tracks into hits subsets." << endl;
173 for (
unsigned int n = 0; n < hits->GetNumberOfHits(); n++) {
174 Double_t x = hits->GetX(n);
175 Double_t y = hits->GetY(n);
176 Double_t z = hits->GetZ(n);
177 Double_t sX = hits->GetSigmaX(n);
178 Double_t sY = hits->GetSigmaY(n);
179 Double_t sZ = hits->GetSigmaZ(n);
180 Double_t energy = hits->GetEnergy(n);
183 cout <<
"Distance : " << hits->GetDistance(n - 1, n);
184 if (hits->GetDistance(n - 1, n) > fMeanDistance + nSigma * fSigma) cout <<
" BREAKKKK";
188 if (n > 0 && hits->GetDistance(n - 1, n) > fMeanDistance + nSigma * fSigma) {
189 hitSets.push_back(subHits);
193 subHits.AddHit(x, y, z, energy, 0, hits->GetType(n), sX, sY, sZ);
196 cout <<
"H : " << n <<
" X : " << x <<
" Y : " << y <<
" Z : " << z << endl;
199 hitSets.push_back(subHits);
202 cout <<
"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
205void TRestTrackReconnectionProcess::ReconnectTracks(vector<TRestVolumeHits>& hitSets) {
207 cout <<
"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
208 cout <<
"ReconnectTracks. Connecting back sub tracks " << endl;
211 Int_t nSubTracks = hitSets.size();
213 if (nSubTracks == 1)
return;
215 Double_t minDistance = 1.e10;
217 Int_t tracks[2][2] = {{0, 0}, {0, 0}};
219 vector<Int_t> nHits(nSubTracks);
220 for (
int i = 0; i < nSubTracks; i++) nHits[i] = hitSets[i].GetNumberOfHits();
223 cout <<
"ORIGINAL" << endl;
224 cout <<
"--------" << endl;
225 for (
int i = 0; i < nSubTracks; i++) {
226 cout <<
"Subset : " << i << endl;
227 cout <<
" Sub hits : " << nHits[i] << endl;
229 hitSets[i].PrintHits();
231 cout <<
"--------" << endl;
235 for (
int i = 0; i < nSubTracks; i++) {
236 for (
int j = 0; j < nSubTracks; j++) {
238 Int_t x1_0 = hitSets[i].GetX(0);
239 Int_t x1_1 = hitSets[i].GetX(nHits[i] - 1);
241 Int_t y1_0 = hitSets[i].GetY(0);
242 Int_t y1_1 = hitSets[i].GetY(nHits[i] - 1);
244 Int_t z1_0 = hitSets[i].GetZ(0);
245 Int_t z1_1 = hitSets[i].GetZ(nHits[i] - 1);
247 Int_t x2_0 = hitSets[j].GetX(0);
248 Int_t x2_1 = hitSets[j].GetX(nHits[j] - 1);
250 Int_t y2_0 = hitSets[j].GetY(0);
251 Int_t y2_1 = hitSets[j].GetY(nHits[j] - 1);
253 Int_t z2_0 = hitSets[j].GetZ(0);
254 Int_t z2_1 = hitSets[j].GetZ(nHits[j] - 1);
257 d = TMath::Sqrt((x1_0 - x2_0) * (x1_0 - x2_0) + (y1_0 - y2_0) * (y1_0 - y2_0) +
258 (z1_0 - z2_0) * (z1_0 - z2_0));
260 if (d < minDistance) {
268 d = TMath::Sqrt((x1_0 - x2_1) * (x1_0 - x2_1) + (y1_0 - y2_1) * (y1_0 - y2_1) +
269 (z1_0 - z2_1) * (z1_0 - z2_1));
271 if (d < minDistance) {
279 d = TMath::Sqrt((x1_1 - x2_0) * (x1_1 - x2_0) + (y1_1 - y2_0) * (y1_1 - y2_0) +
280 (z1_1 - z2_0) * (z1_1 - z2_0));
282 if (d < minDistance) {
290 d = TMath::Sqrt((x1_1 - x2_1) * (x1_1 - x2_1) + (y1_1 - y2_1) * (y1_1 - y2_1) +
291 (z1_1 - z2_1) * (z1_1 - z2_1));
293 if (d < minDistance) {
314 Int_t tck1 = tracks[0][0];
315 Int_t tck2 = tracks[1][0];
318 if (tracks[0][1] == 0 && tracks[1][1] == 0) {
320 for (
int n = nHits[tck1] - 1; n >= 0; n--) newHits.AddHit(hitSets[tck1], n);
322 for (
int n = 0; n < nHits[tck2]; n++) newHits.AddHit(hitSets[tck2], n);
323 }
else if (tracks[0][1] == 1 && tracks[1][1] == 0) {
326 for (
int n = 0; n < nHits[tck1]; n++) newHits.AddHit(hitSets[tck1], n);
328 for (
int n = 0; n < nHits[tck2]; n++) newHits.AddHit(hitSets[tck2], n);
329 }
else if (tracks[0][1] == 0 && tracks[1][1] == 1) {
332 for (
int n = 0; n < nHits[tck2]; n++) newHits.AddHit(hitSets[tck2], n);
334 for (
int n = 0; n < nHits[tck1]; n++) newHits.AddHit(hitSets[tck1], n);
338 for (
int n = 0; n < nHits[tck1]; n++) newHits.AddHit(hitSets[tck1], n);
340 for (
int n = nHits[tck2] - 1; n >= 0; n--) newHits.AddHit(hitSets[tck2], n);
343 hitSets.erase(hitSets.begin() + tck2);
344 hitSets.erase(hitSets.begin() + tck1);
345 hitSets.push_back(newHits);
348 nSubTracks = hitSets.size();
351 cout <<
"New subtracks : " << nSubTracks << endl;
353 cout <<
"AFTER REMOVAL" << endl;
354 cout <<
"--------" << endl;
355 for (
int i = 0; i < nSubTracks; i++) {
356 cout <<
"Subset : " << i << endl;
357 cout <<
" Sub hits : " << nHits[i] << endl;
359 hitSets[i].PrintHits();
361 cout <<
"--------" << endl;
365 if (nSubTracks > 1) ReconnectTracks(hitSets);
368 cout <<
"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
371Int_t TRestTrackReconnectionProcess::GetTrackBranches(
TRestHits& h, Double_t nSigma) {
373 Int_t nHits = h.GetNumberOfHits();
375 for (
int n = 1; n < nHits; n++)
376 if (h.GetDistance(n - 1, n) > fMeanDistance + nSigma * fSigma) breaks++;
391void TRestTrackReconnectionProcess::SetDistanceMeanAndSigma(
TRestHits* h) {
392 Int_t nHits = h->GetNumberOfHits();
395 for (
int n = 1; n < nHits; n++) fMeanDistance += h->GetDistance(n - 1, n);
396 fMeanDistance /= nHits;
398 fSigma = TMath::Sqrt(fMeanDistance);
401 cout <<
"-----> Node distance average ; " << fMeanDistance << endl;
402 cout <<
"-----> Node distance sigma : " << fSigma << endl;
void SetObservableValue(const std::string &name, const T &value)
Set observable value for AnalysisTree.
A base class for any REST event.
It saves a 3-coordinate position and an energy for each punctual deposition.
Double_t GetHitsPathLength(Int_t n=0, Int_t m=0) const
It determines the distance required to travel from hit n to hit m adding all the distances of the hit...
@ REST_Extreme
show everything
@ REST_Debug
+show the defined debug messages
void EndProcess() override
To be executed at the end of the run (outside event loop)
void InitProcess() override
To be executed at the beginning of the run (outside event loop)
TRestEvent * ProcessEvent(TRestEvent *inputEvent) override
Process one event.
void BreakTracks(TRestVolumeHits *hits, std::vector< TRestVolumeHits > &hitSets, Double_t nSigma=2.)
void InitFromConfigFile() override
To make settings from rml file. This method must be implemented in the derived class.
void Initialize() override
Making default settings.
void PrintMetadata() override
Implemented it in the derived metadata class to print out specific metadata information.
void RemoveHits()
It removes all hits inside the class.
Int_t GetChar(std::string hint="Press a KEY to continue ...")
Helps to pause the program, printing a message before pausing.
Double_t StringToDouble(std::string in)
Gets a double from a string.