-
Notifications
You must be signed in to change notification settings - Fork 51
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
Multiprocessing #486
base: master
Are you sure you want to change the base?
Multiprocessing #486
Conversation
opengate/managers.py
Outdated
output = se.run_engine() | ||
return output | ||
|
||
def run(self, start_new_process=False): | ||
def generate_run_timing_interval_map(self, number_of_processes): | ||
if number_of_processes % len(self.run_timing_intervals) != 0: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why ? I thought we just divide ALL time_interval by the number_of_processes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, but letting the user define the total number of processes rather than the process per run is more intuitive and will not require an API change if we implement a more advanced splitting scheme in the future. So I think it's better this way.
Yes, but letting the user define the total number of processes rather than the process per run is more intuitive and will not require an API change if we implement a more advanced splitting scheme in the future. So I think it's better this way.
…On Oct 11 2024, at 11:00 am, David Sarrut ***@***.***> wrote:
@dsarrut commented on this pull request.
In opengate/managers.py (#486 (comment)):
> output = se.run_engine()
return output
- def run(self, start_new_process=False):
+ def generate_run_timing_interval_map(self, number_of_processes):
+ if number_of_processes % len(self.run_timing_intervals) != 0:
why ? I thought we just divide ALL time_interval by the number_of_processes
—
Reply to this email directly, view it on GitHub (#486 (review)), or unsubscribe (https://github.com/notifications/unsubscribe-auth/AIFQFYM2QBJ7YWBUP4ELK2TZ26HTVAVCNFSM6AAAAABPVS5KBSVHI2DSMVQWIX3LMV43YUDVNRWFEZLROVSXG5CSMV3GSZLXHMZDGNRSGMYTOOBUHE).
You are receiving this because you authored the thread.
|
I figured out a flexible mechanism to merge data back into one single actor output (if data is mergeable: true for images, not true yet for ROOT). Note: FinalizeSimulation() will not have access to engines because they do not exist any more outside of the subprocess. |
New:
Works with test019_phsp_actor -> created a new variant of the test. Still need to create variants of other tests that use ROOT output to check. |
…och time rather than date time str
@nkrah I think all actors shall have atomic variables, this way all actors will be thread safe by default, watch this library https://pypi.org/project/atomicx/ . It already implemented the atomic doubles on my suggestion from atomicx import AtomicFloat
# Create an atomic float with an initial value of 0.0
atom = AtomicFloat()
print(f"Initial Value: {atom.load()}")
# Perform atomic operations
atom.store(3.14)
value = atom.load()
print(f"Value: {value}")
# See docs for more operations |
@BishopWolf Thanks for the suggestion. I think atomic doubles will be useful for certain parts of the actors. Bear in mind that this PR is about multiprocessing, i.e. running a (independent) simulation in a newly spawn process. There is no issue with shared memory handling in this case. Concerning multithreading: We are actually using the multithreading architecture from Geant4 which means that not every part of a simulation runs in separate threads, only certain methods. Therefore, only certain shared data structures, e.g. images into which all threads write, need to be thread safe. Currently, there is no python-side function that accesses shared data on a per-thread basis, only C++ functions. In case this changes in the future, I think the package you suggest could be a good option. |
I will pick this up again once PR #599 is done. |
Enable GATE 10 to split a simulation into multiple parallel processes.
THIS IS WORK IN PROGRESS
First implemented items:
Still missing: