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 // G4Trajectory class implementation 26 // G4Trajectory class implementation 27 // 27 // 28 // Contact: 28 // Contact: 29 // Questions and comments to this code shoul 29 // Questions and comments to this code should be sent to 30 // Katsuya Amako (e-mail: Katsuya.Amako@k 30 // Katsuya Amako (e-mail: Katsuya.Amako@kek.jp) 31 // Makoto Asai (e-mail: asai@slac.stanf 31 // Makoto Asai (e-mail: asai@slac.stanford.edu) 32 // Takashi Sasaki (e-mail: Takashi.Sasaki@ 32 // Takashi Sasaki (e-mail: Takashi.Sasaki@kek.jp) 33 // ------------------------------------------- 33 // -------------------------------------------------------------------- 34 34 35 #include "G4Trajectory.hh" 35 #include "G4Trajectory.hh" 36 << 36 #include "G4TrajectoryPoint.hh" 37 #include "G4AttDef.hh" << 37 #include "G4ParticleTable.hh" 38 #include "G4AttDefStore.hh" 38 #include "G4AttDefStore.hh" >> 39 #include "G4AttDef.hh" 39 #include "G4AttValue.hh" 40 #include "G4AttValue.hh" 40 #include "G4ParticleTable.hh" << 41 #include "G4TrajectoryPoint.hh" << 42 #include "G4ClonedTrajectory.hh" << 43 #include "G4UIcommand.hh" 41 #include "G4UIcommand.hh" 44 #include "G4UnitsTable.hh" 42 #include "G4UnitsTable.hh" 45 #include "G4AutoLock.hh" << 46 << 47 namespace { << 48 G4Mutex CloneTrajectoryMutex = G4MUTEX_INITIA << 49 } << 50 43 51 // #define G4ATTDEBUG 44 // #define G4ATTDEBUG 52 #ifdef G4ATTDEBUG 45 #ifdef G4ATTDEBUG 53 # include "G4AttCheck.hh" << 46 #include "G4AttCheck.hh" 54 #endif 47 #endif 55 48 56 G4Allocator<G4Trajectory>*& aTrajectoryAllocat 49 G4Allocator<G4Trajectory>*& aTrajectoryAllocator() 57 { 50 { 58 G4ThreadLocalStatic G4Allocator<G4Trajectory 51 G4ThreadLocalStatic G4Allocator<G4Trajectory>* _instance = nullptr; 59 return _instance; 52 return _instance; 60 } 53 } 61 54 >> 55 G4Trajectory::G4Trajectory() >> 56 : initialMomentum( G4ThreeVector() ) >> 57 { >> 58 } >> 59 62 G4Trajectory::G4Trajectory(const G4Track* aTra 60 G4Trajectory::G4Trajectory(const G4Track* aTrack) 63 { 61 { 64 G4ParticleDefinition* fpParticleDefinition = 62 G4ParticleDefinition* fpParticleDefinition = aTrack->GetDefinition(); 65 ParticleName = fpParticleDefinition->GetPart 63 ParticleName = fpParticleDefinition->GetParticleName(); 66 PDGCharge = fpParticleDefinition->GetPDGChar 64 PDGCharge = fpParticleDefinition->GetPDGCharge(); 67 PDGEncoding = fpParticleDefinition->GetPDGEn 65 PDGEncoding = fpParticleDefinition->GetPDGEncoding(); 68 fTrackID = aTrack->GetTrackID(); 66 fTrackID = aTrack->GetTrackID(); 69 fParentID = aTrack->GetParentID(); 67 fParentID = aTrack->GetParentID(); 70 initialKineticEnergy = aTrack->GetKineticEne 68 initialKineticEnergy = aTrack->GetKineticEnergy(); 71 initialMomentum = aTrack->GetMomentum(); 69 initialMomentum = aTrack->GetMomentum(); 72 positionRecord = new G4TrajectoryPointContai 70 positionRecord = new G4TrajectoryPointContainer(); 73 71 74 // Following is for the first trajectory poi 72 // Following is for the first trajectory point 75 positionRecord->push_back(new G4TrajectoryPo 73 positionRecord->push_back(new G4TrajectoryPoint(aTrack->GetPosition())); 76 } 74 } 77 75 78 G4Trajectory::G4Trajectory(G4Trajectory& right 76 G4Trajectory::G4Trajectory(G4Trajectory& right) >> 77 : G4VTrajectory() 79 { 78 { 80 ParticleName = right.ParticleName; 79 ParticleName = right.ParticleName; 81 PDGCharge = right.PDGCharge; 80 PDGCharge = right.PDGCharge; 82 PDGEncoding = right.PDGEncoding; 81 PDGEncoding = right.PDGEncoding; 83 fTrackID = right.fTrackID; 82 fTrackID = right.fTrackID; 84 fParentID = right.fParentID; 83 fParentID = right.fParentID; 85 initialKineticEnergy = right.initialKineticE 84 initialKineticEnergy = right.initialKineticEnergy; 86 initialMomentum = right.initialMomentum; 85 initialMomentum = right.initialMomentum; 87 positionRecord = new G4TrajectoryPointContai 86 positionRecord = new G4TrajectoryPointContainer(); 88 87 89 for (auto& i : *right.positionRecord) { << 88 for(std::size_t i=0; i<right.positionRecord->size(); ++i) 90 auto rightPoint = (G4TrajectoryPoint*)i; << 89 { >> 90 G4TrajectoryPoint* rightPoint >> 91 = (G4TrajectoryPoint*)((*(right.positionRecord))[i]); 91 positionRecord->push_back(new G4Trajectory 92 positionRecord->push_back(new G4TrajectoryPoint(*rightPoint)); 92 } 93 } 93 } 94 } 94 95 95 G4VTrajectory* G4Trajectory::CloneForMaster() << 96 { << 97 G4AutoLock lock(&CloneTrajectoryMutex); << 98 auto* cloned = new G4ClonedTrajectory(*this) << 99 return cloned; << 100 } << 101 << 102 G4Trajectory::~G4Trajectory() 96 G4Trajectory::~G4Trajectory() 103 { 97 { 104 if (positionRecord != nullptr) { << 98 if (positionRecord != nullptr) 105 for (auto& i : *positionRecord) { << 99 { 106 delete i; << 100 for(std::size_t i=0; i<positionRecord->size(); ++i) >> 101 { >> 102 delete (*positionRecord)[i]; 107 } 103 } 108 positionRecord->clear(); 104 positionRecord->clear(); 109 delete positionRecord; 105 delete positionRecord; 110 } 106 } 111 } 107 } 112 108 113 void G4Trajectory::ShowTrajectory(std::ostream 109 void G4Trajectory::ShowTrajectory(std::ostream& os) const 114 { 110 { 115 // Invoke the default implementation in G4VT 111 // Invoke the default implementation in G4VTrajectory... 116 G4VTrajectory::ShowTrajectory(os); 112 G4VTrajectory::ShowTrajectory(os); 117 113 118 // ... or override with your own code here. 114 // ... or override with your own code here. 119 } 115 } 120 116 121 void G4Trajectory::DrawTrajectory() const 117 void G4Trajectory::DrawTrajectory() const 122 { 118 { 123 // Invoke the default implementation in G4VT 119 // Invoke the default implementation in G4VTrajectory... 124 G4VTrajectory::DrawTrajectory(); 120 G4VTrajectory::DrawTrajectory(); 125 121 126 // ... or override with your own code here. 122 // ... or override with your own code here. 127 } 123 } 128 124 129 const std::map<G4String, G4AttDef>* G4Trajecto << 125 const std::map<G4String,G4AttDef>* G4Trajectory::GetAttDefs() const 130 { 126 { 131 G4bool isNew; 127 G4bool isNew; 132 std::map<G4String, G4AttDef>* store = G4AttD << 128 std::map<G4String,G4AttDef>* store 133 if (isNew) { << 129 = G4AttDefStore::GetInstance("G4Trajectory",isNew); >> 130 if (isNew) >> 131 { 134 G4String ID("ID"); 132 G4String ID("ID"); 135 (*store)[ID] = G4AttDef(ID, "Track ID", "P << 133 (*store)[ID] = G4AttDef(ID,"Track ID","Physics","","G4int"); 136 134 137 G4String PID("PID"); 135 G4String PID("PID"); 138 (*store)[PID] = G4AttDef(PID, "Parent ID", << 136 (*store)[PID] = G4AttDef(PID,"Parent ID","Physics","","G4int"); 139 137 140 G4String PN("PN"); 138 G4String PN("PN"); 141 (*store)[PN] = G4AttDef(PN, "Particle Name << 139 (*store)[PN] = G4AttDef(PN,"Particle Name","Physics","","G4String"); 142 140 143 G4String Ch("Ch"); 141 G4String Ch("Ch"); 144 (*store)[Ch] = G4AttDef(Ch, "Charge", "Phy << 142 (*store)[Ch] = G4AttDef(Ch,"Charge","Physics","e+","G4double"); 145 143 146 G4String PDG("PDG"); 144 G4String PDG("PDG"); 147 (*store)[PDG] = G4AttDef(PDG, "PDG Encodin << 145 (*store)[PDG] = G4AttDef(PDG,"PDG Encoding","Physics","","G4int"); 148 146 149 G4String IKE("IKE"); 147 G4String IKE("IKE"); 150 (*store)[IKE] = G4AttDef(IKE, "Initial kin << 148 (*store)[IKE] = >> 149 G4AttDef(IKE, "Initial kinetic energy", >> 150 "Physics","G4BestUnit","G4double"); 151 151 152 G4String IMom("IMom"); 152 G4String IMom("IMom"); 153 (*store)[IMom] = G4AttDef(IMom, "Initial m << 153 (*store)[IMom] = G4AttDef(IMom, "Initial momentum", >> 154 "Physics","G4BestUnit","G4ThreeVector"); 154 155 155 G4String IMag("IMag"); 156 G4String IMag("IMag"); 156 (*store)[IMag] = << 157 (*store)[IMag] = 157 G4AttDef(IMag, "Initial momentum magnitu << 158 G4AttDef(IMag, "Initial momentum magnitude", >> 159 "Physics","G4BestUnit","G4double"); 158 160 159 G4String NTP("NTP"); 161 G4String NTP("NTP"); 160 (*store)[NTP] = G4AttDef(NTP, "No. of poin << 162 (*store)[NTP] = G4AttDef(NTP,"No. of points","Physics","","G4int"); >> 163 161 } 164 } 162 return store; 165 return store; 163 } 166 } 164 167 165 std::vector<G4AttValue>* G4Trajectory::CreateA 168 std::vector<G4AttValue>* G4Trajectory::CreateAttValues() const 166 { 169 { 167 auto values = new std::vector<G4AttValue>; << 170 std::vector<G4AttValue>* values = new std::vector<G4AttValue>; 168 171 169 values->push_back(G4AttValue("ID", G4UIcomma << 172 values->push_back >> 173 (G4AttValue("ID",G4UIcommand::ConvertToString(fTrackID),"")); 170 174 171 values->push_back(G4AttValue("PID", G4UIcomm << 175 values->push_back >> 176 (G4AttValue("PID",G4UIcommand::ConvertToString(fParentID),"")); 172 177 173 values->push_back(G4AttValue("PN", ParticleN << 178 values->push_back(G4AttValue("PN",ParticleName,"")); 174 179 175 values->push_back(G4AttValue("Ch", G4UIcomma << 180 values->push_back >> 181 (G4AttValue("Ch",G4UIcommand::ConvertToString(PDGCharge),"")); 176 182 177 values->push_back(G4AttValue("PDG", G4UIcomm << 183 values->push_back >> 184 (G4AttValue("PDG",G4UIcommand::ConvertToString(PDGEncoding),"")); 178 185 179 values->push_back(G4AttValue("IKE", G4BestUn << 186 values->push_back >> 187 (G4AttValue("IKE",G4BestUnit(initialKineticEnergy,"Energy"),"")); 180 188 181 values->push_back(G4AttValue("IMom", G4BestU << 189 values->push_back >> 190 (G4AttValue("IMom",G4BestUnit(initialMomentum,"Energy"),"")); 182 191 183 values->push_back(G4AttValue("IMag", G4BestU << 192 values->push_back >> 193 (G4AttValue("IMag",G4BestUnit(initialMomentum.mag(),"Energy"),"")); 184 194 185 values->push_back(G4AttValue("NTP", G4UIcomm << 195 values->push_back >> 196 (G4AttValue("NTP",G4UIcommand::ConvertToString(GetPointEntries()),"")); 186 197 187 #ifdef G4ATTDEBUG 198 #ifdef G4ATTDEBUG 188 G4cout << G4AttCheck(values, GetAttDefs()); << 199 G4cout << G4AttCheck(values,GetAttDefs()); 189 #endif 200 #endif 190 201 191 return values; 202 return values; 192 } 203 } 193 204 194 void G4Trajectory::AppendStep(const G4Step* aS 205 void G4Trajectory::AppendStep(const G4Step* aStep) 195 { 206 { 196 positionRecord->push_back(new G4TrajectoryPo << 207 positionRecord->push_back( new G4TrajectoryPoint(aStep->GetPostStepPoint()-> >> 208 GetPosition()) ); 197 } 209 } 198 << 210 199 G4ParticleDefinition* G4Trajectory::GetParticl 211 G4ParticleDefinition* G4Trajectory::GetParticleDefinition() 200 { 212 { 201 return (G4ParticleTable::GetParticleTable()- 213 return (G4ParticleTable::GetParticleTable()->FindParticle(ParticleName)); 202 } 214 } 203 215 204 void G4Trajectory::MergeTrajectory(G4VTrajecto 216 void G4Trajectory::MergeTrajectory(G4VTrajectory* secondTrajectory) 205 { 217 { 206 if (secondTrajectory == nullptr) return; << 218 if(secondTrajectory == nullptr) return; 207 219 208 auto seco = (G4Trajectory*)secondTrajectory; << 220 G4Trajectory* seco = (G4Trajectory*)secondTrajectory; 209 G4int ent = seco->GetPointEntries(); 221 G4int ent = seco->GetPointEntries(); 210 for (G4int i = 1; i < ent; ++i) // initial << 222 for(G4int i=1; i<ent; ++i) // initial pt of 2nd trajectory shouldn't be merged 211 { 223 { 212 positionRecord->push_back((*(seco->positio 224 positionRecord->push_back((*(seco->positionRecord))[i]); 213 } 225 } 214 delete (*seco->positionRecord)[0]; 226 delete (*seco->positionRecord)[0]; 215 seco->positionRecord->clear(); 227 seco->positionRecord->clear(); 216 } 228 } 217 229