G4PSPassageTrackLength.cc

Go to the documentation of this file.
00001 //
00002 // ********************************************************************
00003 // * License and Disclaimer                                           *
00004 // *                                                                  *
00005 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
00006 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
00007 // * conditions of the Geant4 Software License,  included in the file *
00008 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
00009 // * include a list of copyright holders.                             *
00010 // *                                                                  *
00011 // * Neither the authors of this software system, nor their employing *
00012 // * institutes,nor the agencies providing financial support for this *
00013 // * work  make  any representation or  warranty, express or implied, *
00014 // * regarding  this  software system or assume any liability for its *
00015 // * use.  Please see the license in the file  LICENSE  and URL above *
00016 // * for the full disclaimer and the limitation of liability.         *
00017 // *                                                                  *
00018 // * This  code  implementation is the result of  the  scientific and *
00019 // * technical work of the GEANT4 collaboration.                      *
00020 // * By using,  copying,  modifying or  distributing the software (or *
00021 // * any work based  on the software)  you  agree  to acknowledge its *
00022 // * use  in  resulting  scientific  publications,  and indicate your *
00023 // * acceptance of all terms of the Geant4 Software license.          *
00024 // ********************************************************************
00025 //
00026 //
00027 // $Id$
00028 //
00029 // G4PSPassageTrackLength
00030 #include "G4PSPassageTrackLength.hh"
00031 #include "G4StepStatus.hh"
00032 #include "G4Track.hh"
00033 #include "G4UnitsTable.hh"
00034 
00036 // (Description)
00037 //   This is a primitive scorer class for scoring only track length.
00038 //   The tracks which passed a geometry is taken into account.
00039 // 
00040 //
00041 // Created: 2005-11-14  Tsukasa ASO, Akinori Kimura.
00042 // 2010-07-22   Introduce Unit specification.
00043 // 
00045 
00046 G4PSPassageTrackLength::G4PSPassageTrackLength(G4String name, G4int depth)
00047   :G4VPrimitiveScorer(name,depth),HCID(-1),fCurrentTrkID(-1),fTrackLength(0.),
00048    weighted(false)
00049 {
00050     SetUnit("mm");
00051 }
00052 
00053 G4PSPassageTrackLength::G4PSPassageTrackLength(G4String name, 
00054                                                const G4String& unit, 
00055                                                G4int depth)
00056   :G4VPrimitiveScorer(name,depth),HCID(-1),fCurrentTrkID(-1),fTrackLength(0.),
00057    weighted(false)
00058 {
00059     SetUnit(unit);
00060 }
00061 
00062 
00063 G4PSPassageTrackLength::~G4PSPassageTrackLength()
00064 {;}
00065 
00066 G4bool G4PSPassageTrackLength::ProcessHits(G4Step* aStep,G4TouchableHistory*)
00067 {
00068 
00069   if ( IsPassed(aStep) ) {
00070     G4int index = GetIndex(aStep);
00071     EvtMap->add(index,fTrackLength);
00072   }
00073 
00074   return TRUE;
00075 }
00076 
00077 G4bool G4PSPassageTrackLength::IsPassed(G4Step* aStep){
00078   G4bool Passed = FALSE;
00079 
00080   G4bool IsEnter = aStep->GetPreStepPoint()->GetStepStatus() == fGeomBoundary;
00081   G4bool IsExit  = aStep->GetPostStepPoint()->GetStepStatus() == fGeomBoundary;
00082 
00083   G4int  trkid  = aStep->GetTrack()->GetTrackID();
00084   G4double trklength  = aStep->GetStepLength();
00085   if(weighted) trklength *= aStep->GetPreStepPoint()->GetWeight();
00086 
00087   if ( IsEnter &&IsExit ){         // Passed at one step
00088     fTrackLength = trklength;      // Track length is absolutely given.
00089     Passed = TRUE;                 
00090   }else if ( IsEnter ){            // Enter a new geometry
00091     fCurrentTrkID = trkid;         // Resetting the current track.
00092     fTrackLength  = trklength;     
00093   }else if ( IsExit ){             // Exit a current geometry
00094     if ( fCurrentTrkID == trkid ) {
00095       fTrackLength  += trklength;  // Adding the track length to current one,
00096       Passed = TRUE;               // if the track is same as entered.
00097     }
00098   }else{                           // Inside geometry
00099     if ( fCurrentTrkID == trkid ){ // Adding the track length to current one ,
00100       fTrackLength  += trklength;  // if the track is same as entered.
00101     }
00102   }
00103 
00104   return Passed;
00105 }
00106 
00107 void G4PSPassageTrackLength::Initialize(G4HCofThisEvent* HCE)
00108 {
00109   fCurrentTrkID = -1;
00110 
00111   EvtMap = new G4THitsMap<G4double>(detector->GetName(),GetName());
00112   if ( HCID < 0 ) HCID = GetCollectionID(0);
00113   HCE->AddHitsCollection(HCID,EvtMap);
00114 }
00115 
00116 void G4PSPassageTrackLength::EndOfEvent(G4HCofThisEvent*)
00117 {;}
00118 
00119 void G4PSPassageTrackLength::clear(){
00120   EvtMap->clear();
00121 }
00122 
00123 void G4PSPassageTrackLength::DrawAll()
00124 {;}
00125 
00126 void G4PSPassageTrackLength::PrintAll()
00127 {
00128   G4cout << " MultiFunctionalDet  " << detector->GetName() << G4endl;
00129   G4cout << " PrimitiveSenstivity " << GetName() << G4endl;
00130   G4cout << " Number of entries " << EvtMap->entries() << G4endl;
00131   std::map<G4int,G4double*>::iterator itr = EvtMap->GetMap()->begin();
00132   for(; itr != EvtMap->GetMap()->end(); itr++) {
00133     G4cout << "  copy no.: " << itr->first
00134            << "  track length : " 
00135            << *(itr->second)/GetUnitValue()
00136            << " [" << GetUnit()<< "]"
00137            << G4endl;
00138   }
00139 }
00140 
00141 void G4PSPassageTrackLength::SetUnit(const G4String& unit)
00142 {
00143     CheckAndSetUnit(unit,"Length");
00144 }

Generated on Mon May 27 17:49:29 2013 for Geant4 by  doxygen 1.4.7