pub struct PyCosTheta(pub CosTheta);Expand description
The cosine of the polar 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.costheta
Tuple Fields§
§0: CosThetaTrait Implementations§
Source§impl Clone for PyCosTheta
impl Clone for PyCosTheta
Source§fn clone(&self) -> PyCosTheta
fn clone(&self) -> PyCosTheta
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<'de> Deserialize<'de> for PyCosTheta
impl<'de> Deserialize<'de> for PyCosTheta
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 PyCosTheta
impl<'py> IntoPyObject<'py> for PyCosTheta
Source§type Target = PyCosTheta
type Target = PyCosTheta
Source§type Output = Bound<'py, <PyCosTheta as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <PyCosTheta 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 PyClass for PyCosTheta
impl PyClass for PyCosTheta
Source§impl PyClassImpl for PyCosTheta
impl PyClassImpl for PyCosTheta
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 cosine of the polar 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.costheta
///
const RAW_DOC: &'static CStr = /// The cosine of the polar 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.costheta ///
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<PyCosTheta>
type ThreadChecker = SendablePyClass<PyCosTheta>
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 PyCosTheta
impl PyClassNewTextSignature for PyCosTheta
const TEXT_SIGNATURE: &'static str = "(beam, recoil, daughter, resonance, frame=\"Helicity\")"
Source§impl PyClass__eq__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
impl PyClass__eq__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
Source§impl PyClass__ge__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
impl PyClass__ge__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
Source§impl PyClass__gt__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
impl PyClass__gt__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
Source§impl PyClass__le__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
impl PyClass__le__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
Source§impl PyClass__lt__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
impl PyClass__lt__SlotFragment<PyCosTheta> for PyClassImplCollector<PyCosTheta>
Source§impl<'a, 'holder, 'py> PyFunctionArgument<'a, 'holder, 'py, false> for &'holder PyCosTheta
impl<'a, 'holder, 'py> PyFunctionArgument<'a, 'holder, 'py, false> for &'holder PyCosTheta
Source§impl<'a, 'holder, 'py> PyFunctionArgument<'a, 'holder, 'py, false> for &'holder mut PyCosTheta
impl<'a, 'holder, 'py> PyFunctionArgument<'a, 'holder, 'py, false> for &'holder mut PyCosTheta
Source§impl PyMethods<PyCosTheta> for PyClassImplCollector<PyCosTheta>
impl PyMethods<PyCosTheta> for PyClassImplCollector<PyCosTheta>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for PyCosTheta
impl PyTypeInfo for PyCosTheta
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>
Source§impl Serialize for PyCosTheta
impl Serialize for PyCosTheta
impl DerefToPyAny for PyCosTheta
Auto Trait Implementations§
impl Freeze for PyCosTheta
impl RefUnwindSafe for PyCosTheta
impl Send for PyCosTheta
impl Sync for PyCosTheta
impl Unpin for PyCosTheta
impl UnwindSafe for PyCosTheta
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.