19#ifndef BDSLASERCOMPTON_H
20#define BDSLASERCOMPTON_H
23#include "G4VDiscreteProcess.hh"
24#include "G4Electron.hh"
25#include "G4Positron.hh"
26#include "BDSMaterials.hh"
37extern G4bool FireLaserCompton;
62 virtual G4bool
IsApplicable(
const G4ParticleDefinition&);
66 G4double previousStepSize,
67 G4ForceCondition* condition );
69 virtual G4VParticleChange *PostStepDoIt(
const G4Track& track,
72 inline void SetLaserDirection(G4ThreeVector aDirection);
73 inline G4ThreeVector GetLaserDirection()
const;
75 inline void SetLaserWavelength(G4double aWavelength);
76 inline G4double GetLaserWavelength()
const;
79 G4double ComputeMeanFreePath(
const G4ParticleDefinition* ParticleType,
80 G4double KineticEnergy,
81 const G4Material* aMaterial);
90 G4double laserWavelength;
91 G4ThreeVector laserDirection;
98 return ( (&particle == G4Electron::Electron()) || (&particle == G4Positron::Positron()) );
103 G4ForceCondition* ForceCondition)
107 {*ForceCondition = Forced;}
108 return std::numeric_limits<double>::max();
111inline void BDSLaserCompton::SetLaserDirection(G4ThreeVector laserDirectionIn)
112{laserDirection = laserDirectionIn;}
114inline G4ThreeVector BDSLaserCompton::GetLaserDirection()
const
115{
return laserDirection;}
117inline void BDSLaserCompton::SetLaserWavelength(G4double wavelengthIn)
118{laserWavelength = wavelengthIn;}
120inline G4double BDSLaserCompton::GetLaserWavelength()
const
121{
return laserWavelength;}
Engine to calculate product of compton scattering process.
A class that holds global options and constants.
Laser compton scattering process to achieve a laserwire.
virtual G4bool IsApplicable(const G4ParticleDefinition &)
Overridden from G4VProcess - whether applicable to a particular particle.
virtual G4double GetMeanFreePath(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition)
Overridden from G4VDiscreteProcess.
static BDSMaterials * Instance()
Singleton pattern access.
G4Material * GetMaterial(G4String material) const
Get material by name.