From ae31d1c41c56403c9c49156cefbd54ca247d4c74 Mon Sep 17 00:00:00 2001 From: Lester Hedges Date: Thu, 31 Oct 2024 09:53:19 +0000 Subject: [PATCH] Fix replica mixing. --- src/somd2/runner/_repex.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/somd2/runner/_repex.py b/src/somd2/runner/_repex.py index 7b24660..1ab6d2c 100644 --- a/src/somd2/runner/_repex.py +++ b/src/somd2/runner/_repex.py @@ -173,8 +173,10 @@ def mix_states(self): for i, (old_state, new_state) in enumerate(zip(self._old_states, self._states)): # The state has changed. if old_state != new_state: - positions, velocities = self._omm_states[new_state] - self._dynamics[i]._d._omm_mols.setStates(self._omm_states[new_state]) + _logger.debug( + f"Replica {i} changed state from {old_state} to {new_state}" + ) + self._dynamics[i]._d._omm_mols.setState(self._omm_states[new_state]) class RepexRunner(_RunnerBase): @@ -591,6 +593,9 @@ def _mix_replicas(num_replicas, energy_matrix, states): The new states. """ + # Copy the states. + states = states.copy() + for swap in range(num_replicas**3): # Choose two replicas to swap. replica_i = _np.random.randint(num_replicas)