00001 #ifndef L2PEDALGO_H
00002 #define L2PEDALGO_H
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014 class L2Histo;
00015 #ifdef IS_REAL_L2 //in l2-ana environmen
00016 #include "L2VirtualAlgo.h"
00017 #else
00018 #include "StTriggerUtilities/L2Emulator/L2algoUtil/L2VirtualAlgo.h"
00019 #endif
00020
00021 class L2pedAlgo : public L2VirtualAlgo {
00022 enum{minAdc=-20, maxAdc=4096};
00023
00024 #define MaxBtowRdo (L2EmcDb::BTOW_MAXFEE*L2EmcDb::BTOW_DATSIZE)
00025 #define MaxEtowRdo (L2EmcDb::ETOW_MAXFEE*L2EmcDb::ETOW_DATSIZE)
00026
00027 bool par_pedSubtr;
00028 bool par_saveBinary;
00029 int par_speedFact;
00030 int par_dbg;
00031 int par_prescAccept;
00032
00033
00034
00035 short s_stepE, s_stepB, s_lastE, s_lastB;
00036
00037
00038 enum { mxHA=64};
00039 L2Histo *hA[mxHA];
00040
00041 L2Histo *btowAdc[MaxBtowRdo];
00042 L2Histo *etowAdc[MaxEtowRdo];
00043 int nInp;
00044 int run_number;
00045
00046
00047 unsigned short db_btowPed[MaxBtowRdo];
00048 unsigned short db_etowPed[MaxEtowRdo];
00049
00050
00051 TrgDataType* myTrigData;
00052
00053 public:
00054 L2pedAlgo(const char* name, L2EmcDb* db, char* outDir, int resOff);
00055
00056 int initRun(int runNo, int *rc_ints, float *rc_floats);
00057
00058 bool doEvent(int L0trg, int inpEveId, TrgDataType* trgData,
00059 int bemcIn, ushort *bemcData,
00060 int eemcIn, ushort *eemcData);
00061
00062 void finishRun();
00063 };
00064
00065 #endif
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092