Geant4 output different when changing G4-unrelated configuration
I was checking if the raw wire signals with spacecharge turned on and off look as they were similar for the same event. Let me explain what I did and what I wanted to accomplish:
The main goal was to compare single muon tracks with and without spacecharge effects switched on, so we can quantify the effect of spacecharge on tracks. To accomplish this in a first stage I did the generation with this parameter switched on (so I do not get random seeds for the later geant4 stage) using the single_muon_gen.fcl.
Then I do the detector simulation stage once with spacecharge switched on and off separately (one needs the SCEoffsets_70kV.root file do do this), with the service above switched on in this fhicl file as well. Unfortunately when I look at the two first events in each set I generated, they look very different and certainly not like they are just a distorted version of each other (see the attached two png files). It seems that although I am using the seed service per event, geant4 does not take the same seed for simulation. Do you have any idea what I am doing wrong (I also put in the fhicl files if you have time to look at them)?
#2 Updated by Gianluca Petrillo about 4 years ago
I could reproduce the issue.
Configurations are [A] without space charge and [B] with space charge.
Each of them is singularly perfectly reproducible and in full control of random seeds.
The very first particles of jobs [A] and [B] also match perfectly.
At a certain point, Geant4 random number generator is asked more random numbers in one job than in the other for the same particle, and the simulation diverges.
Space charge is supposed not to have any random component, and to affect only propagation of electrons to the wires.
It might be that randomness is used during the propagation, that might be affected by the position.
I have to dig deeper.
#4 Updated by Gianluca Petrillo about 4 years ago
The issue is understood.
The transportation mechanism first applies attenuation to the electrons generated in the active volume, reducing their number.
The attenuation represents the loss of electrons while they follow the electric field through the liquid argon toward the wire planes. This reduction is proportional to the distance from the wire plane (x coordinate).
Then the electrons are divided in "clusters" and each cluster is subject to diffusion. The amount of diffusion is stochastic.
So, in summary: the space charge dislocation changes the amount of attenuation, that may change the amount of electron clusters, that would change the number of diffusion-related random numbers extracted.
Solution is in progress. There may be some further effect after this one that I have missed so far.
#6 Updated by Gianluca Petrillo about 4 years ago
- Status changed from Assigned to Resolved
- % Done changed from 40 to 100
- generation (the engine used also by Geant4) [
NestAlg, part of
- radiological decay: part of
The idea is that changes in the propagation and in the radiodecay will not affect the generation.
The changes are somehow breaking: the control of
LArG4 random seeds is now done with three configuration parameters (in brackets in the list above) rather than just with the old
There should be no consequence when the configuration does not try to override seeds.
Of course, the new version is not able to replicate old runs, since the random streams will differ.
I have published the branch
larsim repository, based on
I have verified that on two events the generation is the same (comparing log messages at
DEBUG threshold), and that is all the verification I can do.
A bit of physics validation is recommended.
I do not plan to port the change back in
v04_36_00, where the feature request started from.
It is a hard work, it would compromise v. 4.36 jobs and it's not really worth the effort.
As a side effect, I have developed a small debug tool that prints the current call stack. It was useful to track who was calling random functions without the use of a debugger.
It is published in the branch