pub struct MiePotential {
pub radius: f64,
pub strength: f64,
pub bound: f64,
pub cutoff: f64,
pub en: f64,
pub em: f64,
}Expand description
Generalizeation of the BoundLennardJones potential.
\begin{align} U(r) &= C\epsilon\left[ \left(\frac{\sigma}{r}\right)^n - \left(\frac{\sigma}{r}\right)^m\right]\\ C &= \frac{n}{n-m}\left(\frac{n}{m}\right)^{\frac{n}{n-m}}\\ V(r) &= \min(U(r), \beta)\theta(r-\zeta) \end{align}
This struct comes in a 64bit version MiePotential and a 32bit variant MiePotentialF32.
§References
G. Mie, “Zur kinetischen Theorie der einatomigen Körper,” Annalen der Physik, vol. 316, no. 8. Wiley, pp. 657–697, Jan. 1903. doi: 10.1002/andp.19033160802.
Fields§
§radius: f64Interaction strength $\epsilon$ of the potential.
strength: f64Overall size $\sigma$ of the object of the potential.
bound: f64Numerical bound $\beta$ of the interaction strength.
cutoff: f64Defines a cutoff $\zeta$ after which the potential will be fixed to exactly zero.
en: f64Exponent $n$ of the potential
em: f64Exponent $m$ of the potential
Implementations§
Source§impl MiePotential
impl MiePotential
Sourcepub fn new(
radius: f64,
strength: f64,
bound: f64,
cutoff: f64,
en: f64,
em: f64,
) -> Self
Available on crate feature pyo3 only.
pub fn new( radius: f64, strength: f64, bound: f64, cutoff: f64, en: f64, em: f64, ) -> Self
pyo3 only.Constructs a new MiePotential
use cellular_raza_building_blocks::MiePotential;
let (radius, strength, bound, cutoff, en, em) = (1.0, 1.0, 1.0, 1.0, 1.0, 1.0);
let mie_potential = MiePotential::new(
radius,
strength,
bound,
cutoff,
en,
em,
);Trait Implementations§
Source§impl AbsDiffEq for MiePotential
impl AbsDiffEq for MiePotential
Source§fn default_epsilon() -> Self::Epsilon
fn default_epsilon() -> Self::Epsilon
Source§fn abs_diff_eq(&self, other: &Self, epsilon: Self::Epsilon) -> bool
fn abs_diff_eq(&self, other: &Self, epsilon: Self::Epsilon) -> bool
§fn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
fn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
AbsDiffEq::abs_diff_eq].Source§impl Clone for MiePotential
impl Clone for MiePotential
Source§fn clone(&self) -> MiePotential
fn clone(&self) -> MiePotential
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for MiePotential
impl Debug for MiePotential
Source§impl<'de> Deserialize<'de> for MiePotential
impl<'de> Deserialize<'de> for MiePotential
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<const D: usize> Interaction<Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, f64> for MiePotential
impl<const D: usize> Interaction<Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, f64> for MiePotential
Source§fn calculate_force_between(
&self,
own_pos: &SVector<f64, D>,
_own_vel: &SVector<f64, D>,
ext_pos: &SVector<f64, D>,
_ext_vel: &SVector<f64, D>,
ext_radius: &f64,
) -> Result<(SVector<f64, D>, SVector<f64, D>), CalcError>
fn calculate_force_between( &self, own_pos: &SVector<f64, D>, _own_vel: &SVector<f64, D>, ext_pos: &SVector<f64, D>, _ext_vel: &SVector<f64, D>, ext_radius: &f64, ) -> Result<(SVector<f64, D>, SVector<f64, D>), CalcError>
§fn is_neighbor(
&self,
own_pos: &Pos,
ext_pos: &Pos,
ext_inf: &Inf,
) -> Result<bool, CalcError>
fn is_neighbor( &self, own_pos: &Pos, ext_pos: &Pos, ext_inf: &Inf, ) -> Result<bool, CalcError>
§fn react_to_neighbors(&mut self, neighbors: usize) -> Result<(), CalcError>
fn react_to_neighbors(&mut self, neighbors: usize) -> Result<(), CalcError>
Source§impl InteractionInformation<f64> for MiePotential
impl InteractionInformation<f64> for MiePotential
Source§fn get_interaction_information(&self) -> f64
fn get_interaction_information(&self) -> f64
Source§impl<'py> IntoPyObject<'py> for MiePotential
impl<'py> IntoPyObject<'py> for MiePotential
Source§type Target = MiePotential
type Target = MiePotential
Source§type Output = Bound<'py, <MiePotential as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <MiePotential 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 PartialEq for MiePotential
impl PartialEq for MiePotential
Source§impl PyClass for MiePotential
impl PyClass for MiePotential
Source§impl PyClassImpl for MiePotential
impl PyClassImpl for MiePotential
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 = c"Generalizeation of the [BoundLennardJones] potential.\n\n\\\\begin{align}\n U(r) &= C\\epsilon\\left[ \\left(\\frac{\\sigma}{r}\\right)^n -\n \\left(\\frac{\\sigma}{r}\\right)^m\\right]\\\\\\\\\n C &= \\frac{n}{n-m}\\left(\\frac{n}{m}\\right)^{\\frac{n}{n-m}}\\\\\\\\\n V(r) &= \\min(U(r), \\beta)\\theta(r-\\zeta)\n\\\\end{align}\n\nThis struct comes in a 64bit version [MiePotential] and a 32bit variant\n[MiePotentialF32].\n\n# References\nG. Mie, \xe2\x80\x9cZur kinetischen Theorie der einatomigen K\xc3\xb6rper,\xe2\x80\x9d\nAnnalen der Physik, vol. 316, no. 8. Wiley, pp. 657\xe2\x80\x93697, Jan. 1903.\ndoi: [10.1002/andp.19033160802](https://doi.org/10.1002/andp.19033160802).\x00"
const RAW_DOC: &'static CStr = c"Generalizeation of the [BoundLennardJones] potential.\n\n\\\\begin{align}\n U(r) &= C\\epsilon\\left[ \\left(\\frac{\\sigma}{r}\\right)^n -\n \\left(\\frac{\\sigma}{r}\\right)^m\\right]\\\\\\\\\n C &= \\frac{n}{n-m}\\left(\\frac{n}{m}\\right)^{\\frac{n}{n-m}}\\\\\\\\\n V(r) &= \\min(U(r), \\beta)\\theta(r-\\zeta)\n\\\\end{align}\n\nThis struct comes in a 64bit version [MiePotential] and a 32bit variant\n[MiePotentialF32].\n\n# References\nG. Mie, \xe2\x80\x9cZur kinetischen Theorie der einatomigen K\xc3\xb6rper,\xe2\x80\x9d\nAnnalen der Physik, vol. 316, no. 8. Wiley, pp. 657\xe2\x80\x93697, Jan. 1903.\ndoi: [10.1002/andp.19033160802](https://doi.org/10.1002/andp.19033160802).\x00"
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<MiePotential>
type ThreadChecker = SendablePyClass<MiePotential>
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 MiePotential
impl PyClassNewTextSignature for MiePotential
const TEXT_SIGNATURE: &'static str = "(radius, strength, bound, cutoff, en, em)"
Source§impl PyMethods<MiePotential> for PyClassImplCollector<MiePotential>
impl PyMethods<MiePotential> for PyClassImplCollector<MiePotential>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for MiePotential
impl PyTypeInfo for MiePotential
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.Source§impl RelativeEq for MiePotential
impl RelativeEq for MiePotential
Source§fn default_max_relative() -> Self::Epsilon
fn default_max_relative() -> Self::Epsilon
Source§fn relative_eq(
&self,
other: &Self,
epsilon: Self::Epsilon,
max_relative: Self::Epsilon,
) -> bool
fn relative_eq( &self, other: &Self, epsilon: Self::Epsilon, max_relative: Self::Epsilon, ) -> bool
§fn relative_ne(
&self,
other: &Rhs,
epsilon: Self::Epsilon,
max_relative: Self::Epsilon,
) -> bool
fn relative_ne( &self, other: &Rhs, epsilon: Self::Epsilon, max_relative: Self::Epsilon, ) -> bool
RelativeEq::relative_eq].Source§impl Serialize for MiePotential
impl Serialize for MiePotential
impl DerefToPyAny for MiePotential
impl ExtractPyClassWithClone for MiePotential
impl StructuralPartialEq for MiePotential
Auto Trait Implementations§
impl Freeze for MiePotential
impl RefUnwindSafe for MiePotential
impl Send for MiePotential
impl Sync for MiePotential
impl Unpin for MiePotential
impl UnwindSafe for MiePotential
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> 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 more§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§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.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read more§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read more§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).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.