File indexing completed on 2024-04-06 12:30:16
0001 #ifndef SimG4Core_CheckSecondary_TreatSecondary_H
0002 #define SimG4Core_CheckSecondary_TreatSecondary_H
0003
0004 #include "DataFormats/Math/interface/LorentzVector.h"
0005 #include "FWCore/ParameterSet/interface/ParameterSet.h"
0006
0007 #include <iostream>
0008 #include <memory>
0009 #include <string>
0010 #include <vector>
0011
0012 class G4Step;
0013 class G4Track;
0014 class G4ProcessTypeEnumerator;
0015
0016 class TreatSecondary {
0017 public:
0018 TreatSecondary(const edm::ParameterSet &p);
0019 TreatSecondary(const TreatSecondary &) = delete;
0020 const TreatSecondary &operator=(const TreatSecondary &) = delete;
0021 virtual ~TreatSecondary();
0022
0023 void initTrack(const G4Track *trk);
0024 std::vector<math::XYZTLorentzVector> tracks(
0025 const G4Step *step, std::string &procName, int &procID, bool &intr, double &deltaE, std::vector<int> &charges);
0026
0027 private:
0028 int verbosity, minSec, killAfter;
0029 double minDeltaE, eTrack;
0030 G4ProcessTypeEnumerator *typeEnumerator;
0031 int step, nHad, nsecL;
0032 };
0033
0034 #endif