-
Notifications
You must be signed in to change notification settings - Fork 105
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
Proposal: Generating ./geometry/*.root during build #335
Comments
To my understanding the files in macros/geo/ are under the code control and evolve with time, while the existing root files should not be modified, as they correspond to particular situations, and therefore they do not evolve. If a root file is modified, then it is stored under other name. If this cause a problem (space, info, ...), it could be modified.
|
I see this issue as well, and would like to raise some further points:
*) Tangent topic: As there are so many folders in the root dir, it has become quite cluttered. In general, I would propose moving all detectors to |
I would agree with Jan and produce the geometries on the fly for the simulation. I also agree to Jans * ;) |
Or/And individual repositories for each experiment instead of that big macro repo. |
The idea for this issue came to me when I read this code:
What happens here is that we try to extract numbers from a string in a geometry file. As the string was created using the format specifier %d in one place instead of e.g. %02d, we now have to work around this and catch the case where the first number is larger than 9. The lamentable need to do string parsing in the inner loop of the simulation non-withstanding, a better solution would have been to update the califa 2020 geometry to use %02d. If geometry files were though of as easily generated, transient files (such as the cxx.o files are), this update would have been easy. If they are instead thought of as fixed, essential components of our project, we will always need workarounds like that. I would furthermore propose to move both the generation macros (and the macros used in test cases) to the main repository, so that there is a clear correspondence between macro versions and detector code versions. This would take a lot of detective work (e.g. "this main repo commit was followed by that macros commit by the same author, so the two versions are probably intended to work with each other") out of the job of people wanting to run old versions. (We can still keep the macros subrepository as a Schmuddelecke for code which is neither compiled nor tested against the latest version of the detector classes and thus will probably not work.) While talking about hypothetical changes, I would also propose making "dev" the default branch of R3BRoot, imposing a function length limit of 30 lines, reject any PRs containing the string "sprintf" with prejudice and providing all code authors with fusion powered jetpacks. :-) |
I guess you are at the wrong forum making your suggestion: your comment "using the format specifier %d in one place instead of e.g. %02d" and "The lamentable need to do string parsing in the inner loop of the simulation non-withstanding, a better solution would have been to update the califa 2020 geometry to use %02d" correspond to features of the TGeoVolume::AddNode() function in ROOT VMC, and not to the macros that we made for the CALIFA geometry. https://root.cern.ch/doc/master/TGeoVolume_8cxx_source.html#l00930 As the only way to retrieve the object is using the volume path, we should perform the string parsing. As I told you previously, if you know another method to access to the volume information, please, let us know. |
Yeah, the ROOT geometry stuff is extremely bad - and to think this terrible interface is at the core of our simulations... Can we just drop ROOT Geo and just use pure Geant4? On Topic: Could you use |
Ooops. I stand corrected. Sorry.
I do not have a method which does not break the TVirtualMC abstraction. :-( That being said, I noticed a speedup by several orders of magnitudes when I stopped simulating 4.4GeV photons and started with 4.4MeV photons instead, so my complaints about speed are mostly a thing of the past now. :-) |
General remark: branches are useful for code development, not history tracking of a setup. Please do not use git branches to try to handle things that code-wise shall survive for a long time. If there were two different geometries in use at different experiments, both (generating macros!) should be in the code, in (all later) branches. (Even better: not separate macros, but options within the macro to handle the differences.) If needed, then separate repositories for different experiments. (With only the experiment-specific stuff of course, not duplicating/forking the big project.) |
This, 100%. Today, while waiting for a 10M event simulation to finish, I tried to get rid of the ">>> Event " ... lines our simulation includes once per event. While there is obviously a simple way to do that which I am totally missing, I had to: 0.) break abstraction by casting TVirtualMC to TGeant4 So, all in all, it just took five evil things (excluding step 3) to get rid of the spam. Needless to say, by the time I was done, so was my simulation. Also notice that @janmayer, who proposed moving to raw Geant4 is a NeuLAND person. From my point of view, this means that the argument "We need to support Geant3 because it handles neutrons better" is probably no longer true.
|
Thank you for the confidence in my expertise, but that's maybe a bit too much. I simply don't use Geant3 anymore - its super annoying to install, as the "modern" fortran compilers don't want to compile it anymore, i.e. I have to change my devtoolset during the compilation of FairSoft. It often simply refuses to work for me. It does give different results from Geant4, depending on the physics lists, but I can't really tell if they are better - but I can tell that Geant4 is updated and benchmarked regularly by a large user base. Overall I simply think Geant3 is simply obsolete, and with it so is TVirtualMC and the whole ROOT geometry module. |
@klenze - some text to describe to the reader about when / with which commits this issue was resolved? |
@inkdot7: Sorry, I was just cleaning up my stuff. In the meantime, @jose-luis-rs has implemented automatic generation of At least for CALIFA, the correctness of the result very much seems to depend on the exact platform used. So it seems that without a way to check if a geometry file is good, auto-creating geometry files might not be a good idea. If you have an idea of how to check if two compressed, opaque root files contain compatible floating point values, that would be helpful. Personally, I find the syntax to extract even the center of a crystal a bit byzantine compared to plain geant4. Jan's suggestion to move to plain Geant4 would be my preferred solution as well, but this is very much a minority view. |
Does this mean that actual results (e.g. simulated spectra) vary a lot (beyond random fluctuations) (= bug), or 'just' that the generated geometry files have slightly different values due to rounding differences? I do not have anything to compare generic .root files for compatibility, but if spectra can be generated, this fuzzy spectra CI helper may be of some use: |
From what I understand, the geometry root files are generated from macros/geo/create_${DETECTOR}.C.
Still, they are added to the repository. This could cause some possible problems:
The largest file in geometries is some 150kBytes. I think it is both feasible and desirable to auto-generate the supported versions of these files (e.g. 2019, 2020) during the cmake build process.
What do you think?
The text was updated successfully, but these errors were encountered: