From 6d4bdfb86e17729d17d4a28d28452a41bf3925ae Mon Sep 17 00:00:00 2001 From: hannahbaumann Date: Tue, 17 Dec 2024 15:41:25 +0100 Subject: [PATCH 1/3] Make MD output settings optional --- .../protocols/openmm_md/plain_md_methods.py | 47 +++++++++++-------- openfe/protocols/openmm_utils/omm_settings.py | 8 ++-- 2 files changed, 31 insertions(+), 24 deletions(-) diff --git a/openfe/protocols/openmm_md/plain_md_methods.py b/openfe/protocols/openmm_md/plain_md_methods.py index 25ae1953b..d6fb53bca 100644 --- a/openfe/protocols/openmm_md/plain_md_methods.py +++ b/openfe/protocols/openmm_md/plain_md_methods.py @@ -431,26 +431,33 @@ def _run_MD(simulation: openmm.app.Simulation, mc_steps=1, ) - simulation.reporters.append(XTCReporter( - file=str(shared_basepath / output_settings.production_trajectory_filename), - reportInterval=write_interval, - atomSubset=selection_indices)) - simulation.reporters.append(openmm.app.CheckpointReporter( - file=str(shared_basepath / output_settings.checkpoint_storage_filename), - reportInterval=checkpoint_interval)) - simulation.reporters.append(openmm.app.StateDataReporter( - str(shared_basepath / output_settings.log_output), - checkpoint_interval, - step=True, - time=True, - potentialEnergy=True, - kineticEnergy=True, - totalEnergy=True, - temperature=True, - volume=True, - density=True, - speed=True, - )) + if output_settings.production_trajectory_filename: + simulation.reporters.append(XTCReporter( + file=str( + shared_basepath / + output_settings.production_trajectory_filename), + reportInterval=write_interval, + atomSubset=selection_indices)) + if output_settings.checkpoint_storage_filename: + simulation.reporters.append(openmm.app.CheckpointReporter( + file=str( + shared_basepath / + output_settings.checkpoint_storage_filename), + reportInterval=checkpoint_interval)) + if output_settings.log_output: + simulation.reporters.append(openmm.app.StateDataReporter( + str(shared_basepath / output_settings.log_output), + checkpoint_interval, + step=True, + time=True, + potentialEnergy=True, + kineticEnergy=True, + totalEnergy=True, + temperature=True, + volume=True, + density=True, + speed=True, + )) t0 = time.time() simulation.step(prod_steps) t1 = time.time() diff --git a/openfe/protocols/openmm_utils/omm_settings.py b/openfe/protocols/openmm_utils/omm_settings.py index 63cb5789c..f194769e7 100644 --- a/openfe/protocols/openmm_utils/omm_settings.py +++ b/openfe/protocols/openmm_utils/omm_settings.py @@ -637,16 +637,16 @@ class Config: arbitrary_types_allowed = True # reporter settings - production_trajectory_filename = 'simulation.xtc' + production_trajectory_filename: Optional[str] = 'simulation.xtc' """Path to the storage file for analysis. Default 'simulation.xtc'.""" trajectory_write_interval: FloatQuantity['picosecond'] = 20 * unit.picosecond """ Frequency to write the xtc file. Default 5000 * unit.timestep. """ - preminimized_structure = 'system.pdb' + preminimized_structure: Optional[str] = 'system.pdb' """Path to the pdb file of the full pre-minimized system. Default 'system.pdb'.""" - minimized_structure = 'minimized.pdb' + minimized_structure: Optional[str] = 'minimized.pdb' """Path to the pdb file of the system after minimization. Only the specified atom subset is saved. Default 'minimized.pdb'.""" equil_nvt_structure: Optional[str] = 'equil_nvt.pdb' @@ -655,7 +655,7 @@ class Config: equil_npt_structure: Optional[str] = 'equil_npt.pdb' """Path to the pdb file of the system after NPT equilibration. Only the specified atom subset is saved. Default 'equil_npt.pdb'.""" - log_output = 'simulation.log' + log_output: Optional[str] = 'simulation.log' """ Filename for writing the log of the MD simulation, including timesteps, energies, density, etc. From 10b65b0ffc036679fad4386e9833d7c33da6494f Mon Sep 17 00:00:00 2001 From: hannahbaumann Date: Tue, 17 Dec 2024 15:52:42 +0100 Subject: [PATCH 2/3] More optionals --- .../protocols/openmm_md/plain_md_methods.py | 20 +++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/openfe/protocols/openmm_md/plain_md_methods.py b/openfe/protocols/openmm_md/plain_md_methods.py index d6fb53bca..65b6e7c51 100644 --- a/openfe/protocols/openmm_md/plain_md_methods.py +++ b/openfe/protocols/openmm_md/plain_md_methods.py @@ -341,9 +341,10 @@ def _run_MD(simulation: openmm.app.Simulation, mdtraj_top.subset(selection_indices), ) - traj.save_pdb( - shared_basepath / output_settings.minimized_structure - ) + if output_settings.minimized_structure: + traj.save_pdb( + shared_basepath / output_settings.minimized_structure + ) # equilibrate # NVT equilibration if equil_steps_nvt: @@ -577,7 +578,7 @@ def run(self, *, dry=False, verbose=True, self._assign_partial_charges(charge_settings, smc_components) # b. get a system generator - if output_settings.forcefield_cache is not None: + if output_settings.forcefield_cache: ffcache = shared_basepath / output_settings.forcefield_cache else: ffcache = None @@ -623,10 +624,13 @@ def run(self, *, dry=False, verbose=True, ) # f. Save pdb of entire system - with open(shared_basepath / output_settings.preminimized_structure, "w") as f: - openmm.app.PDBFile.writeFile( - stateA_topology, stateA_positions, file=f, keepIds=True - ) + if output_settings.preminimized_structure: + with open( + shared_basepath / + output_settings.preminimized_structure, "w") as f: + openmm.app.PDBFile.writeFile( + stateA_topology, stateA_positions, file=f, keepIds=True + ) # 10. Get platform restrict_cpu = forcefield_settings.nonbonded_method.lower() == 'nocutoff' From 01d3512788a2d053a56866c1cdfc77cb871f4c45 Mon Sep 17 00:00:00 2001 From: hannahbaumann Date: Tue, 17 Dec 2024 15:53:54 +0100 Subject: [PATCH 3/3] Some fix --- openfe/protocols/openmm_md/plain_md_methods.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/openfe/protocols/openmm_md/plain_md_methods.py b/openfe/protocols/openmm_md/plain_md_methods.py index 65b6e7c51..24c3f1fb0 100644 --- a/openfe/protocols/openmm_md/plain_md_methods.py +++ b/openfe/protocols/openmm_md/plain_md_methods.py @@ -578,7 +578,7 @@ def run(self, *, dry=False, verbose=True, self._assign_partial_charges(charge_settings, smc_components) # b. get a system generator - if output_settings.forcefield_cache: + if output_settings.forcefield_cache is not None: ffcache = shared_basepath / output_settings.forcefield_cache else: ffcache = None