Session 10 : Exercise – 2015

Code for download: session10_start.tar.gz

Start code: session9_start with updated geometry with addition of a shield made of concrete.

Introduction:

The exercise shows one usage of the biasing classes.

We have a shield, made of concrete, which is inserted between the calorimeter and the screen of session 9. This shield is divided in 10 slices, using a replica.

We want to estimate the efficiency of the shield to neutrons, and characterize the neutrons which succeed in exiting the shield. As this one is doing its job, only a few neutrons can traverse this shield. The goal of the exercise is to bias the simulation in the shield to get more neutrons traversing.

First stage:

The following items have been introduced:

  • two biasing classes:
    EDBiasingOperator,
    EDBiasingOperationSplitAndKill
  • in the detector construction, the ConstructSDandField() method has been modified to attach the biasing operator to the logical volume of the shield slices
  • in the main program, a command line option « -b » has been added to activate or not the biasing, this option controls the use or not of the G4GenericBiasingPhysics physi constructor.

Compile and run the code in a non-biased way (so-called analog way):
./exampleED -b off

  • Look at how the neutron processes appear.
  • Shoot a few protons, to verify that the shield is indeed preventing most of particles to traverse.

Run the code in baised mode:
./exampleED -b on

  • Look at how the neutron processes appear now.
  • Shoot a few protons, you will see that now more particles can go through the shield.

First Exercise :

The EDBiasingOperator must send the EDBiasingOperationSplitAndKill biasing operation to be applied. In the code here, it does not. Make it returning the biasing operation using the proper method.
Run the code in biasing mode to verify that now particles go through the shield.

You will notice that the track weight has been added to the ntuple. Plot some quantities (eg: Ekin) not using and using the weight: this second plot is the correct one.
root [] Screen->Draw("Ekin");
root [] Screen->Draw("Ekin","weight");

Second Exercise :

We will reduce the flux backward, for this apply a « Russian Roulette » technique. Look at the corresponding section of the code on the EDBiasingOperationSplitAndKill class, which provides further hints to implement the killing.

Solution: session10_solution.tar.gz