2 #include "CalibTracker/SiStripCommon/interface/TTREE_FOREACH_ENTRY.hh" 8 TTREE_FOREACH_ENTRY(
tree) {
11 std::vector<unsigned> PLEAF(tsostrackmulti,
tree);
12 std::vector<unsigned> PLEAF(clusterdetid,
tree);
13 std::vector<unsigned> PLEAF(clusterwidth,
tree);
14 std::vector<float> PLEAF(clustervariance,
tree);
15 std::vector<float> PLEAF(tsosdriftx,
tree);
16 std::vector<float> PLEAF(tsosdriftz,
tree);
17 std::vector<float> PLEAF(tsoslocaltheta,
tree);
18 std::vector<float> PLEAF(tsoslocalphi,
tree);
19 std::vector<float> PLEAF(tsosglobalZofunitlocalY,
tree);
21 const unsigned N(clusterdetid.size());
22 std::vector<float> BdotY(
N, 0);
24 std::vector<float> PLEAF(tsosBdotY,
tree);
25 swap(BdotY, tsosBdotY);
27 std::vector<float> localy(
N, 0);
29 std::vector<float> PLEAF(tsoslocaly,
tree);
30 swap(localy, tsoslocaly);
32 std::vector<unsigned> seedstrip(
N, 0);
34 std::vector<unsigned> PLEAF(clusterseedstrip,
tree);
35 swap(seedstrip, clusterseedstrip);
38 for (
unsigned i = 0;
i <
N;
i++) {
40 if (tsostrackmulti[
i] != 1 ||
44 const int sign = tsosglobalZofunitlocalY[
i] < 0 ? -1 : 1;
45 const float tthetaL =
sign * tsosdriftx[
i] / tsosdriftz[
i];
46 const float tthetaT =
sign *
tan(tsoslocaltheta[
i]) *
cos(tsoslocalphi[
i]);
49 granularity(detid, tthetaL, TFE_index, localy[
i], seedstrip[
i] % 128),
65 const float BdotY)
const {
66 book.
fill(tthetaL, gran +
"_reconstruction", 360, -1.0, 1.0);
72 book.
fill(BdotY, gran +
"_field", 101, 1, 5);
73 book.
fill(
width, gran +
"_width", 10, 0, 10);
96 const Long64_t TFE_index,
98 const unsigned apvstrip)
const {
poly< std::string > varWidth(const unsigned width) const
unsigned int tobLayer(const DetId &id) const
void fill_one_cluster(Book &, const poly< std::string > &, const unsigned, const float, const float, const float, const float) const
const Long64_t maxEvents_
SubDetector subDetector() const
static std::string moduleLabel(const SiStripDetId)
void swap(Association< C > &lhs, Association< C > &rhs)
static std::string to_string(const XMLCh *ch)
uint32_t tobStereo(const DetId &id) const
Cos< T >::type cos(const T &t)
Tan< T >::type tan(const T &t)
Abs< T >::type abs(const T &t)
poly< std::string > granularity(const SiStripDetId, const float, const Long64_t, const float, const unsigned) const
constexpr int subdetId() const
get the contents of the subdetector field (not cast into any detector's numbering enum) ...
static constexpr auto TOB
static std::string method(Method m, bool fit=true)
poly< std::string > allAndOne(const unsigned width) const
Detector identifier class for the strip tracker.
static constexpr auto TIB
void fill(double_t X, const char *name, uint_t NbinsX, double_t Xlow, double_t Xup, double_t W=1)
const TrackerTopology * tTopo_
static constexpr auto TIB
static std::string subdetLabel(const SiStripDetId)
void fill(TTree *, Book &) const
const unsigned stripsPerBin_
std::string layerLabel(const SiStripDetId) const
unsigned int tibLayer(const DetId &id) const
const double ensembleLow_
uint32_t tibStereo(const DetId &id) const