Geant4  9.6.p02
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4RDAugerTransition.cc
Go to the documentation of this file.
1 //
2 // ********************************************************************
3 // * License and Disclaimer *
4 // * *
5 // * The Geant4 software is copyright of the Copyright Holders of *
6 // * the Geant4 Collaboration. It is provided under the terms and *
7 // * conditions of the Geant4 Software License, included in the file *
8 // * LICENSE and available at http://cern.ch/geant4/license . These *
9 // * include a list of copyright holders. *
10 // * *
11 // * Neither the authors of this software system, nor their employing *
12 // * institutes,nor the agencies providing financial support for this *
13 // * work make any representation or warranty, express or implied, *
14 // * regarding this software system or assume any liability for its *
15 // * use. Please see the license in the file LICENSE and URL above *
16 // * for the full disclaimer and the limitation of liability. *
17 // * *
18 // * This code implementation is the result of the scientific and *
19 // * technical work of the GEANT4 collaboration. *
20 // * By using, copying, modifying or distributing the software (or *
21 // * any work based on the software) you agree to acknowledge its *
22 // * use in resulting scientific publications, and indicate your *
23 // * acceptance of all terms of the Geant4 Software license. *
24 // ********************************************************************
25 //
26 //
27 // $Id: G4RDAugerTransition.cc,v 1.2 ????
28 //
29 // Based on G4AtomicTransition.cc by
30 // Elena Guardincerri (Elena.Guardincerri@ge.infn.it)
31 //
32 // Author: Alfonso Mantero (Alfonso.Mantero@ge.infn.it)
33 //
34 // History:
35 // -----------
36 // 4 Mar 2002: first implementation
37 //
38 // -------------------------------------------------------------------
39 
40 #include "G4RDAugerTransition.hh"
41 
42 // the final shell in wich the electron goes is needed, to know the data for the auger electron emitted
43 // (i.e. originating shell id, electron energy and transition probability)
44 
45 G4RDAugerTransition::G4RDAugerTransition(G4int finalShell, std::vector<G4int> transIds,
46  const std::map<G4int,std::vector<G4int>,std::less<G4int> >* idMap,
47  const std::map<G4int,G4DataVector,std::less<G4int> >* energyMap,
48  const std::map<G4int,G4DataVector,std::less<G4int> >* probabilityMap)
49 {
50  finalShellId = finalShell;
51  augerOriginatingShellIdsMap = *idMap;
52  augerTransitionEnergiesMap = *energyMap;
53  augerTransitionProbabilitiesMap = *probabilityMap;
54  transitionOriginatingShellIds = transIds;
55 
56 
57 }
58 
60 {
61 
62 }
63 
64 // Returns the ids of the shells from wich an auger electron culd came from, given th shell
65 // from wich the transition electron cames from.
66 
67 const std::vector<G4int>* G4RDAugerTransition::AugerOriginatingShellIds(G4int startShellId) const
68 {
69  std::map<G4int,std::vector<G4int>,std::less<G4int> >::const_iterator shellId = augerOriginatingShellIdsMap.find(startShellId);
70 
71  const std::vector<G4int>* dataSet = &(*shellId).second;
72  //const std::vector<G4int>* dataOut = 0;
73 
74  if (dataSet->size() == 0) {G4cout << "Error: no auger Id found"<< G4endl;}
75  else {
76 
77  // dataOut = &dataSet;
78 
79  }
80 
81  return dataSet;
82 }
83 
84 // Returns the ids of the shells from wich an electron cuuld fill the vacancy in finalShellId
85 
86 const std::vector<G4int>* G4RDAugerTransition::TransitionOriginatingShellIds() const
87 {
88 
89  const std::vector<G4int>* dataSet = &transitionOriginatingShellIds;
90  return dataSet;
91 }
92 
93 // Returns the energiess of the possible auger electrons, given th shell
94 // from wich the transition electron cames from.
95 
97 {
98  std::map<G4int,G4DataVector,std::less<G4int> >::const_iterator shellId = augerTransitionEnergiesMap.find(startShellId);
99  const G4DataVector* dataSet = &(*shellId).second;
100 
101 
102  return dataSet;
103 }
104 
105 // Returns the emission probabilities of the auger electrons, given th shell
106 // from wich the transition electron cames from.
107 
109 {
110  std::map<G4int,G4DataVector,std::less<G4int> >::const_iterator shellId = augerTransitionProbabilitiesMap.find(startShellId);
111  const G4DataVector* dataSet = &(*shellId).second;
112  return dataSet;
113 }
114 
116 {
117  return finalShellId;
118 }
119 
120 // Returns the id of the shell from wich come the auger electron , given the shell
121 // from wich the transition electron cames from and the index number.
122 
124 {
125  const std::vector<G4int>* ids = AugerOriginatingShellIds(startShellId);
126  // G4int i =
127  std::vector<G4int>::const_iterator pos = ids->begin();
128  G4int n = 0;
129  n = *(pos+index);
130  return n;
131 }
132 
133 // Returns the energy of the auger electron, given the shell
134 // from wich the transition electron cames from and the index number.
135 
137 {
138  const G4DataVector* energies = AugerTransitionEnergies(startShellId);
139  G4double energy = 0;
140  if (index < (G4int) energies->size()) {
141  G4DataVector::const_iterator pos = energies->begin();
142  energy = *(pos+index);
143  }
144  return energy;
145 }
146 
147 // Returns the probability of the auger emission, given the shell
148 // from wich the transition electron cames from and the index number.
149 
151 {
152 
153  const G4DataVector *probabilities = AugerTransitionProbabilities(startShellId);
154  G4DataVector::const_iterator pos = probabilities->begin();
155 
156  G4double probability = 0;
157  probability = *(pos+index);
158 
159  return probability;
160 
161 }
162 
164 {
165  return transitionOriginatingShellIds[index];
166 }
167 
168 
169 
170 
171 
172 
173 
174 
175 
176 
177 
178 
179 
180 
181 
182 
183 
184 
185 
186 
187