pub struct LennardJones<const N: i32 = 12, const M: i32 = 6> {
pub epsilon: f64,
pub sigma: f64,
}Expand description
Potential with a steep repulsive core and an attractive well.
U(r) = 4 \varepsilon \left[ \left( \frac{\sigma}{r} \right)^{N} - \left( \frac{\sigma}{r} \right)^{M} \right]Compute the Lennard-Jones (LJ) potential and force as a function of r.
§Examples
In basic usage, the exponents N and M default to 12 and 6, respectively:
use approxim::{assert_abs_diff_eq, assert_relative_eq};
use hoomd_interaction::univariate::{
LennardJones, UnivariateEnergy, UnivariateForce,
};
let epsilon = 1.5;
let sigma = 2.5;
let lennard_jones: LennardJones = LennardJones { epsilon, sigma };
assert_abs_diff_eq!(lennard_jones.energy(sigma), 0.0);
assert_relative_eq!(
lennard_jones.energy(2.0_f64.powf(1.0 / 6.0) * sigma),
-epsilon
);
assert_abs_diff_eq!(
lennard_jones.force(2.0_f64.powf(1.0 / 6.0) * sigma),
0.0,
epsilon = 1e-12
);You can choose any values for N and M at compile time:
use approxim::{assert_abs_diff_eq, assert_relative_eq};
use hoomd_interaction::univariate::{
LennardJones, UnivariateEnergy, UnivariateForce,
};
let epsilon = 1.5;
let sigma = 2.5;
let lennard_jones: LennardJones<8, 4> = LennardJones { epsilon, sigma };
assert_abs_diff_eq!(lennard_jones.energy(sigma), 0.0);
assert_relative_eq!(
lennard_jones.energy(2.0_f64.powf(1.0 / 4.0) * sigma),
-epsilon
);
assert_abs_diff_eq!(
lennard_jones.force(2.0_f64.powf(1.0 / 4.0) * sigma),
0.0,
epsilon = 1e-12
);The parameters are public fields and may be accessed directly:
use hoomd_interaction::univariate::LennardJones;
let mut lennard_jones: LennardJones = LennardJones::default();
lennard_jones.epsilon = 1.5;
lennard_jones.sigma = 3.0;Fields§
§epsilon: f64Energy scale ([energy]).
sigma: f64Interaction width ([length]).
Trait Implementations§
Source§impl<const N: i32, const M: i32> Clone for LennardJones<N, M>
impl<const N: i32, const M: i32> Clone for LennardJones<N, M>
Source§fn clone(&self) -> LennardJones<N, M>
fn clone(&self) -> LennardJones<N, M>
Returns a duplicate 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 moreSource§impl<const N: i32, const M: i32> Default for LennardJones<N, M>
impl<const N: i32, const M: i32> Default for LennardJones<N, M>
Source§fn default() -> Self
fn default() -> Self
Construct a LennardJones with default parameters (epsilon=1.0, sigma=1.0)
§Example
use hoomd_interaction::univariate::LennardJones;
let lennard_jones: LennardJones = LennardJones::default();Source§impl<'de, const N: i32, const M: i32> Deserialize<'de> for LennardJones<N, M>
impl<'de, const N: i32, const M: i32> Deserialize<'de> for LennardJones<N, M>
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>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<const N: i32, const M: i32> UnivariateEnergy for LennardJones<N, M>
impl<const N: i32, const M: i32> UnivariateEnergy for LennardJones<N, M>
Source§impl<const N: i32, const M: i32> UnivariateForce for LennardJones<N, M>
impl<const N: i32, const M: i32> UnivariateForce for LennardJones<N, M>
impl<const N: i32, const M: i32> StructuralPartialEq for LennardJones<N, M>
Auto Trait Implementations§
impl<const N: i32, const M: i32> Freeze for LennardJones<N, M>
impl<const N: i32, const M: i32> RefUnwindSafe for LennardJones<N, M>
impl<const N: i32, const M: i32> Send for LennardJones<N, M>
impl<const N: i32, const M: i32> Sync for LennardJones<N, M>
impl<const N: i32, const M: i32> Unpin for LennardJones<N, M>
impl<const N: i32, const M: i32> UnwindSafe for LennardJones<N, M>
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,
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