Struct MorsePotential
pub struct MorsePotential {
pub radius: f64,
pub potential_stiffness: f64,
pub cutoff: f64,
pub strength: f64,
}Available on crate feature
elli only.Expand description
Famous Morse potential for diatomic molecules.
§Parameters & Variables
| Symbol | Struct Field | Description |
|---|---|---|
| $R$ | radius | Radius of the particle |
| $\lambda$ | potential_stiffness | Can be interpreted as the inverse width of the potential |
cutoff | Cutoff after which the interaction strength is identically 0 | |
| $V_0$ | strength | Interaction strength |
| $r$ | Distance between interacting particles |
\begin{equation} V(r) = V_0\left(1 - e^{-\lambda(r-R)}\right)^2 \end{equation}
§References
[1] P. M. Morse, “Diatomic Molecules According to the Wave Mechanics. II. Vibrational Levels,” Physical Review, vol. 34, no. 1. American Physical Society (APS), pp. 57–64, Jul. 01, 1929. doi: 10.1103/physrev.34.57.
Fields§
§radius: f64Radius of the object
potential_stiffness: f64Defines the length for the interaction range
cutoff: f64Cutoff after which the interaction is exactly 0
strength: f64Strength of the interaction
Implementations§
§impl MorsePotential
impl MorsePotential
pub fn new(
radius: f64,
potential_stiffness: f64,
cutoff: f64,
strength: f64,
) -> MorsePotential
Available on crate feature cpu_os_threads only.
pub fn new( radius: f64, potential_stiffness: f64, cutoff: f64, strength: f64, ) -> MorsePotential
cpu_os_threads only.Constructs a new MorsePotential
use cellular_raza_building_blocks::MorsePotential;
let morse_potential = MorsePotential::new(
radius,
potential_stiffness,
cutoff,
strength,
);Trait Implementations§
§impl AbsDiffEq for MorsePotential
impl AbsDiffEq for MorsePotential
§fn default_epsilon() -> <MorsePotential as AbsDiffEq>::Epsilon
fn default_epsilon() -> <MorsePotential as AbsDiffEq>::Epsilon
The default tolerance to use when testing values that are close together. Read more
§fn abs_diff_eq(
&self,
other: &MorsePotential,
epsilon: <MorsePotential as AbsDiffEq>::Epsilon,
) -> bool
fn abs_diff_eq( &self, other: &MorsePotential, epsilon: <MorsePotential as AbsDiffEq>::Epsilon, ) -> bool
A test for equality that uses the absolute difference to compute the approximimate
equality of two numbers.
§fn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
fn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
The inverse of [
AbsDiffEq::abs_diff_eq].§impl Clone for MorsePotential
impl Clone for MorsePotential
§fn clone(&self) -> MorsePotential
fn clone(&self) -> MorsePotential
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read more§impl Debug for MorsePotential
impl Debug for MorsePotential
§impl<'de> Deserialize<'de> for MorsePotential
impl<'de> Deserialize<'de> for MorsePotential
§fn deserialize<__D>(
__deserializer: __D,
) -> Result<MorsePotential, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<MorsePotential, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
§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 MorsePotential
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 MorsePotential
§fn calculate_force_between(
&self,
own_pos: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>,
_own_vel: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>,
ext_pos: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>,
_ext_vel: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>,
ext_info: &f64,
) -> Result<(Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>), CalcError>
fn calculate_force_between( &self, own_pos: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, _own_vel: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, ext_pos: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, _ext_vel: &Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, ext_info: &f64, ) -> Result<(Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>, Matrix<f64, Const<D>, Const<1>, ArrayStorage<f64, D, 1>>), CalcError>
Calculates the forces (velocity-derivative) on the corresponding external position given
external velocity.
By providing velocities, we can calculate terms that are related to friction.
The function returns two forces, one acting on the current agent and the other on the
external agent.
§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>
Checks if the other cell represented by position and information is a neighbor to the current one or not.
§fn react_to_neighbors(&mut self, neighbors: usize) -> Result<(), CalcError>
fn react_to_neighbors(&mut self, neighbors: usize) -> Result<(), CalcError>
Reacts to the results gathered by the Interaction::is_neighbor
method and changes the state of the cell.
§impl InteractionInformation<f64> for MorsePotential
impl InteractionInformation<f64> for MorsePotential
§fn get_interaction_information(&self) -> f64
fn get_interaction_information(&self) -> f64
Get additional information of cellular properties (ie. for cell-specific interactions).
§impl IntoPy<Py<PyAny>> for MorsePotential
impl IntoPy<Py<PyAny>> for MorsePotential
§impl<'py> IntoPyObject<'py> for MorsePotential
impl<'py> IntoPyObject<'py> for MorsePotential
§type Target = MorsePotential
type Target = MorsePotential
The Python output type
§type Output = Bound<'py, <MorsePotential as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <MorsePotential as IntoPyObject<'py>>::Target>
The smart pointer type to use. Read more
§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<MorsePotential as IntoPyObject<'py>>::Output, <MorsePotential as IntoPyObject<'py>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<MorsePotential as IntoPyObject<'py>>::Output, <MorsePotential as IntoPyObject<'py>>::Error>
Performs the conversion.
§impl PartialEq for MorsePotential
impl PartialEq for MorsePotential
§impl PyClass for MorsePotential
impl PyClass for MorsePotential
§impl PyTypeInfo for MorsePotential
impl PyTypeInfo for MorsePotential
§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
Returns the safe abstraction over the type object.
§fn type_object_bound(py: Python<'_>) -> Bound<'_, PyType>
fn type_object_bound(py: Python<'_>) -> Bound<'_, PyType>
👎Deprecated since 0.23.0: renamed to
PyTypeInfo::type_objectDeprecated name for [
PyTypeInfo::type_object].§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object is an instance of this type or a subclass of this type.§fn is_type_of_bound(object: &Bound<'_, PyAny>) -> bool
fn is_type_of_bound(object: &Bound<'_, PyAny>) -> bool
👎Deprecated since 0.23.0: renamed to
PyTypeInfo::is_type_ofDeprecated name for [
PyTypeInfo::is_type_of].§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object is an instance of this type.§fn is_exact_type_of_bound(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of_bound(object: &Bound<'_, PyAny>) -> bool
👎Deprecated since 0.23.0: renamed to
PyTypeInfo::is_exact_type_ofDeprecated name for [
PyTypeInfo::is_exact_type_of].§impl RelativeEq for MorsePotential
impl RelativeEq for MorsePotential
§fn default_max_relative() -> <MorsePotential as AbsDiffEq>::Epsilon
fn default_max_relative() -> <MorsePotential as AbsDiffEq>::Epsilon
The default relative tolerance for testing values that are far-apart. Read more
§fn relative_eq(
&self,
other: &MorsePotential,
epsilon: <MorsePotential as AbsDiffEq>::Epsilon,
max_relative: <MorsePotential as AbsDiffEq>::Epsilon,
) -> bool
fn relative_eq( &self, other: &MorsePotential, epsilon: <MorsePotential as AbsDiffEq>::Epsilon, max_relative: <MorsePotential as AbsDiffEq>::Epsilon, ) -> bool
A test for equality that uses a relative comparison if the values are far apart.
§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
The inverse of [
RelativeEq::relative_eq].§impl Serialize for MorsePotential
impl Serialize for MorsePotential
§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl DerefToPyAny for MorsePotential
impl StructuralPartialEq for MorsePotential
Auto Trait Implementations§
impl Freeze for MorsePotential
impl RefUnwindSafe for MorsePotential
impl Send for MorsePotential
impl Sync for MorsePotential
impl Unpin for MorsePotential
impl UnwindSafe for MorsePotential
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> FromPyObject<'_> for Twhere
T: PyClass + Clone,
impl<T> FromPyObject<'_> for Twhere
T: PyClass + Clone,
§fn extract_bound(obj: &Bound<'_, PyAny>) -> Result<T, PyErr>
fn extract_bound(obj: &Bound<'_, PyAny>) -> Result<T, PyErr>
§impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
§fn from_py_object_bound(ob: Borrowed<'_, 'py, PyAny>) -> Result<T, PyErr>
fn from_py_object_bound(ob: Borrowed<'_, 'py, PyAny>) -> Result<T, PyErr>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
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> ⓘ
Converts
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> ⓘ
Converts
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>
Converts
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>
Converts
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>
Converts
self into a Python object. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§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>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
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
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.