File indexing completed on 2025-08-06 08:17:52
0001 #ifndef MBD_MBDOUTV2_H
0002 #define MBD_MBDOUTV2_H
0003
0004 #include "MbdOut.h"
0005
0006 #include <iostream>
0007 #include <limits>
0008
0009 class TClonesArray;
0010
0011
0012 class MbdOutV2 : public MbdOut
0013 {
0014 public:
0015
0016 MbdOutV2() = default;
0017
0018 ~MbdOutV2() override = default;
0019
0020
0021 void Reset() override;
0022
0023
0024
0025
0026 void identify(std::ostream &out = std::cout) const override;
0027
0028
0029 int isValid() const override;
0030
0031
0032 PHObject* CloneMe() const override { return new MbdOutV2(*this); }
0033 void CopyTo(MbdOut *mbd) override;
0034
0035
0036 Float_t get_zvtx() const override { return bz; }
0037
0038
0039 Float_t get_zvtxerr() const override { return bzerr; }
0040
0041
0042 Float_t get_t0() const override { return bt0; }
0043
0044
0045 Float_t get_t0err() const override { return bt0err; }
0046
0047
0048
0049
0050
0051 void set_t0(const Float_t t0, const Float_t t0err = 0) override;
0052
0053
0054 void set_zvtx(const Float_t vtx, const Float_t vtxerr = 0) override;
0055
0056
0057
0058
0059 void set_zvtxerr(const Float_t vtxerr) override;
0060
0061
0062
0063
0064
0065
0066
0067 void set_arm(const int iarm, const Short_t npmt, const Float_t chargesum, const Float_t timing) override;
0068
0069
0070
0071
0072
0073
0074 virtual void set_clocks(const Int_t ievt, const UShort_t iclk, const UShort_t ifemclk) override;
0075
0076
0077
0078
0079 Short_t get_npmt(const int iarm) const override;
0080
0081
0082
0083
0084 Float_t get_q(const int iarm) const override;
0085
0086
0087
0088
0089 Float_t get_time(const int iarm) const override;
0090
0091
0092
0093 virtual Int_t get_evt() const override;
0094
0095
0096
0097 virtual UShort_t get_clock() const override;
0098
0099
0100
0101 virtual UShort_t get_femclock() const override;
0102
0103 private:
0104 Float_t bz{std::numeric_limits<Float_t>::quiet_NaN()};
0105 Float_t bzerr{std::numeric_limits<Float_t>::quiet_NaN()};
0106 Float_t bt0{std::numeric_limits<Float_t>::quiet_NaN()};
0107 Float_t bt0err{std::numeric_limits<Float_t>::quiet_NaN()};
0108 Float_t bqs{0};
0109 Float_t bqn{0};
0110 Float_t bts{std::numeric_limits<Float_t>::quiet_NaN()};
0111 Float_t btn{std::numeric_limits<Float_t>::quiet_NaN()};
0112 Short_t bns{0};
0113 Short_t bnn{0};
0114 Int_t evt{-1};
0115 UShort_t clk{0};
0116 UShort_t femclk{0};
0117
0118 ClassDefOverride(MbdOutV2, 1)
0119 };
0120
0121 #endif