Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VMultipleScattering Class Referenceabstract

#include <G4VMultipleScattering.hh>

+ Inheritance diagram for G4VMultipleScattering:

Public Member Functions

 G4VMultipleScattering (const G4String &name="msc", G4ProcessType type=fElectromagnetic)
 
 ~G4VMultipleScattering () override
 
void ProcessDescription (std::ostream &outFile) const override
 
virtual void InitialiseProcess (const G4ParticleDefinition *)=0
 
void StreamInfo (std::ostream &outFile, const G4ParticleDefinition &, G4bool rst=false) const
 
void PreparePhysicsTable (const G4ParticleDefinition &) override
 
void BuildPhysicsTable (const G4ParticleDefinition &) override
 
G4bool StorePhysicsTable (const G4ParticleDefinition *, const G4String &directory, G4bool ascii=false) override
 
G4bool RetrievePhysicsTable (const G4ParticleDefinition *, const G4String &directory, G4bool ascii) override
 
void StartTracking (G4Track *) override
 
G4double AlongStepGetPhysicalInteractionLength (const G4Track &, G4double previousStepSize, G4double currentMinimalStep, G4double &currentSafety, G4GPILSelection *selection) override
 
G4double PostStepGetPhysicalInteractionLength (const G4Track &, G4double previousStepSize, G4ForceCondition *condition) override
 
G4VParticleChangeAlongStepDoIt (const G4Track &, const G4Step &) override
 
G4double ContinuousStepLimit (const G4Track &track, G4double previousStepSize, G4double currentMinimalStep, G4double &currentSafety)
 
 G4VMultipleScattering (G4VMultipleScattering &)=delete
 
G4VMultipleScatteringoperator= (const G4VMultipleScattering &right)=delete
 
G4VEmModelSelectModel (G4double kinEnergy, size_t idx)
 
void AddEmModel (G4int order, G4VMscModel *, const G4Region *region=nullptr)
 
void SetEmModel (G4VMscModel *, G4int idx=0)
 
G4VMscModelEmModel (size_t index=0) const
 
G4int NumberOfModels () const
 
G4VMscModelGetModelByIndex (G4int idx, G4bool ver=false) const
 
G4bool LateralDisplasmentFlag () const
 
G4double Skin () const
 
G4double RangeFactor () const
 
G4double GeomFactor () const
 
G4double PolarAngleLimit () const
 
G4bool UseBaseMaterial () const
 
G4MscStepLimitType StepLimitType () const
 
void SetStepLimitType (G4MscStepLimitType val)
 
G4double LowestKinEnergy () const
 
void SetLowestKinEnergy (G4double val)
 
const G4ParticleDefinitionFirstParticle () const
 
- Public Member Functions inherited from G4VContinuousDiscreteProcess
 G4VContinuousDiscreteProcess (const G4String &, G4ProcessType aType=fNotDefined)
 
 G4VContinuousDiscreteProcess (G4VContinuousDiscreteProcess &)
 
virtual ~G4VContinuousDiscreteProcess ()
 
G4VContinuousDiscreteProcessoperator= (const G4VContinuousDiscreteProcess &)=delete
 
virtual G4VParticleChangePostStepDoIt (const G4Track &, const G4Step &)
 
virtual G4double AtRestGetPhysicalInteractionLength (const G4Track &, G4ForceCondition *)
 
virtual G4VParticleChangeAtRestDoIt (const G4Track &, const G4Step &)
 
- Public Member Functions inherited from G4VProcess
 G4VProcess (const G4String &aName="NoName", G4ProcessType aType=fNotDefined)
 
 G4VProcess (const G4VProcess &right)
 
virtual ~G4VProcess ()
 
G4VProcessoperator= (const G4VProcess &)=delete
 
G4bool operator== (const G4VProcess &right) const
 
G4bool 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)
 
virtual G4bool IsApplicable (const G4ParticleDefinition &)
 
const G4StringGetPhysicsTableFileName (const G4ParticleDefinition *, const G4String &directory, const G4String &tableName, G4bool ascii=false)
 
const G4StringGetProcessName () const
 
G4ProcessType GetProcessType () const
 
void SetProcessType (G4ProcessType)
 
G4int GetProcessSubType () const
 
void SetProcessSubType (G4int)
 
virtual const G4VProcessGetCreatorProcess () const
 
virtual void EndTracking ()
 
virtual void SetProcessManager (const G4ProcessManager *)
 
virtual const G4ProcessManagerGetProcessManager ()
 
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 G4VProcessGetMasterProcess () const
 
virtual void BuildWorkerPhysicsTable (const G4ParticleDefinition &part)
 
virtual void PrepareWorkerPhysicsTable (const G4ParticleDefinition &)
 

Protected Member Functions

virtual void StreamProcessInfo (std::ostream &) const
 
G4double GetMeanFreePath (const G4Track &track, G4double, G4ForceCondition *condition) override
 
G4double GetContinuousStepLimit (const G4Track &track, G4double previousStepSize, G4double currentMinimalStep, G4double &currentSafety) override
 
- Protected Member Functions inherited from G4VContinuousDiscreteProcess
void SetGPILSelection (G4GPILSelection selection)
 
G4GPILSelection GetGPILSelection () const
 
- Protected Member Functions inherited from G4VProcess
void SubtractNumberOfInteractionLengthLeft (G4double prevStepSize)
 
void ClearNumberOfInteractionLengthLeft ()
 

Protected Attributes

G4ParticleChangeForMSC fParticleChange
 
- Protected Attributes inherited from G4VProcess
const G4ProcessManageraProcessManager = nullptr
 
G4VParticleChangepParticleChange = nullptr
 
G4ParticleChange aParticleChange
 
G4double theNumberOfInteractionLengthLeft = -1.0
 
G4double currentInteractionLength = -1.0
 
G4double theInitialNumberOfInteractionLength = -1.0
 
G4String theProcessName
 
G4String thePhysicsTableFileName
 
G4ProcessType theProcessType = fNotDefined
 
G4int theProcessSubType = -1
 
G4double thePILfactor = 1.0
 
G4int verboseLevel = 0
 
G4bool enableAtRestDoIt = true
 
G4bool enableAlongStepDoIt = true
 
G4bool enablePostStepDoIt = true
 

Additional Inherited Members

- Static Public Member Functions inherited from G4VProcess
static const G4StringGetProcessTypeName (G4ProcessType)
 

Detailed Description

Definition at line 86 of file G4VMultipleScattering.hh.

Constructor & Destructor Documentation

◆ G4VMultipleScattering() [1/2]

G4VMultipleScattering::G4VMultipleScattering ( const G4String & name = "msc",
G4ProcessType type = fElectromagnetic )
explicit

Definition at line 86 of file G4VMultipleScattering.cc.

88 fNewPosition(0.,0.,0.),
89 fNewDirection(0.,0.,1.)
90{
91 theParameters = G4EmParameters::Instance();
94
95 lowestKinEnergy = 10*CLHEP::eV;
96
97 geomMin = 0.05*CLHEP::nm;
98 minDisplacement2 = geomMin*geomMin;
99
101
102 modelManager = new G4EmModelManager();
103 emManager = G4LossTableManager::Instance();
104 mscModels.reserve(2);
105 emManager->Register(this);
106}
@ fMultipleScattering
@ fElectromagnetic
static G4EmParameters * Instance()
static G4LossTableManager * Instance()
G4VContinuousDiscreteProcess(const G4String &, G4ProcessType aType=fNotDefined)
G4ParticleChangeForMSC fParticleChange
void SetVerboseLevel(G4int value)
void SetProcessSubType(G4int)
G4VParticleChange * pParticleChange

Referenced by BuildPhysicsTable(), G4AdjointhMultipleScattering::G4AdjointhMultipleScattering(), G4eAdjointMultipleScattering::G4eAdjointMultipleScattering(), G4eMultipleScattering::G4eMultipleScattering(), G4hMultipleScattering::G4hMultipleScattering(), G4MuMultipleScattering::G4MuMultipleScattering(), G4VMultipleScattering(), and operator=().

◆ ~G4VMultipleScattering()

G4VMultipleScattering::~G4VMultipleScattering ( )
override

Definition at line 110 of file G4VMultipleScattering.cc.

111{
112 delete modelManager;
113 emManager->DeRegister(this);
114}

◆ G4VMultipleScattering() [2/2]

G4VMultipleScattering::G4VMultipleScattering ( G4VMultipleScattering & )
delete

Member Function Documentation

◆ AddEmModel()

void G4VMultipleScattering::AddEmModel ( G4int order,
G4VMscModel * ptr,
const G4Region * region = nullptr )

Definition at line 118 of file G4VMultipleScattering.cc.

120{
121 if(nullptr == ptr) { return; }
122 G4VEmFluctuationModel* fm = nullptr;
123 modelManager->AddEmModel(order, ptr, fm, region);
125}
void SetParticleChange(G4VParticleChange *, G4VEmFluctuationModel *f=nullptr)

Referenced by G4AdjointhMultipleScattering::InitialiseProcess(), G4eAdjointMultipleScattering::InitialiseProcess(), G4eMultipleScattering::InitialiseProcess(), G4hMultipleScattering::InitialiseProcess(), G4MuMultipleScattering::InitialiseProcess(), and G4EmConfigurator::PrepareModels().

◆ AlongStepDoIt()

G4VParticleChange * G4VMultipleScattering::AlongStepDoIt ( const G4Track & track,
const G4Step & step )
overridevirtual

Reimplemented from G4VContinuousDiscreteProcess.

Definition at line 289 of file G4VMultipleScattering.cc.

290{
291 fParticleChange.InitialiseMSC(track, step);
292 fNewPosition = fParticleChange.GetProposedPosition();
293 fPositionChanged = false;
294
295 G4double geomLength = step.GetStepLength();
296
297 // very small step - no msc
298 if(!isActive) {
299 tPathLength = geomLength;
300
301 // sample msc
302 } else {
303 G4double range =
304 currentModel->GetRange(currParticle,track.GetKineticEnergy(),
305 track.GetMaterialCutsCouple());
306
307 tPathLength = currentModel->ComputeTrueStepLength(geomLength);
308
309 /*
310 if(currParticle->GetPDGMass() > 0.9*GeV)
311 G4cout << "G4VMsc::AlongStepDoIt: GeomLength= "
312 << geomLength
313 << " tPathLength= " << tPathLength
314 << " physStepLimit= " << physStepLimit
315 << " dr= " << range - tPathLength
316 << " ekin= " << track.GetKineticEnergy() << G4endl;
317 */
318 // protection against wrong t->g->t conversion
319 tPathLength = std::min(tPathLength, physStepLimit);
320
321 // do not sample scattering at the last or at a small step
322 if(tPathLength < range && tPathLength > geomMin) {
323
324 static const G4double minSafety = 1.20*CLHEP::nm;
325 static const G4double sFact = 0.99;
326
327 G4ThreeVector displacement = currentModel->SampleScattering(
328 step.GetPostStepPoint()->GetMomentumDirection(),minSafety);
329
330 G4double r2 = displacement.mag2();
331 //G4cout << " R= " << sqrt(r2) << " Rmin= " << sqrt(minDisplacement2)
332 // << " flag= " << fDispBeyondSafety << G4endl;
333 if(r2 > minDisplacement2) {
334
335 fPositionChanged = true;
336 G4double dispR = std::sqrt(r2);
337 G4double postSafety =
338 sFact*safetyHelper->ComputeSafety(fNewPosition, dispR);
339 //G4cout<<" R= "<< dispR<<" postSafety= "<<postSafety<<G4endl;
340
341 // far away from geometry boundary
342 if(postSafety > 0.0 && dispR <= postSafety) {
343 fNewPosition += displacement;
344
345 //near the boundary
346 } else {
347 // displaced point is definitely within the volume
348 //G4cout<<" R= "<<dispR<<" postSafety= "<<postSafety<<G4endl;
349 if(dispR < postSafety) {
350 fNewPosition += displacement;
351
352 // reduced displacement
353 } else if(postSafety > geomMin) {
354 fNewPosition += displacement*(postSafety/dispR);
355
356 // very small postSafety
357 } else {
358 fPositionChanged = false;
359 }
360 }
361 if(fPositionChanged) {
362 safetyHelper->ReLocateWithinVolume(fNewPosition);
363 fParticleChange.ProposePosition(fNewPosition);
364 }
365 }
366 }
367 }
368 fParticleChange.ProposeTrueStepLength(tPathLength);
369 return &fParticleChange;
370}
CLHEP::Hep3Vector G4ThreeVector
double G4double
Definition G4Types.hh:83
double mag2() const
const G4ThreeVector & GetMomentumDirection() const
G4double GetStepLength() const
G4StepPoint * GetPostStepPoint() const
G4double GetKineticEnergy() const
const G4MaterialCutsCouple * GetMaterialCutsCouple() const

◆ AlongStepGetPhysicalInteractionLength()

G4double G4VMultipleScattering::AlongStepGetPhysicalInteractionLength ( const G4Track & track,
G4double previousStepSize,
G4double currentMinimalStep,
G4double & currentSafety,
G4GPILSelection * selection )
overridevirtual

Reimplemented from G4VContinuousDiscreteProcess.

Definition at line 218 of file G4VMultipleScattering.cc.

224{
225 // get Step limit proposed by the process
226 *selection = NotCandidateForSelection;
227 physStepLimit = gPathLength = tPathLength = currentMinimalStep;
228
229 G4double ekin = track.GetKineticEnergy();
230 /*
231 G4cout << "MSC::AlongStepGPIL: Ekin= " << ekin
232 << " " << currParticle->GetParticleName()
233 << " currMod " << currentModel
234 << G4endl;
235 */
236 // isIon flag is used only to select a model
237 if(isIon) {
238 ekin *= proton_mass_c2/track.GetParticleDefinition()->GetPDGMass();
239 }
240 const G4MaterialCutsCouple* couple = track.GetMaterialCutsCouple();
241
242 // select new model, static cast is possible in this class
243 if(1 < numberOfModels) {
244 currentModel =
245 static_cast<G4VMscModel*>(SelectModel(ekin,couple->GetIndex()));
246 }
247 currentModel->SetCurrentCouple(couple);
248 // msc is active is model is active, energy above the limit,
249 // and step size is above the limit;
250 // if it is active msc may limit the step
251 if(currentModel->IsActive(ekin) && tPathLength > geomMin
252 && ekin >= lowestKinEnergy) {
253 isActive = true;
254 tPathLength =
255 currentModel->ComputeTruePathLengthLimit(track, gPathLength);
256 if (tPathLength < physStepLimit) {
257 *selection = CandidateForSelection;
258 }
259 } else {
260 isActive = false;
261 gPathLength = DBL_MAX;
262 }
263
264 //if(currParticle->GetPDGMass() > GeV)
265 /*
266 G4cout << "MSC::AlongStepGPIL: Ekin= " << ekin
267 << " " << currParticle->GetParticleName()
268 << " gPathLength= " << gPathLength
269 << " tPathLength= " << tPathLength
270 << " currentMinimalStep= " << currentMinimalStep
271 << " isActive " << isActive << G4endl;
272 */
273 return gPathLength;
274}
@ CandidateForSelection
@ NotCandidateForSelection
const G4ParticleDefinition * GetParticleDefinition() const
G4VEmModel * SelectModel(G4double kinEnergy, size_t idx)
#define DBL_MAX
Definition templates.hh:62

Referenced by GetContinuousStepLimit().

◆ BuildPhysicsTable()

void G4VMultipleScattering::BuildPhysicsTable ( const G4ParticleDefinition & part)
overridevirtual

Reimplemented from G4VProcess.

Definition at line 169 of file G4VMultipleScattering.cc.

170{
171 G4bool master = emManager->IsMaster();
172
173 if(firstParticle == &part) {
174 emManager->BuildPhysicsTable(&part);
175 }
176 const G4VMultipleScattering* ptr = this;
177 if(!master) {
178 ptr = static_cast<const G4VMultipleScattering*>(GetMasterProcess());
179 }
180
181 G4EmTableUtil::BuildMscProcess(this, ptr, part, firstParticle,
182 numberOfModels, master);
183}
bool G4bool
Definition G4Types.hh:86
static void BuildMscProcess(G4VMultipleScattering *proc, const G4VMultipleScattering *masterProc, const G4ParticleDefinition &part, const G4ParticleDefinition *firstPart, G4int nModels, G4bool master)
G4VMultipleScattering(const G4String &name="msc", G4ProcessType type=fElectromagnetic)
const G4VProcess * GetMasterProcess() const

◆ ContinuousStepLimit()

G4double G4VMultipleScattering::ContinuousStepLimit ( const G4Track & track,
G4double previousStepSize,
G4double currentMinimalStep,
G4double & currentSafety )

Definition at line 390 of file G4VMultipleScattering.cc.

395{
396 return GetContinuousStepLimit(track,previousStepSize,currentMinimalStep,
397 currentSafety);
398}
G4double GetContinuousStepLimit(const G4Track &track, G4double previousStepSize, G4double currentMinimalStep, G4double &currentSafety) override

◆ EmModel()

G4VMscModel * G4VMultipleScattering::EmModel ( size_t index = 0) const
inline

◆ FirstParticle()

const G4ParticleDefinition * G4VMultipleScattering::FirstParticle ( ) const
inline

Definition at line 361 of file G4VMultipleScattering.hh.

362{
363 return firstParticle;
364}

◆ GeomFactor()

G4double G4VMultipleScattering::GeomFactor ( ) const
inline

Definition at line 319 of file G4VMultipleScattering.hh.

320{
321 return theParameters->MscGeomFactor();
322}

Referenced by G4eAdjointMultipleScattering::StreamProcessInfo(), G4eMultipleScattering::StreamProcessInfo(), and G4hMultipleScattering::StreamProcessInfo().

◆ GetContinuousStepLimit()

G4double G4VMultipleScattering::GetContinuousStepLimit ( const G4Track & track,
G4double previousStepSize,
G4double currentMinimalStep,
G4double & currentSafety )
overrideprotectedvirtual

Implements G4VContinuousDiscreteProcess.

Definition at line 374 of file G4VMultipleScattering.cc.

379{
381 G4double x = AlongStepGetPhysicalInteractionLength(track,previousStepSize,
382 currentMinimalStep,
383 currentSafety,
384 &selection);
385 return x;
386}
G4GPILSelection
G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double previousStepSize, G4double currentMinimalStep, G4double &currentSafety, G4GPILSelection *selection) override

Referenced by ContinuousStepLimit().

◆ GetMeanFreePath()

G4double G4VMultipleScattering::GetMeanFreePath ( const G4Track & track,
G4double ,
G4ForceCondition * condition )
overrideprotectedvirtual

Implements G4VContinuousDiscreteProcess.

Definition at line 402 of file G4VMultipleScattering.cc.

404{
405 *condition = Forced;
406 return DBL_MAX;
407}
G4double condition(const G4ErrorSymMatrix &m)
@ Forced

◆ GetModelByIndex()

G4VMscModel * G4VMultipleScattering::GetModelByIndex ( G4int idx,
G4bool ver = false ) const
inline

Definition at line 383 of file G4VMultipleScattering.hh.

384{
385 // static cast is possible inside this class
386 return static_cast<G4VMscModel*>(modelManager->GetModel(idx, ver));
387}

Referenced by G4EmTableUtil::BuildMscProcess(), G4EmTableUtil::PrepareMscProcess(), PreparePhysicsTable(), StartTracking(), and G4EmTableUtil::StoreMscTable().

◆ InitialiseProcess()

virtual void G4VMultipleScattering::InitialiseProcess ( const G4ParticleDefinition * )
pure virtual

◆ LateralDisplasmentFlag()

◆ LowestKinEnergy()

G4double G4VMultipleScattering::LowestKinEnergy ( ) const
inline

Definition at line 347 of file G4VMultipleScattering.hh.

348{
349 return lowestKinEnergy;
350}

◆ NumberOfModels()

G4int G4VMultipleScattering::NumberOfModels ( ) const
inline

Definition at line 375 of file G4VMultipleScattering.hh.

376{
377 return numberOfModels;
378}

◆ operator=()

G4VMultipleScattering & G4VMultipleScattering::operator= ( const G4VMultipleScattering & right)
delete

◆ PolarAngleLimit()

G4double G4VMultipleScattering::PolarAngleLimit ( ) const
inline

Definition at line 326 of file G4VMultipleScattering.hh.

327{
328 return theParameters->MscThetaLimit();
329}

Referenced by G4MuMultipleScattering::StreamProcessInfo().

◆ PostStepGetPhysicalInteractionLength()

G4double G4VMultipleScattering::PostStepGetPhysicalInteractionLength ( const G4Track & ,
G4double previousStepSize,
G4ForceCondition * condition )
overridevirtual

Reimplemented from G4VContinuousDiscreteProcess.

Definition at line 279 of file G4VMultipleScattering.cc.

281{
283 return DBL_MAX;
284}
@ NotForced

◆ PreparePhysicsTable()

void G4VMultipleScattering::PreparePhysicsTable ( const G4ParticleDefinition & part)
overridevirtual

Reimplemented from G4VProcess.

Definition at line 141 of file G4VMultipleScattering.cc.

142{
143 G4bool master = emManager->IsMaster();
144 if (nullptr == firstParticle) { firstParticle = &part; }
145
146 emManager->PreparePhysicsTable(&part, this);
147 currParticle = nullptr;
148
149 if(firstParticle == &part) {
150 baseMat = emManager->GetTableBuilder()->GetBaseMaterialFlag();
151 G4EmTableUtil::PrepareMscProcess(this, part, modelManager,
152 stepLimit, facrange,
153 latDisplacement, master,
154 isIon, baseMat);
155
156 numberOfModels = modelManager->NumberOfModels();
157 currentModel = GetModelByIndex(0);
158
159 if (nullptr == safetyHelper) {
161 ->GetSafetyHelper();
162 safetyHelper->InitialiseHelper();
163 }
164 }
165}
static void PrepareMscProcess(G4VMultipleScattering *proc, const G4ParticleDefinition &part, G4EmModelManager *modelManager, G4MscStepLimitType &stepLimit, G4double &facrange, G4bool &latDisplacement, G4bool &master, G4bool &isIon, G4bool &baseMat)
static G4TransportationManager * GetTransportationManager()
G4SafetyHelper * GetSafetyHelper() const
G4VMscModel * GetModelByIndex(G4int idx, G4bool ver=false) const

◆ ProcessDescription()

void G4VMultipleScattering::ProcessDescription ( std::ostream & outFile) const
overridevirtual

Reimplemented from G4VProcess.

Definition at line 436 of file G4VMultipleScattering.cc.

437{
438 if(nullptr != firstParticle) {
439 StreamInfo(outFile, *firstParticle, true);
440 }
441}
void StreamInfo(std::ostream &outFile, const G4ParticleDefinition &, G4bool rst=false) const

Referenced by G4eMultipleScattering::ProcessDescription(), G4hMultipleScattering::ProcessDescription(), and G4MuMultipleScattering::ProcessDescription().

◆ RangeFactor()

◆ RetrievePhysicsTable()

G4bool G4VMultipleScattering::RetrievePhysicsTable ( const G4ParticleDefinition * ,
const G4String & directory,
G4bool ascii )
overridevirtual

Reimplemented from G4VProcess.

Definition at line 427 of file G4VMultipleScattering.cc.

430{
431 return true;
432}

◆ SelectModel()

G4VEmModel * G4VMultipleScattering::SelectModel ( G4double kinEnergy,
size_t idx )
inline

Definition at line 291 of file G4VMultipleScattering.hh.

292{
293 return modelManager->SelectModel(kinEnergy, coupleIndex);
294}

Referenced by AlongStepGetPhysicalInteractionLength().

◆ SetEmModel()

void G4VMultipleScattering::SetEmModel ( G4VMscModel * ptr,
G4int idx = 0 )

◆ SetLowestKinEnergy()

void G4VMultipleScattering::SetLowestKinEnergy ( G4double val)
inline

Definition at line 354 of file G4VMultipleScattering.hh.

355{
356 lowestKinEnergy = val;
357}

◆ SetStepLimitType()

void G4VMultipleScattering::SetStepLimitType ( G4MscStepLimitType val)
inline

Definition at line 340 of file G4VMultipleScattering.hh.

341{
342 theParameters->SetMscStepLimitType(val);
343}

Referenced by LBE::ConstructEM().

◆ Skin()

G4double G4VMultipleScattering::Skin ( ) const
inline

◆ StartTracking()

void G4VMultipleScattering::StartTracking ( G4Track * track)
overridevirtual

Reimplemented from G4VProcess.

Definition at line 199 of file G4VMultipleScattering.cc.

200{
201 G4VEnergyLossProcess* eloss = nullptr;
202 if(track->GetParticleDefinition() != currParticle) {
203 currParticle = track->GetParticleDefinition();
204 fIonisation = emManager->GetEnergyLossProcess(currParticle);
205 eloss = fIonisation;
206 }
207 for(G4int i=0; i<numberOfModels; ++i) {
208 G4VMscModel* msc = GetModelByIndex(i);
209 msc->StartTracking(track);
210 if(nullptr != eloss) {
211 msc->SetIonisation(eloss, currParticle);
212 }
213 }
214}
int G4int
Definition G4Types.hh:85
virtual void StartTracking(G4Track *)
void SetIonisation(G4VEnergyLossProcess *, const G4ParticleDefinition *part)

Referenced by G4eAdjointMultipleScattering::StartTracking().

◆ StepLimitType()

◆ StorePhysicsTable()

G4bool G4VMultipleScattering::StorePhysicsTable ( const G4ParticleDefinition * part,
const G4String & directory,
G4bool ascii = false )
overridevirtual

Reimplemented from G4VProcess.

Definition at line 412 of file G4VMultipleScattering.cc.

415{
416 G4bool yes = true;
417 if(part != firstParticle || !emManager->IsMaster()) { return yes; }
418
419 return G4EmTableUtil::StoreMscTable(this, part, directory,
420 numberOfModels, verboseLevel,
421 ascii);
422}
static G4bool StoreMscTable(G4VMultipleScattering *proc, const G4ParticleDefinition *part, const G4String &directory, const G4int nModels, const G4int verb, const G4bool ascii)
G4int verboseLevel

◆ StreamInfo()

void G4VMultipleScattering::StreamInfo ( std::ostream & outFile,
const G4ParticleDefinition & part,
G4bool rst = false ) const

Definition at line 187 of file G4VMultipleScattering.cc.

189{
190 G4String indent = (rst ? " " : "");
191 outFile << G4endl << indent << GetProcessName() << ": ";
192 if (!rst) outFile << " for " << part.GetParticleName();
193 outFile << " SubType= " << GetProcessSubType() << G4endl;
194 modelManager->DumpModelList(outFile, verboseLevel);
195}
#define G4endl
Definition G4ios.hh:67
const G4String & GetParticleName() const
G4int GetProcessSubType() const
const G4String & GetProcessName() const

Referenced by G4EmTableUtil::BuildMscProcess(), and ProcessDescription().

◆ StreamProcessInfo()

virtual void G4VMultipleScattering::StreamProcessInfo ( std::ostream & ) const
inlineprotectedvirtual

◆ UseBaseMaterial()

G4bool G4VMultipleScattering::UseBaseMaterial ( ) const
inline

Definition at line 391 of file G4VMultipleScattering.hh.

392{
393 return baseMat;
394}

Member Data Documentation

◆ fParticleChange

G4ParticleChangeForMSC G4VMultipleScattering::fParticleChange
protected

Definition at line 260 of file G4VMultipleScattering.hh.

Referenced by AlongStepDoIt(), and G4VMultipleScattering().


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