Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2025-02-23 09:20:10

0001 //
0002 // ********************************************************************
0003 // * License and Disclaimer                                           *
0004 // *                                                                  *
0005 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
0006 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
0007 // * conditions of the Geant4 Software License,  included in the file *
0008 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
0009 // * include a list of copyright holders.                             *
0010 // *                                                                  *
0011 // * Neither the authors of this software system, nor their employing *
0012 // * institutes,nor the agencies providing financial support for this *
0013 // * work  make  any representation or  warranty, express or implied, *
0014 // * regarding  this  software system or assume any liability for its *
0015 // * use.  Please see the license in the file  LICENSE  and URL above *
0016 // * for the full disclaimer and the limitation of liability.         *
0017 // *                                                                  *
0018 // * This  code  implementation is the result of  the  scientific and *
0019 // * technical work of the GEANT4 collaboration.                      *
0020 // * By using,  copying,  modifying or  distributing the software (or *
0021 // * any work based  on the software)  you  agree  to acknowledge its *
0022 // * use  in  resulting  scientific  publications,  and indicate your *
0023 // * acceptance of all terms of the Geant4 Software license.          *
0024 // ********************************************************************
0025 //
0026 // Previous authors: G. Guerrieri, S. Guatelli and M. G. Pia, INFN Genova, Italy
0027 // Authors (since 2007): S. Guatelli, University of Wollongong, Australia
0028 //
0029 #include "G4HumanPhantomSD.hh"
0030 #include "G4HCofThisEvent.hh"
0031 #include "G4Step.hh"
0032 #include "G4SDManager.hh"
0033 #include "G4ios.hh"
0034 
0035 G4HumanPhantomSD::G4HumanPhantomSD(const G4String& name,
0036                          const G4String& hitsCollectionName)
0037   :G4VSensitiveDetector(name)
0038 {
0039  G4String HCname;
0040  collectionName.insert(hitsCollectionName);
0041 }
0042 
0043 G4HumanPhantomSD::~G4HumanPhantomSD()
0044 { 
0045 }
0046 
0047 void G4HumanPhantomSD::Initialize(G4HCofThisEvent* HCE)
0048 {
0049   collection = new G4HumanPhantomHitsCollection
0050                           (SensitiveDetectorName,collectionName[0]); 
0051   static G4int HCID = -1;
0052   if(HCID<0)
0053   { 
0054   HCID = G4SDManager::GetSDMpointer()->GetCollectionID(collectionName[0]); }
0055   HCE->AddHitsCollection( HCID, collection ); 
0056 }
0057 
0058 G4bool G4HumanPhantomSD::ProcessHits(G4Step* aStep,G4TouchableHistory*)
0059 {  
0060   G4double edep = aStep->GetTotalEnergyDeposit();
0061 
0062   if(edep==0.) return false;
0063  
0064   G4String bodypartName = aStep->GetPreStepPoint()->GetTouchable()
0065             ->GetVolume()->GetLogicalVolume()->GetName();
0066 
0067   // G4cout <<bodypartName <<":" << edep/MeV<< G4endl; 
0068 
0069   G4HumanPhantomHit* newHit = new G4HumanPhantomHit();
0070   newHit->SetEdep(edep);
0071   newHit->SetBodyPartID(bodypartName);
0072   collection->insert(newHit);
0073   
0074  return true;
0075 }
0076 
0077 void G4HumanPhantomSD::EndOfEvent(G4HCofThisEvent*)
0078 {
0079 
0080 // G4int NbHits = collection->entries();
0081 //      G4cout << "\n-------->Hits Collection: in this event they are " << NbHits 
0082 //             << " hits in the tracker chambers: " << G4endl;
0083 //      for (G4int i=0;i<NbHits;i++) (*collection)[i]->Print();
0084 }