Formula momentum conversion
- Add two functions to Utilities/Util
- Update documentation
Summary
I'm not sure if this is a bug, but I don't understand the formula used to convert P [eV/c] to
Distribution::converteVToBetaGamma
:
If the user gives momentum in eV/c, I would imagine that the conversion should be
If it's not a bug then I think it should be better explained in the manual.
Designs
- Show closed items
Relates to
Activity
-
Newest first Oldest first
-
Show all activity Show comments only Show history only
- albajacas_a added Bug label
added Bug label
- gsell changed milestone to %OPAL 2.4.0
changed milestone to %OPAL 2.4.0
@adelmann @snuverink_j @kraus any comments on this?
- Developer
I had a discussion with @albajacas_a about this at some point. Then we didn't really manage to understand it, but the formula comes from
γ=massIneVE+1.0β=1.0−γ21.0From this it follows:
β∗γ=γ2−1.0=(massIneVE+1)2−1Edited by snuverink_j Collapse replies - Author Developer
Ah OK now I understand the formula, but then it is transforming kinetic energy to momentum. I think that this makes sense for the emission models, where p_mean is along the z-axis only
double wThermal = std::abs(Attributes::getReal(itsAttr[Attrib::Distribution::EKIN])); pTotThermal_m = converteVToBetaGamma(wThermal, beam->getM()); pmean_m = Vector_t(0.0, 0.0, 0.5 * pTotThermal_m);
but IMO it doesn't make sense to use it for the momenta in three directions like here
if (inputMoUnits_m == InputMomentumUnitsT::EV) { sigmaP_m[0] = converteVToBetaGamma(sigmaP_m[0], massIneV); sigmaP_m[1] = converteVToBetaGamma(sigmaP_m[1], massIneV); sigmaP_m[2] = converteVToBetaGamma(sigmaP_m[2], massIneV); }
I think the current
converteVToBetaGamma
should be renamed toconvertEkinToMomentum
, and then there should be another function likeconvertMomentumeVToBetaGamma
which returnsγβx=massIneVPxc.Do you agree? Then we can also correct it in the manual
- Author Developer
@snuverink_j @kraus If you agree with this I will make a merge request and fix it
- Developer
@albajacas_a Agreed, and yes please. And as Christof mentioned, put the methods in a more common place.
Classic/Utilities/Util
seems good. 1
- snuverink_j changed the description
changed the description
- adelmann assigned to @albajacas_a
assigned to @albajacas_a
- albajacas_a created merge request !385 (merged) to address this issue
created merge request !385 (merged) to address this issue
- albajacas_a mentioned in merge request !385 (merged)
mentioned in merge request !385 (merged)
- albajacas_a changed the description
changed the description
- Author Developer
could one of you give me access to the manual repository so that I can update this in the documentation, please? (https://gitlab.psi.ch/OPAL/documentation/manual)
Collapse replies - Developer
@albajacas_a @snuverink_j Done.
- albajacas_a marked the checklist item Add two functions to Utilities/Util as completed
marked the checklist item Add two functions to Utilities/Util as completed
- albajacas_a mentioned in issue OPAL/documentation/manual#36 (closed)
mentioned in issue OPAL/documentation/manual#36 (closed)
- albajacas_a marked the checklist item Update documentation as completed
marked the checklist item Update documentation as completed
- gsell changed due date to July 24, 2020
changed due date to July 24, 2020
- albajacas_a closed
closed
- snuverink_j marked this issue as related to OPAL/documentation/manual#36 (closed)
marked this issue as related to OPAL/documentation/manual#36 (closed)
- snuverink_j mentioned in commit regression-tests@7777cf7d
mentioned in commit regression-tests@7777cf7d
- ext-calvo_p added Add/modify Doc label
added Add/modify Doc label
- albajacas_a mentioned in issue #649 (closed)
mentioned in issue #649 (closed)