pub struct Snapshot {
pub time: f64,
pub atom_posits: Vec<Vec3>,
pub atom_velocities: Option<Vec<Vec3>>,
pub energy_data: Option<SnapshotEnergyData>,
pub water_o_posits: Vec<Vec3>,
pub water_h0_posits: Vec<Vec3>,
pub water_h1_posits: Vec<Vec3>,
pub water_velocities: Option<Vec<Vec3>>,
}Expand description
This stores the positions and velocities of all atoms in the system, and the total energy. It represents the output of the simulation. A set of these can be used to play it back over time. We save load and save this to disk in the __ format.
Fields§
§time: f64§atom_posits: Vec<Vec3>§atom_velocities: Option<Vec<Vec3>>§energy_data: Option<SnapshotEnergyData>§water_o_posits: Vec<Vec3>§water_h0_posits: Vec<Vec3>§water_h1_posits: Vec<Vec3>§water_velocities: Option<Vec<Vec3>>Single velocity per solvent molecule, as it’s rigid.
Implementations§
Source§impl Snapshot
impl Snapshot
Sourcepub fn new(state: &MdState) -> Self
pub fn new(state: &MdState) -> Self
Initialize with position data only. We construct these with positions only, then augment with velocity and energy data as required.
pub fn update_with_velocities(&mut self, state: &MdState)
pub fn update_with_energy( &mut self, state: &MdState, pressure: f32, temperature: f32, )
Sourcepub fn unflatten(
&self,
mol_start_indices: &[usize],
) -> Result<Vec<Vec<(Vec3, Vec3)>>>
pub fn unflatten( &self, mol_start_indices: &[usize], ) -> Result<Vec<Vec<(Vec3, Vec3)>>>
Unflatten positions and velocities into a per-molecule basis. mol_start_indices may be
taken directly from MdState. Inner: (Posit, Vel). Does not unflatten the solvent, which is placed
after all non-solvent molecules in the flat arrays.
Sourcepub fn populate_hydrogen_bonds(&mut self, _atoms: &[AtomDynamics])
pub fn populate_hydrogen_bonds(&mut self, _atoms: &[AtomDynamics])
The element indices must match the atom posits.
pub fn to_dcd(&self, cell: &SimBox, write_water: bool) -> DcdFrame
Sourcepub fn from_dcd(dcd: &DcdTrajectory) -> Vec<Self>
pub fn from_dcd(dcd: &DcdTrajectory) -> Vec<Self>
Note: Most of our fields are not available in the DCD format, so we leave them empty, using the Default impl.
Source§impl Snapshot
impl Snapshot
pub fn make_mol2( &self, atoms_: &[AtomGeneric], bonds: &[BondGeneric], ) -> Result<Mol2>
pub fn make_mmcif( &self, atoms_: &[AtomGeneric], _bonds: &[BondGeneric], ) -> Result<MmCif>
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Snapshot
impl RefUnwindSafe for Snapshot
impl Send for Snapshot
impl Sync for Snapshot
impl Unpin for Snapshot
impl UnsafeUnpin for Snapshot
impl UnwindSafe for Snapshot
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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>
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<T> Pointable for T
impl<T> Pointable for T
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.