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

The basf2 physics list. More...

#include <PhysicsList.h>

Inheritance diagram for PhysicsList:
Collaboration diagram for PhysicsList:

Public Member Functions

 PhysicsList (const std::string &physicsListName)
 The PhysicsList constructor. More...
 
virtual ~PhysicsList ()
 The PhysicsList destructor.
 
void SetCuts ()
 Sets the Cuts on the physics list.
 
void setProductionCutValue (double productionCut)
 Sets the production cut value. More...
 
void registerOpticalPhysicsList ()
 Registers the optical physics list.
 

Detailed Description

The basf2 physics list.

Uses the Geant4 standard lists, specified by a string and adds optical processes if requested.

Definition at line 30 of file PhysicsList.h.

Constructor & Destructor Documentation

◆ PhysicsList()

PhysicsList ( const std::string &  physicsListName)
explicit

The PhysicsList constructor.

Loads the physics list specified by its name.

Parameters
physicsListNameThe name of the physics list which should be loaded.

Definition at line 28 of file PhysicsList.cc.

28  : G4VModularPhysicsList()
29 {
30  defaultCutValue = 0.7 * CLHEP::mm; //Default production cut value. Unit given in Geant4 units.
31 
32  //First register the physics form Geant4 predefined PhysicsList.
33  G4PhysListFactory physListFactory;
34  G4VModularPhysicsList* physList = NULL;
35 
36  if (physListFactory.IsReferencePhysList(physicsListName)) physList = physListFactory.GetReferencePhysList(physicsListName);
37  if (physList == NULL) B2FATAL("Could not load the physics list " << physicsListName);
38 
39  int iPhysList = 1;
40  G4VPhysicsConstructor* regPhys = const_cast<G4VPhysicsConstructor*>(physList->GetPhysics(0));
41  while (regPhys != NULL) {
42  B2DEBUG(10, "RegisterPhysics: " << regPhys->GetPhysicsName());
43  RegisterPhysics(regPhys);
44  regPhys = const_cast<G4VPhysicsConstructor*>(physList->GetPhysics(iPhysList++));
45  }
46  // LEP: Append the geant4e-specific physics constructor to the list
47  RegisterPhysics(new ExtPhysicsConstructor);
48 }

Member Function Documentation

◆ setProductionCutValue()

void setProductionCutValue ( double  productionCut)

Sets the production cut value.

If a primary particle has no longer enough energy to produce secondaries which travel at least the specified productionCut distance, two things happen: 1) Discrete energy loss ceases (no more secondaries will be produced) 2) The primary particle is tracked down to zero energy using continuous energy loss

Parameters
productionCutThe production cut value in [cm].

Definition at line 80 of file PhysicsList.cc.


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