Belle II Software  release-08-01-10
G4mplIonisation Class Reference

Monopole ionisation class. More...

#include <G4mplIonisation.h>

Inheritance diagram for G4mplIonisation:
Collaboration diagram for G4mplIonisation:

Public Member Functions

 G4mplIonisation (G4double mCharge=0.0, const G4String &name="mplIoni")
 Constructor. More...
 
virtual ~G4mplIonisation ()
 Destructor.
 
virtual G4bool IsApplicable (const G4ParticleDefinition &p) override
 Dummy to check if the proccess is is applicable to a certain particle. More...
 
virtual G4double MinPrimaryEnergy (const G4ParticleDefinition *p, const G4Material *, G4double cut) final
 Threshold for zero value.
 
G4mplIonisationoperator= (const G4mplIonisation &right)=delete
 Assignment operator should be hidden. More...
 
 G4mplIonisation (const G4mplIonisation &copy)=delete
 Copy constructor should be hidden. More...
 

Protected Member Functions

virtual void InitialiseEnergyLossProcess (const G4ParticleDefinition *p, const G4ParticleDefinition *) override
 G4VEnergyLossProcess::InitialiseEnergyLossProcess() implementation. More...
 

Private Attributes

G4double magneticCharge
 Monopole charge, in e+ units.
 
G4bool isInitialised
 Is the process initialised.
 

Detailed Description

Monopole ionisation class.

A wrapper, rather than a concrete class. Different ionisation models can be plugged in.

Definition at line 32 of file G4mplIonisation.h.

Constructor & Destructor Documentation

◆ G4mplIonisation() [1/2]

G4mplIonisation ( G4double  mCharge = 0.0,
const G4String &  name = "mplIoni" 
)
explicit

Constructor.

Parameters
mChargeMonopole magnetic charge
nameName of the ionisation process in GEANT4

Definition at line 25 of file G4mplIonisation.cc.

26  : G4VEnergyLossProcess(name),
27  magneticCharge(mCharge),
28  isInitialised(false)
29 {
30  // By default 1e magnetic charge is used
31  if (magneticCharge == 0.0) { magneticCharge = 1.0 * eplus; }
32 
33  SetVerboseLevel(0);
34  SetProcessSubType(fIonisation);
35  SetStepFunction(0.2, 1 * mm);
36  SetSecondaryParticle(G4Electron::Electron());
37 }
G4double magneticCharge
Monopole charge, in e+ units.
G4bool isInitialised
Is the process initialised.

◆ G4mplIonisation() [2/2]

G4mplIonisation ( const G4mplIonisation copy)
delete

Copy constructor should be hidden.

Parameters
copyCopy reference

Member Function Documentation

◆ InitialiseEnergyLossProcess()

void InitialiseEnergyLossProcess ( const G4ParticleDefinition *  p,
const G4ParticleDefinition *   
)
overrideprotectedvirtual

G4VEnergyLossProcess::InitialiseEnergyLossProcess() implementation.

Initialise ionisation proccess, if not it has not been initialised yet.

Concrete ionisation model is called inside this function.

Parameters
pParticle definition pointer, the monopole in our case

Definition at line 58 of file G4mplIonisation.cc.

◆ IsApplicable()

G4bool IsApplicable ( const G4ParticleDefinition &  p)
overridevirtual

Dummy to check if the proccess is is applicable to a certain particle.

Parameters
pParticle definition reference
Returns
true

Definition at line 42 of file G4mplIonisation.cc.

◆ operator=()

G4mplIonisation& operator= ( const G4mplIonisation right)
delete

Assignment operator should be hidden.

Parameters
rightAssign reference

The documentation for this class was generated from the following files: