Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members | Related Pages

CandFitTrackSRHandle.cxx

Go to the documentation of this file.
00001 
00002 // $Id: CandFitTrackSRHandle.cxx,v 1.43 2007/02/04 06:05:51 rhatcher Exp $
00003 //
00004 // CandFitTrackSRHandle
00005 //
00006 // CandFitTrackSRHandle is specialized access handle to CandFitTrackSR.
00007 //
00008 // Each concrete CandHandle must define a DupHandle function.
00009 //
00010 // Author:  R. Lee 2001.03.30
00011 // Revised: B. Rebel 2003.07.15
00013 
00014 #include <cassert>
00015 #include <iostream>
00016 
00017 #include "CandFitTrackSR/CandFitTrackSRHandle.h"
00018 #include "CandFitTrackSR/CandFitTrackSR.h"
00019 #include "CandFitTrackSR/KalmanPlaneSR.h"
00020 #include "CandFitTrackSR/SwimObjSR.h"
00021 #include "CandTrackSR/TrackClusterSR.h"
00022 #include "Conventions/Mphysical.h"
00023 #include "MessageService/MsgFormat.h"
00024 #include "MessageService/MsgService.h"
00025 #include "Navigation/NavKey.h"
00026 #include "Navigation/NavSet.h"
00027 #include "Plex/PlexStripEndId.h"
00028 #include "RecoBase/CandFitTrackHandle.h"
00029 #include "RecoBase/CandStripHandle.h"
00030 #include "UgliGeometry/UgliGeomHandle.h"
00031 #include "UgliGeometry/UgliScintPlnHandle.h"
00032 #include "UgliGeometry/UgliSteelPlnHandle.h"
00033 #include "Algorithm/AlgConfig.h"
00034 #include "TMath.h"
00035 
00036 ClassImp(CandFitTrackSRHandle)
00037 
00038 //______________________________________________________________________
00039 CVSID("$Id: CandFitTrackSRHandle.cxx,v 1.43 2007/02/04 06:05:51 rhatcher Exp $");
00040 
00041 // Swim state variable assignments
00042 static const int kU      = 0;
00043 static const int kV      = 1;
00044 static const int kdUdZ   = 2;
00045 static const int kdVdZ   = 3;
00046 static const int kQoverP = 4;
00047 
00048 //______________________________________________________________________
00049 CandFitTrackSRHandle::CandFitTrackSRHandle()
00050 {
00051 }
00052 
00053 //______________________________________________________________________
00054 CandFitTrackSRHandle::CandFitTrackSRHandle(const CandFitTrackSRHandle &cdh) :
00055   CandFitTrackHandle(cdh)
00056 {
00057 }
00058 
00059 //______________________________________________________________________
00060 CandFitTrackSRHandle::CandFitTrackSRHandle(CandFitTrackSR *cd) :
00061   CandFitTrackHandle(cd)
00062 {
00063 }
00064 
00065 //______________________________________________________________________
00066 CandFitTrackSRHandle::~CandFitTrackSRHandle()
00067 {
00068 }
00069 
00070 //______________________________________________________________________
00071 CandFitTrackSRHandle *CandFitTrackSRHandle::DupHandle() const
00072 {
00073    return (new CandFitTrackSRHandle(*this));
00074 }
00075 
00076 //______________________________________________________________________
00077 void CandFitTrackSRHandle::Trace(const char *c) const
00078 {
00079   MSG("Cand", Msg::kDebug)
00080     << "**********Begin CandFitTrackSRHandle::Trace(\"" << c << "\")" << endl
00081            << "Information from CandFitTrackSRHandle's CandHandle: " << endl;
00082   CandHandle::Trace(c);
00083   MSG("Cand", Msg::kDebug)
00084      << "**********End CandFitTrackSRHandle::Trace(\"" << c << "\")" << endl;
00085 }
00086 
00087 //----------------------------------------------------------------------
00088 Int_t CandFitTrackSRHandle::GetKalmanLast() const
00089 {
00090   return dynamic_cast<const CandFitTrackSR *>
00091     (GetCandBase())->fPlaneList->GetLast();
00092 }
00093 
00094 //----------------------------------------------------------------------
00095 void CandFitTrackSRHandle::ClearKalmanPlaneList(Bool_t deletekp)
00096 {
00097   TObjArray *KalmanPlaneList = dynamic_cast<CandFitTrackSR*>
00098     (GetOwnedCandBase())->fPlaneList;
00099   if(deletekp){
00100     KalmanPlaneSR *kp = 0;
00101     for(int i=0; i<=KalmanPlaneList->GetLast(); ++i){
00102       kp = dynamic_cast<KalmanPlaneSR*>(KalmanPlaneList->At(i));
00103       delete kp;
00104     }
00105   }
00106   KalmanPlaneList->Clear();
00107   KalmanPlaneList->Compress();
00108   dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrent = 0;
00109   dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrentU = 0;
00110   dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrentV = 0;
00111 }
00112 
00113 //----------------------------------------------------------------------
00114 void CandFitTrackSRHandle::ClearTrackClusterList()
00115 {
00116   TObjArray *TrackClusterList = dynamic_cast<CandFitTrackSR*>
00117     (GetOwnedCandBase())->fTrackClusterList;
00118   TrackClusterSR *tc = 0;
00119   for(int i=0; i<=TrackClusterList->GetLast(); ++i){
00120     tc = dynamic_cast<TrackClusterSR*>(TrackClusterList->At(i));
00121     delete tc;
00122   }
00123   TrackClusterList->Clear();
00124   TrackClusterList->Compress();
00125 }
00126 
00127 //----------------------------------------------------------------------
00128 KalmanPlaneSR *CandFitTrackSRHandle::GetKalmanPlane(Int_t indx)
00129 {
00130   TObjArray *KalmanPlaneList = dynamic_cast<CandFitTrackSR*>
00131     (GetOwnedCandBase())->fPlaneList;
00132   return dynamic_cast<KalmanPlaneSR*>(KalmanPlaneList->At(indx));
00133 }
00134 
00135 //----------------------------------------------------------------------
00136 void CandFitTrackSRHandle::RemoveKalmanPlane(Int_t indx, Int_t idir)
00137 {
00138 // assumes first kalmanplane in kalmanplanelist is never removed
00139   TObjArray *KalmanPlaneList = dynamic_cast<CandFitTrackSR*>
00140     (GetOwnedCandBase())->fPlaneList;
00141   KalmanPlaneSR *kp = 0;
00142   if(indx>=0) kp = dynamic_cast<KalmanPlaneSR*>(KalmanPlaneList->At(indx));
00143   else {
00144     kp = GetCurrentKalmanPlane();
00145     indx = KalmanPlaneList->IndexOf(kp);
00146   }
00147   KalmanPlaneSR *newkplast = 0;
00148   if(idir==0){
00149     assert(indx-1>=0);
00150     newkplast = GetKalmanPlane(indx-1);
00151   } 
00152   else{
00153     assert(indx+1<=GetKalmanLast());
00154     newkplast = GetKalmanPlane(indx+1);
00155   }
00156   SetCurrentKalmanPlane(newkplast);
00157   KalmanPlaneList->RemoveAt(indx);
00158   KalmanPlaneList->Compress();
00159   delete kp;
00160 }
00161 
00162 //----------------------------------------------------------------------
00163 void CandFitTrackSRHandle::CompressKalmanPlaneList()
00164 {
00165   TObjArray *KalmanPlaneList = dynamic_cast<CandFitTrackSR*>
00166     (GetOwnedCandBase())->fPlaneList;
00167   KalmanPlaneList->Compress();
00168 }
00169 
00170 //----------------------------------------------------------------------
00171 KalmanPlaneSR * CandFitTrackSRHandle::AddKalmanPlaneAt(KalmanPlaneSR *kpnew, Int_t indx)
00172 {
00173   TObjArray *KalmanPlaneList = dynamic_cast<CandFitTrackSR*>
00174     (GetOwnedCandBase())->fPlaneList;
00175   Int_t ilast = KalmanPlaneList->GetLast();
00176 
00177   // KalmanPlaneList owns objects, so create new KalmanPlaneSR based on input
00178   KalmanPlaneSR *kpnewer = new KalmanPlaneSR(kpnew);
00179   KalmanPlaneSR *kp = 0;
00180   for(int i=ilast; i>=indx; --i){
00181     kp = dynamic_cast<KalmanPlaneSR*>(KalmanPlaneList->At(i));
00182     KalmanPlaneList->AddAtAndExpand(kp,i+1);
00183   }
00184   KalmanPlaneList->AddAtAndExpand(kpnewer,indx);
00185   return kpnewer;
00186 }
00187 
00188 //----------------------------------------------------------------------
00189 void CandFitTrackSRHandle::RemoveForward(KalmanPlaneSR *kp)
00190 {
00191   TObjArray *KalmanPlaneList = dynamic_cast<CandFitTrackSR*>
00192     (GetOwnedCandBase())->fPlaneList;
00193   if(!kp) kp = GetCurrentKalmanPlane();
00194   Int_t indx = KalmanPlaneList->IndexOf(kp);
00195   KalmanPlaneSR *newkplast = GetKalmanPlane(indx-1);
00196   SetCurrentKalmanPlane(newkplast);
00197   Int_t nmax = KalmanPlaneList->GetLast();
00198   for(Int_t i=indx; i<=nmax; ++i){
00199     KalmanPlaneList->RemoveAt(i);
00200     kp = dynamic_cast<KalmanPlaneSR*>(KalmanPlaneList->At(i));
00201     delete kp;
00202   }
00203   KalmanPlaneList->Compress();
00204 }
00205 
00206 
00207 //----------------------------------------------------------------------
00208 const KalmanPlaneSR *CandFitTrackSRHandle::GetKalmanPlane(Int_t indx) const
00209 {
00210   TObjArray *KalmanPlaneList = dynamic_cast<const CandFitTrackSR*>
00211     (GetCandBase())->fPlaneList;
00212   return dynamic_cast<const KalmanPlaneSR*>(KalmanPlaneList->At(indx));
00213 }
00214 
00215 
00216 //----------------------------------------------------------------------
00217 Double_t CandFitTrackSRHandle::GetInitialQP() const
00218 {
00219   return dynamic_cast<const CandFitTrackSR*>(GetCandBase())->fInitialQP;
00220 }
00221 
00222 
00223 //----------------------------------------------------------------------
00224 void CandFitTrackSRHandle::SetInitialQP(Double_t qp0)
00225 {
00226   dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fInitialQP = qp0;
00227 }
00228 
00229 //----------------------------------------------------------------------
00230 void CandFitTrackSRHandle::SetVtx(const KalmanPlaneSR *currentkp)
00231 {
00232   if(currentkp->GetFilStateValue(kQoverP,1)!=0) 
00233     SetInitialQP(currentkp->GetFilStateValue(kQoverP,1));
00234   if(currentkp->GetFilStateValue(kU,1)!=0) 
00235     SetVtxU(currentkp->GetFilStateValue(kU,1));
00236   if(currentkp->GetFilStateValue(kV,1)!=0) 
00237     SetVtxV(currentkp->GetFilStateValue(kV,1));
00238   SetVtxZ(currentkp->GetTrackCluster()->GetZPos());
00239   Double_t dudz = currentkp->GetFilStateValue(kdUdZ,1);
00240   Double_t dvdz = currentkp->GetFilStateValue(kdVdZ,1);
00241   Double_t dsdz = TMath::Sqrt(1.+dudz*dudz+dvdz*dvdz)*(Double_t)(currentkp->GetZDir());
00242   if(dudz!=0) SetDirCosU(dudz/dsdz);
00243   if(dvdz!=0)SetDirCosV(dvdz/dsdz);
00244   if(dsdz!=1) SetDirCosZ(1./dsdz);
00245   SetVtxPlane(currentkp->GetTrackCluster()->GetPlane());
00246 
00247 }
00248 
00249 //----------------------------------------------------------------------
00250 void CandFitTrackSRHandle::SetEnd(const KalmanPlaneSR *currentkp)
00251 {
00252   SetEndQP(currentkp->GetFilStateValue(kQoverP,0));
00253   if(currentkp->GetFilStateValue(kU,1)!=0) 
00254     SetEndU(currentkp->GetFilStateValue(kU,0));
00255   if(currentkp->GetFilStateValue(kV,1)!=0) 
00256      SetEndV(currentkp->GetFilStateValue(kV,0));
00257   SetEndZ(currentkp->GetTrackCluster()->GetZPos());
00258   Double_t dudz = currentkp->GetFilStateValue(kdUdZ,0);
00259   Double_t dvdz = currentkp->GetFilStateValue(kdVdZ,0);
00260   Double_t dsdz = TMath::Sqrt(1.+dudz*dudz+dvdz*dvdz)*(Double_t)(currentkp->GetZDir());
00261   if(dudz!=0) SetEndDirCosU(dudz/dsdz);
00262   if(dvdz!=0) SetEndDirCosV(dvdz/dsdz);
00263   if(dsdz!=1) SetEndDirCosZ(1./dsdz);
00264   SetEndPlane(currentkp->GetTrackCluster()->GetPlane());
00265 }
00266 
00267 //______________________________________________________________________
00268 
00269 TObjArray * CandFitTrackSRHandle::GetTrackClusterList() {
00270   return dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fTrackClusterList;
00271 }
00272 
00273 //______________________________________________________________________
00274 
00275 TObjArray * CandFitTrackSRHandle::GetPlaneList(){
00276   return dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fPlaneList;
00277 }
00278 //______________________________________________________________________
00279 
00280 Int_t  CandFitTrackSRHandle::GetNChangedFitPoint(){
00281   return dynamic_cast<const CandFitTrackSR*>(GetCandBase())->fNChangedFitPoint;
00282 }
00283 //______________________________________________________________________
00284 
00285 void CandFitTrackSRHandle::SetNChangedFitPoint(Int_t i){
00286   dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fNChangedFitPoint=i;
00287 }
00288 //----------------------------------------------------------------------
00289 KalmanPlaneSR *CandFitTrackSRHandle::GetCurrentKalmanPlane(PlaneView::PlaneView_t planeview_t) 
00290 {
00291   if (planeview_t==PlaneView::kU) 
00292     return dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrentU;
00293   else if (planeview_t==PlaneView::kV) 
00294     return dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrentV;
00295   else 
00296     return dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrent;
00297   
00298 }
00299 //----------------------------------------------------------------------
00300 const KalmanPlaneSR *CandFitTrackSRHandle::GetCurrentKalmanPlane(PlaneView::PlaneView_t planeview_t) const
00301 {
00302   if (planeview_t==PlaneView::kU) 
00303     return dynamic_cast<const CandFitTrackSR*>(GetCandBase())->fCurrentU;
00304   else if (planeview_t==PlaneView::kV) 
00305     return dynamic_cast<const CandFitTrackSR*>(GetCandBase())->fCurrentV;
00306   else 
00307     return dynamic_cast<const CandFitTrackSR*>(GetCandBase())->fCurrent;
00308   
00309 }
00310 
00311 //----------------------------------------------------------------------
00312 void CandFitTrackSRHandle::SetCurrentKalmanPlane(KalmanPlaneSR *kp)
00313 {
00314   dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrent = kp;  
00315   if(kp->GetTrackCluster()->GetPlaneView()==PlaneView::kU){
00316     dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrentU = kp;
00317   }
00318   else if(kp->GetTrackCluster()->GetPlaneView()==PlaneView::kV){
00319     dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fCurrentV = kp;
00320   }
00321 }
00322 
00323 //----------------------------------------------------------------------
00324 void CandFitTrackSRHandle::AddUpstreamPlaneList(TObjArray *uplist)
00325 {
00326   Int_t nup = uplist->GetLast()+1;
00327   Int_t nmax = GetKalmanLast();
00328   TObjArray *KalmanPlaneList = dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase())->fPlaneList;
00329   KalmanPlaneSR *kp = 0;
00330   for(Int_t i=nmax; i>=0; --i){
00331     kp = dynamic_cast<KalmanPlaneSR*>(KalmanPlaneList->At(i));
00332     KalmanPlaneList->AddAtAndExpand(kp,i+nup);
00333   }
00334   for(Int_t i=0; i<=uplist->GetLast(); ++i){
00335     kp = dynamic_cast<KalmanPlaneSR*>(uplist->At(i));
00336     KalmanPlaneList->AddAt(kp,nup-i-1);
00337   }
00338 
00339 }
00340 
00341 //----------------------------------------------------------------------
00342 Bool_t CandFitTrackSRHandle::GetBadFit(Int_t iplane) const
00343 {
00344   map<TrackClusterSR *,Bool_t>::iterator iter;
00345   const TObjArray *KalmanPlaneList = dynamic_cast<const CandFitTrackSR*>
00346     (GetCandBase())->fPlaneList;
00347   Bool_t found(0);
00348  
00349   KalmanPlaneSR *kp = 0;
00350   for(int i=0; i<=KalmanPlaneList->GetLast() && !found; ++i){
00351     kp = dynamic_cast<KalmanPlaneSR*>(KalmanPlaneList->At(i));
00352     if(kp->GetTrackCluster()->GetPlane()==iplane){
00353       found = true;
00354       iter = (dynamic_cast<const CandFitTrackSR *>
00355               (GetCandBase())->fBadFit).find(kp->GetTrackCluster());
00356 
00357       if(iter!=(dynamic_cast<const CandFitTrackSR *>
00358                 (GetCandBase())->fBadFit).end()){
00359         return 1;
00360       }
00361       return 0;
00362     }//end if this is the plain
00363   }//end loop over kalman planes
00364   return 0;
00365 }
00366 
00367 //----------------------------------------------------------------------
00368 Bool_t CandFitTrackSRHandle::GetBadFit(TrackClusterSR *tc) const
00369 {
00370   map<TrackClusterSR *,Bool_t>::iterator iter;
00371   iter = (dynamic_cast<const CandFitTrackSR *>
00372           (GetCandBase())->fBadFit).find(tc);
00373   if (iter!=(dynamic_cast<const CandFitTrackSR *>
00374              (GetCandBase())->fBadFit).end()) {
00375     return 1;
00376   }
00377   return 0;
00378 }
00379 
00380 //----------------------------------------------------------------------
00381 Int_t CandFitTrackSRHandle::GetNGoodFit() const
00382 {
00383   Int_t ngood=0;
00384   const KalmanPlaneSR *kp = 0;
00385   for(int i=0; i<=GetKalmanLast(); ++i){
00386     kp = GetKalmanPlane(i);
00387     if (!GetBadFit(kp->GetTrackCluster())) ngood++;
00388   }
00389   return ngood;
00390 }
00391 
00392 //----------------------------------------------------------------------
00393 void CandFitTrackSRHandle::SetBadFit(TrackClusterSR *tc)
00394 {
00395   dynamic_cast<CandFitTrackSR *>(GetOwnedCandBase())->fBadFit[tc] = 1;
00396 }
00397 
00398 
00399 //----------------------------------------------------------------------
00400 Float_t CandFitTrackSRHandle::GetPlanePreChi2(Int_t iplane) const
00401 {
00402   map<Int_t,Float_t>::iterator iter;
00403   iter = (dynamic_cast<const CandFitTrackSR *>(GetCandBase())->fPlanePreChi2).find(iplane);
00404   if (iter!=(dynamic_cast<const CandFitTrackSR *>(GetCandBase())->fPlanePreChi2).end()) {
00405     return dynamic_cast<const CandFitTrackSR *>(GetCandBase())->fPlanePreChi2[iplane];
00406   }
00407   return -1.;
00408 }
00409 
00410 //----------------------------------------------------------------------
00411 void CandFitTrackSRHandle::SetPlanePreChi2(Int_t iplane, Double_t chi2)
00412 {
00413   dynamic_cast<CandFitTrackSR *>(GetOwnedCandBase())->fPlanePreChi2[iplane] = (Float_t)chi2;
00414 }
00415 
00416 //----------------------------------------------------------------------
00417 void CandFitTrackSRHandle::AddTrackCluster(TrackClusterSR *tc) {
00418   TrackClusterSR *newtc = new TrackClusterSR(*tc);
00419   CandFitTrackSR *track = dynamic_cast<CandFitTrackSR *>(GetOwnedCandBase());
00420   track->fTrackClusterList->Add(newtc);
00421 }
00422 
00423 
00424 //----------------------------------------------------------------------
00425 Int_t CandFitTrackSRHandle::GetNChangedFitPoint() const
00426 {
00427   return dynamic_cast<const CandFitTrackSR *>(GetCandBase())->fNChangedFitPoint;
00428 }
00429 
00430 //----------------------------------------------------------------------
00431 void CandFitTrackSRHandle::SetVtxExtrapolate(Int_t nplane, 
00432                                              PlaneView::PlaneView_t planeview_t)
00433 {
00434   if(planeview_t == PlaneView::kU){
00435     dynamic_cast<CandFitTrackSR *>(GetOwnedCandBase())->fVtxExtrapolate[0] = nplane;
00436   } 
00437   else if(planeview_t == PlaneView::kV){
00438     dynamic_cast<CandFitTrackSR *>(GetOwnedCandBase())->fVtxExtrapolate[1] = nplane;
00439   }
00440 }
00441 
00442 //----------------------------------------------------------------------
00443 void CandFitTrackSRHandle::SetEndExtrapolate(Int_t nplane, 
00444                                              PlaneView::PlaneView_t planeview_t)
00445 {
00446   if(planeview_t == PlaneView::kU){
00447     dynamic_cast<CandFitTrackSR *>(GetOwnedCandBase())->fEndExtrapolate[0] = nplane;
00448   } 
00449   else if (planeview_t == PlaneView::kV){
00450     dynamic_cast<CandFitTrackSR *>(GetOwnedCandBase())->fEndExtrapolate[1] = nplane;
00451   }
00452 }
00453 
00454 //----------------------------------------------------------------------
00455 Int_t CandFitTrackSRHandle::GetVtxExtrapolate(PlaneView::PlaneView_t planeview_t) const
00456 {
00457   const CandFitTrackSR *track = dynamic_cast<const CandFitTrackSR *>(GetCandBase());
00458   if(planeview_t == PlaneView::kU){
00459     return track->fVtxExtrapolate[0];
00460   } 
00461   else if(planeview_t == PlaneView::kV){
00462     return track->fVtxExtrapolate[1];
00463   }
00464   else{
00465     return min(track->fVtxExtrapolate[0],track->fVtxExtrapolate[1]);
00466   }
00467 }
00468 
00469 //----------------------------------------------------------------------
00470 Int_t CandFitTrackSRHandle::GetEndExtrapolate(PlaneView::PlaneView_t planeview_t) const
00471 {
00472   const CandFitTrackSR *track = dynamic_cast<const CandFitTrackSR *>(GetCandBase());
00473   if(planeview_t == PlaneView::kU){
00474     return track->fEndExtrapolate[0];
00475   } 
00476   else if(planeview_t == PlaneView::kV){
00477     return track->fEndExtrapolate[1];
00478   } 
00479   else{
00480     return min(track->fEndExtrapolate[0],track->fEndExtrapolate[1]);
00481   }
00482 }
00483 
00484 
00485 //----------------------------------------------------------------------
00486 void CandFitTrackSRHandle::SetdUdZ(Int_t plane, Float_t ddz)
00487 {
00488   CandFitTrackSR *track = dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase());
00489   track->fdUdZ[plane] = ddz;
00490 }
00491 
00492 //----------------------------------------------------------------------
00493 void CandFitTrackSRHandle::SetdVdZ(Int_t plane, Float_t ddz)
00494 {
00495   CandFitTrackSR *track = dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase());
00496   track->fdVdZ[plane] = ddz;
00497 }
00498 
00499 //----------------------------------------------------------------------
00500 Float_t CandFitTrackSRHandle::GetdUdZ(Int_t plane) const
00501 {
00502   const CandFitTrackSR *track = dynamic_cast<const CandFitTrackSR*>(GetCandBase());
00503   if ((track->fdUdZ).count(plane)) {
00504     return track->fdUdZ[plane];
00505   }
00506   return -99999.;
00507 }
00508 
00509 //----------------------------------------------------------------------
00510 Float_t CandFitTrackSRHandle::GetdVdZ(Int_t plane) const
00511 {
00512   const CandFitTrackSR *track = dynamic_cast<const CandFitTrackSR*>(GetCandBase());
00513   if ((track->fdVdZ).count(plane)) {
00514     return track->fdVdZ[plane];
00515   }
00516   return -99999.;
00517 }
00518 
00519 
00520 //----------------------------------------------------------------------
00521 void CandFitTrackSRHandle::ClearMaps()
00522 {
00523   CandFitTrackSR *track = dynamic_cast<CandFitTrackSR*>(GetOwnedCandBase());
00524   track->fdUdZ.clear();
00525   track->fdVdZ.clear();
00526   track->fPlanePreChi2.clear();
00527   CandFitTrackHandle::ClearMaps();
00528 }
00529 
00530 
00531 XXXITRIMP(CandFitTrackSRHandle)

Generated on Mon Feb 15 11:06:28 2010 for loon by  doxygen 1.3.9.1