Skip to main content

A tool to convert Geant4 geometries into shared libraries

Project description

g42so

PyPI version

This is g42so, a simple Python script that compiles Geant4 detector-construction and primary-generator-action classes, wraps them in C-style (unmangled) adapter functions and produces a shared library. The library can then be loaded via dlopen by third-party code, allowing instantiation of a Geant4 detector construction or primary generator action even if the name of the specific class is not known in advance.

Installing g42so

The recommended installation procedure for g42so is to use pip:

$ pip install g42so

Quick tutorial

Compilation is delegated to g++ by default (no, I did not reimplement gcc from scratch), but this can be configured using the -c option. Note however that g42so must know what compilation flags to use for your compiler; at the moment, it only recognizes g++ and clang++.

Running g42so -h gives a list of available options. You will typically want to run something along the lines of the following:

$ g42so -I /path/to/include/ \
   /path/to/src/MyDetectorConstruction.cc /path/to/src/MyPrimaryGeneratorAction.cc

Notes

  • Geant4 must be installed and the geant4-config script must be in the $PATH, or its location can be specified with the --geant4-config option.

  • g42so tries to automatically detect the names of the classes you want to wrap. If it fails or is unsure, it will ask you to explicitly specify your class names.

  • If your class constructors require arguments, you will need to customise the C wrappers generated by the code. First run

    $ g42so --dump-detector-wrapper >detectorWrapper.cc
    

    to dump the relevant wrapper. Modify it to your needs and pass it to g42so along with the --custom-detector-wrapper option, which tells g42so not to include its default wrapper. For instance:

    $ g42so --custom-detector-wrapper -I /path/to/include/ \
      /path/to/src/MyDetectorConstruction.cc detectorWrapper.cc
    

    The --dump-pga-wrapper and --custom-pga-wrapper do the same job for primary-generator-action classes.

  • Note that dlopening shared libraries that link to Geant4 is likely to fail if Geant4 was compiled is multi-threaded mode (the GEANT4_BUILD_MULTITHREADED CMake flag is set to ON) with the default value for the GEANT4_BUILD_TLS_MODEL (the default is initial-exec). If you want to dlopen the libraries created by g42so (which is the whole point of this tool, really!), then you should make sure that either Geant4 was compiled in single-threaded mode, or GEANT4_BUILD_TLS_MODEL was set to global-dynamic.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

g42so-0.3.0.tar.gz (8.3 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

g42so-0.3.0-py3-none-any.whl (10.6 kB view details)

Uploaded Python 3

g42so-0.3.0-py2-none-any.whl (10.6 kB view details)

Uploaded Python 2

File details

Details for the file g42so-0.3.0.tar.gz.

File metadata

  • Download URL: g42so-0.3.0.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.5.2

File hashes

Hashes for g42so-0.3.0.tar.gz
Algorithm Hash digest
SHA256 bd056527030d303c94c380c617e5b62289efa3ed8b3e762dcb38ec74cc5e364e
MD5 d8ddf242308beaf842d4fea0f4dcbf2f
BLAKE2b-256 6192cfe0cc13ad4ffe1ad39d7cd87639079974d02d89ded3c1ff35489d25a0bf

See more details on using hashes here.

File details

Details for the file g42so-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: g42so-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 10.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.5.2

File hashes

Hashes for g42so-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c51663fb3ceda9226f8dca23d1dab442f585035f6cc37fd8db7bca328fa10b6c
MD5 5bd4bf218dec516115f042bcb69dde66
BLAKE2b-256 c7f8fce4fe8ab9fb196b644d3f0c963599e32ff1304bb54d66e0ffc11e47a84a

See more details on using hashes here.

File details

Details for the file g42so-0.3.0-py2-none-any.whl.

File metadata

  • Download URL: g42so-0.3.0-py2-none-any.whl
  • Upload date:
  • Size: 10.6 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.5.2

File hashes

Hashes for g42so-0.3.0-py2-none-any.whl
Algorithm Hash digest
SHA256 4ca7bed57dc160d31db30f787a5bed8cc15e06ebc9e9bad5332ec8837a13515f
MD5 e505f4f89091c89ec773914271db5f91
BLAKE2b-256 38eb09bf9d0924481ed4744f28f724a9cb2be40a7313bde47f61eb98a6113db7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page