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

Apply Lorentz correction after binning into (d, theta)? #31

Open
SimonHeybrock opened this issue Feb 16, 2024 · 4 comments
Open

Apply Lorentz correction after binning into (d, theta)? #31

SimonHeybrock opened this issue Feb 16, 2024 · 4 comments

Comments

@SimonHeybrock
Copy link
Member

SimonHeybrock commented Feb 16, 2024

In #29 the Lorentz correction is computed in event mode and applied to the data. I think a cheaper approach would be something like:

data = data.bin(dspacing, theta)  # no more pixels, or data.groupby(theta).bins.concat('pixel')
lorentz_factor = sc.midpoints(dspacing)**4 * sc.sin(sc.midpoints(theta))
scale = lorentz_factor / vanadium  # vandium depends only on dspacing
data *= scale

This would result only in a single event-data op (which we would have to do anyway for the vanadium normalization). Binning in theta would have some extra cost, but we may need it anyway for other purposes. Computation of the Lorentz correction itself would essentially be free, and independent of the event count.

@jl-wynen
Copy link
Member

This would require knowing the final binning when applying the correction. Otherwise, we'd lose precision.

@SimonHeybrock
Copy link
Member Author

If that becomes a problem then one could always apply it at the "finest" sensible $d$-spacing binning. There is probably also some point where one exceeds the instrument resolution, i.e., any finer binning is not useful.

@SimonHeybrock
Copy link
Member Author

One potential problem may be the bias that one would get when using a binned representation: A bin on the rising or falling edge of a peak should actually use a slightly larger or smaller (respectively) value of $d$ than the bin center, since more events are in the right or left part (respectively) of the bin.

@SimonHeybrock
Copy link
Member Author

According to latest information a) other software might apply this correction (which implies binning in $d$) and b) we might only need to apply the $\sin\theta$-part, which varies less, I think we can conclude that the precision problems are likely not relevant. I would therefore suggest to move ahead with this. This will also simply making the correction "configurable", choosing, e.g., whether only the $\sin\theta$-part gets applied.

@SimonHeybrock SimonHeybrock added this to the Essentials milestone Feb 26, 2024
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

No branches or pull requests

2 participants