9 #define TRG_SHORT_NAMES
10 #define TRGECLCLUSTER_SHORT_NAMES
11 #include <framework/gearbox/Unit.h>
13 #include <trg/ecl/TrgEclBeamBKG.h>
20 TrgEclBeamBKG::TrgEclBeamBKG()
22 for (
int iii = 0; iii <= 2; iii++) {
23 for (
int jjj = 0; jjj <= 3; jjj++) {
24 Quadrant[iii][jjj] = 0;
33 TrgEclBeamBKG::~TrgEclBeamBKG()
41 int TrgEclBeamBKG::GetBeamBkg(std::vector<std::vector<double>> ThetaRingSum)
45 for (
int iFwd = 0 ; iFwd < 32 ; iFwd++) {
47 if (ThetaRingSum[0][iFwd] > 0) {
48 if ((phiid >= 1 && phiid <= 9) || phiid == 32) {
51 if (phiid >= 8 && phiid <= 17) {
54 if (phiid >= 16 && phiid <= 25) {
58 if ((phiid >= 24 && phiid <= 32) || phiid == 1) {
64 for (
int iBr = 0 ; iBr < 36 ; iBr++) {
66 if (ThetaRingSum[1][iBr] > 0) {
67 if ((phiid >= 1 && phiid <= 10) || phiid == 36) {
70 if (phiid >= 9 && phiid <= 19) {
73 if (phiid >= 18 && phiid <= 28) {
77 if ((phiid >= 27 && phiid <= 36) || phiid == 1) {
84 ((Quadrant[0][0] && Quadrant[0][2]) ||
85 (Quadrant[0][1] && Quadrant[0][3]));
88 ((Quadrant[1][0] && Quadrant[1][2]) ||
89 (Quadrant[1][1] && Quadrant[1][3]));
91 int iBeamBkgVeto0 = 0;
92 int iBeamBkgVeto1 = 0;
93 int iBeamBkgVeto2 = 0;
94 if (boolForward || boolBarrel) {
97 if ((!boolForward) && boolBarrel) {
100 if (boolForward && (!boolBarrel)) {
105 BeamBkgVeto |= (iBeamBkgVeto2 & 0x01);
107 BeamBkgVeto |= (iBeamBkgVeto1 & 0x01);
109 BeamBkgVeto |= (iBeamBkgVeto0 & 0x01);
Abstract base class for different kinds of events.