]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - EVE/alice-macros/trd_tracks.C
fix TRD digits display
[u/mrichter/AliRoot.git] / EVE / alice-macros / trd_tracks.C
index 0c53a66b9c731da41ae605cfd1c4b09b4162e80f..713b798335f55addb7c4fa3a709a7b65c5778741 100644 (file)
 void trd_tracks(TEveElement *cont = 0)
 {
   // Link data containers
-  AliESDfriend *eventESDfriend = 0x0;
-  if(!(eventESDfriend = AliEveEventManager::AssertESDfriend())){
-    Warning("trd_tracks", "AliESDfriend not found");
+  AliESDEvent* esd(AliEveEventManager::AssertESD());
+  AliESDfriend *esdFriend(AliEveEventManager::AssertESDfriend());
+  if(!esd || !esdFriend){
+    Warning("trd_tracks", "Full ESD data missing.");
     return;
   }
 
-  AliESDEvent* esd = AliEveEventManager::AssertESD();
-
-  AliEveEventManager::AssertGeometry();
-
+/*  AliEveEventManager::AssertGeometry();
+  AliRunLoader *rl = AliEveEventManager::AssertRunLoader();
+*/
   AliTRDrecoParam *trdRecoParam = AliTRDrecoParam::GetLowFluxParam();
   trdRecoParam->SetPIDNeuralNetwork();
   AliTRDReconstructor *reco = new AliTRDReconstructor();
@@ -31,16 +31,20 @@ void trd_tracks(TEveElement *cont = 0)
 
   AliEveTRDTrackList *tracks = new AliEveTRDTrackList("TRD Tracks");
   for (Int_t n=0; n<esd->GetNumberOfTracks(); n++){
-    AliESDtrack* esdTrack = esd->GetTrack(n);
-    AliESDfriendTrack *friendTrack = eventESDfriend->GetTrack(n);
+    AliESDtrack* esdTrack(esd->GetTrack(n));
+    if(!esdTrack) continue;
+    AliESDfriendTrack *friendTrack(esdTrack->GetFriendTrack());
+    if(!friendTrack) continue;
+    //Info("trd_tracks", Form("Track[%3d] esd[%p] friend[%p]", n, (void*)esdTrack, (void*)friendTrack));
 
-    TObject *cal = 0x0;
-    Int_t ical = 0;
+    TObject *cal(NULL);
+    Int_t ical(0);
     while((cal = friendTrack->GetCalibObject(ical++))){
+      //Info("trd_tracks", Form("  Obj[%d] %s", ical-1, cal->IsA()->GetName()));
       if(strcmp(cal->IsA()->GetName(), "AliTRDtrackV1") != 0) continue;
       AliTRDtrackV1 *trackObj = dynamic_cast<AliTRDtrackV1 *>(cal);
       trackObj->SetReconstructor(reco);
-      AliEveTRDTrack *trackEve = new AliEveTRDTrack(trackObj);
+      AliEveTRDTrack *trackEve = new AliEveTRDTrack(new AliTRDtrackV1(*trackObj));
       tracks->AddElement(trackEve);
       trackEve->SetESDstatus(esdTrack->GetStatus());
       trackEve->SetName(Form("[%4d] %s", n, trackEve->GetName()));