Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Validation suite #162

Open
gipert opened this issue Nov 14, 2024 · 9 comments
Open

Validation suite #162

gipert opened this issue Nov 14, 2024 · 9 comments
Labels
discussion Further information is requested good first issue Good for newcomers help wanted Extra attention is needed validation Validation and tests

Comments

@gipert
Copy link
Member

gipert commented Nov 14, 2024

We should start planning for a serious validation suite, to be hopefully incorporated in our GitHub CI. The idea is to test all the microphysics in the simulation and compare to models/literature every time there is an upgrade.

Here are some simpler ideas that would already help (from a conversation with R. Henning):

  • Design a simple geometry in remage like a HPGe detector in LAr with light readout and a variety of sources. When there is a software upgrade, we run high-stats simulations and generate diagnostic pdfs (e.g. energy spectra, heat maps, source spectra, etc.). We then compare these pdfs to those from previous runs and investigate differences. Of course this only finds differences and doesn’t check the physics itself, but should be easy to implement. We could also just use an existing geometry, but I think we’d want something that can run quickly and designed around testing physics we’re be concerned about.
  • A more sophisticated version would be to compare to date from a well-characterized but simple test-stand. The challenge her would be to find a stand where the measurement systematics are small and well-understood.
@gipert gipert added help wanted Extra attention is needed good first issue Good for newcomers labels Nov 14, 2024
@EricMEsch
Copy link
Collaborator

In examples/06-NeutronCapture I have contributed an IsotopeOutputScheme, that can be used in this validation suite to check isotope production and with that capture cross sections etc.

If we have some ideas on how exactly we want to run/design this validation suite i would be glad to add something like that.

@tdixon97
Copy link
Collaborator

tdixon97 commented Nov 17, 2024

Other things we could do, not neccesarily really validation.

  • compare output to MaGe for a simple simulation
  • could try some very simplified public datasets eg [g4-em-validation]
  • for the test stand we probably need to use a variety of different ones, not sure how easily it can be included in CI, but we should start working on that soon

@gipert
Copy link
Member Author

gipert commented Nov 18, 2024

@EricMEsch if you have time, it would be great contribution. We can meet in the next weeks to define a list of tests to be implemented

@EricMEsch
Copy link
Collaborator

@EricMEsch if you have time, it would be great contribution. We can meet in the next weeks to define a list of tests to be implemented

Sure, I will be available next weeks

@gipert gipert added the discussion Further information is requested label Nov 28, 2024
@gipert
Copy link
Member Author

gipert commented Dec 5, 2024

Note

Work in progress!

Unit tests

  • test the LH5 output generation code, i.e. that we don't lose events on the way. This can be done by running a simulation with predictable number of events and check that we get all of them written out
  • test whether setting different seeds generates a different statistical realization (especially with multithreading)

"Absolute" low-level validation

Physics list and Geant4 built-in generators

  • print list of registered processes per particle
  • production cuts: plot intensity of bremsstrahlung photons / low-angle Compton scatters vs cut value. Goal: understand if observable is stable and if we chose a good cut value
  • check step sizes by plotting distribution of simulations from point above. Relevant for active volume so e.g. shoot a beta against a Ge surface
  • unit tests of decay chains like Ra226 (long livetime threshold)
  • cross check neutron physics with MCNP
  • check Ar39 beta shape, maybe interesting to compare to bxdecay0

Generators

  • confinement: option to force G4 containment check after vertex generation
  • find way to run confinement tests in CI and make figures downloadable
  • implement option to store track pre-tracking information: New output table to store track vertex information #178
  • start plotting vertex data and identify useful plots for each kind of physics (double beta, cosmogenics, ...)
  • check bxdecay0, is it implementing the best double-beta calculations?

"Relative" validation

Compare results with remage before the change.

High-level validation

  • L200 calibration rates
  • Simple test stand: HPGe and radioactive source at different distances

Compare to MaGe

  • input simple GDML from high-level validation above and compare output (e.g. energy histograms)

Existing Geant4 validation:

https://geant4-internal.web.cern.ch/publications_validations/testing_and_validation

L200 geometry and materials

See legend-exp/legend-pygeom-l200#66

@gipert
Copy link
Member Author

gipert commented Dec 7, 2024

Found the right link to the Geant4 validation portal: https://geant-val-web.cern.ch/

@gipert
Copy link
Member Author

gipert commented Dec 9, 2024

We should try to validate the vertex confinement code more accurately. I've been simulating 0vbb in all detectors at the same time these days and I get weird results. Could be due to a bug in the way remage samples between different volumes.

@gipert
Copy link
Member Author

gipert commented Dec 31, 2024

Note: added few dummy tests for germanium interactions validation in #214.

@tdixon97
Copy link
Collaborator

tdixon97 commented Jan 16, 2025

Ideas to improve the current dump of PDFs. Ide

  • Save into .md files organising with comments
  • Needs most PDFs changed to PNG
  • Could then convert to HTML and upload onto a website (need to think how)
  • Could try to then make use of some libraries for interactive python plots in HTML eg https://mpld3.github.io/ or https://bokeh.org/
  • Possibly similar stuff exists for geant4, eg with vtk ?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
discussion Further information is requested good first issue Good for newcomers help wanted Extra attention is needed validation Validation and tests
Projects
None yet
Development

No branches or pull requests

3 participants