File indexing completed on 2025-08-06 08:17:52
0001 #ifndef __MBD_MBDPMTHITV1_H__
0002 #define __MBD_MBDPMTHITV1_H__
0003
0004 #include "MbdPmtHit.h"
0005
0006 #include <cmath>
0007 #include <iostream>
0008 #include <limits>
0009
0010 class MbdPmtHitV1 : public MbdPmtHit
0011 {
0012 public:
0013 MbdPmtHitV1() = default;
0014 ~MbdPmtHitV1() override = default;
0015
0016
0017 void Reset() override;
0018
0019
0020 void Clear(Option_t* = "") override;
0021
0022
0023 Short_t get_pmt() const override { return bpmt; }
0024
0025
0026 Float_t get_q() const override { return bq; }
0027
0028
0029 Float_t get_tt() const override { return btt; }
0030 Float_t get_time() const override { return btt; }
0031
0032
0033 Float_t get_tq() const override { return btq; }
0034
0035 void set_pmt(const Short_t pmt, const Float_t q, const Float_t tt, const Float_t tq) override
0036 {
0037 bpmt = pmt;
0038 bq = q;
0039 btt = tt;
0040 btq = tq;
0041 }
0042
0043
0044 void identify(std::ostream& out = std::cout) const override;
0045
0046
0047 virtual int isValid() const override
0048 {
0049 if (std::isnan(get_time())) return 0;
0050 return 1;
0051 }
0052
0053 private:
0054
0055
0056
0057
0058 Short_t bpmt;
0059 Float_t bq;
0060 Float_t btt;
0061 Float_t btq;
0062
0063 ClassDefOverride(MbdPmtHitV1, 1)
0064 };
0065
0066 #endif