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

Converters do not work with IOSvc #202

Open
tmadlener opened this issue Sep 5, 2024 · 6 comments · May be fixed by #216
Open

Converters do not work with IOSvc #202

tmadlener opened this issue Sep 5, 2024 · 6 comments · May be fixed by #216
Labels
bug Something isn't working enhancement New feature or request

Comments

@tmadlener
Copy link
Contributor

The converters still partially refer to the PodioDataSvc explicitly and will fail with a segmentation violation when used with the IOSvc.

@tmadlener tmadlener added bug Something isn't working enhancement New feature or request labels Sep 5, 2024
@tmadlener
Copy link
Contributor Author

This probably needs a bit more work, because currently the PodioDataSvc is pretty ingrained in some places, and for some things I am not sure if they will work with the IOSvc.

The LcioEventAlgo currently puts an LCEventWrapper into the eventSvc

auto myEvWr = new LCEventWrapper(std::move(theEvent));
const StatusCode sc = eventSvc()->registerObject("/Event/LCEvent", myEvWr);

Does this still work with the IOSvc? @jmcarcell IIUC, this should still work, but the LCEvent will not be available for our functional algorithms, right?

For the converters it should be possible to put in place checks that check the IOSvc, resp. MetadataSvc and the PodioDataSvc.

@tmadlener
Copy link
Contributor Author

tmadlener commented Sep 24, 2024

As discussed during the EDM4hep meeting, we will not put too much effort into supporting IOSvc with the k4MarlinWrapper, because that is intended mainly for multithreaded usage, and only very few Marlin processors are actually thread safe. We will keep this issue open, so that it is visible for people who try to use the IOSvc with the wrapper.

If necessary we will come back to this in the future to add support. For now we will mainly try to avoid the segmentation fault and rather give users a proper error for that.

@BrieucF
Copy link
Contributor

BrieucF commented Dec 6, 2024

Trying to raise the priority of this issue: it is not really a matter of running in multi-threaded way, it is rather that we try to write all the new algorithms with Functionals and this issue currently prevents one to access the ILCSoft world.

@samf25
Copy link

samf25 commented Jan 8, 2025

I would also like to add in my voice, here. The fact that we can't use the converters with Transformers is hampering my progress on Muon Collider work. I've converted a number of Marlin Processors to Transformers but now I have to run the converted algorithms separately from the ones that are still in MarlinWrappers.

@BrieucF
Copy link
Contributor

BrieucF commented Jan 9, 2025

Hi @samf25 , are these translated Marlin Processors available centrally in Key4hep?

@samf25
Copy link

samf25 commented Jan 9, 2025

No. Currently, they are just located in a separate repo (there's also TrackPerf, and I am currently working on some digitization libraries). Once I can get it all hooked up and running (with MarlinWrappers around they as of yet untranslated ones) they will be added to the MuCol software stack. I don't think there are any plans to include them centrally since they are specific to the muon collider.

@jmcarcell jmcarcell linked a pull request Jan 14, 2025 that will close this issue
2 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working enhancement New feature or request
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants