diff --git a/examples/hodtest_cuts.def b/examples/hodtest_cuts.def
index f6003c2200a18b2f4d7156e51c0250c8b5ce2b06..8d0581f60b0568bcad842814e83ce58d74803e4c 100644
--- a/examples/hodtest_cuts.def
+++ b/examples/hodtest_cuts.def
@@ -2,16 +2,68 @@
 #
 
 Block: RawDecode
-
-Pedestal_event    g.evtyp==4
 RawDecode_master  1
+Pedestal_event    g.evtyp==4
 
 Block: Decode
 Decode_master     !Pedestal_event
 
 Block: CoarseTracking
-CoarseTracking_master !Pedestal_event
+
+hfoundtrack	H.dc.ntrack != 0
+hfound1track	H.dc.ntrack == 1
+hfound2track	H.dc.ntrack == 2
+hfound3track	H.dc.ntrack == 3
+hfound4track	H.dc.ntrack == 4
+
+goodhdc1x1	(H.dc.1x1.nhit > 0) && (H.dc.1x1.nhit < 3)
+goodhdc1y1	(H.dc.1y1.nhit > 0) && (H.dc.1y1.nhit < 3)
+goodhdc1u1	(H.dc.1u1.nhit > 0) && (H.dc.1u1.nhit < 3)
+goodhdc1v1	(H.dc.1v1.nhit > 0) && (H.dc.1v1.nhit < 3)
+goodhdc1y2	(H.dc.1y2.nhit > 0) && (H.dc.1y2.nhit < 3)
+goodhdc1x2	(H.dc.1x2.nhit > 0) && (H.dc.1x2.nhit < 3)
+
+goodhdc2x1	(H.dc.2x1.nhit > 0) && (H.dc.2x1.nhit < 3)
+goodhdc2y1	(H.dc.2y1.nhit > 0) && (H.dc.2y1.nhit < 3)
+goodhdc2u1	(H.dc.2u1.nhit > 0) && (H.dc.2u1.nhit < 3)
+goodhdc2v1	(H.dc.2v1.nhit > 0) && (H.dc.2v1.nhit < 3)
+goodhdc2y2	(H.dc.2y2.nhit > 0) && (H.dc.2y2.nhit < 3)
+goodhdc2x2	(H.dc.2x2.nhit > 0) && (H.dc.2x2.nhit < 3)
+
+goodhdc1	goodhdc1x1 && goodhdc1y1 && goodhdc1u1 && goodhdc1v1 && goodhdc1y2 && goodhdc1x2
+goodhdc2	goodhdc2x1 && goodhdc2y1 && goodhdc2u1 && goodhdc2v1 && goodhdc2y2 && goodhdc2x2
+bothgoodhdc	goodhdc1 && goodhdc2
+
+realhdc1x1	goodhdc1x1 && (H.dc.nsp != 0)
+realhdc1y1	goodhdc1y1 && (H.dc.nsp != 0)
+realhdc1u1	goodhdc1u1 && (H.dc.nsp != 0)
+realhdc1v1	goodhdc1v1 && (H.dc.nsp != 0)
+realhdc1y2	goodhdc1y2 && (H.dc.nsp != 0)
+realhdc1x2	goodhdc1x2 && (H.dc.nsp != 0)
+realhdc2x1	goodhdc2x1 && (H.dc.nsp != 0)
+realhdc2y1	goodhdc2y1 && (H.dc.nsp != 0)
+realhdc2u1	goodhdc2u1 && (H.dc.nsp != 0)
+realhdc2v1	goodhdc2v1 && (H.dc.nsp != 0)
+realhdc2y2	goodhdc2y2 && (H.dc.nsp != 0)
+realhdc2x2	goodhdc2x2 && (H.dc.nsp != 0)
+
+#hlowchi2	(hschi2perdeg<10) && hcleantrack
+
+hlowchi2	1
+
+hdcres_1	(H.dc.residual[0] < 1000) && hlowchi2
+hdcres_2	(H.dc.residual[1] < 1000) && hlowchi2
+hdcres_3	(H.dc.residual[2] < 1000) && hlowchi2
+hdcres_4	(H.dc.residual[3] < 1000) && hlowchi2
+hdcres_5	(H.dc.residual[4] < 1000) && hlowchi2
+hdcres_6	(H.dc.residual[5] < 1000) && hlowchi2
+hdcres_7	(H.dc.residual[6] < 1000) && hlowchi2
+hdcres_8	(H.dc.residual[7] < 1000) && hlowchi2
+hdcres_9	(H.dc.residual[8] < 1000) && hlowchi2
+hdcres_10	(H.dc.residual[9] < 1000) && hlowchi2
+hdcres_11	(H.dc.residual[10] < 1000) && hlowchi2
+hdcres_12	(H.dc.residual[11] < 1000) && hlowchi2
 
 Block: CoarseReconstruct
-RawCoarseReconstruct !Pedestal_event
+CourseReconstruct 1
 
diff --git a/examples/report.template b/examples/report.template
index 53b51a8eedd9bd1fde7bf0d4b103f3ceaf33e9ff..01259927f28493fcb5d5b15a5a2f518d39c96c53 100644
--- a/examples/report.template
+++ b/examples/report.template
@@ -30,7 +30,7 @@ The names of the HMS drift chamber planes are: {hdc_plane_names}
 
 DC Events: {hdc_tot_events}
 Hit in chamber: {hdc_cham_hits[0]/hdc_tot_events:%.3f} {hdc_cham_hits[1]/hdc_tot_events:%.3f}
-Hit in plane: {hdc_hits_per_plane[0]/hdc_tot_events:%.3f} {hdc_hits_per_plane[1]/hdc_tot_events:%.3f} {hdc_hits_per_plane[2]/hdc_tot_events:%.3f} {hdc_hits_per_plane[3]/hdc_tot_events:%.3f} {hdc_hits_per_plane[4]/hdc_tot_events:%.3f} {hdc_hits_per_plane[5]/hdc_tot_events:%.3f} {hdc_hits_per_plane[6]/hdc_tot_events:%.3f} {hdc_hits_per_plane[7]/hdc_tot_events:%.3f} {hdc_hits_per_plane[8]/hdc_tot_events:%.3f} {hdc_hits_per_plane[9]/hdc_tot_events:%.3f} {hdc_hits_per_plane[10]/hdc_tot_events:%.3f} {hdc_hits_per_plane[11]/hdc_tot_events:%.3f}
+Hit in plane: {hdc_events[0]/hdc_tot_events:%.3f} {hdc_events[1]/hdc_tot_events:%.3f} {hdc_events[2]/hdc_tot_events:%.3f} {hdc_events[3]/hdc_tot_events:%.3f} {hdc_events[4]/hdc_tot_events:%.3f} {hdc_events[5]/hdc_tot_events:%.3f} {hdc_events[6]/hdc_tot_events:%.3f} {hdc_events[7]/hdc_tot_events:%.3f} {hdc_events[8]/hdc_tot_events:%.3f} {hdc_events[9]/hdc_tot_events:%.3f} {hdc_events[10]/hdc_tot_events:%.3f} {hdc_events[11]/hdc_tot_events:%.3f}
 
 Run #{gen_run_number}
 first event = {gen_run_starting_event:%7d}
diff --git a/src/THcDC.cxx b/src/THcDC.cxx
index 30ecae9c696bc2928409c1651fcfc1ec4664ec45..9015cf3bd207d1f069b866f36e3787d2389f92e5 100644
--- a/src/THcDC.cxx
+++ b/src/THcDC.cxx
@@ -23,8 +23,6 @@
 #include "TMath.h"
 #include "TVectorD.h"
 
-#include "THaTrackProj.h"
-
 #include <cstring>
 #include <cstdio>
 #include <cstdlib>
@@ -40,7 +38,6 @@ THcDC::THcDC(
 {
   // Constructor
 
-  //  fTrackProj = new TClonesArray( "THaTrackProj", 5 );
   fNPlanes = 0;			// No planes until we make them
 
   fXCenter = NULL;
@@ -333,6 +330,7 @@ Int_t THcDC::DefineVariables( EMode mode )
   RVarDef vars[] = {
     { "nhit", "Number of DC hits",  "fNhits" },
     { "ntrack", "Number of Tracks", "fNDCTracks" },
+    { "nsp", "Number of Space Points", "fNSp" },
     { "x", "X at focal plane", "fDCTracks.THcDCTrack.GetX()"},
     { "y", "Y at focal plane", "fDCTracks.THcDCTrack.GetY()"},
     { "xp", "YP at focal plane", "fDCTracks.THcDCTrack.GetXP()"},
@@ -361,10 +359,6 @@ THcDC::~THcDC()
   for (vector<THcDriftChamber*>::iterator ip = fChambers.begin();
        ip != fChambers.end(); ip++) delete *ip;
 
-  if (fTrackProj) {
-    fTrackProj->Clear();
-    delete fTrackProj; fTrackProj = 0;
-  }
   delete fDCTracks;
 }
 
@@ -549,7 +543,7 @@ void THcDC::LinkStubs()
   //                     stubs.
 
   std::vector<THcSpacePoint*> fSp;
-  Int_t fNSp=0;
+  fNSp=0;
   fSp.clear();
   fSp.reserve(10);
   // Make a vector of pointers to the SpacePoints
@@ -985,19 +979,18 @@ void THcDC::EffInit()
   // variables can be used in end of run reports.
 
   delete [] fNChamHits;  fNChamHits = new Int_t [fNChambers];
-  delete [] fHitsPerPlane; fHitsPerPlane = new Int_t [fNPlanes];
+  delete [] fPlaneEvents; fPlaneEvents = new Int_t [fNPlanes];
   
   fTotEvents = 0;
   for(Int_t i=0;i<fNChambers;i++) {
     fNChamHits[i] = 0;
   }
   for(Int_t i=0;i<fNPlanes;i++) {
-    fHitsPerPlane[i] = 0;
+    fPlaneEvents[i] = 0;
   }
   gHcParms->Define(Form("%sdc_tot_events",fPrefix),"Total DC Events",fTotEvents);
   gHcParms->Define(Form("%sdc_cham_hits[%d]",fPrefix,fNChambers),"N events with hits per chamber",*fNChamHits);
-  gHcParms->Define(Form("%sdc_hits_per_plane[%d]",fPrefix,fNPlanes),"N events with hits per plane",*fHitsPerPlane);
-  cout << Form("%sdc_hits_per_plane[%d]",fPrefix,fNPlanes) << endl;
+  gHcParms->Define(Form("%sdc_events[%d]",fPrefix,fNPlanes),"N events with hits per plane",*fPlaneEvents);
 }
 
 //_____________________________________________________________________________
@@ -1010,7 +1003,7 @@ void THcDC::Eff()
     if(fChambers[i]->GetNHits()>0) fNChamHits[i]++;
   }
   for(Int_t i=0;i<fNPlanes;i++) {
-    if(fPlanes[i]->GetNHits() > 0) fHitsPerPlane[i]++;
+    if(fPlanes[i]->GetNHits() > 0) fPlaneEvents[i]++;
   }
   return;
 }
diff --git a/src/THcDC.h b/src/THcDC.h
index 041b2eb6baf4bd2b5ef7d131469e7b359c538ea7..fb727a90d1464724bf662b328331161f78bf9493 100644
--- a/src/THcDC.h
+++ b/src/THcDC.h
@@ -36,8 +36,8 @@ public:
 
   //  Int_t GetNHits() const { return fNhit; }
   
-  Int_t GetNTracks() const { return fTrackProj->GetLast()+1; }
-  const TClonesArray* GetTrackHits() const { return fTrackProj; }
+  //  Int_t GetNTracks() const { return fNDCTracks; }
+  //  const TClonesArray* GetTrackHits() const { return fTrackProj; }
 
   Int_t GetNWires(Int_t plane) const { return fNWires[plane-1];}
   Int_t GetNChamber(Int_t plane) const { return fNChamber[plane-1];}
@@ -97,7 +97,7 @@ protected:
 
   // Per-event data
   Int_t fNhits;
-  Int_t ntracks_fp;		/* Change this to fN something */
+  Int_t fNSp;                   // Number of space points
   Double_t* fResiduals;         //[fNPlanes] Array of residuals
 
   Double_t fNSperChan;		/* TDC bin size */
@@ -141,7 +141,7 @@ protected:
   // For accumulating statitics for efficiencies
   Int_t fTotEvents;
   Int_t* fNChamHits;
-  Int_t* fHitsPerPlane;
+  Int_t* fPlaneEvents;
 
   // Useful derived quantities
   // double tan_angle, sin_angle, cos_angle;
diff --git a/src/THcDriftChamberPlane.cxx b/src/THcDriftChamberPlane.cxx
index fb97cc90c8482fc01b34d92112b05c1df9c80a50..4bdf51b4bf7406aca994cacfd4ba1da1f8c4483b 100644
--- a/src/THcDriftChamberPlane.cxx
+++ b/src/THcDriftChamberPlane.cxx
@@ -236,6 +236,7 @@ Int_t THcDriftChamberPlane::DefineVariables( EMode mode )
      "fHits.THcDCHit.GetTime()"},
     {"dist","Drift distancess",
      "fHits.THcDCHit.GetDist()"},
+    {"nhit", "Number of hits", "GetNHits()"},
     { 0 }
   };