1use std::path::Path;
4
5use bio_files::{MmCif, Mol2};
6use dynamics::{
7 ComputationDevice, FfMolType, MdConfig, MdState, MolDynamics,
8 params::{FfParamSet, prepare_peptide_mmcif},
9};
10
11fn main() {
12 let dev = ComputationDevice::Cpu;
13 let param_set = FfParamSet::new_amber().unwrap();
14
15 let mut protein = MmCif::load(Path::new("1c8k.cif")).unwrap();
16 let mol = Mol2::load(Path::new("CPB.mol2")).unwrap();
17
18 let (_bonds, _dihedrals) = prepare_peptide_mmcif(
22 &mut protein,
23 ¶m_set.peptide_ff_q_map.as_ref().unwrap(),
24 7.0,
25 )
26 .unwrap();
27
28 let mols = vec![
29 MolDynamics::from_mol2(&mol, None),
30 MolDynamics {
31 ff_mol_type: FfMolType::Peptide,
32 atoms: protein.atoms.clone(),
33 static_: true,
34 ..Default::default()
35 },
36 ];
37
38 let mut md = MdState::new(&dev, &MdConfig::default(), &mols, ¶m_set).unwrap();
39
40 let n_steps = 100;
41 let dt = 0.002; for _ in 0..n_steps {
44 md.step(&dev, dt);
45 }
46
47 let snap = &md.snapshots[md.snapshots.len() - 1]; println!(
49 "KE: {}, PE: {}, Atom posits:",
50 snap.energy_kinetic, snap.energy_potential
51 );
52 for posit in &snap.atom_posits {
53 println!("Posit: {posit}");
54 }
56
57 for snap in &md.snapshots {}
61}