From 5c6f4b3b7c9171278d27e03230b6d82f9ba29d1e Mon Sep 17 00:00:00 2001 From: richardjgowers Date: Tue, 16 Oct 2018 10:15:23 -0500 Subject: [PATCH 01/21] deprecate Timestep argument to Writers (issue #2043) - identified which Writers can currently use a ts (lots don't anyway) - deprecated Timestep as argument to Writer.write - Update package/MDAnalysis/coordinates/base.py - Update package/MDAnalysis/coordinates/XYZ.py - Update package/MDAnalysis/coordinates/GRO.py - add test_writer_api.py - removed obsolete test --- package/MDAnalysis/coordinates/GRO.py | 8 ++- package/MDAnalysis/coordinates/XYZ.py | 5 ++ package/MDAnalysis/coordinates/base.py | 10 +++- .../coordinates/test_netcdf.py | 8 --- .../coordinates/test_writer_api.py | 54 +++++++++++++++++++ 5 files changed, 75 insertions(+), 10 deletions(-) create mode 100644 testsuite/MDAnalysisTests/coordinates/test_writer_api.py diff --git a/package/MDAnalysis/coordinates/GRO.py b/package/MDAnalysis/coordinates/GRO.py index 981ea1f7c00..dd7d1e38439 100644 --- a/package/MDAnalysis/coordinates/GRO.py +++ b/package/MDAnalysis/coordinates/GRO.py @@ -344,7 +344,7 @@ def write(self, obj): Parameters ----------- - obj : AtomGroup or Universe or :class:`Timestep` + obj : AtomGroup or Universe Note ---- @@ -357,6 +357,8 @@ def write(self, obj): *resName* and *atomName* are truncated to a maximum of 5 characters .. versionchanged:: 0.16.0 `frame` kwarg has been removed + .. versionchanged:: 0.19.1 + Deprecated calling with Timestep, use AtomGroup or Universe """ # write() method that complies with the Trajectory API @@ -368,6 +370,10 @@ def write(self, obj): except AttributeError: if isinstance(obj, base.Timestep): + warnings.warn( + 'Passing a Timestep to write is deprecated, and will be removed in 1.0; ' + 'use either an AtomGroup or Universe', + DeprecationWarning) ag_or_ts = obj.copy() else: raise_from(TypeError("No Timestep found in obj argument"), None) diff --git a/package/MDAnalysis/coordinates/XYZ.py b/package/MDAnalysis/coordinates/XYZ.py index abd72e14fce..bba712601af 100644 --- a/package/MDAnalysis/coordinates/XYZ.py +++ b/package/MDAnalysis/coordinates/XYZ.py @@ -89,6 +89,7 @@ import os import errno import numpy as np +import warnings import logging logger = logging.getLogger('MDAnalysis.coordinates.XYZ') @@ -208,6 +209,10 @@ def write(self, obj): atoms = obj.atoms except AttributeError: if isinstance(obj, base.Timestep): + warnings.warn( + 'Passing a Timestep to write is deprecated, and will be removed in 1.0; ' + 'use either an AtomGroup or Universe', + DeprecationWarning) ts = obj else: six.raise_from(TypeError("No Timestep found in obj argument"), None) diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index 90afb37f417..b628fe4e827 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2196,15 +2196,23 @@ def write(self, obj): Parameters ---------- - obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` or a :class:`Timestep` + obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` write coordinate information associate with `obj` Note ---- The size of the `obj` must be the same as the number of atoms provided when setting up the trajectory. + + .. versionchanged:: 0.19.1 + Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe """ + # TODO: Make this either Universe or AtomGroup if isinstance(obj, Timestep): + warnings.warn( + 'Passing a Timestep to write is deprecated, and will be removed 1.0; ' + 'use either an AtomGroup or Universe', + DeprecationWarning) ts = obj else: try: diff --git a/testsuite/MDAnalysisTests/coordinates/test_netcdf.py b/testsuite/MDAnalysisTests/coordinates/test_netcdf.py index de040e9a092..47102776904 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_netcdf.py +++ b/testsuite/MDAnalysisTests/coordinates/test_netcdf.py @@ -902,11 +902,3 @@ def test_wrong_n_atoms(self, outfile): u = make_Universe(trajectory=True) with pytest.raises(IOError): w.write(u.trajectory.ts) - - def test_no_ts(self, outfile): - # no ts supplied at any point - from MDAnalysis.coordinates.TRJ import NCDFWriter - - with NCDFWriter(outfile, 100) as w: - with pytest.raises(IOError): - w.write_next_timestep() diff --git a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py new file mode 100644 index 00000000000..7de62835d08 --- /dev/null +++ b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py @@ -0,0 +1,54 @@ +# -*- Mode: python; tab-width: 4; indent-tabs-mode:nil; coding:utf-8 -*- +# vim: tabstop=4 expandtab shiftwidth=4 softtabstop=4 fileencoding=utf-8 +# +# MDAnalysis --- https://www.mdanalysis.org +# Copyright (c) 2006-2017 The MDAnalysis Development Team and contributors +# (see the file AUTHORS for the full list of names) +# +# Released under the GNU Public Licence, v2 or any higher version +# +# Please cite your use of MDAnalysis in published work: +# +# R. J. Gowers, M. Linke, J. Barnoud, T. J. E. Reddy, M. N. Melo, S. L. Seyler, +# D. L. Dotson, J. Domanski, S. Buchoux, I. M. Kenney, and O. Beckstein. +# MDAnalysis: A Python package for the rapid analysis of molecular dynamics +# simulations. In S. Benthall and S. Rostrup editors, Proceedings of the 15th +# Python in Science Conference, pages 102-109, Austin, TX, 2016. SciPy. +# +# N. Michaud-Agrawal, E. J. Denning, T. B. Woolf, and O. Beckstein. +# MDAnalysis: A Toolkit for the Analysis of Molecular Dynamics Simulations. +# J. Comput. Chem. 32 (2011), 2319--2327, doi:10.1002/jcc.21787 +# +from __future__ import absolute_import + +import itertools +import pytest + +import MDAnalysis as mda + + +# grab all known writers +# sort so test order is predictable for parallel tests +writers = sorted(set(mda._MULTIFRAME_WRITERS.values()) | + set(mda._SINGLEFRAME_WRITERS.values()), + key=lambda x: x.__name__) +known_ts_haters = [ + mda.coordinates.MOL2.MOL2Writer, + mda.coordinates.PDB.PDBWriter, + mda.coordinates.PDB.MultiPDBWriter, + mda.coordinates.PQR.PQRWriter, + mda.coordinates.PDBQT.PDBQTWriter, + mda.coordinates.LAMMPS.DATAWriter, + mda.coordinates.CRD.CRDWriter, +] + +@pytest.mark.parametrize('writer', [w for w in writers + if not w in known_ts_haters]) +def test_ts_deprecated(writer, tmpdir): + u = mda.Universe.empty(10, trajectory=True) + + fn = str(tmpdir.join('out.traj')) + + with writer(fn, n_atoms=10) as w: + with pytest.warns(DeprecationWarning): + w.write(u.trajectory.ts) From 926212e1ecd6d0843f3d596b31ab332e9346a087 Mon Sep 17 00:00:00 2001 From: richardjgowers Date: Wed, 17 Oct 2018 13:56:33 -0500 Subject: [PATCH 02/21] made AtomGroup/Universe default argument to write_next_timestep --- package/MDAnalysis/coordinates/DCD.py | 23 +++++++++++++-- package/MDAnalysis/coordinates/TRJ.py | 39 ++++++++++++++++---------- package/MDAnalysis/coordinates/TRR.py | 26 +++++++++++++++-- package/MDAnalysis/coordinates/XTC.py | 28 ++++++++++++++++-- package/MDAnalysis/coordinates/base.py | 14 ++------- 5 files changed, 97 insertions(+), 33 deletions(-) diff --git a/package/MDAnalysis/coordinates/DCD.py b/package/MDAnalysis/coordinates/DCD.py index e6216a266b9..037c73d25e2 100644 --- a/package/MDAnalysis/coordinates/DCD.py +++ b/package/MDAnalysis/coordinates/DCD.py @@ -390,17 +390,36 @@ def __init__(self, is_periodic=1, istart=istart) - def write_next_timestep(self, ts): + def write_next_timestep(self, ag): """Write timestep object into trajectory. Parameters ---------- - ts: TimeStep + ag : AtomGroup or Universe See Also -------- :meth:`DCDWriter.write` takes a more general input + + .. versionchanged:: 0.19.1 + Deprecated use of Timestep as argument. + Added ability to pass AtomGroup or Universe """ + if isinstance(ag, base.Timestep): + warnings.warn( + 'Passing a Timestep to write is deprecated, ' + 'use either an AtomGroup or Universe', + DeprecationWarning) + ts = ag + else: + try: + ts = ag.ts + except AttributeError: + try: + # Universe? + ts = ag.trajectory.ts + except AttributeError: + raise TypeError("No Timestep found in ag argument") xyz = ts.positions.copy() dimensions = ts.dimensions.copy() diff --git a/package/MDAnalysis/coordinates/TRJ.py b/package/MDAnalysis/coordinates/TRJ.py index e35d606e5ad..6445f644728 100644 --- a/package/MDAnalysis/coordinates/TRJ.py +++ b/package/MDAnalysis/coordinates/TRJ.py @@ -869,7 +869,6 @@ def __init__(self, self.dt = dt self.remarks = remarks or "AMBER NetCDF format (MDAnalysis.coordinates.trj.NCDFWriter)" - self.ts = None # when/why would this be assigned?? self._first_frame = True # signals to open trajectory self.trjfile = None # open on first write with _init_netcdf() self.periodic = None # detect on first write @@ -972,39 +971,49 @@ def _init_netcdf(self, periodic=True): self._first_frame = False self.trjfile = ncfile - def is_periodic(self, ts=None): + def is_periodic(self, ts): """Test if `Timestep` contains a periodic trajectory. Parameters ---------- ts : :class:`Timestep` :class:`Timestep` instance containing coordinates to - be written to trajectory file; default is the current - timestep + be written to trajectory file Returns ------- bool Return ``True`` if `ts` contains a valid simulation box """ - ts = ts if ts is not None else self.ts return np.all(ts.dimensions > 0) - def write_next_timestep(self, ts=None): + def write_next_timestep(self, ag): """write a new timestep to the trj file Parameters ---------- - ts : :class:`Timestep` - :class:`Timestep` instance containing coordinates to - be written to trajectory file; default is the current - timestep + ag : AtomGroup or Universe + + .. versionchanged:: 0.19.1 + Deprecated using Timestep + Added ability to use either AtomGroup or Universe """ - if ts is None: - ts = self.ts - if ts is None: - raise IOError( - "NCDFWriter: no coordinate data to write to trajectory file") + if isinstance(ag, base.Timestep): + warnings.warn( + 'Passing a Timestep to write is deprecated, ' + 'use either an AtomGroup or Universe', + DeprecationWarning) + ts = ag + else: + try: + # Atomgroup? + ts = ag.ts + except AttributeError: + try: + # Universe? + ts = ag.trajectory.ts + except AttributeError: + raise TypeError("No Timestep found in ag argument") if ts.n_atoms != self.n_atoms: raise IOError( diff --git a/package/MDAnalysis/coordinates/TRR.py b/package/MDAnalysis/coordinates/TRR.py index e92871f77b0..f403d29cb1d 100644 --- a/package/MDAnalysis/coordinates/TRR.py +++ b/package/MDAnalysis/coordinates/TRR.py @@ -33,6 +33,9 @@ """ from __future__ import absolute_import +import warnings + +from . import base from .XDR import XDRBaseReader, XDRBaseWriter from ..lib.formats.libmdaxdr import TRRFile from ..lib.mdamath import triclinic_vectors, triclinic_box @@ -58,18 +61,37 @@ class TRRWriter(XDRBaseWriter): 'force': 'kJ/(mol*nm)'} _file = TRRFile - def write_next_timestep(self, ts): + def write_next_timestep(self, ag): """Write timestep object into trajectory. Parameters ---------- - ts : :class:`~base.Timestep` + ag : AtomGroup or Universe See Also -------- .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input + + .. versionchanged:: 0.19.1 + Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe """ + if isinstance(ag, base.Timestep): + warnings.warn( + 'Passing a Timestep to write is deprecated, ' + 'use either an AtomGroup or Universe', + DeprecationWarning) + ts = ag + else: + try: + ts = ag.ts + except AttributeError: + try: + # special case: can supply a Universe, too... + ts = ag.trajectory.ts + except AttributeError: + raise TypeError("No Timestep found in ag argument") + xyz = None if ts.has_positions: xyz = ts.positions.copy() diff --git a/package/MDAnalysis/coordinates/XTC.py b/package/MDAnalysis/coordinates/XTC.py index a581748ed01..b42ec99c4c7 100644 --- a/package/MDAnalysis/coordinates/XTC.py +++ b/package/MDAnalysis/coordinates/XTC.py @@ -33,6 +33,9 @@ """ from __future__ import absolute_import +import warnings + +from . import base from .XDR import XDRBaseReader, XDRBaseWriter from ..lib.formats.libmdaxdr import XTCFile from ..lib.mdamath import triclinic_vectors, triclinic_box @@ -70,18 +73,39 @@ def __init__(self, filename, n_atoms, convert_units=True, **kwargs) self.precision = precision - def write_next_timestep(self, ts): + def write_next_timestep(self, ag): """Write timestep object into trajectory. Parameters ---------- - ts : :class:`~base.Timestep` + ag : AtomGroup or Universe See Also -------- .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input + + .. versionchanged:: 0.19.1 + Deprecated using Timestep + Added ability to use either AtomGroup or Universe """ + if isinstance(ag, base.Timestep): + warnings.warn( + 'Passing a Timestep to write is deprecated, ' + 'use either an AtomGroup or Universe', + DeprecationWarning) + ts = ag + else: + try: + # Atomgroup? + ts = ag.ts + except AttributeError: + try: + # Universe? + ts = ag.trajectory.ts + except AttributeError: + raise TypeError("No Timestep found in ag argument") + xyz = ts.positions.copy() time = ts.time step = ts.frame diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index b628fe4e827..c06ac67e279 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2207,23 +2207,13 @@ def write(self, obj): .. versionchanged:: 0.19.1 Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe """ - # TODO: Make this either Universe or AtomGroup if isinstance(obj, Timestep): warnings.warn( 'Passing a Timestep to write is deprecated, and will be removed 1.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) - ts = obj - else: - try: - ts = obj.ts - except AttributeError: - try: - # special case: can supply a Universe, too... - ts = obj.trajectory.ts - except AttributeError: - six.raise_from(TypeError("No Timestep found in obj argument"), None) - return self.write_next_timestep(ts) + + return self.write_next_timestep(obj) def __del__(self): self.close() From 2e7e1640679a4f49b7ae16a871dfec11f098e714 Mon Sep 17 00:00:00 2001 From: richard Date: Fri, 5 Jun 2020 09:35:38 +0100 Subject: [PATCH 03/21] pushed chemfiles into line removed chemfiles.Writer.write (to use base API method) and put logic into write_next_timestep --- package/MDAnalysis/coordinates/chemfiles.py | 15 +++------------ .../coordinates/test_writer_api.py | 5 ++++- 2 files changed, 7 insertions(+), 13 deletions(-) diff --git a/package/MDAnalysis/coordinates/chemfiles.py b/package/MDAnalysis/coordinates/chemfiles.py index c7fbe842c2c..fbd20f20882 100644 --- a/package/MDAnalysis/coordinates/chemfiles.py +++ b/package/MDAnalysis/coordinates/chemfiles.py @@ -273,8 +273,8 @@ def close(self): self._file.close() self._closed = True - def write(self, obj): - """Write object `obj` at current trajectory frame to file. + def write_next_timestep(self, obj): + """Write timestep object into trajectory. Topology for the output is taken from the `obj` or default to the value of the `topology` keyword supplied to the :class:`ChemfilesWriter` @@ -286,7 +286,7 @@ def write(self, obj): Parameters ---------- - obj : Universe or AtomGroup + obj : AtomGroup or Universe The :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` to write. """ @@ -311,16 +311,7 @@ def write(self, obj): frame = self._timestep_to_chemfiles(ts) frame.topology = self._topology_to_chemfiles(obj, len(frame.atoms)) - self._file.write(frame) - - def write_next_timestep(self, ts): - """Write timestep object into trajectory. - Parameters - ---------- - ts: TimeStep - """ - frame = self._timestep_to_chemfiles(ts) self._file.write(frame) def _timestep_to_chemfiles(self, ts): diff --git a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py index 7de62835d08..7eec61a150f 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py +++ b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py @@ -47,7 +47,10 @@ def test_ts_deprecated(writer, tmpdir): u = mda.Universe.empty(10, trajectory=True) - fn = str(tmpdir.join('out.traj')) + if writer == mda.coordinates.chemfiles.ChemfilesWriter: + fn = str(tmpdir.join('out.xtc')) + else: + fn = str(tmpdir.join('out.traj')) with writer(fn, n_atoms=10) as w: with pytest.warns(DeprecationWarning): From 937c2155930d74f2b906988ac46b8d78dee36b6d Mon Sep 17 00:00:00 2001 From: richard Date: Fri, 5 Jun 2020 09:53:28 +0100 Subject: [PATCH 04/21] make NAMDBINWriter use write_next_timestep method --- package/MDAnalysis/coordinates/NAMDBIN.py | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/package/MDAnalysis/coordinates/NAMDBIN.py b/package/MDAnalysis/coordinates/NAMDBIN.py index ef4a5bb68ea..58a51c731db 100755 --- a/package/MDAnalysis/coordinates/NAMDBIN.py +++ b/package/MDAnalysis/coordinates/NAMDBIN.py @@ -113,15 +113,14 @@ def __init__(self, filename, n_atoms=None, **kwargs): """ self.filename = util.filename(filename) - def write(self, obj): + def write_next_timestep(self, obj): """Write obj at current trajectory frame to file. Parameters ---------- - obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` or a :class:`Timestep` + obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` write coordinate information associate with `obj` """ - if isinstance(obj, base.Timestep): n_atoms = obj.n_atoms coor = obj.positions.reshape(n_atoms*3) From 5590b9ada62350b9f7e60d82033c3f3ead0895ef Mon Sep 17 00:00:00 2001 From: richard Date: Fri, 5 Jun 2020 10:00:54 +0100 Subject: [PATCH 05/21] updated deprecation warnings for Writer.write(timestep) now started in 1.0 and targets v2.0 --- package/MDAnalysis/coordinates/DCD.py | 1 + package/MDAnalysis/coordinates/GRO.py | 5 +++-- package/MDAnalysis/coordinates/TRJ.py | 3 ++- package/MDAnalysis/coordinates/TRR.py | 3 ++- package/MDAnalysis/coordinates/XTC.py | 3 ++- package/MDAnalysis/coordinates/XYZ.py | 3 ++- package/MDAnalysis/coordinates/base.py | 5 +++-- 7 files changed, 15 insertions(+), 8 deletions(-) diff --git a/package/MDAnalysis/coordinates/DCD.py b/package/MDAnalysis/coordinates/DCD.py index 037c73d25e2..ef951052dd1 100644 --- a/package/MDAnalysis/coordinates/DCD.py +++ b/package/MDAnalysis/coordinates/DCD.py @@ -408,6 +408,7 @@ def write_next_timestep(self, ag): if isinstance(ag, base.Timestep): warnings.warn( 'Passing a Timestep to write is deprecated, ' + 'and will be removed in 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) ts = ag diff --git a/package/MDAnalysis/coordinates/GRO.py b/package/MDAnalysis/coordinates/GRO.py index dd7d1e38439..0714b6d462b 100644 --- a/package/MDAnalysis/coordinates/GRO.py +++ b/package/MDAnalysis/coordinates/GRO.py @@ -357,7 +357,7 @@ def write(self, obj): *resName* and *atomName* are truncated to a maximum of 5 characters .. versionchanged:: 0.16.0 `frame` kwarg has been removed - .. versionchanged:: 0.19.1 + .. versionchanged:: 1.0.0 Deprecated calling with Timestep, use AtomGroup or Universe """ # write() method that complies with the Trajectory API @@ -371,7 +371,8 @@ def write(self, obj): except AttributeError: if isinstance(obj, base.Timestep): warnings.warn( - 'Passing a Timestep to write is deprecated, and will be removed in 1.0; ' + 'Passing a Timestep to write is deprecated, ' + 'and will be removed in 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) ag_or_ts = obj.copy() diff --git a/package/MDAnalysis/coordinates/TRJ.py b/package/MDAnalysis/coordinates/TRJ.py index 6445f644728..6558f014811 100644 --- a/package/MDAnalysis/coordinates/TRJ.py +++ b/package/MDAnalysis/coordinates/TRJ.py @@ -994,13 +994,14 @@ def write_next_timestep(self, ag): ---------- ag : AtomGroup or Universe - .. versionchanged:: 0.19.1 + .. versionchanged:: 1.0.0 Deprecated using Timestep Added ability to use either AtomGroup or Universe """ if isinstance(ag, base.Timestep): warnings.warn( 'Passing a Timestep to write is deprecated, ' + 'and will be removed in 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) ts = ag diff --git a/package/MDAnalysis/coordinates/TRR.py b/package/MDAnalysis/coordinates/TRR.py index f403d29cb1d..6a1188b673d 100644 --- a/package/MDAnalysis/coordinates/TRR.py +++ b/package/MDAnalysis/coordinates/TRR.py @@ -73,12 +73,13 @@ def write_next_timestep(self, ag): .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input - .. versionchanged:: 0.19.1 + .. versionchanged:: 1.0.0 Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe """ if isinstance(ag, base.Timestep): warnings.warn( 'Passing a Timestep to write is deprecated, ' + 'and will be removed in 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) ts = ag diff --git a/package/MDAnalysis/coordinates/XTC.py b/package/MDAnalysis/coordinates/XTC.py index b42ec99c4c7..1e2e083d459 100644 --- a/package/MDAnalysis/coordinates/XTC.py +++ b/package/MDAnalysis/coordinates/XTC.py @@ -85,13 +85,14 @@ def write_next_timestep(self, ag): .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input - .. versionchanged:: 0.19.1 + .. versionchanged:: 1.0.0 Deprecated using Timestep Added ability to use either AtomGroup or Universe """ if isinstance(ag, base.Timestep): warnings.warn( 'Passing a Timestep to write is deprecated, ' + 'and will be removed in 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) ts = ag diff --git a/package/MDAnalysis/coordinates/XYZ.py b/package/MDAnalysis/coordinates/XYZ.py index bba712601af..75ede42f965 100644 --- a/package/MDAnalysis/coordinates/XYZ.py +++ b/package/MDAnalysis/coordinates/XYZ.py @@ -210,7 +210,8 @@ def write(self, obj): except AttributeError: if isinstance(obj, base.Timestep): warnings.warn( - 'Passing a Timestep to write is deprecated, and will be removed in 1.0; ' + 'Passing a Timestep to write is deprecated, ' + 'and will be removed in 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) ts = obj diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index c06ac67e279..80efd4a87b3 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2204,12 +2204,13 @@ def write(self, obj): The size of the `obj` must be the same as the number of atoms provided when setting up the trajectory. - .. versionchanged:: 0.19.1 + .. versionchanged:: 1.0.0 Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe """ if isinstance(obj, Timestep): warnings.warn( - 'Passing a Timestep to write is deprecated, and will be removed 1.0; ' + 'Passing a Timestep to write is deprecated, ' + 'and will be removed 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) From 7173865d155395ab370f61fd43ea1ffdef033213 Mon Sep 17 00:00:00 2001 From: richard Date: Sat, 6 Jun 2020 12:22:46 +0100 Subject: [PATCH 06/21] fix up chemfiles test --- testsuite/MDAnalysisTests/coordinates/test_writer_api.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py index 7eec61a150f..186d34ae564 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py +++ b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py @@ -48,6 +48,8 @@ def test_ts_deprecated(writer, tmpdir): u = mda.Universe.empty(10, trajectory=True) if writer == mda.coordinates.chemfiles.ChemfilesWriter: + # chemfiles Writer exists but doesn't work without chemfiles + pytest.importorskip('chemfiles') fn = str(tmpdir.join('out.xtc')) else: fn = str(tmpdir.join('out.traj')) From 0377dfc2874852ed040b28b812b99a9743b38cc6 Mon Sep 17 00:00:00 2001 From: richard Date: Sat, 6 Jun 2020 14:19:55 +0100 Subject: [PATCH 07/21] fixup FHAIMS to raise deprecation warning on timestep input --- package/MDAnalysis/coordinates/FHIAIMS.py | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/package/MDAnalysis/coordinates/FHIAIMS.py b/package/MDAnalysis/coordinates/FHIAIMS.py index 11fb1ed03ce..22eb6ca4a01 100644 --- a/package/MDAnalysis/coordinates/FHIAIMS.py +++ b/package/MDAnalysis/coordinates/FHIAIMS.py @@ -267,22 +267,19 @@ def __init__(self, filename, convert_units=True, n_atoms=None, **kwargs): self.filename = util.filename(filename, ext='.in', keep=True) self.n_atoms = n_atoms - def write(self, obj): + def write_next_timestep(self, obj): """Write selection at current trajectory frame to file. Parameters ----------- - obj : AtomGroup or Universe or :class:`Timestep` - + obj : AtomGroup or Universe """ # write() method that complies with the Trajectory API try: - # make sure to use atoms (Issue 46) ag_or_ts = obj.atoms # can write from selection == Universe (Issue 49) - except AttributeError: if isinstance(obj, base.Timestep): ag_or_ts = obj.copy() From cf4e3a8dd6b20751ab1c1502b44980f7da58c9b0 Mon Sep 17 00:00:00 2001 From: richard Date: Sat, 6 Jun 2020 14:20:08 +0100 Subject: [PATCH 08/21] fixed chemfiles test with old version of chemfiles CI seems to get 0.7.4 for some builds --- testsuite/MDAnalysisTests/coordinates/test_writer_api.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py index 186d34ae564..37086485328 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py +++ b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py @@ -49,7 +49,8 @@ def test_ts_deprecated(writer, tmpdir): if writer == mda.coordinates.chemfiles.ChemfilesWriter: # chemfiles Writer exists but doesn't work without chemfiles - pytest.importorskip('chemfiles') + if not mda.coordinates.chemfiles.check_chemfiles_version(): + pytest.skip() fn = str(tmpdir.join('out.xtc')) else: fn = str(tmpdir.join('out.traj')) From d19fbd8ca00990d3424100651bcea4bb60ab5422 Mon Sep 17 00:00:00 2001 From: richard Date: Sun, 7 Jun 2020 16:58:58 +0100 Subject: [PATCH 09/21] changed versionchanged to deprecated added TODO 2.0 for removing timestep logic --- package/MDAnalysis/coordinates/DCD.py | 2 +- package/MDAnalysis/coordinates/GRO.py | 2 +- package/MDAnalysis/coordinates/NAMDBIN.py | 4 ++++ package/MDAnalysis/coordinates/TRJ.py | 2 +- package/MDAnalysis/coordinates/TRR.py | 2 +- package/MDAnalysis/coordinates/XTC.py | 2 +- package/MDAnalysis/coordinates/base.py | 2 +- package/MDAnalysis/coordinates/chemfiles.py | 1 + 8 files changed, 11 insertions(+), 6 deletions(-) diff --git a/package/MDAnalysis/coordinates/DCD.py b/package/MDAnalysis/coordinates/DCD.py index ef951052dd1..c14444cef6b 100644 --- a/package/MDAnalysis/coordinates/DCD.py +++ b/package/MDAnalysis/coordinates/DCD.py @@ -401,7 +401,7 @@ def write_next_timestep(self, ag): -------- :meth:`DCDWriter.write` takes a more general input - .. versionchanged:: 0.19.1 + .. deprecated:: 1.0.0 Deprecated use of Timestep as argument. Added ability to pass AtomGroup or Universe """ diff --git a/package/MDAnalysis/coordinates/GRO.py b/package/MDAnalysis/coordinates/GRO.py index 0714b6d462b..4d231f2e34f 100644 --- a/package/MDAnalysis/coordinates/GRO.py +++ b/package/MDAnalysis/coordinates/GRO.py @@ -357,7 +357,7 @@ def write(self, obj): *resName* and *atomName* are truncated to a maximum of 5 characters .. versionchanged:: 0.16.0 `frame` kwarg has been removed - .. versionchanged:: 1.0.0 + .. deprecated:: 1.0.0 Deprecated calling with Timestep, use AtomGroup or Universe """ # write() method that complies with the Trajectory API diff --git a/package/MDAnalysis/coordinates/NAMDBIN.py b/package/MDAnalysis/coordinates/NAMDBIN.py index 58a51c731db..5cef1fbc834 100755 --- a/package/MDAnalysis/coordinates/NAMDBIN.py +++ b/package/MDAnalysis/coordinates/NAMDBIN.py @@ -120,7 +120,11 @@ def write_next_timestep(self, obj): ---------- obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` write coordinate information associate with `obj` + + .. deprecated:: 1.0.0 + Passing a Timestep is deprecated for removal in version 2.0 """ + # TODO 2.0: Remove Timestep logic if isinstance(obj, base.Timestep): n_atoms = obj.n_atoms coor = obj.positions.reshape(n_atoms*3) diff --git a/package/MDAnalysis/coordinates/TRJ.py b/package/MDAnalysis/coordinates/TRJ.py index 6558f014811..46a030d058e 100644 --- a/package/MDAnalysis/coordinates/TRJ.py +++ b/package/MDAnalysis/coordinates/TRJ.py @@ -994,7 +994,7 @@ def write_next_timestep(self, ag): ---------- ag : AtomGroup or Universe - .. versionchanged:: 1.0.0 + .. deprecated:: 1.0.0 Deprecated using Timestep Added ability to use either AtomGroup or Universe """ diff --git a/package/MDAnalysis/coordinates/TRR.py b/package/MDAnalysis/coordinates/TRR.py index 6a1188b673d..a761ccd00e1 100644 --- a/package/MDAnalysis/coordinates/TRR.py +++ b/package/MDAnalysis/coordinates/TRR.py @@ -73,7 +73,7 @@ def write_next_timestep(self, ag): .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input - .. versionchanged:: 1.0.0 + .. deprecated:: 1.0.0 Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe """ if isinstance(ag, base.Timestep): diff --git a/package/MDAnalysis/coordinates/XTC.py b/package/MDAnalysis/coordinates/XTC.py index 1e2e083d459..0005a4e3ebc 100644 --- a/package/MDAnalysis/coordinates/XTC.py +++ b/package/MDAnalysis/coordinates/XTC.py @@ -85,7 +85,7 @@ def write_next_timestep(self, ag): .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input - .. versionchanged:: 1.0.0 + .. deprecated:: 1.0.0 Deprecated using Timestep Added ability to use either AtomGroup or Universe """ diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index 80efd4a87b3..cb4a6be0a76 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2204,7 +2204,7 @@ def write(self, obj): The size of the `obj` must be the same as the number of atoms provided when setting up the trajectory. - .. versionchanged:: 1.0.0 + .. deprecated:: 1.0.0 Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe """ if isinstance(obj, Timestep): diff --git a/package/MDAnalysis/coordinates/chemfiles.py b/package/MDAnalysis/coordinates/chemfiles.py index fbd20f20882..6e28b460de4 100644 --- a/package/MDAnalysis/coordinates/chemfiles.py +++ b/package/MDAnalysis/coordinates/chemfiles.py @@ -290,6 +290,7 @@ def write_next_timestep(self, obj): The :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` to write. """ + # TODO 2.0: Remove timestep logic if hasattr(obj, "atoms"): if hasattr(obj, 'universe'): # For AtomGroup and children (Residue, ResidueGroup, Segment) From 2b034a406f1b560787018da803372358d4bd7819 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 7 Jun 2020 18:13:27 +0100 Subject: [PATCH 10/21] deprecation docstring changes --- package/MDAnalysis/coordinates/DCD.py | 6 ++++-- package/MDAnalysis/coordinates/FHIAIMS.py | 2 +- package/MDAnalysis/coordinates/GRO.py | 3 ++- package/MDAnalysis/coordinates/NAMDBIN.py | 1 + package/MDAnalysis/coordinates/TRJ.py | 6 ++++-- package/MDAnalysis/coordinates/TRR.py | 4 +++- package/MDAnalysis/coordinates/XTC.py | 6 ++++-- package/MDAnalysis/coordinates/XYZ.py | 5 +++++ package/MDAnalysis/coordinates/base.py | 4 +++- 9 files changed, 27 insertions(+), 10 deletions(-) diff --git a/package/MDAnalysis/coordinates/DCD.py b/package/MDAnalysis/coordinates/DCD.py index c14444cef6b..2377c9ee3da 100644 --- a/package/MDAnalysis/coordinates/DCD.py +++ b/package/MDAnalysis/coordinates/DCD.py @@ -401,9 +401,11 @@ def write_next_timestep(self, ag): -------- :meth:`DCDWriter.write` takes a more general input + .. deprecated:: 1.0.0 - Deprecated use of Timestep as argument. - Added ability to pass AtomGroup or Universe + Deprecated use of Timestep as argument. To be removed in version 2.0 + .. versionchanged:: 1.0.0 + Added ability to pass AtomGroup or Universe. """ if isinstance(ag, base.Timestep): warnings.warn( diff --git a/package/MDAnalysis/coordinates/FHIAIMS.py b/package/MDAnalysis/coordinates/FHIAIMS.py index 22eb6ca4a01..11a291cff2c 100644 --- a/package/MDAnalysis/coordinates/FHIAIMS.py +++ b/package/MDAnalysis/coordinates/FHIAIMS.py @@ -275,7 +275,7 @@ def write_next_timestep(self, obj): obj : AtomGroup or Universe """ # write() method that complies with the Trajectory API - + # TODO 2.0: Remove timestep logic try: # make sure to use atoms (Issue 46) ag_or_ts = obj.atoms diff --git a/package/MDAnalysis/coordinates/GRO.py b/package/MDAnalysis/coordinates/GRO.py index 4d231f2e34f..3e091816860 100644 --- a/package/MDAnalysis/coordinates/GRO.py +++ b/package/MDAnalysis/coordinates/GRO.py @@ -358,7 +358,8 @@ def write(self, obj): .. versionchanged:: 0.16.0 `frame` kwarg has been removed .. deprecated:: 1.0.0 - Deprecated calling with Timestep, use AtomGroup or Universe + Deprecated calling with Timestep, use AtomGroup or Universe. + To be removed in version 2.0. """ # write() method that complies with the Trajectory API diff --git a/package/MDAnalysis/coordinates/NAMDBIN.py b/package/MDAnalysis/coordinates/NAMDBIN.py index 5cef1fbc834..c2d9d8e5c7e 100755 --- a/package/MDAnalysis/coordinates/NAMDBIN.py +++ b/package/MDAnalysis/coordinates/NAMDBIN.py @@ -121,6 +121,7 @@ def write_next_timestep(self, obj): obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` write coordinate information associate with `obj` + .. deprecated:: 1.0.0 Passing a Timestep is deprecated for removal in version 2.0 """ diff --git a/package/MDAnalysis/coordinates/TRJ.py b/package/MDAnalysis/coordinates/TRJ.py index 46a030d058e..bcea60a5544 100644 --- a/package/MDAnalysis/coordinates/TRJ.py +++ b/package/MDAnalysis/coordinates/TRJ.py @@ -994,9 +994,11 @@ def write_next_timestep(self, ag): ---------- ag : AtomGroup or Universe + .. deprecated:: 1.0.0 - Deprecated using Timestep - Added ability to use either AtomGroup or Universe + Deprecated using Timestep. To be removed in version 2.0. + .. versionchanged:: 1.0.0 + Added ability to use either AtomGroup or Universe. """ if isinstance(ag, base.Timestep): warnings.warn( diff --git a/package/MDAnalysis/coordinates/TRR.py b/package/MDAnalysis/coordinates/TRR.py index a761ccd00e1..c24ae1a7aff 100644 --- a/package/MDAnalysis/coordinates/TRR.py +++ b/package/MDAnalysis/coordinates/TRR.py @@ -73,8 +73,10 @@ def write_next_timestep(self, ag): .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input + .. deprecated:: 1.0.0 - Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe + Deprecated the use of Timestep as arguments to write. Use either + an AtomGroup or Universe. To be removed in version 2.0. """ if isinstance(ag, base.Timestep): warnings.warn( diff --git a/package/MDAnalysis/coordinates/XTC.py b/package/MDAnalysis/coordinates/XTC.py index 0005a4e3ebc..0f7a6e56977 100644 --- a/package/MDAnalysis/coordinates/XTC.py +++ b/package/MDAnalysis/coordinates/XTC.py @@ -85,9 +85,11 @@ def write_next_timestep(self, ag): .write(AtomGroup/Universe/TimeStep) The normal write() method takes a more general input + .. deprecated:: 1.0.0 - Deprecated using Timestep - Added ability to use either AtomGroup or Universe + Deprecated using Timestep. To be removed in version 2.0. + .. versionchanged:: 1.0.0 + Added ability to use either AtomGroup or Universe. """ if isinstance(ag, base.Timestep): warnings.warn( diff --git a/package/MDAnalysis/coordinates/XYZ.py b/package/MDAnalysis/coordinates/XYZ.py index 75ede42f965..6b4f263348b 100644 --- a/package/MDAnalysis/coordinates/XYZ.py +++ b/package/MDAnalysis/coordinates/XYZ.py @@ -200,6 +200,11 @@ def write(self, obj): obj : Universe or AtomGroup The :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` to write. + + + .. deprecated:: 1.0.0 + Deprecated the use of Timestep as arguments to write. Use either an + AtomGroup or Universe. To be removed in version 2.0. """ # prepare the Timestep and extract atom names if possible # (The way it is written it should be possible to write diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index cb4a6be0a76..844b5948c05 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2204,8 +2204,10 @@ def write(self, obj): The size of the `obj` must be the same as the number of atoms provided when setting up the trajectory. + .. deprecated:: 1.0.0 - Deprecated the use of Timestep as arguments to write. Use either a AtomGroup or Universe + Deprecated the use of Timestep as arguments to write. Use either + an AtomGroup or Universe. To be removed in version 2.0. """ if isinstance(obj, Timestep): warnings.warn( From fac4510aacb8f2068ebe0725d20061920508ca63 Mon Sep 17 00:00:00 2001 From: richard Date: Sun, 7 Jun 2020 20:05:51 +0100 Subject: [PATCH 11/21] fixed up TRZ to accept non Timestep arguments added tests for each Writer to make them accept AtomGroup or Universe --- package/MDAnalysis/coordinates/TRZ.py | 16 +++++-- .../coordinates/test_writer_api.py | 46 ++++++++++++++++++- 2 files changed, 57 insertions(+), 5 deletions(-) diff --git a/package/MDAnalysis/coordinates/TRZ.py b/package/MDAnalysis/coordinates/TRZ.py index 8f2d1d5fff0..58efcbbacd1 100644 --- a/package/MDAnalysis/coordinates/TRZ.py +++ b/package/MDAnalysis/coordinates/TRZ.py @@ -530,10 +530,20 @@ def _writeheader(self, title): out['nrec'] = 10 out.tofile(self.trzfile) - def write_next_timestep(self, ts): + def write_next_timestep(self, obj): # Check size of ts is same as initial - if not ts.n_atoms == self.n_atoms: - raise ValueError("Number of atoms in ts different to initialisation") + # TODO: Remove Timestep logic in 2.0 + if isinstance(obj, base.Timestep): + ts = obj + if not ts.n_atoms == self.n_atoms: + raise ValueError("Number of atoms in ts different to initialisation") + else: + try: # atomgroup? + ts = obj.ts + except AttributeError: # universe? + ts = obj.trajectory.ts + if not obj.atoms.n_atoms == self.n_atoms: + raise ValueError("Number of atoms in ts different to initialisation") # Gather data, faking it when unavailable data = {} diff --git a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py index 37086485328..ad578732733 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_writer_api.py +++ b/testsuite/MDAnalysisTests/coordinates/test_writer_api.py @@ -42,6 +42,7 @@ mda.coordinates.CRD.CRDWriter, ] + @pytest.mark.parametrize('writer', [w for w in writers if not w in known_ts_haters]) def test_ts_deprecated(writer, tmpdir): @@ -50,11 +51,52 @@ def test_ts_deprecated(writer, tmpdir): if writer == mda.coordinates.chemfiles.ChemfilesWriter: # chemfiles Writer exists but doesn't work without chemfiles if not mda.coordinates.chemfiles.check_chemfiles_version(): - pytest.skip() + pytest.skip("Chemfiles not available") fn = str(tmpdir.join('out.xtc')) else: fn = str(tmpdir.join('out.traj')) - with writer(fn, n_atoms=10) as w: + with writer(fn, n_atoms=u.atoms.n_atoms) as w: with pytest.warns(DeprecationWarning): w.write(u.trajectory.ts) + + +@pytest.mark.parametrize('writer', writers) +def test_write_with_atomgroup(writer, tmpdir): + u = mda.Universe.empty(10, trajectory=True) + + if writer == mda.coordinates.chemfiles.ChemfilesWriter: + # chemfiles Writer exists but doesn't work without chemfiles + if not mda.coordinates.chemfiles.check_chemfiles_version(): + pytest.skip("Chemfiles not available") + fn = str(tmpdir.join('out.xtc')) + elif writer == mda.coordinates.MOL2.MOL2Writer: + pytest.skip("MOL2 only writes MOL2 back out") + elif writer == mda.coordinates.LAMMPS.DATAWriter: + pytest.skip("DATAWriter requires integer atom types") + else: + fn = str(tmpdir.join('out.traj')) + + with writer(fn, n_atoms=u.atoms.n_atoms) as w: + w.write(u.atoms) + + +@pytest.mark.parametrize('writer', writers) +def test_write_with_universe(writer, tmpdir): + u = mda.Universe.empty(10, trajectory=True) + + if writer == mda.coordinates.chemfiles.ChemfilesWriter: + # chemfiles Writer exists but doesn't work without chemfiles + if not mda.coordinates.chemfiles.check_chemfiles_version(): + pytest.skip("Chemfiles not available") + fn = str(tmpdir.join('out.xtc')) + elif writer == mda.coordinates.MOL2.MOL2Writer: + pytest.skip("MOL2 only writes MOL2 back out") + elif writer == mda.coordinates.LAMMPS.DATAWriter: + pytest.skip("DATAWriter requires integer atom types") + else: + fn = str(tmpdir.join('out.traj')) + + with writer(fn, n_atoms=10) as w: + w.write(u) + From cbc8a0ac987ddf1b3e6f07658a5c5c2084001504 Mon Sep 17 00:00:00 2001 From: richard Date: Sun, 7 Jun 2020 21:33:19 +0100 Subject: [PATCH 12/21] deprecated write_next_timestep use write() instead renamed many functions to _write_next_frame for the internal workings of how to write a frame --- package/CHANGELOG | 3 ++- package/MDAnalysis/coordinates/DCD.py | 7 +----- package/MDAnalysis/coordinates/FHIAIMS.py | 2 +- package/MDAnalysis/coordinates/MOL2.py | 11 +-------- package/MDAnalysis/coordinates/NAMDBIN.py | 2 +- package/MDAnalysis/coordinates/PDB.py | 8 +++---- package/MDAnalysis/coordinates/TRJ.py | 9 ++------ package/MDAnalysis/coordinates/TRR.py | 7 +----- package/MDAnalysis/coordinates/TRZ.py | 2 +- package/MDAnalysis/coordinates/XDR.py | 2 +- package/MDAnalysis/coordinates/XTC.py | 7 +----- package/MDAnalysis/coordinates/XYZ.py | 4 ++-- package/MDAnalysis/coordinates/__init__.py | 10 +++----- package/MDAnalysis/coordinates/base.py | 23 ++++++++++++++++--- package/MDAnalysis/coordinates/chemfiles.py | 2 +- package/MDAnalysis/coordinates/null.py | 2 +- .../coordinates/test_chemfiles.py | 6 ++--- 17 files changed, 46 insertions(+), 61 deletions(-) diff --git a/package/CHANGELOG b/package/CHANGELOG index 94a9e86e2d4..cf8ebdebd65 100644 --- a/package/CHANGELOG +++ b/package/CHANGELOG @@ -210,7 +210,8 @@ Deprecations * analysis.density.density_from_Universe() (remove in 2.0) * analysis.density.notwithin_coordinates_factory() (remove in 2.0) * analysis.density.density_from_PDB and BfactorDensityCreator (remove in 2.0) - + * Writer.write_next_timestep is deprecated, use write() instead (remove in 2.0) + * Writer.write(Timestep) is deprecated, use either a Universe or AtomGroup 09/05/19 IAlibay, richardjgowers diff --git a/package/MDAnalysis/coordinates/DCD.py b/package/MDAnalysis/coordinates/DCD.py index 2377c9ee3da..529d0899d9e 100644 --- a/package/MDAnalysis/coordinates/DCD.py +++ b/package/MDAnalysis/coordinates/DCD.py @@ -390,7 +390,7 @@ def __init__(self, is_periodic=1, istart=istart) - def write_next_timestep(self, ag): + def _write_next_frame(self, ag): """Write timestep object into trajectory. Parameters @@ -408,11 +408,6 @@ def write_next_timestep(self, ag): Added ability to pass AtomGroup or Universe. """ if isinstance(ag, base.Timestep): - warnings.warn( - 'Passing a Timestep to write is deprecated, ' - 'and will be removed in 2.0; ' - 'use either an AtomGroup or Universe', - DeprecationWarning) ts = ag else: try: diff --git a/package/MDAnalysis/coordinates/FHIAIMS.py b/package/MDAnalysis/coordinates/FHIAIMS.py index 11a291cff2c..f475b2c7620 100644 --- a/package/MDAnalysis/coordinates/FHIAIMS.py +++ b/package/MDAnalysis/coordinates/FHIAIMS.py @@ -267,7 +267,7 @@ def __init__(self, filename, convert_units=True, n_atoms=None, **kwargs): self.filename = util.filename(filename, ext='.in', keep=True) self.n_atoms = n_atoms - def write_next_timestep(self, obj): + def _write_next_frame(self, obj): """Write selection at current trajectory frame to file. Parameters diff --git a/package/MDAnalysis/coordinates/MOL2.py b/package/MDAnalysis/coordinates/MOL2.py index c21a64db3b9..a83efa4c702 100644 --- a/package/MDAnalysis/coordinates/MOL2.py +++ b/package/MDAnalysis/coordinates/MOL2.py @@ -373,16 +373,7 @@ def encode_block(self, obj): molecule[1] = molecule_1_store return return_val - def write(self, obj): - """Write a new frame to the MOL2 file. - - Parameters - ---------- - obj : AtomGroup or Universe - """ - self.write_next_timestep(obj) - - def write_next_timestep(self, obj): + def _write_next_frame(self, obj): """Write a new frame to the MOL2 file. Parameters diff --git a/package/MDAnalysis/coordinates/NAMDBIN.py b/package/MDAnalysis/coordinates/NAMDBIN.py index c2d9d8e5c7e..bc5d799075b 100755 --- a/package/MDAnalysis/coordinates/NAMDBIN.py +++ b/package/MDAnalysis/coordinates/NAMDBIN.py @@ -113,7 +113,7 @@ def __init__(self, filename, n_atoms=None, **kwargs): """ self.filename = util.filename(filename) - def write_next_timestep(self, obj): + def _write_next_frame(self, obj): """Write obj at current trajectory frame to file. Parameters diff --git a/package/MDAnalysis/coordinates/PDB.py b/package/MDAnalysis/coordinates/PDB.py index 23f8914c79b..b8994154f03 100644 --- a/package/MDAnalysis/coordinates/PDB.py +++ b/package/MDAnalysis/coordinates/PDB.py @@ -825,7 +825,7 @@ def _update_frame(self, obj): * :attr:`PDBWriter.timestep` (the underlying trajectory :class:`~MDAnalysis.coordinates.base.Timestep`) - Before calling :meth:`write_next_timestep` this method **must** be + Before calling :meth:`_write_next_frame` this method **must** be called at least once to enable extracting topology information from the current frame. """ @@ -864,7 +864,7 @@ def write(self, obj): # Issue 105: with write() ONLY write a single frame; use # write_all_timesteps() to dump everything in one go, or do the # traditional loop over frames - self.write_next_timestep(self.ts, multiframe=self._multiframe) + self._write_next_frame(self.ts, multiframe=self._multiframe) self._write_pdb_bonds() # END record is written when file is being close()d @@ -907,7 +907,7 @@ def write_all_timesteps(self, obj): for framenumber in range(start, len(traj), step): traj[framenumber] - self.write_next_timestep(self.ts, multiframe=True) + self._write_next_frame(self.ts, multiframe=True) self._write_pdb_bonds() self.close() @@ -915,7 +915,7 @@ def write_all_timesteps(self, obj): # Set the trajectory to the starting position traj[start] - def write_next_timestep(self, ts=None, **kwargs): + def _write_next_frame(self, ts=None, **kwargs): '''write a new timestep to the PDB file :Keywords: diff --git a/package/MDAnalysis/coordinates/TRJ.py b/package/MDAnalysis/coordinates/TRJ.py index bcea60a5544..87ec9558e9c 100644 --- a/package/MDAnalysis/coordinates/TRJ.py +++ b/package/MDAnalysis/coordinates/TRJ.py @@ -987,7 +987,7 @@ def is_periodic(self, ts): """ return np.all(ts.dimensions > 0) - def write_next_timestep(self, ag): + def _write_next_frame(self, ag): """write a new timestep to the trj file Parameters @@ -1001,11 +1001,6 @@ def write_next_timestep(self, ag): Added ability to use either AtomGroup or Universe. """ if isinstance(ag, base.Timestep): - warnings.warn( - 'Passing a Timestep to write is deprecated, ' - 'and will be removed in 2.0; ' - 'use either an AtomGroup or Universe', - DeprecationWarning) ts = ag else: try: @@ -1032,7 +1027,7 @@ def _write_next_timestep(self, ts): """Write coordinates and unitcell information to NCDF file. Do not call this method directly; instead use - :meth:`write_next_timestep` because some essential setup is done + :meth:`write` because some essential setup is done there before writing the first frame. Based on Joshua Adelman's `netcdf4storage.py`_ in `Issue 109`_. diff --git a/package/MDAnalysis/coordinates/TRR.py b/package/MDAnalysis/coordinates/TRR.py index c24ae1a7aff..023a093341a 100644 --- a/package/MDAnalysis/coordinates/TRR.py +++ b/package/MDAnalysis/coordinates/TRR.py @@ -61,7 +61,7 @@ class TRRWriter(XDRBaseWriter): 'force': 'kJ/(mol*nm)'} _file = TRRFile - def write_next_timestep(self, ag): + def _write_next_frame(self, ag): """Write timestep object into trajectory. Parameters @@ -79,11 +79,6 @@ def write_next_timestep(self, ag): an AtomGroup or Universe. To be removed in version 2.0. """ if isinstance(ag, base.Timestep): - warnings.warn( - 'Passing a Timestep to write is deprecated, ' - 'and will be removed in 2.0; ' - 'use either an AtomGroup or Universe', - DeprecationWarning) ts = ag else: try: diff --git a/package/MDAnalysis/coordinates/TRZ.py b/package/MDAnalysis/coordinates/TRZ.py index 58efcbbacd1..bc62dadfe8d 100644 --- a/package/MDAnalysis/coordinates/TRZ.py +++ b/package/MDAnalysis/coordinates/TRZ.py @@ -530,7 +530,7 @@ def _writeheader(self, title): out['nrec'] = 10 out.tofile(self.trzfile) - def write_next_timestep(self, obj): + def _write_next_frame(self, obj): # Check size of ts is same as initial # TODO: Remove Timestep logic in 2.0 if isinstance(obj, base.Timestep): diff --git a/package/MDAnalysis/coordinates/XDR.py b/package/MDAnalysis/coordinates/XDR.py index bb7bd010433..8095323ade9 100644 --- a/package/MDAnalysis/coordinates/XDR.py +++ b/package/MDAnalysis/coordinates/XDR.py @@ -92,7 +92,7 @@ class XDRBaseReader(base.ReaderBase): """Base class for libmdaxdr file formats xtc and trr This class handles integration of XDR based formats into MDAnalysis. The - XTC and TRR classes only implement `write_next_timestep` and + XTC and TRR classes only implement `_write_next_frame` and `_frame_to_ts`. .. _offsets-label: diff --git a/package/MDAnalysis/coordinates/XTC.py b/package/MDAnalysis/coordinates/XTC.py index 0f7a6e56977..258e4695215 100644 --- a/package/MDAnalysis/coordinates/XTC.py +++ b/package/MDAnalysis/coordinates/XTC.py @@ -73,7 +73,7 @@ def __init__(self, filename, n_atoms, convert_units=True, **kwargs) self.precision = precision - def write_next_timestep(self, ag): + def _write_next_frame(self, ag): """Write timestep object into trajectory. Parameters @@ -92,11 +92,6 @@ def write_next_timestep(self, ag): Added ability to use either AtomGroup or Universe. """ if isinstance(ag, base.Timestep): - warnings.warn( - 'Passing a Timestep to write is deprecated, ' - 'and will be removed in 2.0; ' - 'use either an AtomGroup or Universe', - DeprecationWarning) ts = ag else: try: diff --git a/package/MDAnalysis/coordinates/XYZ.py b/package/MDAnalysis/coordinates/XYZ.py index 6b4f263348b..48e38b433ed 100644 --- a/package/MDAnalysis/coordinates/XYZ.py +++ b/package/MDAnalysis/coordinates/XYZ.py @@ -237,9 +237,9 @@ def write(self, obj): # update atom names self.atomnames = self._get_atoms_elements_or_names(atoms) - self.write_next_timestep(ts) + self._write_next_frame(ts) - def write_next_timestep(self, ts=None): + def _write_next_frame(self, ts=None): """Write coordinate information in *ts* to the trajectory""" if ts is None: if not hasattr(self, 'ts'): diff --git a/package/MDAnalysis/coordinates/__init__.py b/package/MDAnalysis/coordinates/__init__.py index d8548f24648..361489a9ab0 100644 --- a/package/MDAnalysis/coordinates/__init__.py +++ b/package/MDAnalysis/coordinates/__init__.py @@ -622,14 +622,12 @@ class can choose an appropriate reader automatically. Signature:: - W = TrajectoryWriter(filename,n_atoms,**kwargs) - W.write_next_timestep(Timestep) + with TrajectoryWriter(filename, n_atoms, **kwargs) as w: + w.write(Universe) # write a whole universe or:: - W.write(AtomGroup) # write a selection - W.write(Universe) # write a whole universe - W.write(Timestep) # same as write_next_timestep() + w.write(AtomGroup) # write a selection of Atoms from Universe Methods @@ -639,8 +637,6 @@ class can choose an appropriate reader automatically. opens *filename* and writes header if required by format ``write(obj)`` write Timestep data in *obj* - ``write_next_timestep([timestep])`` - write data in *timestep* to trajectory file ``convert_dimensions_to_unitcell(timestep)`` take the dimensions from the timestep and convert to the native unitcell representation of the format diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index 844b5948c05..3a6854ec43b 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2216,7 +2216,26 @@ def write(self, obj): 'use either an AtomGroup or Universe', DeprecationWarning) - return self.write_next_timestep(obj) + return self._write_next_frame(obj) + + def write_next_timestep(self, obj) + """Write current timestep, using the supplied `obj`. + + Parameters + ---------- + obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` + write coordinate information associate with `obj` + + + .. deprecated:: 1.0.0 + Deprecated, use write() instead + """ + warnings.warn( + 'Writer.write_next_timestep is deprecated, ' + 'and will be removed 2.0; ' + 'use Writer.write()', + DeprecationWarning) + return self.write(obj) def __del__(self): self.close() @@ -2250,8 +2269,6 @@ def has_valid_coordinates(self, criteria, x): x = np.ravel(x) return np.all(criteria["min"] < x) and np.all(x <= criteria["max"]) - # def write_next_timestep(self, ts=None) - class SingleFrameReaderBase(ProtoReader): """Base class for Readers that only have one frame. diff --git a/package/MDAnalysis/coordinates/chemfiles.py b/package/MDAnalysis/coordinates/chemfiles.py index 6e28b460de4..8e88d42e665 100644 --- a/package/MDAnalysis/coordinates/chemfiles.py +++ b/package/MDAnalysis/coordinates/chemfiles.py @@ -273,7 +273,7 @@ def close(self): self._file.close() self._closed = True - def write_next_timestep(self, obj): + def _write_next_frame(self, obj): """Write timestep object into trajectory. Topology for the output is taken from the `obj` or default to the value diff --git a/package/MDAnalysis/coordinates/null.py b/package/MDAnalysis/coordinates/null.py index c3a4e5118f8..3ba8cda6087 100644 --- a/package/MDAnalysis/coordinates/null.py +++ b/package/MDAnalysis/coordinates/null.py @@ -56,5 +56,5 @@ class NullWriter(base.WriterBase): def __init__(self, filename, **kwargs): pass - def write_next_timestep(self, ts=None): + def _write_next_frame(self, obj): pass diff --git a/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py b/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py index d21506f3fe5..21c0a0271ce 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py +++ b/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py @@ -162,12 +162,12 @@ def test_write_topology(self, tmpdir): # Manually setting the topology when creating the ChemfilesWriter # (1) from an object with ChemfilesWriter(outfile, topology=u) as writer: - writer.write_next_timestep(u.trajectory.ts) + writer.write(u) self.check_topology(datafiles.CONECT, outfile) # (2) from a file with ChemfilesWriter(outfile, topology=datafiles.CONECT) as writer: - writer.write_next_timestep(u.trajectory.ts) + writer.write(u) # FIXME: this does not work, since chemfiles also insert the bonds # which are implicit in PDB format (between standard residues), while # MDAnalysis only read the explicit CONNECT records. @@ -201,7 +201,7 @@ def test_write_velocities(self, tmpdir): outfile = "chemfiles-write-velocities.lmp" with tmpdir.as_cwd(): with ChemfilesWriter(outfile, topology=u, chemfiles_format='LAMMPS Data') as writer: - writer.write_next_timestep(ts) + writer.write(u) with open(outfile) as file: content = file.read() From 8f1be73f7e01b013d8d38d30107d5393f44f1c46 Mon Sep 17 00:00:00 2001 From: richard Date: Sun, 7 Jun 2020 21:37:06 +0100 Subject: [PATCH 13/21] removed testsuit usage of write_next_timestep --- testsuite/MDAnalysisTests/coordinates/test_dcd.py | 2 +- testsuite/MDAnalysisTests/coordinates/test_netcdf.py | 6 +++--- testsuite/MDAnalysisTests/coordinates/test_trz.py | 2 +- testsuite/MDAnalysisTests/coordinates/test_xdr.py | 10 +++++----- 4 files changed, 10 insertions(+), 10 deletions(-) diff --git a/testsuite/MDAnalysisTests/coordinates/test_dcd.py b/testsuite/MDAnalysisTests/coordinates/test_dcd.py index dccfca070b9..e21e6e6e420 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_dcd.py +++ b/testsuite/MDAnalysisTests/coordinates/test_dcd.py @@ -280,7 +280,7 @@ def test_other_writer(universe_dcd, tmpdir, ext, decimal): outfile = str(tmpdir.join("test.{}".format(ext))) with t.OtherWriter(outfile) as W: for ts in universe_dcd.trajectory: - W.write_next_timestep(ts) + W.write(universe_dcd) uw = mda.Universe(PSF, outfile) # check that the coordinates are identical for each time step diff --git a/testsuite/MDAnalysisTests/coordinates/test_netcdf.py b/testsuite/MDAnalysisTests/coordinates/test_netcdf.py index 47102776904..81409b82d00 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_netcdf.py +++ b/testsuite/MDAnalysisTests/coordinates/test_netcdf.py @@ -664,7 +664,7 @@ def test_OtherWriter(self, universe, outfile): def _copy_traj(self, writer, universe): for ts in universe.trajectory: - writer.write_next_timestep(ts) + writer.write(universe) def _check_new_traj(self, universe, outfile): uw = mda.Universe(self.topology, outfile) @@ -724,7 +724,7 @@ def test_TRR2NCDF(self, outfile): with mda.Writer(outfile, trr.trajectory.n_atoms, velocities=True, format="ncdf") as W: for ts in trr.trajectory: - W.write_next_timestep(ts) + W.write(trr) uw = mda.Universe(GRO, outfile) @@ -877,7 +877,7 @@ def test_writer_units(self, outfile, var, expected): with mda.Writer(outfile, trr.trajectory.n_atoms, velocities=True, forces=True, format='ncdf') as W: for ts in trr.trajectory: - W.write_next_timestep(ts) + W.write(trr) with netcdf.netcdf_file(outfile, mode='r') as ncdf: unit = ncdf.variables[var].units.decode('utf-8') diff --git a/testsuite/MDAnalysisTests/coordinates/test_trz.py b/testsuite/MDAnalysisTests/coordinates/test_trz.py index 5e814a0402e..7f1c542241b 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_trz.py +++ b/testsuite/MDAnalysisTests/coordinates/test_trz.py @@ -153,7 +153,7 @@ def test_write_trajectory(self, universe, outfile): def _copy_traj(self, writer, universe, outfile): for ts in universe.trajectory: - writer.write_next_timestep(ts) + writer.write(universe) writer.close() uw = mda.Universe(TRZ_psf, outfile) diff --git a/testsuite/MDAnalysisTests/coordinates/test_xdr.py b/testsuite/MDAnalysisTests/coordinates/test_xdr.py index c34f307f9ab..47d65cee913 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_xdr.py +++ b/testsuite/MDAnalysisTests/coordinates/test_xdr.py @@ -340,7 +340,7 @@ def test_write_trajectory(self, universe, Writer, outfile): """Test writing Gromacs trajectories (Issue 38)""" with Writer(outfile, universe.atoms.n_atoms, dt=universe.trajectory.dt) as W: for ts in universe.trajectory: - W.write_next_timestep(ts) + W.write(universe) uw = mda.Universe(GRO, outfile) @@ -366,7 +366,7 @@ def test_timestep_not_modified_by_writer(self, universe, Writer, outfile): with Writer(outfile, trj.n_atoms, dt=trj.dt) as W: # last timestep (so that time != 0) (say it again, just in case...) trj[-1] - W.write_next_timestep(ts) + W.write(universe) assert_equal( ts._pos, @@ -388,7 +388,7 @@ class TestTRRWriter(_GromacsWriter): def test_velocities(self, universe, Writer, outfile): with Writer(outfile, universe.atoms.n_atoms, dt=universe.trajectory.dt) as W: for ts in universe.trajectory: - W.write_next_timestep(ts) + W.write(universe) uw = mda.Universe(GRO, outfile) @@ -414,7 +414,7 @@ def test_gaps(self, universe, Writer, outfile): ts.has_positions = False if ts.frame % 2 == 0: ts.has_velocities = False - W.write_next_timestep(ts) + W.write(universe) uw = mda.Universe(GRO, outfile) # check that the velocities are identical for each time step, except @@ -509,7 +509,7 @@ def test_write_trajectory(self, universe, tmpdir): outfile = str(tmpdir.join('xdr-writer-issue117' + self.ext)) with mda.Writer(outfile, n_atoms=universe.atoms.n_atoms) as W: for ts in universe.trajectory: - W.write_next_timestep(ts) + W.write(universe) uw = mda.Universe(PRMncdf, outfile) From 2d1f27b52c798ca00c76b3baf5264b56734088d4 Mon Sep 17 00:00:00 2001 From: richard Date: Sun, 7 Jun 2020 21:41:19 +0100 Subject: [PATCH 14/21] i'm such a genius --- package/MDAnalysis/coordinates/base.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index 3a6854ec43b..09734e84c89 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2218,7 +2218,7 @@ def write(self, obj): return self._write_next_frame(obj) - def write_next_timestep(self, obj) + def write_next_timestep(self, obj): """Write current timestep, using the supplied `obj`. Parameters From b39aa241d219adedb356a8fb10f43db820207e62 Mon Sep 17 00:00:00 2001 From: richard Date: Mon, 8 Jun 2020 09:24:32 +0100 Subject: [PATCH 15/21] fixed up test_chemfiles --- .../MDAnalysisTests/coordinates/test_chemfiles.py | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) diff --git a/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py b/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py index 21c0a0271ce..21dd97759c9 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py +++ b/testsuite/MDAnalysisTests/coordinates/test_chemfiles.py @@ -175,9 +175,11 @@ def test_write_topology(self, tmpdir): # self.check_topology(datafiles.CONECT, outfile) def test_write_velocities(self, tmpdir): - ts = mda.coordinates.base.Timestep(4, velocities=True) - ts.dimensions = [20, 30, 41, 90, 90, 90] + u = mda.Universe.empty(4, trajectory=True) + u.add_TopologyAttr('type', values=['H', 'H', 'H', 'H']) + ts = u.trajectory.ts + ts.dimensions = [20, 30, 41, 90, 90, 90] ts.positions = [ [1, 1, 1], [2, 2, 2], @@ -191,13 +193,6 @@ def test_write_velocities(self, tmpdir): [40, 40, 40], ] - u = mda.Universe.empty(4) - u.add_TopologyAttr('type') - u.atoms[0].type = "H" - u.atoms[1].type = "H" - u.atoms[2].type = "H" - u.atoms[3].type = "H" - outfile = "chemfiles-write-velocities.lmp" with tmpdir.as_cwd(): with ChemfilesWriter(outfile, topology=u, chemfiles_format='LAMMPS Data') as writer: From 288b2ec43c30aff89b466e6dcfc688c9cb65cb24 Mon Sep 17 00:00:00 2001 From: richard Date: Mon, 8 Jun 2020 09:35:47 +0100 Subject: [PATCH 16/21] added test for DATAWriter with Universe input --- .../MDAnalysisTests/coordinates/test_lammps.py | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/testsuite/MDAnalysisTests/coordinates/test_lammps.py b/testsuite/MDAnalysisTests/coordinates/test_lammps.py index 1e775b94980..2cc4ccf3e25 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_lammps.py +++ b/testsuite/MDAnalysisTests/coordinates/test_lammps.py @@ -154,6 +154,20 @@ def test_Writer_numerical_attrs(self, attr, LAMMPSDATAWriter): decimal=6) +def test_datawriter_universe(tmpdir): + fn = str(tmpdir.join('out.data')) + + u = mda.Universe(LAMMPSdata_mini) + + with mda.Writer(fn, n_atoms=len(u.atoms)) as w: + w.write(u) + + u2 = mda.Universe(fn) + + assert_almost_equal(u.atoms.positions, u2.atoms.positions) + assert_almost_equal(u.dimensions, u2.dimension) + + class TestLAMMPSDATAWriter_data_partial(TestLAMMPSDATAWriter): N_kept = 5 From 3a9614144152e27ccda6224c8e6309e839b48f2c Mon Sep 17 00:00:00 2001 From: Richard Gowers Date: Mon, 8 Jun 2020 11:50:29 +0100 Subject: [PATCH 17/21] Update test_lammps.py --- testsuite/MDAnalysisTests/coordinates/test_lammps.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/testsuite/MDAnalysisTests/coordinates/test_lammps.py b/testsuite/MDAnalysisTests/coordinates/test_lammps.py index 2cc4ccf3e25..e3c88539ab3 100644 --- a/testsuite/MDAnalysisTests/coordinates/test_lammps.py +++ b/testsuite/MDAnalysisTests/coordinates/test_lammps.py @@ -165,7 +165,7 @@ def test_datawriter_universe(tmpdir): u2 = mda.Universe(fn) assert_almost_equal(u.atoms.positions, u2.atoms.positions) - assert_almost_equal(u.dimensions, u2.dimension) + assert_almost_equal(u.dimensions, u2.dimensions) class TestLAMMPSDATAWriter_data_partial(TestLAMMPSDATAWriter): From 0d35fc60abbc970781ff9424fa6a51ea1501f3ac Mon Sep 17 00:00:00 2001 From: IAlibay Date: Mon, 8 Jun 2020 13:23:59 +0100 Subject: [PATCH 18/21] Fixes warning typo and docs (including dev docs) --- package/MDAnalysis/coordinates/DCD.py | 1 + package/MDAnalysis/coordinates/MOL2.py | 4 ++++ package/MDAnalysis/coordinates/NAMDBIN.py | 2 ++ package/MDAnalysis/coordinates/PDB.py | 4 ++++ package/MDAnalysis/coordinates/TRJ.py | 1 + package/MDAnalysis/coordinates/TRR.py | 2 ++ package/MDAnalysis/coordinates/TRZ.py | 10 ++++++++++ package/MDAnalysis/coordinates/XYZ.py | 3 ++- package/MDAnalysis/coordinates/base.py | 5 +++++ 9 files changed, 31 insertions(+), 1 deletion(-) diff --git a/package/MDAnalysis/coordinates/DCD.py b/package/MDAnalysis/coordinates/DCD.py index 529d0899d9e..20d636910d5 100644 --- a/package/MDAnalysis/coordinates/DCD.py +++ b/package/MDAnalysis/coordinates/DCD.py @@ -406,6 +406,7 @@ def _write_next_frame(self, ag): Deprecated use of Timestep as argument. To be removed in version 2.0 .. versionchanged:: 1.0.0 Added ability to pass AtomGroup or Universe. + Renamed from `write_next_timestep` to `_write_next_frame`. """ if isinstance(ag, base.Timestep): ts = ag diff --git a/package/MDAnalysis/coordinates/MOL2.py b/package/MDAnalysis/coordinates/MOL2.py index a83efa4c702..4bd3a1e1b9f 100644 --- a/package/MDAnalysis/coordinates/MOL2.py +++ b/package/MDAnalysis/coordinates/MOL2.py @@ -379,6 +379,10 @@ def _write_next_frame(self, obj): Parameters ---------- obj : AtomGroup or Universe + + + .. versionchanged:: 1.0.0 + Renamed from `write_next_timestep` to `_write_next_frame`. """ block = self.encode_block(obj) self.file.writelines(block) diff --git a/package/MDAnalysis/coordinates/NAMDBIN.py b/package/MDAnalysis/coordinates/NAMDBIN.py index bc5d799075b..ac23c8adb5a 100755 --- a/package/MDAnalysis/coordinates/NAMDBIN.py +++ b/package/MDAnalysis/coordinates/NAMDBIN.py @@ -122,6 +122,8 @@ def _write_next_frame(self, obj): write coordinate information associate with `obj` + .. versionchanged:: 1.0.0 + Renamed from `write` to `_write_next_frame`. .. deprecated:: 1.0.0 Passing a Timestep is deprecated for removal in version 2.0 """ diff --git a/package/MDAnalysis/coordinates/PDB.py b/package/MDAnalysis/coordinates/PDB.py index b8994154f03..649bde13808 100644 --- a/package/MDAnalysis/coordinates/PDB.py +++ b/package/MDAnalysis/coordinates/PDB.py @@ -931,6 +931,10 @@ def _write_next_frame(self, ts=None, **kwargs): argument, :meth:`PDBWriter._update_frame` *must* be called with the :class:`~MDAnalysis.core.groups.AtomGroup.Universe` as its argument so that topology information can be gathered. + + + .. versionchanged:: 1.0.0 + Renamed from `write_next_timestep` to `_write_next_frame`. ''' if ts is None: try: diff --git a/package/MDAnalysis/coordinates/TRJ.py b/package/MDAnalysis/coordinates/TRJ.py index 87ec9558e9c..c6a3c4976b8 100644 --- a/package/MDAnalysis/coordinates/TRJ.py +++ b/package/MDAnalysis/coordinates/TRJ.py @@ -999,6 +999,7 @@ def _write_next_frame(self, ag): Deprecated using Timestep. To be removed in version 2.0. .. versionchanged:: 1.0.0 Added ability to use either AtomGroup or Universe. + Renamed from `write_next_timestep` to `_write_next_frame`. """ if isinstance(ag, base.Timestep): ts = ag diff --git a/package/MDAnalysis/coordinates/TRR.py b/package/MDAnalysis/coordinates/TRR.py index 023a093341a..6bd3ff37948 100644 --- a/package/MDAnalysis/coordinates/TRR.py +++ b/package/MDAnalysis/coordinates/TRR.py @@ -74,6 +74,8 @@ def _write_next_frame(self, ag): The normal write() method takes a more general input + .. versionchanged:: 1.0.0 + Renamed from `write_next_timestep` to `_write_next_frame`. .. deprecated:: 1.0.0 Deprecated the use of Timestep as arguments to write. Use either an AtomGroup or Universe. To be removed in version 2.0. diff --git a/package/MDAnalysis/coordinates/TRZ.py b/package/MDAnalysis/coordinates/TRZ.py index bc62dadfe8d..113db1333e6 100644 --- a/package/MDAnalysis/coordinates/TRZ.py +++ b/package/MDAnalysis/coordinates/TRZ.py @@ -531,6 +531,16 @@ def _writeheader(self, title): out.tofile(self.trzfile) def _write_next_frame(self, obj): + """Write timestep object into trajectory. + + Parameters + ---------- + ag : AtomGroup or Universe + + + .. versionchanged:: 1.0.0 + Renamed from `write_next_timestep` to `_write_next_frame`. + """ # Check size of ts is same as initial # TODO: Remove Timestep logic in 2.0 if isinstance(obj, base.Timestep): diff --git a/package/MDAnalysis/coordinates/XYZ.py b/package/MDAnalysis/coordinates/XYZ.py index 63ca9e33e5e..93fbe768204 100644 --- a/package/MDAnalysis/coordinates/XYZ.py +++ b/package/MDAnalysis/coordinates/XYZ.py @@ -248,6 +248,7 @@ def _write_next_frame(self, ts=None): .. versionchanged:: 1.0.0 Print out :code:`remark` if present, otherwise use generic one (Issue #2692). + Renamed from `write_next_timestep` to `_write_next_frame`. """ if ts is None: if not hasattr(self, 'ts'): @@ -268,7 +269,7 @@ def _write_next_frame(self, ts=None): len(self.atomnames) != ts.n_atoms): logger.info('Trying to write a TimeStep with unkown atoms. ' 'Expected {}, got {}. Try using "write" if you are ' - 'using "write_next_timestep" directly'.format( + 'using "_write_next_frame" directly'.format( len(self.atomnames), ts.n_atoms)) self.atomnames = np.array([self.atomnames[0]] * ts.n_atoms) diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index af2fed3ea39..83ba8761333 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2183,6 +2183,11 @@ class WriterBase(six.with_metaclass(_Writermeta, IOBase)): See Trajectory API definition in :mod:`MDAnalysis.coordinates.__init__` for the required attributes and methods. + + + .. deprecated:: 1.0.0 + :func:`write_next_timestep` has been deprecated, please use + :func:`write` instead. """ def convert_dimensions_to_unitcell(self, ts, inplace=True): From cd0c20991014118c9a691c64ab4545c1d95690a9 Mon Sep 17 00:00:00 2001 From: Richard Gowers Date: Mon, 8 Jun 2020 15:19:52 +0100 Subject: [PATCH 19/21] Apply suggestions from code review Co-authored-by: Lily Wang <31115101+lilyminium@users.noreply.github.com> --- package/MDAnalysis/coordinates/DCD.py | 2 +- package/MDAnalysis/coordinates/NAMDBIN.py | 6 ++++-- package/MDAnalysis/coordinates/TRJ.py | 4 ++-- package/MDAnalysis/coordinates/TRR.py | 4 +--- package/MDAnalysis/coordinates/TRZ.py | 2 +- 5 files changed, 9 insertions(+), 9 deletions(-) diff --git a/package/MDAnalysis/coordinates/DCD.py b/package/MDAnalysis/coordinates/DCD.py index 20d636910d5..d16fd404350 100644 --- a/package/MDAnalysis/coordinates/DCD.py +++ b/package/MDAnalysis/coordinates/DCD.py @@ -391,7 +391,7 @@ def __init__(self, istart=istart) def _write_next_frame(self, ag): - """Write timestep object into trajectory. + """Write information associated with ``obj`` at current frame into trajectory Parameters ---------- diff --git a/package/MDAnalysis/coordinates/NAMDBIN.py b/package/MDAnalysis/coordinates/NAMDBIN.py index ac23c8adb5a..7b70c6e91c2 100755 --- a/package/MDAnalysis/coordinates/NAMDBIN.py +++ b/package/MDAnalysis/coordinates/NAMDBIN.py @@ -114,12 +114,14 @@ def __init__(self, filename, n_atoms=None, **kwargs): self.filename = util.filename(filename) def _write_next_frame(self, obj): - """Write obj at current trajectory frame to file. + """Write information associated with ``obj`` at current frame into trajectory + Parameters ---------- obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` - write coordinate information associate with `obj` + write coordinate information associated with `obj` + .. versionchanged:: 1.0.0 diff --git a/package/MDAnalysis/coordinates/TRJ.py b/package/MDAnalysis/coordinates/TRJ.py index c6a3c4976b8..d87a4ca1824 100644 --- a/package/MDAnalysis/coordinates/TRJ.py +++ b/package/MDAnalysis/coordinates/TRJ.py @@ -972,7 +972,7 @@ def _init_netcdf(self, periodic=True): self.trjfile = ncfile def is_periodic(self, ts): - """Test if `Timestep` contains a periodic trajectory. + """Test if timestep ``ts`` contains a periodic box. Parameters ---------- @@ -988,7 +988,7 @@ def is_periodic(self, ts): return np.all(ts.dimensions > 0) def _write_next_frame(self, ag): - """write a new timestep to the trj file + """Write information associated with ``ag`` at current frame into trajectory Parameters ---------- diff --git a/package/MDAnalysis/coordinates/TRR.py b/package/MDAnalysis/coordinates/TRR.py index 6bd3ff37948..bd77ffea1f0 100644 --- a/package/MDAnalysis/coordinates/TRR.py +++ b/package/MDAnalysis/coordinates/TRR.py @@ -33,8 +33,6 @@ """ from __future__ import absolute_import -import warnings - from . import base from .XDR import XDRBaseReader, XDRBaseWriter from ..lib.formats.libmdaxdr import TRRFile @@ -62,7 +60,7 @@ class TRRWriter(XDRBaseWriter): _file = TRRFile def _write_next_frame(self, ag): - """Write timestep object into trajectory. + """Write information associated with ``ag`` at current frame into trajectory Parameters ---------- diff --git a/package/MDAnalysis/coordinates/TRZ.py b/package/MDAnalysis/coordinates/TRZ.py index 113db1333e6..6598f077b1a 100644 --- a/package/MDAnalysis/coordinates/TRZ.py +++ b/package/MDAnalysis/coordinates/TRZ.py @@ -531,7 +531,7 @@ def _writeheader(self, title): out.tofile(self.trzfile) def _write_next_frame(self, obj): - """Write timestep object into trajectory. + """Write information associated with ``obj`` at current frame into trajectory Parameters ---------- From 205c402c68091ea144f644923a0c8584659f0bec Mon Sep 17 00:00:00 2001 From: Richard Gowers Date: Mon, 8 Jun 2020 15:21:03 +0100 Subject: [PATCH 20/21] Apply suggestions from code review Co-authored-by: Lily Wang <31115101+lilyminium@users.noreply.github.com> --- package/MDAnalysis/coordinates/XTC.py | 6 ++---- package/MDAnalysis/coordinates/XYZ.py | 4 ++-- package/MDAnalysis/coordinates/base.py | 8 ++++---- 3 files changed, 8 insertions(+), 10 deletions(-) diff --git a/package/MDAnalysis/coordinates/XTC.py b/package/MDAnalysis/coordinates/XTC.py index 258e4695215..125db00eacd 100644 --- a/package/MDAnalysis/coordinates/XTC.py +++ b/package/MDAnalysis/coordinates/XTC.py @@ -33,8 +33,6 @@ """ from __future__ import absolute_import -import warnings - from . import base from .XDR import XDRBaseReader, XDRBaseWriter from ..lib.formats.libmdaxdr import XTCFile @@ -74,7 +72,7 @@ def __init__(self, filename, n_atoms, convert_units=True, self.precision = precision def _write_next_frame(self, ag): - """Write timestep object into trajectory. + """Write information associated with ``ag`` at current frame into trajectory Parameters ---------- @@ -82,7 +80,7 @@ def _write_next_frame(self, ag): See Also -------- - .write(AtomGroup/Universe/TimeStep) + .write(AtomGroup/Universe) The normal write() method takes a more general input diff --git a/package/MDAnalysis/coordinates/XYZ.py b/package/MDAnalysis/coordinates/XYZ.py index 93fbe768204..88678e6e64b 100644 --- a/package/MDAnalysis/coordinates/XYZ.py +++ b/package/MDAnalysis/coordinates/XYZ.py @@ -267,8 +267,8 @@ def _write_next_frame(self, ts=None): else: if (not isinstance(self.atomnames, itertools.cycle) and len(self.atomnames) != ts.n_atoms): - logger.info('Trying to write a TimeStep with unkown atoms. ' - 'Expected {}, got {}. Try using "write" if you are ' + logger.info('Trying to write a TimeStep with unknown atoms. ' + 'Expected {} atoms, got {}. Try using "write" if you are ' 'using "_write_next_frame" directly'.format( len(self.atomnames), ts.n_atoms)) self.atomnames = np.array([self.atomnames[0]] * ts.n_atoms) diff --git a/package/MDAnalysis/coordinates/base.py b/package/MDAnalysis/coordinates/base.py index 83ba8761333..640d9af78f9 100644 --- a/package/MDAnalysis/coordinates/base.py +++ b/package/MDAnalysis/coordinates/base.py @@ -2225,19 +2225,19 @@ def write(self, obj): if isinstance(obj, Timestep): warnings.warn( 'Passing a Timestep to write is deprecated, ' - 'and will be removed 2.0; ' + 'and will be removed in 2.0; ' 'use either an AtomGroup or Universe', DeprecationWarning) return self._write_next_frame(obj) def write_next_timestep(self, obj): - """Write current timestep, using the supplied `obj`. + """Write current timestep, using the supplied ``obj``. Parameters ---------- obj : :class:`~MDAnalysis.core.groups.AtomGroup` or :class:`~MDAnalysis.core.universe.Universe` - write coordinate information associate with `obj` + write coordinate information associated with ``obj`` .. deprecated:: 1.0.0 @@ -2245,7 +2245,7 @@ def write_next_timestep(self, obj): """ warnings.warn( 'Writer.write_next_timestep is deprecated, ' - 'and will be removed 2.0; ' + 'and will be removed in 2.0; ' 'use Writer.write()', DeprecationWarning) return self.write(obj) From e3ffe4ccdf6586dc60803137ed3ea4cca25c5458 Mon Sep 17 00:00:00 2001 From: Richard Gowers Date: Mon, 8 Jun 2020 15:21:24 +0100 Subject: [PATCH 21/21] Update package/MDAnalysis/coordinates/chemfiles.py Co-authored-by: Lily Wang <31115101+lilyminium@users.noreply.github.com> --- package/MDAnalysis/coordinates/chemfiles.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package/MDAnalysis/coordinates/chemfiles.py b/package/MDAnalysis/coordinates/chemfiles.py index 8e88d42e665..673c62e2826 100644 --- a/package/MDAnalysis/coordinates/chemfiles.py +++ b/package/MDAnalysis/coordinates/chemfiles.py @@ -274,7 +274,7 @@ def close(self): self._closed = True def _write_next_frame(self, obj): - """Write timestep object into trajectory. + """Write information associated with ``obj`` at current frame into trajectory. Topology for the output is taken from the `obj` or default to the value of the `topology` keyword supplied to the :class:`ChemfilesWriter`