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

add protections for xregion configuration #349

Merged
merged 3 commits into from
Nov 7, 2024
Merged

Conversation

wenqiang-gu
Copy link
Member

@wenqiang-gu wenqiang-gu commented Nov 6, 2024

@brettviren I added two protections related to the new xregion:

First, sometimes "null" values in the faces would introduce a problem because Xregion(null) would be undefined.

Second, AnodePlane requires scalar values (cathode, anode, response) for definition of the BoundingBox of a face's sensitive volume. In such case, we need a backup scalar input, for example:

faces: [
    {
        response: ...,
        anode: ...,
        cathode: {
            x: [...], y:[...], z:[...],  // non-scalar cathode
        },
       cathode_ref: -200*wc.cm, // scalar
    },
    null,
],

@brettviren
Copy link
Member

Hi @wenqiang-gu

Good catch!

Adding new *_ref configuration attributes makes me a little nervous. What do you think about one or both of these ideas:

The response_x value is used in defining the pimpos origin X value held by
the WirePlane. A "non-planar plane" for the response plane would, I think,
never make sense given its main purpose is to connect to the plane on which FR paths start. So, I suggest that AnodePlane should throw an exception if it is ever given a non-scalar value for response.

The other two, cathode and anode are used to make a BoundingBox rectangular volume that is meant to characterize the "sensitive volume". Given the name "bounding" I think it is fitting that AnodePlane can use the extreme value for X when it is given a non-scalar cathode or anode "plane". The BB would then still "bound" the entire shaped cathode and/or anode.

@wenqiang-gu
Copy link
Member Author

@brettviren I can agree with your point 1 and partially agree with your point 2. See the updated PR.

For point 1, I think it's even better to throw an error when anode is not scalar.

For point 2, setting cathode_x to extreme value (eg, ing/-inf) would be tricky as the DepoTransform or DepoSplat rely on the BoundingBox to check if a depo belongs to a face sensitive volume:

if (bb.inside(depo->pos())) {

Therefore, it could be easier just to set the cathode_x to be response_x +/- 0.01mm. As the energy depos after Drifter are all relocated at response_x, the slightly enlarged BoundingBox (0.01mm) can guarantee that inside(depo->pos()) returns true for the corresponding face. How do you think?

@brettviren
Copy link
Member

Sorry, I was not clear.

The "extreme value" does not mean infinity but means the extreme X location of the cathode surface (and etc for anode). This will either be the max() or the min() value of the configured .x array. The max() if the cathode is at larger X values compared to the response plane, min() otherwise. That is, in both cases we wish to find the cathode X location that is the maximum distance from the response plane.

@wenqiang-gu
Copy link
Member Author

@brettviren I see, I didn't realize that. How is the updated PR now?

@brettviren
Copy link
Member

Looks good to me! Thanks for considering the alternatives.

@brettviren brettviren merged commit 44c164f into master Nov 7, 2024
@wenqiang-gu
Copy link
Member Author

Fixed a bug in commit 85c8de3

The bug crashes in PDSP configuration where the faces is defined as:

faces: if sign >0 then [
                    null,
                    {
                        anode: centerline - apa_plane,
                        response: centerline - res_plane,
                        cathode: centerline - cpa_plane, 
                    }
]
...

For a face of value NULL (e.g. faces[0]), the original implementation will always throw an error.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants