ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/UserCode/cbrown/AnalysisFramework/Plotting/Modules/Setup.C
(Generate patch)

Comparing UserCode/cbrown/AnalysisFramework/Plotting/Modules/Setup.C (file contents):
Revision 1.2 by buchmann, Wed Jul 6 11:01:20 2011 UTC vs.
Revision 1.53 by buchmann, Wed Nov 16 21:44:48 2011 UTC

# Line 1 | Line 1
1   #include <iostream>
2 + #include <fstream>
3   #include <TCut.h>
4 + #include <TColor.h>
5 + #include <TStyle.h>
6 +
7   #ifndef SampleClassLoaded
8   #include "SampleClass.C"
9   #endif
10 <
10 > #define SetupLoaded
11  
12   using namespace std;
13  
14  
15   namespace PlottingSetup {
16 <  float luminosity=751.0;//486.0;//468.0//336.;//pb^{-1}
16 >
17 >  string directoryname="official_4653ipb___NewSelection_ForPaperApproval";
18 >  
19 >  bool RestrictToMassPeak=true; //if you want to switch between offpeak ("false") and onpeak ("true") analysis please use this switch; the masscut below will be adapted automatically when adding samples :-)
20 >  
21 >  float luminosity=4653.74;//p3523.18;//2096.0;//3172.73;//2096.0;//1936;//751.0;//486.0;//468.0//336.;//pb^{-1}
22 > //  float luminosity=3523.18;//2096.0;//3172.73;//2096.0;//1936;//751.0;//486.0;//468.0//336.;//pb^{-1}
23 > //  float luminosity=2096.0;//3172.73;//2096.0;//1936;//751.0;//486.0;//468.0//336.;//pb^{-1}
24 >  float lumiuncert=0.045;// to be indicated in [0,1] range, e.g. for 4% write 0.04
25 >
26    string jzbvariabledata="jzb[1]+0.06*pt";
27    string jzbvariablemc="jzb[1]+0.04*pt";
28 <  
28 >  float jzbHigh = 350.; // Range for JZB plots
29 >
30    samplecollection allsamples("completesamplecollection");
31 +  samplecollection signalsamples("signalsamplecollection");
32 +  samplecollection scansample("scansamplecollection");
33 +  samplecollection raresample("raresamplecollection");
34    int data=1;
35    int mc=0;
36    int mcwithsignal=2;
37    TCut passtrig("(passed_triggers||!is_data)");
38    TCut cutmass("abs(mll-91.2)<20");
39 +  TCut genMassCut("abs(genMll-91.2)<20");
40 +  TCut openmasscut("mll>40"); // this is the mass cut used in the off peak analysis!
41 +  TCut openGenmasscut("genMll>40");
42    //TCut cutmass("mll>2");
43    TCut basiccut("mll>2");//basically nothing.
44 <  TCut basicqualitycut("(pfJetGoodNum>=2&&pfJetGoodID[0])&&(pfJetGoodNum>=2&&pfJetGoodID[1])");//don't use this for the "essential cut", because we want to plot nJets as well as mll in the inclusive case; we thus use it as an addition nJets cut.
44 >  TCut basicqualitycut("(pfJetGoodNum>=2&&pfJetGoodID[0]!=0)&&(pfJetGoodNum>=2&&pfJetGoodID[1]!=0)");//don't use this for the "essential cut", because we want to plot nJets as well as mll in the inclusive case; we thus use it as an addition nJets cut.
45    //TCut jetqualitycut("(pfJetGoodNum>=2&&pfJetGoodID[0])&&(pfJetGoodNum>=2&&pfJetGoodID[1])");//now part of the basiccut
46    //TCut jetqualitycut("mll>0");
47 +  
48    TCut cutnJets("pfJetGoodNum>=3"&&basicqualitycut);
49 +  TCut cutnJetsJESdown("pfJetGoodNum25>=3"&&basicqualitycut);
50 +  TCut cutnJetsJESup("pfJetGoodNum35>=3"&&basicqualitycut);
51    TCut cutOSOF("(id1!=id2)&&(ch1*ch2<0)");
52    TCut cutOSSF("(id1==id2)&&(ch1*ch2<0)");
53 +  TCut sidebandcut("(mll>55&&mll<70)||(mll>112&&mll<160)");
54 +
55 +  TCut Weight("weight"); // this is the weight that is used everywhere
56 +
57 +  //TCut sidebandcut("(mll>61&&mll<70)||(mll>112&&mll<190)");
58    //TCut basiccut("(passed_triggers||!is_data)");
59    
60 +  // SUSY scan parameters
61 +  float mglustart=25;float mgluend=1200;float mglustep=25;
62 +  float mLSPstart=25;float mLSPend=1200;float mLSPstep=25;
63 +  
64 +  float m0start=20;  float m0end=2000;  float m0step=20;
65 +  float m12start=20; float m12end=760;  float m12step=20;
66 +  
67 +  int ScanXzones=15; // number of zones in x for (mSUGRA) scans
68 +  int ScanYzones=15; // number of zones in y for (mSUGRA) scans
69 +
70    TCut essential(passtrig);//add here any cuts you ALWAYS want
71    int dogaus=0;
72    int doKM=1;
# Line 36 | Line 74 | namespace PlottingSetup {
74    int dogaus3sigma=3;
75    int Kostasmethod=-99;
76    
77 <  float fitresultconstdata=0;//this is the result when fitting in the 0-30 GeV range!
78 <  float fitresultconstmc=0;//this is the result when fitting in the 0-30 GeV range!
77 >  float fitresultconstdata=0;//this is the result when fitting in the 0-30 GeV range
78 >  float fitresultconstmc=0;//this is the result when fitting in the 0-30 GeV range
79 >  
80 >  int method=-1;//Fitting method
81 >  
82 >  //now some style issues:
83 >  float DataMarkerSize=1.2;
84 >  
85 >  //here we save our number of predicted and observed events (with errors)
86 >  vector<float> Nobs;
87 >  vector<float> Npred;
88 >  vector<float> Nprederr;
89 >  
90 >  //here we save our "flipped" number of predicted and observed events (with errors) -- this means that we consider JZB<-X as observed and construct the corresponding prediction
91 >  bool alwaysflip=false;
92 >  vector<float> flippedNobs;
93 >  vector<float> flippedNpred;
94 >  vector<float> flippedNprederr;
95    
96 <  int method=-1;
96 >  int noJES=0;
97 >  int JESdown=1;
98 >  int JESup=2;
99 >  
100 >  //some refinement: nicer color gradient
101 >  Double_t stops[5] = { 0.00, 0.34, 0.61, 0.84, 1.00 };
102 >  Double_t red[5]   = { 0.00, 0.00, 0.87, 1.00, 0.51 };
103 >  Double_t green[5] = { 0.00, 0.81, 1.00, 0.20, 0.00 };
104 >  Double_t blue[5]  = { 0.51, 1.00, 0.12, 0.00, 0.00 };
105 >  int fi=TColor::CreateGradientColorTable(5, stops, red, green,blue, 255);
106 >  
107 >  // LIMITS
108 >  int nlimittoys=1000; // how many toys for setting limits
109 >  string limitmethod="cls";//what method to use to set limits
110 >  int limitpatience=15; // for how many minutes should the limit calculation (for one configuration!) be allowed to run before being aborted? this only has an effect when when running on the t3 batch; the value for CRAB is on the next line
111 >  int limitpatienceCRAB=60;
112 >  bool ConsiderSignalContaminationForLimits=true; //whether or not to consider signal contamination when computing limits (standard:true)
113 >  int nuisancemodel=1;
114 >  
115 >  float JZBPeakPositionData=-999;
116 >  float JZBPeakPositionMC=-999;
117 >  float JZBPeakWidthData=-999;
118 >  float JZBPeakWidthMC=-999;
119 >
120 >  // two possible future systematics that ATM only take up CPU time in SUSY scans
121 >  bool computeJZBefficiency=false;
122 >  bool computeJZBresponse=false;
123 >
124 >  string ScanSampleDirectory="mSUGRA/"; // possibilities (atm) : SMS/, SMS_T5zzl/, mSUGRA/     note: if you're processing a SMS, you need to include the string "SMS" in the name!
125  
126 +  //watch out, the cbafbasedir string is in GeneralToolBox
127   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines