|  | 
|  | G4PolarizedCompton (const G4String &processName="pol-compt", G4ProcessType type=fElectromagnetic) | 
|  | 
| virtual | ~G4PolarizedCompton () | 
|  | 
| G4bool | IsApplicable (const G4ParticleDefinition &) | 
|  | 
| virtual void | PrintInfo () | 
|  | 
| void | SetModel (const G4String &name) | 
|  | 
|  | G4VEmProcess (const G4String &name, G4ProcessType type=fElectromagnetic) | 
|  | 
| virtual | ~G4VEmProcess () | 
|  | 
| void | PreparePhysicsTable (const G4ParticleDefinition &) | 
|  | 
| void | BuildPhysicsTable (const G4ParticleDefinition &) | 
|  | 
| void | StartTracking (G4Track *) | 
|  | 
| G4double | PostStepGetPhysicalInteractionLength (const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) | 
|  | 
| G4VParticleChange * | PostStepDoIt (const G4Track &, const G4Step &) | 
|  | 
| G4bool | StorePhysicsTable (const G4ParticleDefinition *, const G4String &directory, G4bool ascii=false) | 
|  | 
| G4bool | RetrievePhysicsTable (const G4ParticleDefinition *, const G4String &directory, G4bool ascii) | 
|  | 
| G4double | CrossSectionPerVolume (G4double kineticEnergy, const G4MaterialCutsCouple *couple) | 
|  | 
| G4double | ComputeCrossSectionPerAtom (G4double kineticEnergy, G4double Z, G4double A=0., G4double cut=0.0) | 
|  | 
| G4double | MeanFreePath (const G4Track &track) | 
|  | 
| G4double | GetLambda (G4double &kinEnergy, const G4MaterialCutsCouple *couple) | 
|  | 
| void | SetLambdaBinning (G4int nbins) | 
|  | 
| G4int | LambdaBinning () const | 
|  | 
| void | SetMinKinEnergy (G4double e) | 
|  | 
| G4double | MinKinEnergy () const | 
|  | 
| void | SetMaxKinEnergy (G4double e) | 
|  | 
| G4double | MaxKinEnergy () const | 
|  | 
| void | SetMinKinEnergyPrim (G4double e) | 
|  | 
| G4PhysicsTable * | LambdaTable () const | 
|  | 
| G4PhysicsTable * | LambdaTablePrim () const | 
|  | 
| const G4ParticleDefinition * | Particle () const | 
|  | 
| const G4ParticleDefinition * | SecondaryParticle () const | 
|  | 
| G4VEmModel * | SelectModelForMaterial (G4double kinEnergy, size_t &idxRegion) const | 
|  | 
| void | AddEmModel (G4int, G4VEmModel *, const G4Region *region=0) | 
|  | 
| G4VEmModel * | EmModel (G4int index=1) const | 
|  | 
| void | SetEmModel (G4VEmModel *, G4int index=1) | 
|  | 
| void | UpdateEmModel (const G4String &, G4double, G4double) | 
|  | 
| G4VEmModel * | GetModelByIndex (G4int idx=0, G4bool ver=false) const | 
|  | 
| const G4Element * | GetCurrentElement () const | 
|  | 
| void | SetCrossSectionBiasingFactor (G4double f, G4bool flag=true) | 
|  | 
| G4double | CrossSectionBiasingFactor () const | 
|  | 
| void | ActivateForcedInteraction (G4double length=0.0, const G4String &r="", G4bool flag=true) | 
|  | 
| void | ActivateSecondaryBiasing (const G4String ®ion, G4double factor, G4double energyLimit) | 
|  | 
| void | SetPolarAngleLimit (G4double a) | 
|  | 
| G4double | PolarAngleLimit () const | 
|  | 
| void | SetLambdaFactor (G4double val) | 
|  | 
| void | SetIntegral (G4bool val) | 
|  | 
| G4bool | IsIntegral () const | 
|  | 
| void | SetApplyCuts (G4bool val) | 
|  | 
| void | SetBuildTableFlag (G4bool val) | 
|  | 
|  | G4VDiscreteProcess (const G4String &, G4ProcessType aType=fNotDefined) | 
|  | 
|  | G4VDiscreteProcess (G4VDiscreteProcess &) | 
|  | 
| virtual | ~G4VDiscreteProcess () | 
|  | 
| virtual G4double | AlongStepGetPhysicalInteractionLength (const G4Track &, G4double, G4double, G4double &, G4GPILSelection *) | 
|  | 
| virtual G4double | AtRestGetPhysicalInteractionLength (const G4Track &, G4ForceCondition *) | 
|  | 
| virtual G4VParticleChange * | AtRestDoIt (const G4Track &, const G4Step &) | 
|  | 
| virtual G4VParticleChange * | AlongStepDoIt (const G4Track &, const G4Step &) | 
|  | 
|  | G4VProcess (const G4String &aName="NoName", G4ProcessType aType=fNotDefined) | 
|  | 
|  | G4VProcess (const G4VProcess &right) | 
|  | 
| virtual | ~G4VProcess () | 
|  | 
| G4int | operator== (const G4VProcess &right) const | 
|  | 
| G4int | operator!= (const G4VProcess &right) const | 
|  | 
| G4double | GetCurrentInteractionLength () const | 
|  | 
| void | SetPILfactor (G4double value) | 
|  | 
| G4double | GetPILfactor () const | 
|  | 
| G4double | AlongStepGPIL (const G4Track &track, G4double previousStepSize, G4double currentMinimumStep, G4double &proposedSafety, G4GPILSelection *selection) | 
|  | 
| G4double | AtRestGPIL (const G4Track &track, G4ForceCondition *condition) | 
|  | 
| G4double | PostStepGPIL (const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) | 
|  | 
| const G4String & | GetPhysicsTableFileName (const G4ParticleDefinition *, const G4String &directory, const G4String &tableName, G4bool ascii=false) | 
|  | 
| const G4String & | GetProcessName () const | 
|  | 
| G4ProcessType | GetProcessType () const | 
|  | 
| void | SetProcessType (G4ProcessType) | 
|  | 
| G4int | GetProcessSubType () const | 
|  | 
| void | SetProcessSubType (G4int) | 
|  | 
| virtual void | EndTracking () | 
|  | 
| virtual void | SetProcessManager (const G4ProcessManager *) | 
|  | 
| virtual const G4ProcessManager * | GetProcessManager () | 
|  | 
| virtual void | ResetNumberOfInteractionLengthLeft () | 
|  | 
| G4double | GetNumberOfInteractionLengthLeft () const | 
|  | 
| G4double | GetTotalNumberOfInteractionLengthTraversed () const | 
|  | 
| G4bool | isAtRestDoItIsEnabled () const | 
|  | 
| G4bool | isAlongStepDoItIsEnabled () const | 
|  | 
| G4bool | isPostStepDoItIsEnabled () const | 
|  | 
| virtual void | DumpInfo () const | 
|  | 
| void | SetVerboseLevel (G4int value) | 
|  | 
| G4int | GetVerboseLevel () const | 
|  | 
| virtual void | SetMasterProcess (G4VProcess *masterP) | 
|  | 
| const G4VProcess * | GetMasterProcess () const | 
|  | 
| virtual void | BuildWorkerPhysicsTable (const G4ParticleDefinition &part) | 
|  | 
| virtual void | PrepareWorkerPhysicsTable (const G4ParticleDefinition &) | 
|  | 
|  | 
| virtual void | InitialiseProcess (const G4ParticleDefinition *) | 
|  | 
| virtual void | BuildPhysicsTable (const G4ParticleDefinition &) | 
|  | 
| virtual void | PreparePhysicsTable (const G4ParticleDefinition &) | 
|  | 
| void | BuildAsymmetryTable (const G4ParticleDefinition &part) | 
|  | 
| G4double | ComputeAsymmetry (G4double energy, const G4MaterialCutsCouple *couple, const G4ParticleDefinition &particle, G4double cut, G4double &tAsymmetry) | 
|  | 
| virtual G4double | GetMeanFreePath (const G4Track &aTrack, G4double previousStepSize, G4ForceCondition *condition) | 
|  | 
| virtual G4double | PostStepGetPhysicalInteractionLength (const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) | 
|  | 
| virtual G4double | MinPrimaryEnergy (const G4ParticleDefinition *, const G4Material *) | 
|  | 
| G4VEmModel * | SelectModel (G4double &kinEnergy, size_t index) | 
|  | 
| G4double | GetMeanFreePath (const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) | 
|  | 
| G4PhysicsVector * | LambdaPhysicsVector (const G4MaterialCutsCouple *) | 
|  | 
| G4double | RecalculateLambda (G4double kinEnergy, const G4MaterialCutsCouple *couple) | 
|  | 
| G4ParticleChangeForGamma * | GetParticleChange () | 
|  | 
| void | SetParticle (const G4ParticleDefinition *p) | 
|  | 
| void | SetSecondaryParticle (const G4ParticleDefinition *p) | 
|  | 
| size_t | CurrentMaterialCutsCoupleIndex () const | 
|  | 
| G4double | GetGammaEnergyCut () | 
|  | 
| G4double | GetElectronEnergyCut () | 
|  | 
| void | SetStartFromNullFlag (G4bool val) | 
|  | 
| void | SetSplineFlag (G4bool val) | 
|  | 
| void | SubtractNumberOfInteractionLengthLeft (G4double previousStepSize) | 
|  | 
| void | ClearNumberOfInteractionLengthLeft () | 
|  | 
Definition at line 73 of file G4PolarizedCompton.hh.
 
Implements G4VDiscreteProcess.
Definition at line 139 of file G4PolarizedCompton.cc.
References G4VEmProcess::CurrentMaterialCutsCoupleIndex(), DBL_MAX, G4cout, G4endl, G4Track::GetDynamicParticle(), G4PolarizationManager::GetInstance(), G4DynamicParticle::GetKineticEnergy(), G4VPhysicalVolume::GetLogicalVolume(), G4Track::GetMaterial(), G4VEmProcess::GetMeanFreePath(), G4DynamicParticle::GetMomentumDirection(), G4VPhysicalVolume::GetName(), G4LogicalVolume::GetName(), G4Track::GetPolarization(), G4PhysicsVector::GetValue(), G4Track::GetVolume(), G4PolarizationManager::GetVolumePolarization(), G4PolarizationManager::IsPolarized(), python.hepunit::mm, G4StokesVector::p3(), and G4VProcess::verboseLevel.
  148    if (theAsymmetryTable && useAsymmetryTable) {
 
  165      if (!VolumeIsPolarized || mfp == 
DBL_MAX) 
return mfp;
 
  170        G4cout << 
" Polarization " << GammaPolarization  << 
G4endl;
 
  171        G4cout << 
" MaterialPol. " << ElectronPolarization  << 
G4endl;
 
  183        asymmetry = aVector->
GetValue(GammaEnergy, isOutRange);
 
  185        G4cout << 
" MaterialIndex     " << midx << 
" is out of range \n";
 
  194      G4double pol=ElectronPolarization*GammaDirection0;
 
  196      G4double polProduct = GammaPolarization.
p3() * pol;
 
  197      mfp *= 1. / ( 1. + polProduct * asymmetry );
 
G4double condition(const G4ErrorSymMatrix &m)
const G4ThreeVector & GetPolarization() const 
G4double GetValue(G4double theEnergy, G4bool &isOutRange) const 
G4double GetKineticEnergy() const 
const G4DynamicParticle * GetDynamicParticle() const 
static G4PolarizationManager * GetInstance()
size_t CurrentMaterialCutsCoupleIndex() const 
G4GLOB_DLL std::ostream G4cout
const G4String & GetName() const 
const G4ThreeVector & GetMomentumDirection() const 
G4double GetMeanFreePath(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition)
G4Material * GetMaterial() const 
G4LogicalVolume * GetLogicalVolume() const 
bool IsPolarized(G4LogicalVolume *lVol) const 
G4VPhysicalVolume * GetVolume() const 
const G4ThreeVector & GetVolumePolarization(G4LogicalVolume *lVol) const 
 
 
 
Reimplemented from G4VDiscreteProcess.
Definition at line 209 of file G4PolarizedCompton.cc.
References G4VEmProcess::CurrentMaterialCutsCoupleIndex(), DBL_MAX, G4cout, G4endl, G4Track::GetDynamicParticle(), G4PolarizationManager::GetInstance(), G4DynamicParticle::GetKineticEnergy(), G4VPhysicalVolume::GetLogicalVolume(), G4Track::GetMaterial(), G4DynamicParticle::GetMomentumDirection(), G4VPhysicalVolume::GetName(), G4LogicalVolume::GetName(), G4Track::GetPolarization(), G4PhysicsVector::GetValue(), G4Track::GetVolume(), G4PolarizationManager::GetVolumePolarization(), G4PolarizationManager::IsPolarized(), python.hepunit::mm, G4StokesVector::p3(), G4VEmProcess::PostStepGetPhysicalInteractionLength(), and G4VProcess::verboseLevel.
  218    if (theAsymmetryTable && useAsymmetryTable) {
 
  222      const G4StokesVector GammaPolarization = aTrack.GetPolarization();
 
  235      if (!VolumeIsPolarized || mfp == 
DBL_MAX) 
return mfp;
 
  240        G4cout << 
" Polarization " << GammaPolarization  << 
G4endl;
 
  241        G4cout << 
" MaterialPol. " << ElectronPolarization  << 
G4endl;
 
  253        asymmetry = aVector->
GetValue(GammaEnergy, isOutRange);
 
  255        G4cout << 
" MaterialIndex     " << midx << 
" is out of range \n";
 
  264      G4double pol=ElectronPolarization*GammaDirection0;
 
  266      G4double polProduct = GammaPolarization.
p3() * pol;
 
  267      mfp *= 1. / ( 1. + polProduct * asymmetry );
 
G4double condition(const G4ErrorSymMatrix &m)
G4double GetValue(G4double theEnergy, G4bool &isOutRange) const 
G4double GetKineticEnergy() const 
static G4Material * GetMaterial(const G4String &name, G4bool warning=true)
static G4PolarizationManager * GetInstance()
G4double PostStepGetPhysicalInteractionLength(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition)
size_t CurrentMaterialCutsCoupleIndex() const 
G4GLOB_DLL std::ostream G4cout
const G4String & GetName() const 
const G4ThreeVector & GetMomentumDirection() const 
G4LogicalVolume * GetLogicalVolume() const 
bool IsPolarized(G4LogicalVolume *lVol) const 
const G4ThreeVector & GetVolumePolarization(G4LogicalVolume *lVol) const