Back to home page

sPhenix code displayed by LXR

 
 

    


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   //! Just does a clear
0017   void Reset() override;
0018 
0019   //! Clear is used by TClonesArray to reset the tower to initial state without calling destructor/constructor
0020   void Clear(Option_t* = "") override;
0021 
0022   //! PMT number
0023   Short_t get_pmt() const override { return bpmt; }
0024 
0025   //! Effective Nch in PMT
0026   Float_t get_q() const override { return bq; }
0027 
0028   //! Time from time channel
0029   Float_t get_tt() const override { return btt; }
0030   Float_t get_time() const override { return btt; }
0031 
0032   //! Time from charge channel
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   //! Prints out exact identity of object
0044   void identify(std::ostream& out = std::cout) const override;
0045 
0046   //! isValid returns non zero if object contains valid data
0047   virtual int isValid() const override
0048   {
0049     if (std::isnan(get_time())) return 0;
0050     return 1;
0051   }
0052 
0053  private:
0054   //Short_t bpmt{-1};
0055   //Float_t bq{std::numeric_limits<float>::quiet_NaN()};
0056   //Float_t btt{std::numeric_limits<float>::quiet_NaN()};
0057   //Float_t btq{std::numeric_limits<float>::quiet_NaN()};
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