Geant4 Cross Reference |
1 // 1 // 2 // ******************************************* 2 // ******************************************************************** 3 // * License and Disclaimer 3 // * License and Disclaimer * 4 // * 4 // * * 5 // * The Geant4 software is copyright of th 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/ 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. 9 // * include a list of copyright holders. * 10 // * 10 // * * 11 // * Neither the authors of this software syst 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing fin 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warran 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assum 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitatio 16 // * for the full disclaimer and the limitation of liability. * 17 // * 17 // * * 18 // * This code implementation is the result 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboratio 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // 26 26 27 #ifndef G4FASTHIT_HH 27 #ifndef G4FASTHIT_HH 28 #define G4FASTHIT_HH 28 #define G4FASTHIT_HH 29 29 30 #include "G4ThreeVector.hh" 30 #include "G4ThreeVector.hh" 31 31 32 /** 32 /** 33 * @brief Minimal hit created in the fast simu 33 * @brief Minimal hit created in the fast simulation 34 * 34 * 35 * Minimal hit containing energy and position, 35 * Minimal hit containing energy and position, for use in the fast simulation 36 * classes. 36 * classes. 37 * Hits of G4FastHit type can be created in us 37 * Hits of G4FastHit type can be created in user implementation of fast 38 * simulation model and then deposited in the 38 * simulation model and then deposited in the detector using G4FastSimHitMaker 39 * helper class. The helper will locate the se 39 * helper class. The helper will locate the sensitive volume and check if it 40 * inherits from both base classes: 40 * inherits from both base classes: 41 * - G4VSensitiveDetector: for processing of d 41 * - G4VSensitiveDetector: for processing of detailed/non-fast simulation hits; 42 * - G4VFastSimSensitiveDetector: for processi 42 * - G4VFastSimSensitiveDetector: for processing of fast sim (G4FastSim) hits; 43 * An extended example extended/parameterisati 43 * An extended example extended/parameterisations/Par03 demonstrates how to use 44 * G4FastHit to create multiple deposits from 44 * G4FastHit to create multiple deposits from the fast simulation model. 45 */ 45 */ 46 46 47 class G4FastHit 47 class G4FastHit 48 { 48 { 49 public: 49 public: 50 G4FastHit() = default; 50 G4FastHit() = default; 51 G4FastHit(const G4ThreeVector& aPosition, 51 G4FastHit(const G4ThreeVector& aPosition, G4double aEnergy) 52 : fEnergy(aEnergy), fPosition(aPosition) 52 : fEnergy(aEnergy), fPosition(aPosition) 53 {} 53 {} 54 virtual ~G4FastHit() = default; 54 virtual ~G4FastHit() = default; 55 55 56 /// Set energy 56 /// Set energy 57 inline void SetEnergy(const G4double& aEne 57 inline void SetEnergy(const G4double& aEnergy) { fEnergy = aEnergy; } 58 /// Get energy 58 /// Get energy 59 inline G4double GetEnergy() const { return 59 inline G4double GetEnergy() const { return fEnergy; } 60 /// Set position 60 /// Set position 61 inline void SetPosition(const G4ThreeVecto 61 inline void SetPosition(const G4ThreeVector& aPosition) { fPosition = aPosition; } 62 /// Get position 62 /// Get position 63 inline G4ThreeVector GetPosition() const { 63 inline G4ThreeVector GetPosition() const { return fPosition; } 64 64 65 private: 65 private: 66 /// energy 66 /// energy 67 G4double fEnergy = 0; 67 G4double fEnergy = 0; 68 /// position 68 /// position 69 G4ThreeVector fPosition = G4ThreeVector(); 69 G4ThreeVector fPosition = G4ThreeVector(); 70 }; 70 }; 71 71 72 #endif /* G4FASTHIT_HH */ 72 #endif /* G4FASTHIT_HH */ 73 73