A Geant4 framework for generic simulations of atmospheric muon detection experiments ANNALS OF GEOPHYSICS, 60, 1, 2017, S0108; doi:10.4401/ag-7383 S0108 A Geant4 framework for generic simulations of atmospheric muon detection experiments Nicola Mori1,4,*, Fabio Ambrosino2,3, Lorenzo Bonechi1, Luigi Cimmino2,3, Raffaello D’Alessandro1,4, Pasquale Noli3, Giulio Saracino2,3, Paolo Strolin2,3, Lorenzo Viliani1,4 1 Istituto Nazionale di Fisica Nucleare (INFN), Sezione di Firenze, Sesto Fiorentino, Florence, Italy 2 Università di Napoli Federico II, Dipartimento di Fisica, Naples, Italy 3 Istituto Nazionale di Fisica Nucleare (INFN), Sezione di Napoli, Naples, Italy 4 Università di Firenze, Dipartimento di Fisica e Astronomia, Sesto Fiorentino, Florence, Italy ABSTRACT A flexible and adaptive simulation framework based on Geant4 is pre- sented. The framework has been developed in order to speed up the de- ployment of full-featured Monte Carlo simulation codes for small/medium sized particle detection experiments with generic geometries. Specific com- ponents related to atmospheric muon experiments have been developed and are presented as well. 1. Introduction The detection of atmospheric muons for investi- gating the density structure of target bodies is a growing field with many real-world applications. Modern fields of investigation relying on this technique ranges from geology [Tanaka et al. 2005, Ambrosi et al. 2011] to ar- chaeology [Menichelli et al. 2007]. Novel possibilities opened up recently also for monitoring legacy nuclear waste storage sites [Clarkson et al. 2014], nuclear power plants [Morris et al. 2014] and nuclear contraband [Gnanvo et al. 2008]. The different sizes of the target structure in the var- ious scenarios, as well as the conditions of the environ- ment where the measurement is performed (e.g. difficult access to the site), influence the design of the detectors, resulting in a wide variety of target-detector cases. Monte Carlo simulations are of the utmost im- portance for atmospheric muon detection experiments, in order to optimize the design of the detector, to esti- mate the level of the backgrounds and of the expected signals, and so on. Currently, any simulation program for a specific experiment or measurement scenario must include the details of the geometry of the target and of the detec- tor, the detector response, an accurate description of the muon flux etc. These details must be implemented for the specific target structure and detector involved, so the software development effort has to be repeated for each measurement scenario. However, a careful planning of the software archi- tecture could allow to reuse those elements which are common to every atmospheric muon detection simula- tion, i.e. the generation of a realistic spectrum of muons. Also, some elements can be implemented in a way that is sufficiently general that they can be reused in all scenar- ios where the required accuracy is not very high: for ex- ample, a generic detector may be useful in an early stage where a coarse estimation of the expected performance with a given target structure has to be assessed. In this paper a Monte Carlo simulation frame- work based on the Geant4 [Agostinelli et al. 2003] sim- ulation toolkit is presented. The framework has been developed to enhance the speed of deployment of sim- ulation software for atmospheric cosmic ray detection experiments by implementing all the common features (generation of muons, creation of the output files and so on) and providing a reference implementation of a detector to be used in early stages. A particular focus has been put on making the framework fully extensi- ble to accommodate any experiment and/or scenario specific feature (e.g. the target structure, a more de- tailed description of the detector, a different muon generator), either as a side-by-side implementation or by actually replacing the reference ones. In the follow- Article history Received July 5, 2016; accepted October 5, 2016. Subject classification: Atmospheric muons, Simulations, Muon radiography. ing sections, the software architecture of the frame- work is described. 2. The Monte Carlo framework Starting from the Geant4 toolkit, a full Monte Carlo simulation stack has been developed. The imple- mentation is layered with different levels, from the most generic up to the most specific, in order to maxi- mize code re-usage and development efficiency. The foundation software layer All the software stack is implemented on top of the Geant4 simulation toolkit. Geant4 is a generic (i.e. experiment-independent) package providing tools for simulating the propagation of particles inside matter. It requires the end user to write some mandatory C++ classes describing the detector geometry, handling par- ticle generation and managing the output, in order to produce a full simulation program. While giving the opportunity to finely tune the simulation details, this also increases the time required to deploy the simula- tion program. In order to mitigate this issue, an imple- mentation of the mandatory Geant4 classes, called GGS (generic Geant4 simulation), has been developed. GGS implements all the experiment-independent bits of the mandatory Geant4 classes in a generic and reusable way. In particular, it automatically detects the sensitive volumes (i.e. those volumes where the energy released by the traversing particles has to be recorded on the output files) in the geometry and adapts the format of the output files to the sensitive volumes layout in the current geometry. The implementation leverages the I/O engine of the ROOT framework [Brun and Rade- makers 1997] and the output is produced in the form of ROOT files. While being experiment-independent, GGS has been designed to be fully customizable via plugin li- braries. A plugin API allows the user to define the detec- tor geometry and/or any particular particle generator, to add information to the output files and so on. All these eventual customizations can be implemented as C++ classes, and allow the introduction of experiment-spe- cific features in the simulation while still taking advan- tage of the generic code paths implemented in GGS. The atmospheric muon software layer All the simulation details which are relevant for at- mospheric muon detection have been implemented as GGS plugins. While the geometry of the target struc- ture is a specific feature of the simulated scenario, and thus cannot be implemented in a generic way, a generic, reference muon detector can be defined. The chosen implementation is a tracking device made of N pairs of X-Y tracking layers made of plastic scintillator, either segmented (in fibers or triangular bars; see Ambrosi et al. [2011]) or monolithic (in this case the muon impact point can be determined only by means of the Monte Carlo truth). The user can set any parameter of the de- tector (number and size of planes, plane spacing, num- ber of fibers etc.) at runtime. An arbitrary number of these detectors can be placed with any orientation in the geometry describing the target volume, allowing for a quick geometry development. The plugin infra- structure allows also to replace the reference detector with a more specific one if needed. Two different muon generators based on a theo- retical model [Tanaka et al. 2001] and on ground meas- urements with a magnetic spectrometer [Bonechi et al. 2005] have been implemented. These generators cover different ranges in kinetic energy and zenith angle and generate realistic spectra for vertical and nearly-hori- zontal muons up to some TeV. Besides particle genera- tion inside the simulation, the generators are also used by the flux normalization tool, a program which converts the number of generated events to the corresponding data acquisition time. The software architecture allows for an easy definition and integration of additional models of the muon flux. The simulation runs can be very time consuming for large targets, since only a few muons hitting the tar- get hit also the detector. Those events which do not hit the target might not be relevant, while those not hit- ting the detector would be actually undetected. Simu- lating and saving on disk these events increase the run time, the analysis time and the size of output files with no benefit whatsoever. Thus to increase efficiency while retaining maximum accuracy, an optional two- step acceptance check has been implemented. The un- derlying assumption is that the space surrounding the target is filled with a light material in which the scat- tering of the primary muon is negligible, so that a straight line constitutes a good approximation of the real trajectory. This is generally true since often the tar- get structure is surrounded by air. When the initial kinematics of a muon is generated the framework checks if the extrapolated trajectory hits the target vol- ume: if not the event is discarded and another kine- matics is generated, otherwise the muon is propagated until it exits from the target. At this point the frame- work checks if the extrapolated trajectory hits the de- tector: if not the event is discarded, otherwise the simulation is carried on. The user can enlarge or restrict the acceptance criteria in order to define enlarged or fiducial acceptances. This mechanism minimizes the time spent to simulate useless (i.e. undetected) events MORI ET AL. 2 3 without artificially reducing the background coming from those events whose extrapolated track at genera- tion lies out of the acceptance of the detector but are deviated inside the acceptance by multiple scattering inside the target. A sketch illustrating the mechanism is shown in Figure 1. The scenario-specific simulations If no specific tuning is required (e.g. a particle gen- erator implementing a different flux parameterization or a detailed detector) the simulation of a specific atmos- pheric muon detection experiment can be implemented simply by creating a C++ GGS geometry describing the target and then placing the reference muon detector(s) in the desired position(s) with the desired orientation(s). Every kind of target can be simulated quickly with a minimum effort in terms of code writing. In fact the en- tity of the effort may vary according to the complexity of the target geometry: modeling the surface and the in- ternals of a large geological structure like a volcano would require a considerable effort anyway. Yet this is the only thing that the user has to take care of, reducing the amount of the needed scenario-specific software de- velopment to a bare minimum. The benefits of this approach are even more evi- dent when simulating many different scenarios: besides the further enhanced reduction in development time, the user will also take advantage of having a common output format for all the different scenarios which will speed up also the production of data analysis codes. An example of a simulation scenario implemented with the framework is shown in Figure 2. 3. Discussion The architecture of a software framework for Monte Carlo simulations aimed at atmospheric cosmic ray detection has been presented. Its design guidelines are geared towards code reuse and customizability, to speed up the simulation deployment leveraging stan- dard implementations of common features while re- taining the ability to finely tune the simulation by introducing experiment-specific bits. The framework is currently being used with success for simulating differ- ent muon detection scenarios (i.e. nuclear waste stor- age sites, archeological sites, geological structures), meeting all the design requirements. This framework is currently being used by the MURAVES collaboration for their Mount Vesuvius muography project, and the INFN - University of Glasgow collaboration for their evaluation of muography applied to the Sellfield nu- clear stockage site. References Agostinelli, S., et al. (2003). Geant4 - a simulation toolkit, Nucl. Instrum. Meth. A, 506, 250-303. Ambrosi, G., et al. (2011). The MU-RAY project: Vol- cano radiography with cosmic-ray muons, Nucl. In- strum. Meth. A, 628, 120-123. Bonechi, L., M. Bongi, D. Fedele, M. Grandi, S. Riccia- rini and E. Vannuccini (2005). Development of the ADAMO detector: test with cosmic rays at different zenith angles, Proceedings of the 29th International Cosmic Ray Conference, 9, 283-286. Brun, R., and F. Rademakers (1997). ROOT - An Ob- ject Oriented Data Analysis Framework, Nucl. In- strum. Meth. A, 389, 81-86. Clarkson, A., et al. (2014). GEANT4 simulation of a scintillating-fibre tracker for the cosmic-ray muon tomography of legacy nuclear waste containers, Nucl. Instrum. Meth. A, 746, 64-73. Gnanvo, K., P. Ford, J. Helsby, R. Hoch, D. Mitra and GEANT4 SIMULATIONS OF ATMOSPHERIC MUONS Figure 1. The acceptance checking algorithm: track 1 is propagated down to the detector, track 2 is killed at the exit of the target since its extrapolation does not hit the detector, track 3 is killed just after the generation of initial kinematics since its extrapolation does not hit the target. Figure 2. A simulation scenario implemented with the framework. The target is a cylindrical storage silo for nuclear waste. The detec- tor is constituted by two X-Y pairs of layers with area 2 × 2 m2. The muons (red tracks) are generated from a horizontal surface placed above the silo. M. Hohlmann (2008). Performance expectations for a Tomography System using cosmic ray muons and micro pattern gas detectors for the detection of nu- clear contraband, IEEE Nucl. Sci. Symp. Conf. Record, 1278-1284. Menichelli, M., S. Ansoldi, M. Bari, M. Basset, R. Bat- tiston, S. Blasko, F. Coren, E. Fiori, G. Giannini, D. Iugovaz, A. Papi, S. Reia and G. Scian (2007). A scin- tillating fibres tracker detector for archaeological ap- plications, Nucl. Instrum. Meth. A, 572, 262-265. Morris, C.L., et al. (2014). Analysis of muon radiogra- phy of the Toshiba nuclear critical assembly reactor, Appl. Phys. Lett., 104, 024110. Tanaka, H., K. Nagamine, N. Kawamura, S.N. Naka- mura, K. Ishida and K. Shimomura (2001). Devel- opment of the Cosmic-Ray Muon Detection System for Probing Internal-Structure of a Volcano, Hyperf. Int., 138 (1), 521-526. Tanaka, H.K.M., K. Nagamine, S.N. Nakamura and K. Ishida (2005). Radiographic measurements of the internal structure of Mt. West Iwate with near-hor- izontal cosmic-ray muons and future developments, Nucl. Instrum. Meth. A, 555, 164-172. *Corresponding author: Nicola Mori, Istituto Nazionale di Fisica Nucleare (INFN), Sezione di Firenze, Sesto Fiorentino, Florence, Italy; email: mori@fi.infn.it. © 2017 by the Istituto Nazionale di Geofisica e Vulcanologia. All rights reserved. MORI ET AL. 4 << /ASCII85EncodePages false /AllowTransparency false /AutoPositionEPSFiles false /AutoRotatePages /None /Binding /Left /CalGrayProfile (Dot Gain 20%) /CalRGBProfile (sRGB IEC61966-2.1) /CalCMYKProfile (U.S. Web Coated \050SWOP\051 v2) /sRGBProfile (sRGB IEC61966-2.1) /CannotEmbedFontPolicy /Warning /CompatibilityLevel 1.3 /CompressObjects /Tags /CompressPages true /ConvertImagesToIndexed true /PassThroughJPEGImages true /CreateJobTicket false /DefaultRenderingIntent /Default /DetectBlends true /DetectCurves 0.1000 /ColorConversionStrategy /LeaveColorUnchanged /DoThumbnails false /EmbedAllFonts true /EmbedOpenType false /ParseICCProfilesInComments true /EmbedJobOptions true /DSCReportingLevel 0 /EmitDSCWarnings false /EndPage -1 /ImageMemory 1048576 /LockDistillerParams true /MaxSubsetPct 100 /Optimize false /OPM 1 /ParseDSCComments true /ParseDSCCommentsForDocInfo true /PreserveCopyPage true /PreserveDICMYKValues true /PreserveEPSInfo true /PreserveFlatness true /PreserveHalftoneInfo false /PreserveOPIComments false /PreserveOverprintSettings true /StartPage 1 /SubsetFonts true /TransferFunctionInfo /Apply /UCRandBGInfo /Preserve /UsePrologue false /ColorSettingsFile (None) /AlwaysEmbed [ true /AndaleMono /Apple-Chancery /Arial-Black /Arial-BoldItalicMT /Arial-BoldMT /Arial-ItalicMT /ArialMT /CapitalsRegular /Charcoal /Chicago /ComicSansMS /ComicSansMS-Bold /Courier /Courier-Bold /CourierNewPS-BoldItalicMT /CourierNewPS-BoldMT /CourierNewPS-ItalicMT /CourierNewPSMT /GadgetRegular /Geneva /Georgia /Georgia-Bold /Georgia-BoldItalic /Georgia-Italic /Helvetica /Helvetica-Bold /HelveticaInserat-Roman /HoeflerText-Black /HoeflerText-BlackItalic /HoeflerText-Italic /HoeflerText-Ornaments /HoeflerText-Regular /Impact /Monaco /NewYork /Palatino-Bold /Palatino-BoldItalic /Palatino-Italic /Palatino-Roman /SandRegular /Skia-Regular /Symbol /TechnoRegular /TextileRegular /Times-Bold /Times-BoldItalic /Times-Italic /Times-Roman /TimesNewRomanPS-BoldItalicMT /TimesNewRomanPS-BoldMT /TimesNewRomanPS-ItalicMT /TimesNewRomanPSMT /Trebuchet-BoldItalic /TrebuchetMS /TrebuchetMS-Bold /TrebuchetMS-Italic /Verdana /Verdana-Bold /Verdana-BoldItalic /Verdana-Italic /Webdings ] /NeverEmbed [ true ] /AntiAliasColorImages false /CropColorImages true /ColorImageMinResolution 150 /ColorImageMinResolutionPolicy /OK /DownsampleColorImages true /ColorImageDownsampleType /Bicubic /ColorImageResolution 300 /ColorImageDepth -1 /ColorImageMinDownsampleDepth 1 /ColorImageDownsampleThreshold 1.10000 /EncodeColorImages true /ColorImageFilter /DCTEncode /AutoFilterColorImages true /ColorImageAutoFilterStrategy /JPEG /ColorACSImageDict << /QFactor 0.15 /HSamples [1 1 1 1] /VSamples [1 1 1 1] >> /ColorImageDict << /QFactor 0.15 /HSamples [1 1 1 1] /VSamples [1 1 1 1] >> /JPEG2000ColorACSImageDict << /TileWidth 256 /TileHeight 256 /Quality 30 >> /JPEG2000ColorImageDict << /TileWidth 256 /TileHeight 256 /Quality 30 >> /AntiAliasGrayImages false /CropGrayImages true /GrayImageMinResolution 150 /GrayImageMinResolutionPolicy /OK /DownsampleGrayImages true /GrayImageDownsampleType /Bicubic /GrayImageResolution 300 /GrayImageDepth -1 /GrayImageMinDownsampleDepth 2 /GrayImageDownsampleThreshold 1.10000 /EncodeGrayImages true /GrayImageFilter /DCTEncode /AutoFilterGrayImages true /GrayImageAutoFilterStrategy /JPEG /GrayACSImageDict << /QFactor 0.15 /HSamples [1 1 1 1] /VSamples [1 1 1 1] >> /GrayImageDict << /QFactor 0.15 /HSamples [1 1 1 1] /VSamples [1 1 1 1] >> /JPEG2000GrayACSImageDict << /TileWidth 256 /TileHeight 256 /Quality 30 >> /JPEG2000GrayImageDict << /TileWidth 256 /TileHeight 256 /Quality 30 >> /AntiAliasMonoImages false /CropMonoImages true /MonoImageMinResolution 1200 /MonoImageMinResolutionPolicy /OK /DownsampleMonoImages true /MonoImageDownsampleType /Bicubic /MonoImageResolution 1200 /MonoImageDepth -1 /MonoImageDownsampleThreshold 1.08250 /EncodeMonoImages true /MonoImageFilter /CCITTFaxEncode /MonoImageDict << /K -1 >> /AllowPSXObjects false /CheckCompliance [ /None ] /PDFX1aCheck false /PDFX3Check false /PDFXCompliantPDFOnly false /PDFXNoTrimBoxError true /PDFXTrimBoxToMediaBoxOffset [ 0.00000 0.00000 0.00000 0.00000 ] /PDFXSetBleedBoxToMediaBox true /PDFXBleedBoxToTrimBoxOffset [ 0.00000 0.00000 0.00000 0.00000 ] /PDFXOutputIntentProfile (None) /PDFXOutputConditionIdentifier () /PDFXOutputCondition () /PDFXRegistryName (http://www.color.org) /PDFXTrapped /Unknown /CreateJDFFile false /SyntheticBoldness 1.000000 /Description << /ENU (Use these settings to create PDF documents with higher image resolution for high quality pre-press printing. The PDF documents can be opened with Acrobat and Reader 5.0 and later. These settings require font embedding.) /JPN /FRA /DEU /PTB /DAN /NLD /ESP /SUO /NOR /SVE /KOR /CHS /CHT /ITA >> >> setdistillerparams << /HWResolution [2400 2400] /PageSize [595.000 842.000] >> setpagedevice