pub struct PyPhi(pub Phi);Expand description
The aziumuthal decay angle in the rest frame of the given resonance
This Variable is calculated by forming the given frame (helicity or Gottfried-Jackson) and
calculating the spherical angles according to one of the decaying daughter particles.
The helicity frame is defined in terms of the following Cartesian axes in the rest frame of
the resonance:
.. math:: \hat{z} \propto -\vec{p}’{\text{recoil}} .. math:: \hat{y} \propto \vec{p}{\text{beam}} \times (-\vec{p}_{\text{recoil}}) .. math:: \hat{x} = \hat{y} \times \hat{z}
where primed vectors are in the rest frame of the resonance and unprimed vectors are in
the center-of-momentum frame.
The Gottfried-Jackson frame differs only in the definition of :math:\hat{z}:
.. math:: \hat{z} \propto \vec{p}’_{\text{beam}}
§Parameters
beam : int
The index of the beam particle
recoil : list of int
Indices of particles which are combined to form the recoiling particle (particles which
are not beam or part of the resonance)
daughter : list of int
Indices of particles which are combined to form one of the decay products of the
resonance
resonance : list of int
Indices of particles which are combined to form the resonance
frame : {‘Helicity’, ‘HX’, ‘HEL’, ‘GottfriedJackson’, ‘Gottfried Jackson’, ‘GJ’, ‘Gottfried-Jackson’}
The frame to use in the calculation
§Raises
ValueError
If frame is not one of the valid options
§See Also
laddu.utils.vectors.Vec3.phi
Tuple Fields§
§0: PhiTrait Implementations§
Source§impl<'de> Deserialize<'de> for PyPhi
impl<'de> Deserialize<'de> for PyPhi
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl<'py> IntoPyObject<'py> for PyPhi
impl<'py> IntoPyObject<'py> for PyPhi
Source§type Output = Bound<'py, <PyPhi as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <PyPhi as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PyClassImpl for PyPhi
impl PyClassImpl for PyPhi
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = /// The aziumuthal decay angle in the rest frame of the given `resonance`
///
/// This Variable is calculated by forming the given frame (helicity or Gottfried-Jackson) and
/// calculating the spherical angles according to one of the decaying `daughter` particles.
///
/// The helicity frame is defined in terms of the following Cartesian axes in the rest frame of
/// the `resonance`:
///
/// .. math:: \hat{z} \propto -\vec{p}'_{\text{recoil}}
/// .. math:: \hat{y} \propto \vec{p}_{\text{beam}} \times (-\vec{p}_{\text{recoil}})
/// .. math:: \hat{x} = \hat{y} \times \hat{z}
///
/// where primed vectors are in the rest frame of the `resonance` and unprimed vectors are in
/// the center-of-momentum frame.
///
/// The Gottfried-Jackson frame differs only in the definition of :math:`\hat{z}`:
///
/// .. math:: \hat{z} \propto \vec{p}'_{\text{beam}}
///
/// Parameters
/// ----------
/// beam : int
/// The index of the `beam` particle
/// recoil : list of int
/// Indices of particles which are combined to form the recoiling particle (particles which
/// are not `beam` or part of the `resonance`)
/// daughter : list of int
/// Indices of particles which are combined to form one of the decay products of the
/// `resonance`
/// resonance : list of int
/// Indices of particles which are combined to form the `resonance`
/// frame : {'Helicity', 'HX', 'HEL', 'GottfriedJackson', 'Gottfried Jackson', 'GJ', 'Gottfried-Jackson'}
/// The frame to use in the calculation
///
/// Raises
/// ------
/// ValueError
/// If `frame` is not one of the valid options
///
///
/// See Also
/// --------
/// laddu.utils.vectors.Vec3.phi
///
const RAW_DOC: &'static CStr = /// The aziumuthal decay angle in the rest frame of the given `resonance` /// /// This Variable is calculated by forming the given frame (helicity or Gottfried-Jackson) and /// calculating the spherical angles according to one of the decaying `daughter` particles. /// /// The helicity frame is defined in terms of the following Cartesian axes in the rest frame of /// the `resonance`: /// /// .. math:: \hat{z} \propto -\vec{p}'_{\text{recoil}} /// .. math:: \hat{y} \propto \vec{p}_{\text{beam}} \times (-\vec{p}_{\text{recoil}}) /// .. math:: \hat{x} = \hat{y} \times \hat{z} /// /// where primed vectors are in the rest frame of the `resonance` and unprimed vectors are in /// the center-of-momentum frame. /// /// The Gottfried-Jackson frame differs only in the definition of :math:`\hat{z}`: /// /// .. math:: \hat{z} \propto \vec{p}'_{\text{beam}} /// /// Parameters /// ---------- /// beam : int /// The index of the `beam` particle /// recoil : list of int /// Indices of particles which are combined to form the recoiling particle (particles which /// are not `beam` or part of the `resonance`) /// daughter : list of int /// Indices of particles which are combined to form one of the decay products of the /// `resonance` /// resonance : list of int /// Indices of particles which are combined to form the `resonance` /// frame : {'Helicity', 'HX', 'HEL', 'GottfriedJackson', 'Gottfried Jackson', 'GJ', 'Gottfried-Jackson'} /// The frame to use in the calculation /// /// Raises /// ------ /// ValueError /// If `frame` is not one of the valid options /// /// /// See Also /// -------- /// laddu.utils.vectors.Vec3.phi ///
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<PyPhi>
type ThreadChecker = SendablePyClass<PyPhi>
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyClassNewTextSignature for PyPhi
impl PyClassNewTextSignature for PyPhi
const TEXT_SIGNATURE: &'static str = "(beam, recoil, daughter, resonance, frame=\"Helicity\")"
Source§impl PyMethods<PyPhi> for PyClassImplCollector<PyPhi>
impl PyMethods<PyPhi> for PyClassImplCollector<PyPhi>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for PyPhi
impl PyTypeInfo for PyPhi
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Source§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
impl DerefToPyAny for PyPhi
Auto Trait Implementations§
impl Freeze for PyPhi
impl RefUnwindSafe for PyPhi
impl Send for PyPhi
impl Sync for PyPhi
impl Unpin for PyPhi
impl UnwindSafe for PyPhi
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FromPyObject<'_> for T
impl<T> FromPyObject<'_> for T
Source§impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
Source§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
Source§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
Source§impl<T> Serialize for T
impl<T> Serialize for T
fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<(), Error>
fn do_erased_serialize( &self, serializer: &mut dyn Serializer, ) -> Result<(), ErrorImpl>
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.