-
Notifications
You must be signed in to change notification settings - Fork 29
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
Add in quadfitter #220
base: main
Are you sure you want to change the base?
Add in quadfitter #220
Conversation
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.
Hey Sam, thanks for taking the time to do this! I left a couple comments mostly on code structuring, haven't tested it out yet.
@@ -0,0 +1,8 @@ | |||
{ | |||
name: "FIT_QUAD", |
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.
This data entry should be placed in FITTER.ratdb, with the index of QUAD, rather than initing its own table.
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.
See my other comment. Happy to debate this.
Yes -- I'm working on that;) |
Hi @JamesJieranShen, thanks for the comments! I agree with all of them aside from the one about where to put the fitter ratdb table. Are we sure that we want to keep the tables for all fitters in the same file? I feel like that may become a bookkeeping nightmare, in SNO+ we allow each fitter to have it's own ratdb file. Each fitter might have a pretty large number of indices depending on the lifetime of the experiment and the complexity of the fitter. |
…g a check to make sure the point table size is larger than the maximum nhit value to use the table with.
Hey @smnaugle, I was referring to the json/ratdb internal data-structure. It should be in the same "table" as the other fitter, i.e. have the same "name", but different "index": {
"name": "Fitter",
"index": "QUAD",
...
} Onto splitting the fitters to different files -- I'm ok with putting the fitter ratdb entry as a separate file for book keeping purposes. However, clearly the current purpose of the FITTER.ratdb file is meant to include all fitter parameters. I would suggest changing the file of that name to FITTENSOR.ratdb if you would like to have a separate FITQUAD.ratdb. Thanks again! |
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.
LGTM, on the code front. I will leave to @MarcFBergevin and others to see if there's anything else wrong.
This PR currently crashes when running quadfitter on data. We should hold off on merging until I find the bug. |
OK the previously mentioned crash is now fixed and this PR should be ready to merge in. One thing to note though, even when I return Edit: Resolved in future commit. |
if (pmt->GetDigitizedTime() > 1e6) { | ||
continue; | ||
} | ||
pmtt.push_back(pmt->GetDigitizedTime()); |
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.
We should have a method for how to select which timing to use in the reconstruction algorithms.
I think it would make sense to merge #226 first and adapt this PR to use the functionality provided there. |
Adds in quadfitter as a rat processor that can be used by analyzers.
TODO: Should add in an experiment agnostic way for users to define what ratdb index to use for quadfitter.