89 {
return fSinglePhotonRadiationProbabilityLimit;}
107 {
return fPhotonEnergyInSpectrum;}
116 {fSinglePhotonRadiationProbabilityLimit = wmax;}
121 {fNSmallTrajectorySteps = nSmallTrajectorySteps;}
135 {fRadiationAngleFactor = radiationAngleFactor;}
159 G4int timesPhotonStatistics);
164 {fVirtualCollimatorAngularDiameter=virtualCollimatorAngularDiameter;}
177 G4bool flagEndTrajectory=
false);
191 void SetPhotonSamplingParameters(
G4double ekin,
199 void GeneratePhotonSampling();
205 std::vector<G4double> &vectorParticleAnglesX,
206 std::vector<G4double> &vectorParticleAnglesY,
207 std::vector<G4double> &vectorScatteringAnglesX,
208 std::vector<G4double> &vectorScatteringAnglesY,
209 std::vector<G4double> &vectorSteps,
217 G4int FindVectorIndex(std::vector<G4double> &myvector,
G4double value);
219 G4double fTotalRadiationProbability = 0.;
220 G4double fSinglePhotonRadiationProbabilityLimit=0.25;
224 G4int fNSmallTrajectorySteps=10000;
228 G4int fNMCPhotons =150;
230 G4int fNBinsSpectrum = 110;
231 G4double fMinPhotonEnergy = 0.1*CLHEP::MeV;
232 G4double fMaxPhotonEnergy = 1*CLHEP::GeV;
242 G4double fVirtualCollimatorAngularDiameter=1.;
243 std::vector<G4bool> fInsideVirtualCollimator;
246 std::vector<G4double> fLogAddRangeEmindEmin;
247 std::vector<G4double> fLogAddRangeEmaxdEmin;
248 std::vector<G4int> fTimesPhotonStatistics;
252 G4int fItrajectories = 0;
260 G4double fParamPhotonAngleX=1.e-3*CLHEP::rad;
264 G4double fParamPhotonAngleY=1.e-3*CLHEP::rad;
266 G4double fRadiationAngleFactor = 4.;
279 std::vector<G4double> fPhotonEnergyInIntegral;
280 std::vector<G4double> fPhotonAngleInIntegralX;
281 std::vector<G4double> fPhotonAngleInIntegralY;
282 std::vector<G4double> fPhotonAngleNormCoef;
284 std::vector<G4double> fIBinsSpectrum;
286 std::vector<G4double> fPhotonProductionCDF;
289 std::vector<G4double> fParticleAnglesX;
290 std::vector<G4double> fParticleAnglesY;
291 std::vector<G4double> fScatteringAnglesX;
292 std::vector<G4double> fScatteringAnglesY;
293 std::vector<G4double> fSteps;
294 std::vector<G4double> fGlobalTimes;
295 std::vector<G4ThreeVector> fParticleCoordinatesXYZ;
298 std::vector<G4double> fFa;
299 std::vector<G4double> fSs;
300 std::vector<G4double> fSc;
301 std::vector<G4double> fSsx;
302 std::vector<G4double> fSsy;
303 std::vector<G4double> fScx;
304 std::vector<G4double> fScy;
307 std::vector<G4double> fPhotonEnergyInSpectrum;
309 std::vector<G4int> fNPhotonsPerBin;
312 std::vector<G4double> fSpectrum;
315 std::vector<std::vector<G4double>> fAccumSpectrum;
318 std::vector<G4double> fAccumTotalSpectrum;
323 std::vector<G4double> fTotalSpectrum;
330 std::vector<G4double> fImax0;
333 std::vector<G4double> fTotalRadiationProbabilityAlongTrajectory;
G4bool DoRadiation(G4double etotal, G4double mass, G4double angleX, G4double angleY, G4double angleScatteringX, G4double angleScatteringY, G4double step, G4double globalTime, G4ThreeVector coordinateXYZ, G4bool flagEndTrajectory=false)