/[PAMELA software]/PamCut/TrkCuts/TrkDedxHCut/TrkDedxHCut.h
ViewVC logotype

Contents of /PamCut/TrkCuts/TrkDedxHCut/TrkDedxHCut.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (show annotations) (download)
Wed May 27 13:30:08 2009 UTC (15 years, 7 months ago) by pam-fi
Branch: MAIN
Branch point for: DEV
File MIME type: text/plain
Initial revision

1 /*
2 * TrkDedxHCut.h
3 *
4 * Created on: 26-mar-2009
5 * Author: Nico De Simone, S. Ricciarini
6 */
7
8 /*! @file TrkDedxHCut.h The TrkDedxHCut class definition file */
9
10 #ifndef TRKDEDXHCUT_H_
11 #define TRKDEDXHCUT_H_
12
13 #include "../../PamCutBase/PamCutBase.h"
14
15 #include <TH2F.h>
16
17 /*! @brief The dE/dX cut to select H and anti-H.
18 * This cut discards all the events whose rigidity modulus and dE/dX (both given by TRK) are outside a pre-defined band (by Nico De Simone).
19 * Here rigidity is defined as p/Z (GV) where Z is the particle charge (WITH SIGN) and p the momentum modulus: therefore rigidity can be positive or negative.
20 * CUT DEPENDENCIES: TrkPhysSin for object trkTrack
21 */
22 class TrkDedxHCut: public PamCut {
23
24 public:
25
26 /*! @brief Constructor.
27 *
28 * @param cutName The cut's name.
29 */
30 TrkDedxHCut(const char *cutName) :
31 PamCut(cutName) {
32
33 #ifdef DEBUGPAMCUT
34
35 TString hId;
36 TString hTitle;
37
38 for (UInt_t j = 0; j < 2; j++) {
39 hId.Form("h_trk_he_dedx_vs_rigmod_%i", j);
40 hTitle.Form("TRK HE dE/dX vs |rig| (%i)", j);
41 h_trk_he_dedx_rigmod[j] = new TH2F(hId.Data(), hTitle.Data(), 50, 0, 20, 50, 0, 10);
42 }
43 for (UInt_t j = 0; j < 2; j++) {
44 hId.Form("h_trk_le_dedx_vs_rigmod_%i", j);
45 hTitle.Form("TRK LE dE/dX vs |rig| (%i)", j);
46 h_trk_le_dedx_rigmod[j] = new TH2F(hId.Data(), hTitle.Data(), 60, 0, 3, 50, 0, 10);
47 }
48
49 #endif
50
51 }
52
53 /*! @brief Destructor. */
54 ~TrkDedxHCut() {
55
56 #ifdef DEBUGPAMCUT
57
58 for (UInt_t j = 0; j < 2; j++) {
59 h_trk_he_dedx_rigmod[j]->Write();
60 h_trk_le_dedx_rigmod[j]->Write();
61 }
62
63 #endif
64
65 }
66
67 /*! @brief The rigidity check.
68 *
69 * @param event The event to analyze.
70 * @return #CUTOK if the (rigidity modulus , dE/dX) point is inside the pre-defined band.
71 * @return 0 otherwise.
72 */
73 int Check(PamLevel2 *event);
74
75 private:
76
77 #ifdef DEBUGPAMCUT
78
79 TH2F* h_trk_he_dedx_rigmod[2];
80 TH2F* h_trk_le_dedx_rigmod[2];
81
82 #endif
83
84 // lower cut line
85 static const int _nLow = 23;
86 static const Double_t _xLow[];
87 static const Double_t _yLow[];
88
89 // higher cut line
90 static const int _nHigh = 21;
91 static const Double_t _xHigh[];
92 static const Double_t _yHigh[];
93
94 };
95 #endif

  ViewVC Help
Powered by ViewVC 1.1.23