From 5ffcb58714c93143d8c00841c00e73f46a6c296f Mon Sep 17 00:00:00 2001 From: "Josh A. Mitchell" Date: Thu, 8 Feb 2024 04:52:55 +1100 Subject: [PATCH] Fix all sphinx warnings (#1796) * Fix Sphinx warnings and fail on warning * Fix remaining Sphinx warnings by translating release history to markdown * Update changelog * fix weird formatting thing in releasehistory * fix unclosed literal in to_qcschema docstring --------- Co-authored-by: Jeff Wagner Co-authored-by: Jeff Wagner --- .readthedocs.yaml | 1 + FAQ.md | 5 +- docs/environment.yml | 6 +- docs/installation.md | 2 +- docs/releasehistory.md | 1799 ++++++++--------- docs/topology.md | 8 +- docs/users/concepts.md | 2 +- docs/users/developing.md | 4 +- docs/users/smirnoff.md | 2 +- openff/toolkit/topology/molecule.py | 2 +- openff/toolkit/topology/topology.py | 18 +- .../typing/engines/smirnoff/forcefield.py | 19 +- .../typing/engines/smirnoff/parameters.py | 21 +- 13 files changed, 903 insertions(+), 986 deletions(-) diff --git a/.readthedocs.yaml b/.readthedocs.yaml index 2d12a72e5..b8e758942 100644 --- a/.readthedocs.yaml +++ b/.readthedocs.yaml @@ -2,6 +2,7 @@ version: 2 sphinx: configuration: docs/conf.py + fail_on_warning: true build: os: ubuntu-20.04 tools: diff --git a/FAQ.md b/FAQ.md index b7338a16a..707510d73 100644 --- a/FAQ.md +++ b/FAQ.md @@ -66,10 +66,13 @@ This behavior is in line with OpenFF's general attitude of requiring users to ex ## I'm having troubles installing the OpenFF Toolkit on my Apple Silicon Mac. -As of August 2022, some upstreams (at least AmberTools, possibly more) are not built on `osx-arm64`, so installing the OpenFF stack is only possible with [Rosetta](https://support.apple.com/en-au/HT211861). See the [platform support](installation/m1) section of the installation documentation for more. +As of August 2022, some upstreams (at least AmberTools, possibly more) are not built on `osx-arm64`, so installing the OpenFF stack is only possible with [Rosetta]. See the [platform support] section of the installation documentation for more. (Keywords `osx-arm64`, M1 Mac, M2 Mac) +[Rosetta]: https://support.apple.com/en-au/HT211861 +[platform support]: inv:#install_arm + ## My mamba/conda installation of the toolkit doesn't appear to work. What should I try next? We recommend that you install the toolkit in a fresh environment, explicitly passing the channels to be used, in-order: diff --git a/docs/environment.yml b/docs/environment.yml index cd04c37c6..3a9b096b4 100644 --- a/docs/environment.yml +++ b/docs/environment.yml @@ -7,11 +7,11 @@ channels: dependencies: - pip # readthedocs dependencies - - myst-nb - - myst-parser>=0.14 + - myst-nb=1 + - myst-parser - docutils - sphinx-notfound-page - - sphinx>=5.0,<6 + - sphinx=6 # conda build dependencies - python=3.9 - setuptools diff --git a/docs/installation.md b/docs/installation.md index 136407f31..fc85d544b 100644 --- a/docs/installation.md +++ b/docs/installation.md @@ -26,7 +26,7 @@ If you do not have Mamba or Conda installed, see the [ecosystem installation doc Installation via the Mamba package manager is the recommended method since all dependencies are automatically fetched and installed for you. ::: -[ecosystem installation documentation]: openff.docs:install +[ecosystem installation documentation]: inv:openff.docs#install (installation/platforms)= diff --git a/docs/releasehistory.md b/docs/releasehistory.md index 7ef7e1946..690f91b05 100644 --- a/docs/releasehistory.md +++ b/docs/releasehistory.md @@ -19,7 +19,7 @@ Releases follow the `major.minor.micro` scheme recommended by [PEP440](https://w ### Improved documentation and warnings - [PR #1795](https://github.com/openforcefield/openff-toolkit/pull/1795): Add `NAGLToolkitWrapper` to API reference - +- [PR #1796](https://github.com/openforcefield/openff-toolkit/pull/1796): Update docs tooling and fix warnings ## 0.15.2 @@ -527,8 +527,8 @@ The following properties have been **deprecated** and will be removed in a futur - `Topology.topology_atoms` (use [`Topology.atoms`](Topology.atoms) instead) - `Topology.n_topology_bonds` (use [`Topology.n_bonds`](Topology.n_bonds) instead) - `Topology.topology_bonds` (use [`Topology.bonds`](Topology.bonds) instead) -- `Topology.n_topology_particles` (use [`Topology.n_particles`](Topology.n_particles) instead) -- `Topology.topology_particles` (use [`Topology.particles`](Topology.particles) instead) +- `Topology.n_topology_particles` (use `Topology.n_particles` instead) +- `Topology.topology_particles` (use `Topology.particles` instead) - `Topology.reference_molecules` (use [`Topology.unique_molecules`](Topology.unique_molecules) instead) - `Topology.n_reference_molecules` (use [`Topology.n_unique_molecules`](Topology.n_unique_molecules) instead) - `Topology.n_topology_molecules` (use [`Topology.n_molecules`](Topology.n_molecules) instead) @@ -713,7 +713,7 @@ The `compute_partial_charges_am1bcc()` methods of the `Molecule`, `AmberToolsToo 0.4 of the `` section of the SMIRNOFF specification. - [PR #1279](https://github.com/openforcefield/openforcefield/pull/1279): `ParameterHandler.version` and the `.version` attribute of its subclasses is now a - [``Version``](https://packaging.pypa.io/en/latest/version.html#packaging.version.Version) + [`Version`](https://packaging.pypa.io/en/latest/version.html#packaging.version.Version) object. Previously it was a string, which is not safe for [PEP440](https://www.python.org/dev/peps/pep-0440/#final-releases)-style versioning. - [PR #1250](https://github.com/openforcefield/openff-toolkit/pull/1250): Adds support for @@ -984,7 +984,7 @@ The `compute_partial_charges_am1bcc()` methods of the `Molecule`, `AmberToolsToo [`openff.toolkit.utils.exceptions.ConformerGenerationError`](openff.toolkit.utils.exceptions.ConformerGenerationError) if conformer generation fails. The same behavior occurs in [`Molecule.generate_conformers`](openff.toolkit.topology.Molecule.generate_conformers), but only - when the ``toolkit_registry`` argument is a + when the `toolkit_registry` argument is a [`ToolkitWrapper`](openff.toolkit.utils.toolkits.ToolkitWrapper), not when it is a [`ToolkitRegistry`](openff.toolkit.utils.toolkits.ToolkitRegistry). - [PR #1046](https://github.com/openforcefield/openforcefield/pull/1046): Changes OFFXML output to @@ -1218,235 +1218,207 @@ The `compute_partial_charges_am1bcc()` methods of the `Molecule`, `AmberToolsToo - [PR #906](https://github.com/openforcefield/openff-toolkit/pull/906): Cleaner instructions on how to setup development environment. -:::{TODO} -- Translate previous release history to MyST markdown -::: - -## Earlier releases -:::{eval-rst} +## 0.9.1 - Minor feature and bugfix release -0.9.1 - Minor feature and bugfix release ----------------------------------------- - -New features -"""""""""""" -- `PR #839 `_: Add support for computing WBOs from multiple +### New features +- [PR #839](https://github.com/openforcefield/openforcefield/pull/839): Add support for computing WBOs from multiple conformers using the AmberTools and OpenEye toolkits, and from ELF10 conformers using the OpenEye toolkit wrapper. -- `PR #832 `_: Expose ELF conformer selection through the - ``Molecule`` API via a new ``apply_elf_conformer_selection`` function. -- `PR #831 `_: Expose ELF conformer selection through the +- [PR #832](https://github.com/openforcefield/openforcefield/pull/832): Expose ELF conformer selection through the + `Molecule` API via a new `apply_elf_conformer_selection` function. +- [PR #831](https://github.com/openforcefield/openff-toolkit/pull/831): Expose ELF conformer selection through the OpenEye wrapper. -- `PR #790 `_: Fixes `Issue #720 - `_ where qcschema roundtrip to/from results +- [PR #790](https://github.com/openforcefield/openforcefield/pull/790): Fixes [Issue #720 + ](https://github.com/openforcefield/openforcefield/issues/720) where qcschema roundtrip to/from results in an error due to missing cmiles entry in attributes. -- `PR #793 `_: Add an initial ELF conformer selection +- [PR #793](https://github.com/openforcefield/openff-toolkit/pull/793): Add an initial ELF conformer selection implementation which uses RDKit. -- `PR #799 `_: Closes - `Issue #746 `_ by adding - :py:meth:`Molecule.smirnoff_impropers `, - :py:meth:`Molecule.amber_impropers `, - :py:meth:`TopologyMolecule.smirnoff_impropers `, - :py:meth:`TopologyMolecule.amber_impropers `, - :py:meth:`Topology.smirnoff_impropers `, and - :py:meth:`Topology.amber_impropers `. -- `PR #847 `_: Instances of - :py:class:`ParameterAttribute ` - documentation can now specify their docstrings with the optional ``docstring`` argument to the - ``__init__()`` method. -- `PR #827 `_: The - setter for :py:class:`Topology.box_vectors ` now infers box vectors +- [PR #799](https://github.com/openforcefield/openff-toolkit/pull/799): Closes + [Issue #746](https://github.com/openforcefield/openff-toolkit/issues/746) by adding + [`Molecule.smirnoff_impropers`](openff.toolkit.topology.FrozenMolecule.smirnoff_impropers), + [`Molecule.amber_impropers`](openff.toolkit.topology.FrozenMolecule.amber_impropers), + `TopologyMolecule.smirnoff_impropers`, `TopologyMolecule.amber_impropers`, + [`Topology.smirnoff_impropers`](openff.toolkit.topology.Topology.smirnoff_impropers), and + [`Topology.amber_impropers`](openff.toolkit.topology.Topology.amber_impropers). +- [PR #847](https://github.com/openforcefield/openforcefield/pull/847): Instances of + [`ParameterAttribute`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterAttribute) + documentation can now specify their docstrings with the optional `docstring` argument to the + `__init__()` method. +- [PR #827](https://github.com/openforcefield/openff-toolkit/pull/827): The + setter for [`Topology.box_vectors`](openff.toolkit.topology.Topology) now infers box vectors when box lengths are pass as a list of length 3. -Behavior changed -"""""""""""""""" -- `PR #802 `_: Fixes - `Issue #408 `_. The 1-4 scaling +### Behavior changed +- [PR #802](https://github.com/openforcefield/openforcefield/pull/802): Fixes + [Issue #408](https://github.com/openforcefield/openforcefield/issues/408). The 1-4 scaling factor for electrostatic interactions is now properly set by the value specified in the force field. Previously it fell back to a default value of 0.83333. The toolkit may now produce slightly different energies as a result of this change. -- `PR #839 `_: The average WBO will now be returned when - multiple conformers are provided to ``assign_fractional_bond_orders`` using ``use_conformers``. -- `PR #816 `_: Force field file paths +- [PR #839](https://github.com/openforcefield/openforcefield/pull/839): The average WBO will now be returned when + multiple conformers are provided to `assign_fractional_bond_orders` using `use_conformers`. +- [PR #816](https://github.com/openforcefield/openforcefield/pull/816): Force field file paths are now loaded in a case-insensitive manner. -Bugfixes -"""""""" -- `PR #849 `_: Changes - :py:meth:`create_openmm_system ` so - that it no longer uses the conformers on existing reference molecules (if present) to calculate Wiberg +### Bugfixes +- [PR #849](https://github.com/openforcefield/openforcefield/pull/849): Changes + `create_openmm_system` so that it no longer uses the conformers on existing reference molecules (if present) to calculate Wiberg bond orders. Instead, new conformers are always generated during parameterization. -Improved documentation and warnings -""""""""""""""""""""""""""""""""""" -- `PR #838 `_: Corrects spacing of "forcefield" to "force - field" throughout documentation. Fixes `Issue #112 `_. -- `PR #846 `_: Corrects dead links throughout release history. - Fixes `Issue #835 `_. -- `PR #847 `_: Documentation now compiles - with far fewer warnings, and in many cases more correctly. Additionally, :py:class:`ParameterAttribute - ` documentation no longer - appears incorrectly in classes where it is used. Fixes `Issue #397 - `_. - -0.9.0 - Namespace Migration ---------------------------- - -This release marks the transition from the old ``openforcefield`` branding over to its new -identity as ``openff-toolkit``. This change has been made to better represent the role of the +### Improved documentation and warnings +- [PR #838](https://github.com/openforcefield/openforcefield/pull/838): Corrects spacing of "forcefield" to "force + field" throughout documentation. Fixes [Issue #112](https://github.com/openforcefield/openforcefield/issues/112). +- [PR #846](https://github.com/openforcefield/openff-toolkit/pull/846): Corrects dead links throughout release history. + Fixes [Issue #835](https://github.com/openforcefield/openff-toolkit/issues/835). +- [PR #847](https://github.com/openforcefield/openforcefield/pull/847): Documentation now compiles + with far fewer warnings, and in many cases more correctly. Additionally, [`ParameterAttribute + `](openff.toolkit.typing.engines.smirnoff.parameters.ParameterAttribute) documentation no longer + appears incorrectly in classes where it is used. Fixes [Issue #397 + ](https://github.com/openforcefield/openforcefield/issues/397). + +## 0.9.0 - Namespace Migration + +This release marks the transition from the old `openforcefield` branding over to its new +identity as `openff-toolkit`. This change has been made to better represent the role of the toolkit, and highlight its place in the larger Open Force Field (OpenFF) ecosystem. -From version ``0.9.0`` onwards the toolkit will need to be imported as ``import openff.toolkit.XXX`` and -``from openff.toolkit import XXX``. +From version `0.9.0` onwards the toolkit will need to be imported as `import openff.toolkit.XXX` and +`from openff.toolkit import XXX`. -API-breaking changes -"""""""""""""""""""" -- `PR #803 `_: Migrates ``openforcefield`` - imports to ``openff.toolkit``. +### API-breaking changes +- [PR #803](https://github.com/openforcefield/openff-toolkit/pull/803): Migrates `openforcefield` + imports to `openff.toolkit`. -0.8.4 - Minor feature and bugfix release ----------------------------------------- +## 0.8.4 - Minor feature and bugfix release **This release is intended to be functionally identical to 0.9.1. The only difference is that it uses the "openforcefield" namespace.** -This release is a final patch for the ``0.8.X`` series of releases of the toolkit, and also marks the last -version of the toolkit which will be imported as ``import openforcefield.XXX`` / ``from openforcefield import XXX``. -From version ``0.9.0`` onwards the toolkit will be importable only as ``import openff.toolkit.XXX`` / -``from openff.toolkit import XXX``. +This release is a final patch for the `0.8.X` series of releases of the toolkit, and also marks the last +version of the toolkit which will be imported as `import openforcefield.XXX` / `from openforcefield import XXX`. +From version `0.9.0` onwards the toolkit will be importable only as `import openff.toolkit.XXX` / +`from openff.toolkit import XXX`. -**Note** This change will also be accompanied by a renaming of the package from ``openforcefield`` to ``openff-toolkit``, +**Note** This change will also be accompanied by a renaming of the package from `openforcefield` to `openff-toolkit`, so users need not worry about accidentally pulling in a version with changed imports. Users will have to explicitly -choose to install the ``openff-toolkit`` package once released which will contain the breaking import changes. +choose to install the `openff-toolkit` package once released which will contain the breaking import changes. -0.8.3 - Major bugfix release ----------------------------- +## 0.8.3 - Major bugfix release This release fixes a critical bug in van der Waals parameter assignment. -This release is also a final patch for the ``0.8.X`` series of releases of the toolkit, and also marks the last -version of the toolkit which will be imported as ``import openforcefield.XXX`` / ``from openforcefield import XXX``. -From version ``0.9.0`` onwards the toolkit will be importable only as ``import openff.toolkit.XXX`` / -``from openff.toolkit import XXX``. +This release is also a final patch for the `0.8.X` series of releases of the toolkit, and also marks the last +version of the toolkit which will be imported as `import openforcefield.XXX` / `from openforcefield import XXX`. +From version `0.9.0` onwards the toolkit will be importable only as `import openff.toolkit.XXX` / +`from openff.toolkit import XXX`. -**Note** This change will also be accompanied by a renaming of the package from ``openforcefield`` to ``openff-toolkit``, +**Note** This change will also be accompanied by a renaming of the package from `openforcefield` to `openff-toolkit`, so users need not worry about accidentally pulling in a version with changed imports. Users will have to explicitly -choose to install the ``openff-toolkit`` package once released which will contain the breaking import changes. +choose to install the `openff-toolkit` package once released which will contain the breaking import changes. -Bugfixes -"""""""" -- `PR #808 `_: Fixes - `Issue #807 `_, - which tracks a major bug in the interconversion between a vdW ``sigma`` - and ``rmin_half`` parameter. +### Bugfixes +- [PR #808](https://github.com/openforcefield/openff-toolkit/pull/808): Fixes + [Issue #807](https://github.com/openforcefield/openff-toolkit/issues/807), + which tracks a major bug in the interconversion between a vdW `sigma` + and `rmin_half` parameter. -New features -"""""""""""" -- `PR #794 `_: Adds a decorator - ``@requires_package`` that denotes a function requires an optional dependency. -- `PR #805 `_: Adds a deprecation warning for the up-coming - release of the ``openff-toolkit`` package and its import breaking changes. +### New features +- [PR #794](https://github.com/openforcefield/openff-toolkit/pull/794): Adds a decorator + `@requires_package` that denotes a function requires an optional dependency. +- [PR #805](https://github.com/openforcefield/openff-toolkit/pull/805): Adds a deprecation warning for the up-coming + release of the `openff-toolkit` package and its import breaking changes. -0.8.2 - Bugfix release ----------------------- +## 0.8.2 - Bugfix release **WARNING: This release was later found to contain a major bug,** -`Issue #807 `_, +[Issue #807](https://github.com/openforcefield/openff-toolkit/issues/807), **and produces incorrect energies.** -Bugfixes -"""""""" -- `PR #786 `_: Fixes `Issue #785 - `_ where RDKitToolkitWrapper would +### Bugfixes +- [PR #786](https://github.com/openforcefield/openff-toolkit/pull/786): Fixes [Issue #785 + ](https://github.com/openforcefield/openff-toolkit/issues/785) where RDKitToolkitWrapper would sometimes expect stereochemistry to be defined for non-stereogenic bonds when loading from SDF. -- `PR #786 `_: Fixes an issue where - using the :py:class:`Molecule ` copy constructor - (``newmol = Molecule(oldmol)``) would result - in the copy sharing the same ``.properties`` dict as the original (as in, changes to the - ``.properties`` dict of the copy would be reflected in the original). -- `PR #789 `_: Fixes a regression noted in - `Issue #788 `_ +- [PR #786](https://github.com/openforcefield/openff-toolkit/pull/786): Fixes an issue where + using the [`Molecule`](openff.toolkit.topology.Molecule) copy constructor + (`newmol = Molecule(oldmol)`) would result + in the copy sharing the same `.properties` dict as the original (as in, changes to the + `.properties` dict of the copy would be reflected in the original). +- [PR #789](https://github.com/openforcefield/openff-toolkit/pull/789): Fixes a regression noted in + [Issue #788](https://github.com/openforcefield/openff-toolkit/issues/788) where creating - :py:class:`vdWHandler.vdWType ` - or setting ``sigma`` or ``rmin_half`` using Quantities represented as strings resulted in an error. + [`vdWHandler.vdWType`](openff.toolkit.typing.engines.smirnoff.parameters.vdWHandler.vdWType) + or setting `sigma` or `rmin_half` using Quantities represented as strings resulted in an error. -0.8.1 - Bugfix and minor feature release ----------------------------------------- +## 0.8.1 - Bugfix and minor feature release **WARNING: This release was later found to contain a major bug,** -`Issue #807 `_, +[Issue #807](https://github.com/openforcefield/openff-toolkit/issues/807), **and produces incorrect energies.** -API-breaking changes -"""""""""""""""""""" -- `PR #757 `_: Renames - ``test_forcefields/smirnoff99Frosst.offxml`` to ``test_forcefields/test_forcefield.offxml`` +### API-breaking changes +- [PR #757](https://github.com/openforcefield/openff-toolkit/pull/757): Renames + `test_forcefields/smirnoff99Frosst.offxml` to `test_forcefields/test_forcefield.offxml` to avoid confusion with any of the ACTUAL released FFs in the - `smirnoff99Frosst line `_ -- `PR #751 `_: Removes the - optional ``oetools=("oechem", "oequacpac", "oeiupac", "oeomega")`` keyword argument from - :py:meth:`OpenEyeToolkitWrapper.is_available `, as + [smirnoff99Frosst line](https://github.com/openforcefield/smirnoff99Frosst/) +- [PR #751](https://github.com/openforcefield/openff-toolkit/pull/751): Removes the + optional `oetools=("oechem", "oequacpac", "oeiupac", "oeomega")` keyword argument from + [`OpenEyeToolkitWrapper.is_available`](openff.toolkit.utils.toolkits.OpenEyeToolkitWrapper.is_available), as there are no special behaviors that are accessed in the case of partially-licensed OpenEye backends. The new behavior of this method is the same as if the default value above is always provided. -Behavior Changed -"""""""""""""""" -- `PR #583 `_: Methods - such as :py:meth:`Molecule.from_rdkit ` - and :py:meth:`Molecule.from_openeye `, - which delegate their internal logic to :py:class:`ToolkitRegistry ` - functions, now guarantee that they will return an object of the correct type when being called on ``Molecule``-derived classes. Previously, - running these constructors using subclasses of :py:class:`FrozenMolecule ` +### Behavior Changed +- [PR #583](https://github.com/openforcefield/openff-toolkit/pull/583): Methods + such as [`Molecule.from_rdkit`](openff.toolkit.topology.Molecule.from_rdkit) + and [`Molecule.from_openeye`](openff.toolkit.topology.Molecule.from_openeye), + which delegate their internal logic to [`ToolkitRegistry`](openff.toolkit.utils.toolkits.ToolkitRegistry) + functions, now guarantee that they will return an object of the correct type when being called on `Molecule`-derived classes. Previously, + running these constructors using subclasses of [`FrozenMolecule`](openff.toolkit.topology.Molecule) would not return an instance of that subclass, but rather just an instance of a - :py:class:`Molecule `. -- `PR #753 `_: ``ParameterLookupError`` + [`Molecule`](openff.toolkit.topology.Molecule). +- [PR #753](https://github.com/openforcefield/openff-toolkit/pull/753): `ParameterLookupError` is now raised when passing to - :py:meth:`ParameterList.index ` + [`ParameterList.index`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterList) a SMIRKS pattern not found in the parameter list. -New features -"""""""""""" -- `PR #751 `_: Adds - ``LicenseError``, a subclass of ``ToolkitUnavailableException`` which is raised when attempting to - add a cheminformatics :py:class:`ToolkitWrapper ` for +### New features +- [PR #751](https://github.com/openforcefield/openff-toolkit/pull/751): Adds + `LicenseError`, a subclass of `ToolkitUnavailableException` which is raised when attempting to + add a cheminformatics [`ToolkitWrapper`](openff.toolkit.utils.toolkits.ToolkitWrapper) for a toolkit that is installed but unlicensed. -- `PR #678 `_: Adds - :py:meth:`ForceField.deregister_parameter_handler `. -- `PR #730 `_: Adds - :py:class:`Topology.is_periodic `. -- `PR #753 `_: Adds - :py:meth:`ParameterHandler.__getitem__ ` - to look up individual :py:class:`ParameterType ` +- [PR #678](https://github.com/openforcefield/openff-toolkit/pull/678): Adds + `ForceField.deregister_parameter_handler`. +- [PR #730](https://github.com/openforcefield/openff-toolkit/pull/730): Adds + [`Topology.is_periodic`](openff.toolkit.topology.Topology). +- [PR #753](https://github.com/openforcefield/openff-toolkit/pull/753): Adds + [`ParameterHandler.__getitem__`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) + to look up individual [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) objects. -Bugfixes -"""""""" -- `PR #745 `_: Fixes bug when +### Bugfixes +- [PR #745](https://github.com/openforcefield/openff-toolkit/pull/745): Fixes bug when serializing molecule with conformers to JSON. -- `PR #750 `_: Fixes a bug causing either - ``sigma`` or ``rmin_half`` to sometimes be missing on - :py:class:`vdWHandler.vdWType ` +- [PR #750](https://github.com/openforcefield/openff-toolkit/pull/750): Fixes a bug causing either + `sigma` or `rmin_half` to sometimes be missing on + [`vdWHandler.vdWType`](openff.toolkit.typing.engines.smirnoff.parameters.vdWHandler.vdWType) objects. -- `PR #756 `_: Fixes bug when running - :py:meth:`vdWHandler.create_force ` - using a ``vdWHandler`` that was initialized using the API. -- `PR #776 `_: Fixes a bug in which - the :py:meth:`Topology.from_openmm ` and - :py:meth:`Topology.from_mdtraj ` methods would - dangerously allow ``unique_molecules=None``. -- `PR #777 `_: - :py:class:`RDKitToolkitWrapper ` - now outputs the full warning message when ``allow_undefined_stereo=True`` (previously the +- [PR #756](https://github.com/openforcefield/openff-toolkit/pull/756): Fixes bug when running + [`vdWHandler.create_force`](openff.toolkit.typing.engines.smirnoff.parameters.vdWHandler) + using a `vdWHandler` that was initialized using the API. +- [PR #776](https://github.com/openforcefield/openff-toolkit/pull/776): Fixes a bug in which + the [`Topology.from_openmm`](openff.toolkit.topology.Topology.from_openmm) and + [`Topology.from_mdtraj`](openff.toolkit.topology.Topology.from_mdtraj) methods would + dangerously allow `unique_molecules=None`. +- [PR #777](https://github.com/openforcefield/openff-toolkit/pull/777): + [`RDKitToolkitWrapper`](openff.toolkit.utils.toolkits.RDKitToolkitWrapper) + now outputs the full warning message when `allow_undefined_stereo=True` (previously the description of which stereo was undefined was squelched) -0.8.0 - Virtual Sites ---------------------- +## 0.8.0 - Virtual Sites **Major Feature: Support for the SMIRNOFF VirtualSite tag** @@ -1456,272 +1428,254 @@ modeling on various functional groups. The primary focus was on the ability to p system using virtual sites, and generating an OpenMM system with all virtual sites present and ready for evaluation. Support for formats other than OpenMM has not be implemented in this release, but may come with the appearance of the OpenFF system object. In addition to implementing the -specification, the toolkit :py:class:`Molecule ` objects now +specification, the toolkit [`Molecule`](openff.toolkit.topology.Molecule) objects now allow the creation and manipulation of virtual sites. -This change is documented in the `Virtual sites page `_ of the user guide. +This change is documented in the [Virtual sites page](users/virtualsites) of the user guide. **Minor Feature: Support for the 0.4 ChargeIncrementModel tag** -To allow for more convenient fitting of ``ChargeIncrement`` parameters, it is now possible to specify one less -``charge_increment`` value than there are tagged atoms in a ``ChargeIncrement``'s ``smirks``. The missing -``charge_increment`` value will be calculated at parameterization-time to make the sum of -the charge contributions from a ``ChargeIncrement`` parameter equal to zero. +To allow for more convenient fitting of `ChargeIncrement` parameters, it is now possible to specify one less +`charge_increment` value than there are tagged atoms in a `ChargeIncrement`'s `smirks`. The missing +`charge_increment` value will be calculated at parameterization-time to make the sum of +the charge contributions from a `ChargeIncrement` parameter equal to zero. Since this change allows for force fields that are incompatible with -the previous specification, this new style of ``ChargeIncrement`` must specify a ``ChargeIncrementModel`` -section version of ``0.4``. All ``0.3``-compatible ``ChargeIncrement`` parameters are compatible with -the ``0.4`` ``ChargeIncrementModel`` specification. - -More details and examples of this change are available in `The ChargeIncrementModel tag in the SMIRNOFF specification `_ - - -New features -"""""""""""" -- `PR #726 `_: Adds support for the 0.4 - ChargeIncrementModel spec, allowing for the specification of one fewer ``charge_increment`` values - than there are tagged atoms in the ``smirks``, and automatically assigning the final atom an offsetting charge. -- `PR #548 `_: Adds support for the ``VirtualSites`` tag in the SMIRNOFF specification +the previous specification, this new style of `ChargeIncrement` must specify a `ChargeIncrementModel` +section version of `0.4`. All `0.3`-compatible `ChargeIncrement` parameters are compatible with +the `0.4` `ChargeIncrementModel` specification. -- `PR #548 `_: Adds ``replace`` and ``all_permutations`` kwarg to +More details and examples of this change are available in [The ChargeIncrementModel tag in the SMIRNOFF specification](https://openforcefield.github.io/standards/standards/smirnoff/#chargeincrementmodel-small-molecule-and-fragment-charges) - - :py:meth:`Molecule.add_bond_charge_virtual_site ` - - :py:meth:`Molecule.add_monovalent_lone_pair_virtual_site ` - - :py:meth:`Molecule.add_divalent_lone_pair_virtual_site ` - - :py:meth:`Molecule.add_trivalent_lone_pair_virtual_site ` -- `PR #548 `_: Adds ``orientations`` to - - - :py:class:`BondChargeVirtualSite ` - - :py:class:`MonovalentLonePairVirtualSite ` - - :py:class:`DivalentLonePairVirtualSite ` - - :py:class:`TrivalentLonePairVirtualSite ` - -- `PR #548 `_: Adds - - - :py:class:`VirtualParticle ` - - :py:class:`TopologyVirtualParticle ` - - :py:meth:`BondChargeVirtualSite.get_openmm_virtual_site ` - - :py:meth:`MonovalentLonePairVirtualSite.get_openmm_virtual_site ` - - :py:meth:`DivalentLonePairVirtualSite.get_openmm_virtual_site ` - - :py:meth:`TrivalentLonePairVirtualSite.get_openmm_virtual_site ` - - :py:meth:`ValenceDict.key_transform ` - - :py:meth:`ValenceDict.index_of ` - - :py:meth:`ImproperDict.key_transform ` - - :py:meth:`ImproperDict.index_of ` - -- `PR #705 `_: Adds interpolation +### New features +- [PR #726](https://github.com/openforcefield/openff-toolkit/pull/726): Adds support for the 0.4 + ChargeIncrementModel spec, allowing for the specification of one fewer `charge_increment` values + than there are tagged atoms in the `smirks`, and automatically assigning the final atom an offsetting charge. +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Adds support for the `VirtualSites` tag in the SMIRNOFF specification + +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Adds `replace` and `all_permutations` kwarg to + + - `Molecule.add_bond_charge_virtual_site` + - `Molecule.add_monovalent_lone_pair_virtual_site` + - `Molecule.add_divalent_lone_pair_virtual_site` + - `Molecule.add_trivalent_lone_pair_virtual_site` + +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Adds `orientations` to + + - `BondChargeVirtualSite` + - `MonovalentLonePairVirtualSite` + - `DivalentLonePairVirtualSite` + - `TrivalentLonePairVirtualSite` + +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Adds + + - `VirtualParticle` + - `TopologyVirtualParticle` + - `BondChargeVirtualSite.get_openmm_virtual_site` + - `MonovalentLonePairVirtualSite.get_openmm_virtual_site` + - `DivalentLonePairVirtualSite.get_openmm_virtual_site` + - `TrivalentLonePairVirtualSite.get_openmm_virtual_site` + - [`ValenceDict.key_transform`](openff.toolkit.topology.ValenceDict.key_transform) + - [`ValenceDict.index_of`](openff.toolkit.topology.ValenceDict.index_of) + - [`ImproperDict.key_transform`](openff.toolkit.topology.ImproperDict.key_transform) + - [`ImproperDict.index_of`](openff.toolkit.topology.ImproperDict.index_of) + +- [PR #705](https://github.com/openforcefield/openff-toolkit/pull/705): Adds interpolation based on fractional bond orders for harmonic bonds. This includes interpolation for both - the force constant ``k`` and/or equilibrium bond distance ``length``. This is accompanied by a - bump in the ```` section of the SMIRNOFF spec (but not the entire spec). -- `PR #718 `_: Adds ``.rings`` and - ``.n_rings`` to :py:class:`Molecule ` and ``.is_in_ring`` - to :py:class:`Atom ` and - :py:class:`Bond ` - -Bugfixes -""""""""" -- `PR #682 `_: Catches failures in - :py:meth:`Molecule.from_iupac ` instead of silently + the force constant `k` and/or equilibrium bond distance `length`. This is accompanied by a + bump in the `` section of the SMIRNOFF spec (but not the entire spec). +- [PR #718](https://github.com/openforcefield/openff-toolkit/pull/718): Adds `.rings` and + `.n_rings` to [`Molecule`](openff.toolkit.topology.Molecule) and `.is_in_ring` + to [`Atom`](openff.toolkit.topology.Atom) and + [`Bond`](openff.toolkit.topology.Bond) + +### Bugfixes +- [PR #682](https://github.com/openforcefield/openff-toolkit/pull/682): Catches failures in + [`Molecule.from_iupac`](openff.toolkit.topology.Molecule.from_iupac) instead of silently failing. -- `PR #743 `_: Prevents the non-bonded +- [PR #743](https://github.com/openforcefield/openff-toolkit/pull/743): Prevents the non-bonded (vdW) cutoff from silently falling back to the OpenMM default of 1 nm in - :py:meth:`Forcefield.create_openmm_system - ` and instead - sets its to the value specified by the force field. -- `PR #737 `_: Prevents OpenEye from + `Forcefield.create_openmm_system` and instead sets its to the value specified by the force field. +- [PR #737](https://github.com/openforcefield/openff-toolkit/pull/737): Prevents OpenEye from incidentally being used in the conformer generation step of - :py:class:`AmberToolsToolkitWrapper.assign_fractional_bond_orders - `. - -Behavior changed -"""""""""""""""" -- `PR #705 `_: Changes the default values - in the ```` section of the SMIRNOFF spec to ``fractional_bondorder_method="AM1-Wiberg"`` - and ``potential="(k/2)*(r-length)^2"``, which is backwards-compatible with and equivalent to - ``potential="harmonic"``. - -Examples added -"""""""""""""" -- `PR #548 `_: Adds a virtual site example notebook to run + [`AmberToolsToolkitWrapper.assign_fractional_bond_orders + `](openff.toolkit.utils.toolkits.AmberToolsToolkitWrapper.assign_fractional_bond_orders). + +### Behavior changed +- [PR #705](https://github.com/openforcefield/openff-toolkit/pull/705): Changes the default values + in the `` section of the SMIRNOFF spec to `fractional_bondorder_method="AM1-Wiberg"` + and `potential="(k/2)*(r-length)^2"`, which is backwards-compatible with and equivalent to + `potential="harmonic"`. + +### Examples added +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Adds a virtual site example notebook to run an OpenMM simulation with virtual sites, and compares positions and potential energy of TIP5P water between OpenFF and OpenMM force fields. -API-breaking changes -"""""""""""""""""""" -- `PR #548 `_: Methods +### API-breaking changes +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Methods - - :py:meth:`Molecule.add_bond_charge_virtual_site ` - - :py:meth:`Molecule.add_monovalent_lone_pair_virtual_site ` - - :py:meth:`Molecule.add_divalent_lone_pair_virtual_site ` - - :py:meth:`Molecule.add_trivalent_lone_pair_virtual_site ` - now only accept a list of atoms, not a list of integers, to define to parent atoms + - `Molecule.add_bond_charge_virtual_site` + - `Molecule.add_monovalent_lone_pair_virtual_site` + - `Molecule.add_divalent_lone_pair_virtual_site` + - `Molecule.add_trivalent_lone_pair_virtual_site` + + now only accept a list of atoms, not a list of integers, to define to parent atoms -- `PR #548 `_: Removes - :py:meth:`VirtualParticle.molecule_particle_index ` +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Removes + `VirtualParticle.molecule_particle_index` -- `PR #548 `_: Removes ``outOfPlaneAngle`` from +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Removes `outOfPlaneAngle` from - - :py:class:`DivalentLonePairVirtualSite ` - - :py:class:`TrivalentLonePairVirtualSite ` + - `DivalentLonePairVirtualSite` + - `TrivalentLonePairVirtualSite` -- `PR #548 `_: Removes ``inPlaneAngle`` from - :py:class:`TrivalentLonePairVirtualSite ` +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Removes `inPlaneAngle` from + `TrivalentLonePairVirtualSite` -- `PR #548 `_: Removes ``weights`` from +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Removes `weights` from - - :py:class:`BondChargeVirtualSite ` - - :py:class:`MonovalentLonePairVirtualSite ` - - :py:class:`DivalentLonePairVirtualSite ` - - :py:class:`TrivalentLonePairVirtualSite ` + - `BondChargeVirtualSite` + - `MonovalentLonePairVirtualSite` + - `DivalentLonePairVirtualSite` + - `TrivalentLonePairVirtualSite` -Tests added -""""""""""" +### Tests added -- `PR #548 `_: Adds test for +- [PR #548](https://github.com/openforcefield/openff-toolkit/pull/548): Adds test for - The virtual site parameter handler - TIP5P water dimer energy and positions - Adds tests to for virtual site/particle indexing/counting -0.7.2 - Bugfix and minor feature release ----------------------------------------- +## 0.7.2 - Bugfix and minor feature release -New features -"""""""""""" -- `PR #662 `_: Adds ``.aromaticity_model`` - of :py:class:`ForceField ` and ``.TAGNAME`` - of :py:class:`ParameterHandler ` as +### New features +- [PR #662](https://github.com/openforcefield/openff-toolkit/pull/662): Adds `.aromaticity_model` + of [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) and `.TAGNAME` + of [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) as public attributes. -- `PR #667 `_ and - `PR #681 `_ linted the codebase with - ``black`` and ``isort``, respectively. -- `PR #675 `_ adds - ``.toolkit_version`` to - :py:class:`ToolkitWrapper ` and - ``.registered_toolkit_versions`` to - :py:class:`ToolkitRegistry `. -- `PR #696 `_ Exposes a setter for - :py:class:`ForceField.aromaticity_model ` -- `PR #685 `_ Adds a custom ``__hash__`` +- [PR #667](https://github.com/openforcefield/openff-toolkit/pull/667) and + [PR #681](https://github.com/openforcefield/openff-toolkit/pull/681) linted the codebase with + `black` and `isort`, respectively. +- [PR #675](https://github.com/openforcefield/openff-toolkit/pull/675) adds + `.toolkit_version` to + [`ToolkitWrapper`](openff.toolkit.utils.toolkits.ToolkitWrapper) and + `.registered_toolkit_versions` to + [`ToolkitRegistry`](openff.toolkit.utils.toolkits.ToolkitRegistry). +- [PR #696](https://github.com/openforcefield/openff-toolkit/pull/696) Exposes a setter for + [`ForceField.aromaticity_model`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) +- [PR #685](https://github.com/openforcefield/openff-toolkit/pull/685) Adds a custom `__hash__` function to - :py:class:`ForceField ` + [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) -Behavior changed -"""""""""""""""" -- `PR #684 `_: Changes - :py:class:`ToolkitRegistry ` to return an empty - registry when initialized with no arguments, i.e. ``ToolkitRegistry()`` and makes the - ``register_imported_toolkit_wrappers`` argument private. -- `PR #711 `_: The - setter for :py:class:`Topology.box_vectors ` +### Behavior changed +- [PR #684](https://github.com/openforcefield/openff-toolkit/pull/684): Changes + [`ToolkitRegistry`](openff.toolkit.utils.toolkits.ToolkitRegistry) to return an empty + registry when initialized with no arguments, i.e. `ToolkitRegistry()` and makes the + `register_imported_toolkit_wrappers` argument private. +- [PR #711](https://github.com/openforcefield/openff-toolkit/pull/711): The + setter for [`Topology.box_vectors`](openff.toolkit.topology.Topology) now infers box vectors (a 3x3 matrix) when box lengths (a 3x1 array) are passed, assuming an orthogonal box. -- `PR #649 `_: Makes SMARTS +- [PR #649](https://github.com/openforcefield/openff-toolkit/pull/648): Makes SMARTS searches stereochemistry-specific (if stereo is specified in the SMARTS) for both OpenEye and RDKit backends. Also ensures molecule aromaticity is re-perceived according to the ForceField's specified - aromaticity model, which may overwrite user-specified aromaticity on the ``Molecule`` -- `PR #648 `_: Removes the - ``utils.structure`` module, which was deprecated in 0.2.0. -- `PR #670 `_: Makes the - :py:class:`Topology ` returned by ``create_openmm_system`` + aromaticity model, which may overwrite user-specified aromaticity on the `Molecule` +- [PR #648](https://github.com/openforcefield/openff-toolkit/pull/648): Removes the + `utils.structure` module, which was deprecated in 0.2.0. +- [PR #670](https://github.com/openforcefield/openff-toolkit/pull/670): Makes the + [`Topology`](openff.toolkit.topology.Topology) returned by `create_openmm_system` contain the partial charges and partial bond orders (if any) assigned during parameterization. -- `PR #675 `_ changes the - exception raised when no ``antechamber`` executable is found from ``IOError`` to - ``AntechamberNotFoundError`` -- `PR #696 `_ Adds an - ``aromaticity_model`` keyword argument to the - :py:class:`ForceField ` - constructor, which defaults to ``DEFAULT_AROMATICITY_MODEL``. - -Bugfixes -""""""""" -- `PR #715 `_: Closes issue `Issue #475 - `_ writing a "PDB" file using OE backend rearranges +- [PR #675](https://github.com/openforcefield/openff-toolkit/pull/675) changes the + exception raised when no `antechamber` executable is found from `IOError` to + `AntechamberNotFoundError` +- [PR #696](https://github.com/openforcefield/openff-toolkit/pull/696) Adds an + `aromaticity_model` keyword argument to the + [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) + constructor, which defaults to `DEFAULT_AROMATICITY_MODEL`. + +### Bugfixes +- [PR #715](https://github.com/openforcefield/openff-toolkit/pull/715): Closes issue [Issue #475 + ](https://github.com/openforcefield/openff-toolkit/issues/475) writing a "PDB" file using OE backend rearranges the order of the atoms by pushing the hydrogens to the bottom. -- `PR #649 `_: Prevents 2020 OE +- [PR #649](https://github.com/openforcefield/openff-toolkit/pull/648): Prevents 2020 OE toolkit from issuing a warning caused by doing stereo-specific smarts searches on certain structures. -- `PR #724 `_: Closes issue `Issue #502 - `_ Adding a utility function Topology.to_file() to +- [PR #724](https://github.com/openforcefield/openff-toolkit/pull/724): Closes issue [Issue #502 + ](https://github.com/openforcefield/openff-toolkit/issues/502) Adding a utility function Topology.to_file() to write topology and positions to a "PDB" file using openmm backend for pdb file write. -Tests added -""""""""""" -- `PR #694 `_: Adds automated testing +### Tests added +- [PR #694](https://github.com/openforcefield/openff-toolkit/pull/694): Adds automated testing to code snippets in docs. -- `PR #715 `_: Adds tests for pdb file writes using OE +- [PR #715](https://github.com/openforcefield/openff-toolkit/pull/715): Adds tests for pdb file writes using OE backend. -- `PR #724 `_: Adds tests for the utility function Topology.to_file(). +- [PR #724](https://github.com/openforcefield/openff-toolkit/pull/724): Adds tests for the utility function Topology.to_file(). -0.7.1 - OETK2020 Compatibility and Minor Update ------------------------------------------------ +## 0.7.1 - OETK2020 Compatibility and Minor Update This is the first of our patch releases on our new planned monthly release schedule. Detailed release notes are below, but the major new features of this release are updates for compatibility with the new 2020 OpenEye Toolkits release, the -``get_available_force_fields`` function, and the disregarding of pyrimidal nitrogen stereochemistry +`get_available_force_fields` function, and the disregarding of pyrimidal nitrogen stereochemistry in molecule isomorphism checks. -Behavior changed -"""""""""""""""" -- `PR #646 `_: Checking for - :py:class:`Molecule ` - equality using the ``==`` operator now disregards all pyrimidal nitrogen stereochemistry +### Behavior changed +- [PR #646](https://github.com/openforcefield/openff-toolkit/pull/646): Checking for + [`Molecule`](openff.toolkit.topology.Molecule) + equality using the `==` operator now disregards all pyrimidal nitrogen stereochemistry by default. To re-enable, use - :py:class:`Molecule.{is|are}_isomorphic ` - with the ``strip_pyrimidal_n_atom_stereo=False`` keyword argument. -- `PR #646 `_: Adds - an optional ``toolkit_registry`` keyword argument to - :py:class:`Molecule.are_isomorphic `, + [`Molecule.{is|are}_isomorphic`](openff.toolkit.topology.Molecule) + with the `strip_pyrimidal_n_atom_stereo=False` keyword argument. +- [PR #646](https://github.com/openforcefield/openff-toolkit/pull/646): Adds + an optional `toolkit_registry` keyword argument to + [`Molecule.are_isomorphic`](openff.toolkit.topology.Molecule), which identifies the toolkit that should be used to search for pyrimidal nitrogens. -Bugfixes -"""""""" -- `PR #647 `_: Updates - :py:class:`OpenEyeToolkitWrapper ` +### Bugfixes +- [PR #647](https://github.com/openforcefield/openff-toolkit/pull/647): Updates + [`OpenEyeToolkitWrapper`](openff.toolkit.utils.toolkits.OpenEyeToolkitWrapper) for 2020.0.4 OpenEye Toolkit behavior/API changes. -- `PR #646 `_: Fixes a bug where - :py:class:`Molecule.chemical_environment_matches ` - was not able to accept a :py:class:`ChemicalEnvironment ` object - as a query. -- `PR #634 `_: Fixes a bug in which calling - :py:class:`RDKitToolkitWrapper.from_file ` directly - would not load files correctly if passed lowercase ``file_format``. Note that this bug did not occur when calling - :py:class:`Molecule.from_file `. -- `PR #631 `_: Fixes a bug in which calling - :py:class:`unit_to_string ` returned - ``None`` when the unit is dimensionless. Now ``"dimensionless"`` is returned. -- `PR #630 `_: Closes issue `Issue #629 - `_ in which the wrong exception is raised when - attempting to instantiate a :py:class:`ForceField ` +- [PR #646](https://github.com/openforcefield/openff-toolkit/pull/646): Fixes a bug where + [`Molecule.chemical_environment_matches`](openff.toolkit.topology.Molecule) + was not able to accept a `ChemicalEnvironment` object as a query. +- [PR #634](https://github.com/openforcefield/openff-toolkit/pull/634): Fixes a bug in which calling + [`RDKitToolkitWrapper.from_file`](openff.toolkit.utils.toolkits.RDKitToolkitWrapper) directly + would not load files correctly if passed lowercase `file_format`. Note that this bug did not occur when calling + [`Molecule.from_file`](openff.toolkit.topology.Molecule). +- [PR #631](https://github.com/openforcefield/openff-toolkit/pull/631): Fixes a bug in which calling + [`unit_to_string`](openff.toolkit.utils.utils.unit_to_string) returned + `None` when the unit is dimensionless. Now `"dimensionless"` is returned. +- [PR #630](https://github.com/openforcefield/openff-toolkit/pull/630): Closes issue [Issue #629 + ](https://github.com/openforcefield/openff-toolkit/issues/629) in which the wrong exception is raised when + attempting to instantiate a [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) from an unparsable string. -New features -"""""""""""" -- `PR #632 `_: Adds - :py:class:`ForceField.registered_parameter_handlers ` -- `PR #614 `_: Adds - :py:class:`ToolkitRegistry.deregister_toolkit ` - to de-register registered toolkits, which can include toolkit wrappers loaded into ``GLOBAL_TOOLKIT_REGISTRY`` +### New features +- [PR #632](https://github.com/openforcefield/openff-toolkit/pull/632): Adds + [`ForceField.registered_parameter_handlers`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) +- [PR #614](https://github.com/openforcefield/openff-toolkit/pull/614): Adds + [`ToolkitRegistry.deregister_toolkit`](openff.toolkit.utils.toolkits.ToolkitRegistry) + to de-register registered toolkits, which can include toolkit wrappers loaded into `GLOBAL_TOOLKIT_REGISTRY` by default. -- `PR #656 `_: Adds - a new allowed ``am1elf10`` option to the OpenEye implementation of - :py:class:`assign_partial_charges ` which +- [PR #656](https://github.com/openforcefield/openff-toolkit/pull/656): Adds + a new allowed `am1elf10` option to the OpenEye implementation of + [`assign_partial_charges`](openff.toolkit.utils.toolkits.OpenEyeToolkitWrapper) which calculates the average partial charges at the AM1 level of theory using conformers selected using the ELF10 method. -- `PR #643 `_: Adds - :py:class:`openforcefield.typing.engines.smirnoff.forcefield.get_available_force_fields `, +- [PR #643](https://github.com/openforcefield/openff-toolkit/pull/643): Adds + [`openforcefield.typing.engines.smirnoff.forcefield.get_available_force_fields`](openff.toolkit.typing.engines.smirnoff.get_available_force_fields), which returns paths to the files of force fields available through entry point plugins. -0.7.0 - Charge Increment Model, Proper Torsion interpolation, and new Molecule methods --------------------------------------------------------------------------------------- +## 0.7.0 - Charge Increment Model, Proper Torsion interpolation, and new Molecule methods This is a relatively large release, motivated by the idea that changing existing functionality is bad so we shouldn't do it too often, but when we do change things we should do it all at once. @@ -1729,67 +1683,67 @@ so we shouldn't do it too often, but when we do change things we should do it al Here's a brief rundown of what changed, migration tips, and how to find more details in the full release notes below: * To provide more consistent partial charges for a given molecule, existing conformers are now disregarded by default - by ``Molecule.assign_partial_charges``. Instead, new conformers are generated for use in semiempirical calculations. - Search for ``use_conformers``. -* Formal charges are now always returned as ``simtk.unit.Quantity`` objects, with units of elementary charge. - To convert them to integers, use ``from simtk import unit`` and - ``atom.formal_charge.value_in_unit(unit.elementary_charge)`` or - ``mol.total_charge.value_in_unit(unit.elementary_charge)``. - Search ``atom.formal_charge``. + by `Molecule.assign_partial_charges`. Instead, new conformers are generated for use in semiempirical calculations. + Search for `use_conformers`. +* Formal charges are now always returned as `simtk.unit.Quantity` objects, with units of elementary charge. + To convert them to integers, use `from simtk import unit` and + `atom.formal_charge.value_in_unit(unit.elementary_charge)` or + `mol.total_charge.value_in_unit(unit.elementary_charge)`. + Search `atom.formal_charge`. * The OpenFF Toolkit now automatically reads and writes partial charges in SDF files. Search for - ``atom.dprop.PartialCharges``. + `atom.dprop.PartialCharges`. * The OpenFF Toolkit now has different behavior for handling multi-molecule and multi-conformer SDF files. Search - ``multi-conformer``. + `multi-conformer`. * The OpenFF Toolkit now distinguishes between partial charges that are all-zero and partial charges that are unknown. - Search ``partial_charges = None``. -* ``Topology.to_openmm`` now assigns unique atoms names by default. Search ``ensure_unique_atom_names``. + Search `partial_charges = None`. +* `Topology.to_openmm` now assigns unique atoms names by default. Search `ensure_unique_atom_names`. * Molecule equality checks are now done by graph comparison instead of SMILES comparison. - Search ``Molecule.are_isomorphic``. -* The ``ChemicalEnvironment`` module was almost entirely removed, as it is an outdated duplicate of some Chemper - functionality. Search ``ChemicalEnvironment``. -* ``TopologyMolecule.topology_particle_start_index`` has been removed from the ``TopologyMolecule`` API, since atoms - and virtualsites are no longer contiguous in the ``Topology`` particle indexing system. Search - ``topology_particle_start_index``. -* ``compute_wiberg_bond_orders`` has been renamed to ``assign_fractional_bond_orders``. + Search `Molecule.are_isomorphic`. +* The `ChemicalEnvironment` module was almost entirely removed, as it is an outdated duplicate of some Chemper + functionality. Search `ChemicalEnvironment`. +* `TopologyMolecule.topology_particle_start_index` has been removed from the `TopologyMolecule` API, since atoms + and virtualsites are no longer contiguous in the `Topology` particle indexing system. Search + `topology_particle_start_index`. +* `compute_wiberg_bond_orders` has been renamed to `assign_fractional_bond_orders`. There are also a number of new features, such as: -* Support for ``ChargeIncrementModel`` sections in force fields. -* Support for ``ProperTorsion`` ``k`` interpolation in force fields using fractional bond orders. -* Support for AM1-Mulliken, Gasteiger, and other charge methods using the new ``assign_partial_charges`` methods. +* Support for `ChargeIncrementModel` sections in force fields. +* Support for `ProperTorsion` `k` interpolation in force fields using fractional bond orders. +* Support for AM1-Mulliken, Gasteiger, and other charge methods using the new `assign_partial_charges` methods. * Support for AM1-Wiberg bond order calculation using either the OpenEye or RDKit/AmberTools backends and the - ``assign_fractional_bond_orders`` methods. -* Initial (limited) interoperability with QCArchive, via ``Molecule.to_qcschema`` and ``from_qcschema``. -* A ``Molecule.visualize`` method. -* Several additional ``Molecule`` methods, including state enumeration and mapped SMILES creation. + `assign_fractional_bond_orders` methods. +* Initial (limited) interoperability with QCArchive, via `Molecule.to_qcschema` and `from_qcschema`. +* A `Molecule.visualize` method. +* Several additional `Molecule` methods, including state enumeration and mapped SMILES creation. **Major Feature: Support for the SMIRNOFF ChargeIncrementModel tag** -`The ChargeIncrementModel tag in the SMIRNOFF specification `_ +[The ChargeIncrementModel tag in the SMIRNOFF specification](https://openforcefield.github.io/standards/standards/smirnoff/#chargeincrementmodel-small-molecule-and-fragment-charges) provides analagous functionality to AM1-BCC, except that instead of AM1-Mulliken charges, a number of different charge methods can be called, and instead of a fixed library of two-atom charge corrections, an arbitrary number of SMIRKS-based, N-atom charge corrections can be defined in the SMIRNOFF format. -The initial implementation of the SMIRNOFF ``ChargeIncrementModel`` tag accepts keywords for ``version``, -``partial_charge_method``, and ``number_of_conformers``. ``partial_charge_method`` can be any string, and it is -up to the ``ToolkitWrapper``'s ``compute_partial_charges`` methods to understand what they mean. For -geometry-independent ``partial_charge_method`` choices, ``number_of_conformers`` should be set to zero. +The initial implementation of the SMIRNOFF `ChargeIncrementModel` tag accepts keywords for `version`, +`partial_charge_method`, and `number_of_conformers`. `partial_charge_method` can be any string, and it is +up to the `ToolkitWrapper`'s `compute_partial_charges` methods to understand what they mean. For +geometry-independent `partial_charge_method` choices, `number_of_conformers` should be set to zero. -SMIRKS-based parameter application for ``ChargeIncrement`` parameters is different than other SMIRNOFF sections. -The initial implementation of ``ChargeIncrementModelHandler`` follows these rules: +SMIRKS-based parameter application for `ChargeIncrement` parameters is different than other SMIRNOFF sections. +The initial implementation of `ChargeIncrementModelHandler` follows these rules: -* an atom can be subject to many ``ChargeIncrement`` parameters, which combine additively. -* a ``ChargeIncrement`` that matches a set of atoms is overwritten only if another ``ChargeIncrement`` +* an atom can be subject to many `ChargeIncrement` parameters, which combine additively. +* a `ChargeIncrement` that matches a set of atoms is overwritten only if another `ChargeIncrement` matches the same group of atoms, regardless of order. This overriding follows the normal SMIRNOFF hierarchy. -To give a concise example, what if a molecule ``A-B(-C)-D`` were being parametrized, and the force field -defined ``ChargeIncrement`` SMIRKS in the following order? +To give a concise example, what if a molecule `A-B(-C)-D` were being parametrized, and the force field +defined `ChargeIncrement` SMIRKS in the following order? -1) ``[A:1]-[B:2]`` -2) ``[B:1]-[A:2]`` -3) ``[A:1]-[B:2]-[C:3]`` -4) ``[*:1]-[B:2](-[*:3])-[*:4]`` -5) ``[D:1]-[B:2](-[*:3])-[*:4]`` +1) `[A:1]-[B:2]` +2) `[B:1]-[A:2]` +3) `[A:1]-[B:2]-[C:3]` +4) `[*:1]-[B:2](-[*:3])-[*:4]` +5) `[D:1]-[B:2](-[*:3])-[*:4]` In the case above, the ChargeIncrement from parameters 1 and 4 would NOT be applied to the molecule, since another parameter matching the same set of atoms is specified further down in the parameter hierarchy @@ -1800,209 +1754,196 @@ Ultimately, the ChargeIncrement contributions from parameters 2, 3, and 5 would It's also important to identify a behavior that these rules were written to *avoid*: if not for the "regardless of order" clause in the second rule, parameters 4 and 5 could actually have been applied six and two times, respectively (due to symmetry in the SMIRKS and the use of wildcards). This situation could also arise as a result -of molecular symmetry. For example, a methyl group could match the SMIRKS ``[C:1]([H:2])([H:3])([H:4])`` six ways +of molecular symmetry. For example, a methyl group could match the SMIRKS `[C:1]([H:2])([H:3])([H:4])` six ways (with different orderings of the three hydrogen atoms), but the user would almost certainly not intend for the charge increments to be applied six times. The "regardless of order" clause was added specifically to address this. -In short, the first time a group of atoms becomes involved in a ``ChargeIncrement`` together, the OpenMM ``System`` gains a new -parameter "slot". Only another ``ChargeIncrement`` which applies to the exact same group of atoms (in any order) can -take over the "slot", pushing the original ``ChargeIncrement`` out. +In short, the first time a group of atoms becomes involved in a `ChargeIncrement` together, the OpenMM `System` gains a new +parameter "slot". Only another `ChargeIncrement` which applies to the exact same group of atoms (in any order) can +take over the "slot", pushing the original `ChargeIncrement` out. **Major Feature: Support for ProperTorsion k value interpolation** -`Chaya Stern's work `_ +[Chaya Stern's work](https://chayast.github.io/fragmenter-manuscript/) showed that we may be able to produce higher-quality proper torsion parameters by taking into account the "partial bond order" of the torsion's central bond. We now have the machinery to compute AM1-Wiberg -partial bond orders for entire molecules using the ``assign_fractional_bond_orders`` methods of either ``OpenEyeToolkitWrapper`` or ``AmberToolsToolkitWrapper``. The thought is that, if some simple electron population analysis shows +partial bond orders for entire molecules using the `assign_fractional_bond_orders` methods of either `OpenEyeToolkitWrapper` or `AmberToolsToolkitWrapper`. The thought is that, if some simple electron population analysis shows that a certain aromatic bond's order is 1.53, maybe rotations about that bond can be described well by interpolating 53% of the way between the single and double bond k values. Full details of how to define a torsion-interpolating SMIRNOFF force fields are available in -`the ProperTorsions section of the SMIRNOFF specification `_. +[the ProperTorsions section of the SMIRNOFF specification](https://openforcefield.github.io/standards/standards/smirnoff/#fractional-torsion-bond-orders). -Behavior changed -"""""""""""""""" -- `PR #508 `_: +### Behavior changed +- [PR #508](https://github.com/openforcefield/openff-toolkit/pull/508): In order to provide the same results for the same chemical species, regardless of input conformation, - :py:class:`Molecule ` - ``assign_partial_charges``, ``compute_partial_charges_am1bcc``, and - ``assign_fractional_bond_orders`` methods now default to ignore input conformers + [`Molecule`](openff.toolkit.topology.Molecule) + `assign_partial_charges`, `compute_partial_charges_am1bcc`, and + `assign_fractional_bond_orders` methods now default to ignore input conformers and generate new conformer(s) of the molecule before running semiempirical calculations. Users can override this behavior by specifying the keyword argument - ``use_conformers=molecule.conformers``. -- `PR #281 `_: Closes - `Issue #250 `_ + `use_conformers=molecule.conformers`. +- [PR #281](https://github.com/openforcefield/openff-toolkit/pull/281): Closes + [Issue #250](https://github.com/openforcefield/openff-toolkit/issues/250) by adding support for partial charge I/O in SDF. The partial charges are stored as a property in the - SDF molecule block under the tag ````. -- `PR #281 `_: If a - :py:class:`Molecule `'s - ``partial_charges`` attribute is set to ``None`` (the default value), calling ``to_openeye`` will - now produce a OE molecule with partial charges set to ``nan``. This would previously produce an OE + SDF molecule block under the tag ``. +- [PR #281](https://github.com/openforcefield/openff-toolkit/pull/281): If a + [`Molecule`](openff.toolkit.topology.Molecule)'s + `partial_charges` attribute is set to `None` (the default value), calling `to_openeye` will + now produce a OE molecule with partial charges set to `nan`. This would previously produce an OE molecule with partial charges of 0.0, which was a loss of information, since it wouldn't be clear - whether the original OFFMol's partial charges were REALLY all-zero as opposed to ``None``. OpenEye toolkit - wrapper methods such as ``from_smiles`` and ``from_file`` now produce OFFMols with - ``partial_charges = None`` when appropriate (previously these would produce OFFMols with + whether the original OFFMol's partial charges were REALLY all-zero as opposed to `None`. OpenEye toolkit + wrapper methods such as `from_smiles` and `from_file` now produce OFFMols with + `partial_charges = None` when appropriate (previously these would produce OFFMols with all-zero charges, for the same reasoning as above). -- `PR #281 `_: - :py:class:`Molecule ` - ``to_rdkit`` - now sets partial charges on the RDAtom's ``PartialCharges`` property (this was previously set - on the ``partial_charges`` property). If the - :py:class:`Molecule `'s partial_charges attribute is ``None``, this property +- [PR #281](https://github.com/openforcefield/openff-toolkit/pull/281): + [`Molecule`](openff.toolkit.topology.Molecule) + `to_rdkit` + now sets partial charges on the RDAtom's `PartialCharges` property (this was previously set + on the `partial_charges` property). If the + [`Molecule`](openff.toolkit.topology.Molecule)'s partial_charges attribute is `None`, this property will not be defined on the RDAtoms. -- `PR #281 `_: +- [PR #281](https://github.com/openforcefield/openff-toolkit/pull/281): Enforce the behavior during SDF I/O that a SDF may contain multiple `molecules`, but that the OFF Toolkit does not assume that it contains multiple `conformers of the same molecule`. This is an important distinction, since otherwise there is ambiguity around whether properties of one entry in a SDF are shared among several molecule blocks or not, or how to resolve conflicts if properties are defined differently for several "conformers" of chemically-identical species (More info - `here `_). + [here](https://docs.eyesopen.com/toolkits/python/oechemtk/oemol.html#dude-where-s-my-sd-data)). If the user requests the OFF Toolkit to write a multi-conformer - :py:class:`Molecule ` to SDF, only the first conformer will be written. + [`Molecule`](openff.toolkit.topology.Molecule) to SDF, only the first conformer will be written. For more fine-grained control of writing properties, conformers, and partial charges, consider - using ``Molecule.to_rdkit`` or ``Molecule.to_openeye`` and using the functionality offered by + using `Molecule.to_rdkit` or `Molecule.to_openeye` and using the functionality offered by those packages. -- `PR #281 `_: Due to different +- [PR #281](https://github.com/openforcefield/openff-toolkit/pull/281): Due to different constraints placed on the data types allowed by external toolkits, we make our best effort to - preserve :py:class:`Molecule ` - ``properties`` when converting molecules to other packages, but users should be aware that + preserve [`Molecule`](openff.toolkit.topology.Molecule) + `properties` when converting molecules to other packages, but users should be aware that no guarantee of data integrity is made. The only data format for keys and values in the property dict that - we will try to support through a roundtrip to another toolkit's Molecule object is ``string``. -- `PR #574 `_: Removed check that all - partial charges are zero after assignment by ``quacpac`` when AM1BCC used for charge assignment. + we will try to support through a roundtrip to another toolkit's Molecule object is `string`. +- [PR #574](https://github.com/openforcefield/openff-toolkit/pull/574): Removed check that all + partial charges are zero after assignment by `quacpac` when AM1BCC used for charge assignment. This check fails erroneously for cases in which the partial charge assignments are correctly all zero, - such as for ``N#N``. It is also an unnecessary check given that ``quacpac`` will reliably indicate when + such as for `N#N`. It is also an unnecessary check given that `quacpac` will reliably indicate when it has failed to assign charges. -- `PR #597 `_: Energy-minimized sample systems +- [PR #597](https://github.com/openforcefield/openff-toolkit/pull/597): Energy-minimized sample systems with Parsley 1.1.0. -- `PR #558 `_: The - :py:class:`Topology ` - particle indexing system now orders :py:class:`TopologyVirtualSites ` +- [PR #558](https://github.com/openforcefield/openff-toolkit/pull/558): The + [`Topology`](openff.toolkit.topology.Topology) particle indexing system now orders `TopologyVirtualSites` after all atoms. -- `PR #469 `_: - When running :py:meth:`Topology.to_openmm `, unique atom names +- [PR #469](https://github.com/openforcefield/openff-toolkit/pull/469): + When running [`Topology.to_openmm`](openff.toolkit.topology.Topology.to_openmm), unique atom names are generated if the provided atom names are not unique (overriding any existing atom names). This uniqueness extends only to atoms in the same molecule. To disable this behavior, set the kwarg - ``ensure_unique_atom_names=False``. -- `PR #472 `_: - :py:meth:`Molecule.__eq__ ` now uses the new - :py:meth:`Molecule.are_isomorphic ` to perform the + `ensure_unique_atom_names=False`. +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): + [`Molecule.__eq__`](openff.toolkit.topology.Molecule) now uses the new + [`Molecule.are_isomorphic`](openff.toolkit.topology.Molecule.are_isomorphic) to perform the similarity checking. -- `PR #472 `_: - The :py:meth:`Topology.from_openmm ` and - :py:meth:`Topology.add_molecule ` methods now use the - :py:meth:`Molecule.are_isomorphic ` method to match +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): + The [`Topology.from_openmm`](openff.toolkit.topology.Topology.from_openmm) and + [`Topology.add_molecule`](openff.toolkit.topology.Topology.add_molecule) methods now use the + [`Molecule.are_isomorphic`](openff.toolkit.topology.Molecule.are_isomorphic) method to match molecules. -- `PR #551 `_: Implemented the - :py:meth:`ParameterHandler.get_parameter ` - function (would previously return ``None``). - -API-breaking changes -"""""""""""""""""""" -- `PR #471 `_: Closes - `Issue #465 `_. - ``atom.formal_charge`` and ``molecule.total_charge`` now return ``simtk.unit.Quantity`` objects - instead of integers. To preserve backward compatibility, the setter for ``atom.formal_charge`` - can accept either a ``simtk.unit.Quantity`` or an integer. -- `PR #601 `_: Removes - almost all of the previous - :py:class:`ChemicalEnvironment ` - API, since this entire module was simply copied from - `Chemper `_ several years ago and has fallen behind on updates. - Currently only - :py:meth:`ChemicalEnvironment.get_type `, - :py:meth:`ChemicalEnvironment.validate `, - and an equivalent classmethod - :py:meth:`ChemicalEnvironment.validate_smirks ` - remain. Also, please comment on - `this GitHub issue `_ if you HAVE been using +- [PR #551](https://github.com/openforcefield/openff-toolkit/pull/551): Implemented the + [`ParameterHandler.get_parameter`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler.get_parameter) + function (would previously return `None`). + +### API-breaking changes +- [PR #471](https://github.com/openforcefield/openff-toolkit/pull/471): Closes + [Issue #465](https://github.com/openforcefield/openff-toolkit/issues/465). + `atom.formal_charge` and `molecule.total_charge` now return `simtk.unit.Quantity` objects + instead of integers. To preserve backward compatibility, the setter for `atom.formal_charge` + can accept either a `simtk.unit.Quantity` or an integer. +- [PR #601](https://github.com/openforcefield/openff-toolkit/pull/601): Removes + almost all of the previous `ChemicalEnvironment` API, since this entire module was simply copied from + [Chemper](https://github.com/MobleyLab/chemper) several years ago and has fallen behind on updates. + Currently only `ChemicalEnvironment.get_type`, `ChemicalEnvironment.validate`, and an equivalent classmethod + `ChemicalEnvironment.validate_smirks` remain. Also, please comment on + [this GitHub issue](https://github.com/MobleyLab/chemper/issues/90) if you HAVE been using the previous extra functionality in this module and would like us to prioritize creation of a Chemper conda package. -- `PR #558 `_: Removes - ``TopologyMolecule.topology_particle_start_index``, since the :py:class:`Topology ` - particle indexing system now orders :py:class:`TopologyVirtualSites ` - after all atoms. - :py:meth:`TopologyMolecule.atom_start_topology_index ` - and - :py:meth:`TopologyMolecule.virtual_particle_start_topology_index ` - are still available to access the appropriate values in the respective topology indexing systems. -- `PR #508 `_: - ``OpenEyeToolkitWrapper.compute_wiberg_bond_orders`` is now - :py:meth:`OpenEyeToolkitWrapper.assign_fractional_bond_orders `. - The ``charge_model`` keyword is now ``bond_order_model``. The allowed values of this keyword have - changed from ``am1`` and ``pm3`` to ``am1-wiberg`` and ``pm3-wiberg``, respectively. -- `PR #508 `_: - ``Molecule.compute_wiberg_bond_orders`` is now - :py:meth:`Molecule.assign_fractional_bond_orders `. -- `PR #595 `_: Removed functions - ``openforcefield.utils.utils.temporary_directory`` and - ``openforcefield.utils.utils.temporary_cd`` and replaced their behavior with - ``tempfile.TemporaryDirectory()``. - -New features -"""""""""""" -- `PR #471 `_: Closes - `Issue #208 `_ +- [PR #558](https://github.com/openforcefield/openff-toolkit/pull/558): Removes + `TopologyMolecule.topology_particle_start_index`, since the [`Topology`](openff.toolkit.topology.Topology) + particle indexing system now orders `TopologyVirtualSites` after all atoms. `TopologyMolecule.atom_start_topology_index` + and `TopologyMolecule.virtual_particle_start_topology_index` are still available to access the appropriate values in the + respective topology indexing systems. +- [PR #508](https://github.com/openforcefield/openff-toolkit/pull/508): + `OpenEyeToolkitWrapper.compute_wiberg_bond_orders` is now + [`OpenEyeToolkitWrapper.assign_fractional_bond_orders`](openff.toolkit.utils.toolkits.OpenEyeToolkitWrapper.assign_fractional_bond_orders). + The `charge_model` keyword is now `bond_order_model`. The allowed values of this keyword have + changed from `am1` and `pm3` to `am1-wiberg` and `pm3-wiberg`, respectively. +- [PR #508](https://github.com/openforcefield/openff-toolkit/pull/508): + `Molecule.compute_wiberg_bond_orders` is now + [`Molecule.assign_fractional_bond_orders`](openff.toolkit.topology.Molecule.assign_fractional_bond_orders). +- [PR #595](https://github.com/openforcefield/openff-toolkit/pull/595): Removed functions + `openforcefield.utils.utils.temporary_directory` and + `openforcefield.utils.utils.temporary_cd` and replaced their behavior with + `tempfile.TemporaryDirectory()`. + +### New features +- [PR #471](https://github.com/openforcefield/openff-toolkit/pull/471): Closes + [Issue #208](https://github.com/openforcefield/openff-toolkit/issues/208) by implementing support for the - ``ChargeIncrementModel`` tag in the `SMIRNOFF specification `_. -- `PR #471 `_: Implements - ``Molecule.assign_partial_charges``, which calls one of the newly-implemented - ``OpenEyeToolkitWrapper.assign_partial_charges``, and - ``AmberToolsToolkitWrapper.assign_partial_charges``. ``strict_n_conformers`` is a - optional boolean keyword argument indicating whether an ``IncorrectNumConformersError`` should be raised if an invalid + `ChargeIncrementModel` tag in the [SMIRNOFF specification](https://openforcefield.github.io/standards/standards/smirnoff/#chargeincrementmodel-small-molecule-and-fragment-charges). +- [PR #471](https://github.com/openforcefield/openff-toolkit/pull/471): Implements + `Molecule.assign_partial_charges`, which calls one of the newly-implemented + `OpenEyeToolkitWrapper.assign_partial_charges`, and + `AmberToolsToolkitWrapper.assign_partial_charges`. `strict_n_conformers` is a + optional boolean keyword argument indicating whether an `IncorrectNumConformersError` should be raised if an invalid number of conformers is supplied during partial charge calculation. For example, if two conformers are - supplied, but ``partial_charge_method="AM1BCC"`` is also set, then there is no clear use for + supplied, but `partial_charge_method="AM1BCC"` is also set, then there is no clear use for the second conformer. The previous behavior in this case was to raise a warning, and to preserve that - behavior, ``strict_n_conformers`` defaults to a value of ``False``. -- `PR #471 `_: Adds - keyword argument ``raise_exception_types`` (default: ``[Exception]``) to - :py:meth:`ToolkitRegistry.call `. + behavior, `strict_n_conformers` defaults to a value of `False`. +- [PR #471](https://github.com/openforcefield/openff-toolkit/pull/471): Adds + keyword argument `raise_exception_types` (default: `[Exception]`) to + [`ToolkitRegistry.call`](openff.toolkit.utils.toolkits.ToolkitRegistry.call). The default value will provide the previous OpenFF Toolkit behavior, which is that the first ToolkitWrapper that can provide the requested method is called, and it either returns on success or raises an exception. This new keyword argument allows the ToolkitRegistry to *ignore* certain exceptions, but treat others as fatal. - If ``raise_exception_types = []``, the ToolkitRegistry will attempt to call each ToolkitWrapper that provides the - requested method and if none succeeds, a single ``ValueError`` will be raised, with text listing the + If `raise_exception_types = []`, the ToolkitRegistry will attempt to call each ToolkitWrapper that provides the + requested method and if none succeeds, a single `ValueError` will be raised, with text listing the errors that were raised by each ToolkitWrapper. -- `PR #601 `_: Adds - :py:meth:`RDKitToolkitWrapper.get_tagged_smarts_connectivity ` +- [PR #601](https://github.com/openforcefield/openff-toolkit/pull/601): Adds + [`RDKitToolkitWrapper.get_tagged_smarts_connectivity`](openff.toolkit.utils.toolkits.RDKitToolkitWrapper.get_tagged_smarts_connectivity) and - :py:meth:`OpenEyeToolkitWrapper.get_tagged_smarts_connectivity `, + [`OpenEyeToolkitWrapper.get_tagged_smarts_connectivity`](openff.toolkit.utils.toolkits.OpenEyeToolkitWrapper.get_tagged_smarts_connectivity), which allow the use of either toolkit for smirks/tagged smarts validation. -- `PR #600 `_: - Adds :py:meth:`ForceField.__getitem__ ` - to look up ``ParameterHandler`` objects based on their string names. -- `PR #508 `_: - Adds :py:meth:`AmberToolsToolkitWrapper.assign_fractional_bond_orders `. -- `PR #469 `_: The - :py:class:`Molecule ` class adds - :py:meth:`Molecule.has_unique_atom_names ` - and :py:meth:`Molecule.has_unique_atom_names `. -- `PR #472 `_: - Adds to the :py:class:`Molecule ` class - :py:meth:`Molecule.are_isomorphic ` - and :py:meth:`Molecule.is_isomorphic_with ` - and :py:meth:`Molecule.hill_formula ` - and :py:meth:`Molecule.to_hill_formula ` - and :py:meth:`Molecule.to_qcschema ` - and :py:meth:`Molecule.from_qcschema ` - and :py:meth:`Molecule.from_mapped_smiles ` - and :py:meth:`Molecule.from_pdb_and_smiles ` - and :py:meth:`Molecule.canonical_order_atoms ` - and :py:meth:`Molecule.remap ` +- [PR #600](https://github.com/openforcefield/openff-toolkit/pull/600): + Adds [`ForceField.__getitem__`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) + to look up `ParameterHandler` objects based on their string names. +- [PR #508](https://github.com/openforcefield/openff-toolkit/pull/508): + Adds [`AmberToolsToolkitWrapper.assign_fractional_bond_orders`](openff.toolkit.utils.toolkits.AmberToolsToolkitWrapper.assign_fractional_bond_orders). +- [PR #469](https://github.com/openforcefield/openff-toolkit/pull/469): The + [`Molecule`](openff.toolkit.topology.Molecule) class adds + [`Molecule.has_unique_atom_names`](openff.toolkit.topology.Molecule.has_unique_atom_names) + and [`Molecule.has_unique_atom_names`](openff.toolkit.topology.Molecule.generate_unique_atom_names). +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): + Adds to the [`Molecule`](openff.toolkit.topology.Molecule) class + [`Molecule.are_isomorphic`](openff.toolkit.topology.Molecule.are_isomorphic) + and [`Molecule.is_isomorphic_with`](openff.toolkit.topology.Molecule.is_isomorphic_with) + and [`Molecule.hill_formula`](openff.toolkit.topology.Molecule.hill_formula) + and [`Molecule.to_hill_formula`](openff.toolkit.topology.Molecule.to_hill_formula) + and [`Molecule.to_qcschema`](openff.toolkit.topology.Molecule.to_qcschema) + and [`Molecule.from_qcschema`](openff.toolkit.topology.Molecule.from_qcschema) + and [`Molecule.from_mapped_smiles`](openff.toolkit.topology.Molecule.from_mapped_smiles) + and [`Molecule.from_pdb_and_smiles`](openff.toolkit.topology.Molecule.from_pdb_and_smiles) + and [`Molecule.canonical_order_atoms`](openff.toolkit.topology.Molecule.canonical_order_atoms) + and [`Molecule.remap`](openff.toolkit.topology.Molecule.remap) .. note:: The to_qcschema method accepts an extras dictionary which is passed into the validated qcelemental.models.Molecule object. -- `PR #506 `_: - The :py:class:`Molecule ` class adds - :py:meth:`Molecule.find_rotatable_bonds ` -- `PR #521 `_: - Adds :py:meth:`Molecule.to_inchi ` - and :py:meth:`Molecule.to_inchikey ` - and :py:meth:`Molecule.from_inchi ` +- [PR #506](https://github.com/openforcefield/openff-toolkit/pull/506): + The [`Molecule`](openff.toolkit.topology.Molecule) class adds + [`Molecule.find_rotatable_bonds`](openff.toolkit.topology.Molecule.find_rotatable_bonds) +- [PR #521](https://github.com/openforcefield/openff-toolkit/pull/521): + Adds [`Molecule.to_inchi`](openff.toolkit.topology.Molecule.to_inchi) + and [`Molecule.to_inchikey`](openff.toolkit.topology.Molecule.to_inchikey) + and [`Molecule.from_inchi`](openff.toolkit.topology.Molecule.from_inchi) .. warning:: InChI was not designed as an molecule interchange format and using it as one is not recommended. Many round trip @@ -2010,159 +1951,154 @@ New features hydrogen layer nonstandard InChI which can help in the case of tautomers, but overall creating molecules from InChI should be avoided. -- `PR #529 `_: Adds the ability to write out to XYZ files via - :py:meth:`Molecule.to_file ` Both single frame and multiframe XYZ files are supported. +- [PR #529](https://github.com/openforcefield/openff-toolkit/pull/529): Adds the ability to write out to XYZ files via + [`Molecule.to_file`](openff.toolkit.topology.Molecule.to_file) Both single frame and multiframe XYZ files are supported. Note reading from XYZ files will not be supported due to the lack of connectivity information. -- `PR #535 `_: Extends the the API for the - :py:meth:`Molecule.to_smiles ` to allow for the creation of cmiles +- [PR #535](https://github.com/openforcefield/openff-toolkit/pull/535): Extends the the API for the + [`Molecule.to_smiles`](openff.toolkit.topology.Molecule.to_smiles) to allow for the creation of cmiles identifiers through combinations of isomeric, explicit hydrogen and mapped smiles, the default settings will return isomeric explicit hydrogen smiles as expected. .. warning:: Atom maps can be supplied to the properties dictionary to modify which atoms have their map index included, if no map is supplied all atoms will be mapped in the order they appear in the - :py:class:`Molecule `. + [`Molecule`](openff.toolkit.topology.Molecule). -- `PR #563 `_: - Adds ``test_forcefields/ion_charges.offxml``, giving ``LibraryCharges`` for monatomic ions. -- `PR #543 `_: - Adds 3 new methods to the :py:class:`Molecule ` class which allow the enumeration of molecule - states. These are :py:meth:`Molecule.enumerate_tautomers `, - :py:meth:`Molecule.enumerate_stereoisomers `, - :py:meth:`Molecule.enumerate_protomers ` +- [PR #563](https://github.com/openforcefield/openff-toolkit/pull/563): + Adds `test_forcefields/ion_charges.offxml`, giving `LibraryCharges` for monatomic ions. +- [PR #543](https://github.com/openforcefield/openff-toolkit/pull/543): + Adds 3 new methods to the [`Molecule`](openff.toolkit.topology.Molecule) class which allow the enumeration of molecule + states. These are [`Molecule.enumerate_tautomers`](openff.toolkit.topology.Molecule.enumerate_tautomers), + [`Molecule.enumerate_stereoisomers`](openff.toolkit.topology.Molecule.enumerate_stereoisomers), + [`Molecule.enumerate_protomers`](openff.toolkit.topology.Molecule.enumerate_protomers) .. warning:: Enumerate protomers is currently only available through the OpenEye toolkit. -- `PR #573 `_: - Adds ``quacpac`` error output to ``quacpac`` failure in ``Molecule.compute_partial_charges_am1bcc``. -- `PR #560 `_: Added visualization method to the the Molecule class. -- `PR #620 `_: Added the ability to register parameter handlers via entry point plugins. This functionality is accessible by initializing a ``ForceField`` with the ``load_plugins=True`` keyword argument. -- `PR #582 `_: Added fractional bond order interpolation - Adds `return_topology` kwarg to - :py:meth:`Forcefield.create_openmm_system `, - which returns the processed topology along with the OpenMM ``System`` when ``True`` (default ``False``). - -Tests added -""""""""""" -- `PR #558 `_: Adds tests ensuring +- [PR #573](https://github.com/openforcefield/openff-toolkit/pull/573): + Adds `quacpac` error output to `quacpac` failure in `Molecule.compute_partial_charges_am1bcc`. +- [PR #560](https://github.com/openforcefield/openff-toolkit/issues/560): Added visualization method to the the Molecule class. +- [PR #620](https://github.com/openforcefield/openff-toolkit/pull/620): Added the ability to register parameter handlers via entry + point plugins. This functionality is accessible by initializing a `ForceField` with the `load_plugins=True` keyword argument. +- [PR #582](https://github.com/openforcefield/openff-toolkit/pull/582): Added fractional bond order interpolation + Adds `return_topology` kwarg to `Forcefield.create_openmm_system`, which returns the processed topology along with the OpenMM + `System` when `True` (default `False`). + +### Tests added +- [PR #558](https://github.com/openforcefield/openff-toolkit/pull/558): Adds tests ensuring that the new Topology particle indexing system are properly implemented, and that TopologyVirtualSites reference the correct TopologyAtoms. -- `PR #469 `_: Added round-trip SMILES test - to add coverage for :py:meth:`Molecule.from_smiles `. -- `PR #469 `_: Added tests for unique atom - naming behavior in :py:meth:`Topology.to_openmm `, as - well as tests of the ``ensure_unique_atom_names=False`` kwarg disabling this behavior. -- `PR #472 `_: Added tests for - :py:meth:`Molecule.hill_formula ` and - :py:meth:`Molecule.to_hill_formula ` for the +- [PR #469](https://github.com/openforcefield/openff-toolkit/pull/469): Added round-trip SMILES test + to add coverage for [`Molecule.from_smiles`](openff.toolkit.topology.Molecule.from_smiles). +- [PR #469](https://github.com/openforcefield/openff-toolkit/pull/469): Added tests for unique atom + naming behavior in [`Topology.to_openmm`](openff.toolkit.topology.Topology.to_openmm), as + well as tests of the `ensure_unique_atom_names=False` kwarg disabling this behavior. +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Added tests for + [`Molecule.hill_formula`](openff.toolkit.topology.Molecule.hill_formula) and + [`Molecule.to_hill_formula`](openff.toolkit.topology.Molecule.to_hill_formula) for the various supported input types. -- `PR #472 `_: Added round-trip test for - :py:meth:`Molecule.from_qcschema ` and - :py:meth:`Molecule.to_qcschema `. -- `PR #472 `_: Added tests for - :py:meth:`Molecule.is_isomorphic_with ` and - :py:meth:`Molecule.are_isomorphic ` +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Added round-trip test for + [`Molecule.from_qcschema`](openff.toolkit.topology.Molecule.from_qcschema) and + [`Molecule.to_qcschema`](openff.toolkit.topology.Molecule.to_qcschema). +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Added tests for + [`Molecule.is_isomorphic_with`](openff.toolkit.topology.Molecule.is_isomorphic_with) and + [`Molecule.are_isomorphic`](openff.toolkit.topology.Molecule.are_isomorphic) with various levels of isomorphic graph matching. -- `PR #472 `_: Added toolkit dependent tests - for :py:meth:`Molecule.canonical_order_atoms ` +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Added toolkit dependent tests + for [`Molecule.canonical_order_atoms`](openff.toolkit.topology.Molecule.canonical_order_atoms) due to differences in the algorithms used. -- `PR #472 `_: Added a test for - :py:meth:`Molecule.from_mapped_smiles ` using +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Added a test for + [`Molecule.from_mapped_smiles`](openff.toolkit.topology.Molecule.from_mapped_smiles) using the molecule from issue #412 to ensure it is now fixed. -- `PR #472 `_: Added a test for - :py:meth:`Molecule.remap `, this also checks for expected +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Added a test for + [`Molecule.remap`](openff.toolkit.topology.Molecule.remap), this also checks for expected error when the mapping is not complete. -- `PR #472 `_: Added tests for - :py:meth:`Molecule.from_pdb_and_smiles ` +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Added tests for + [`Molecule.from_pdb_and_smiles`](openff.toolkit.topology.Molecule.from_pdb_and_smiles) to check for a correct combination of smiles and PDB and incorrect combinations. -- `PR #509 `_: Added test for - :py:meth:`Molecule.chemical_environment_matches ` +- [PR #509](https://github.com/openforcefield/openff-toolkit/pull/509): Added test for + [`Molecule.chemical_environment_matches`](openff.toolkit.topology.Molecule.chemical_environment_matches) to check that the complete set of matches is returned. -- `PR #509 `_: Added test for - :py:meth:`Forcefield.create_openmm_system ` - to check that a protein system can be created. -- `PR #506 `_: Added a test for the molecule +- [PR #509](https://github.com/openforcefield/openff-toolkit/pull/509): Added test for + `Forcefield.create_openmm_system` to check that a protein system can be created. +- [PR #506](https://github.com/openforcefield/openff-toolkit/pull/506): Added a test for the molecule identified in issue #513 as losing aromaticity when converted to rdkit. -- `PR #506 `_: Added a verity of toolkit dependent tests +- [PR #506](https://github.com/openforcefield/openff-toolkit/pull/506): Added a verity of toolkit dependent tests for identifying rotatable bonds while ignoring the user requested types. -- `PR #521 `_: Added toolkit independent round-trip InChI - tests which add coverage for :py:meth:`Molecule.to_inchi ` and - :py:meth:`Molecule.from_inchi `. Also added coverage for bad inputs and - :py:meth:`Molecule.to_inchikey `. -- `PR #529 `_: Added to XYZ file coverage tests. -- `PR #563 `_: Added `LibraryCharges` parameterization test - for monatomic ions in ``test_forcefields/ion_charges.offxml``. -- `PR #543 `_: Added tests to assure that state enumeration can +- [PR #521](https://github.com/openforcefield/openff-toolkit/pull/521): Added toolkit independent round-trip InChI + tests which add coverage for [`Molecule.to_inchi`](openff.toolkit.topology.Molecule.to_inchi) and + [`Molecule.from_inchi`](openff.toolkit.topology.Molecule.from_inchi). Also added coverage for bad inputs and + [`Molecule.to_inchikey`](openff.toolkit.topology.Molecule.to_inchikey). +- [PR #529](https://github.com/openforcefield/openff-toolkit/pull/529): Added to XYZ file coverage tests. +- [PR #563](https://github.com/openforcefield/openff-toolkit/pull/563): Added `LibraryCharges` parameterization test + for monatomic ions in `test_forcefields/ion_charges.offxml`. +- [PR #543](https://github.com/openforcefield/openff-toolkit/pull/543): Added tests to assure that state enumeration can correctly find molecules tautomers, stereoisomers and protomers when possible. -- `PR #573 `_: Added test for ``quacpac`` error output - for ``quacpac`` failure in ``Molecule.compute_partial_charges_am1bcc``. -- `PR #579 `_: Adds regression tests to ensure RDKit can be +- [PR #573](https://github.com/openforcefield/openff-toolkit/pull/573): Added test for `quacpac` error output + for `quacpac` failure in `Molecule.compute_partial_charges_am1bcc`. +- [PR #579](https://github.com/openforcefield/openff-toolkit/pull/579): Adds regression tests to ensure RDKit can be be used to write multi-model PDB files. -- `PR #582 `_: Added fractional bond order interpolation tests, - tests for :py:class:`ValidatedDict `. - - -Bugfixes -"""""""" -- `PR #558 `_: Fixes a bug where - :py:meth:`TopologyVirtualSite.atoms ` would - not correctly apply ``TopologyMolecule`` atom ordering on top of the reference molecule ordering, - in cases where the same molecule appears multiple times, but in a different order, in the same Topology. -- `Issue #460 `_: Creates unique atom - names in :py:meth:`Topology.to_openmm ` if the existing +- [PR #582](https://github.com/openforcefield/openff-toolkit/pull/582): Added fractional bond order interpolation tests, + tests for [`ValidatedDict`](openff.toolkit.utils.collections.ValidatedDict). + + +### Bugfixes +- [PR #558](https://github.com/openforcefield/openff-toolkit/pull/558): Fixes a bug where + `TopologyVirtualSite.atoms` would not correctly apply `TopologyMolecule` atom ordering + on top of the reference molecule ordering, in cases where the same molecule appears multiple times, + but in a different order, in the same Topology. +- [Issue #460](https://github.com/openforcefield/openff-toolkit/issues/460): Creates unique atom + names in [`Topology.to_openmm`](openff.toolkit.topology.Topology.to_openmm) if the existing ones are not unique. The lack of unique atom names had been causing problems in workflows involving downstream tools that expect unique atom names. -- `Issue #448 `_: We can now make molecules - from mapped smiles using :py:meth:`Molecule.from_mapped_smiles ` +- [Issue #448](https://github.com/openforcefield/openff-toolkit/issues/448): We can now make molecules + from mapped smiles using [`Molecule.from_mapped_smiles`](openff.toolkit.topology.Molecule.from_mapped_smiles) where the order will correspond to the indeing used in the smiles. Molecules can also be re-indexed at any time using the - :py:meth:`Molecule.remap `. -- `Issue #462 `_: We can now instance the - :py:class:`Molecule ` from a QCArchive entry record instance or dictionary + [`Molecule.remap`](openff.toolkit.topology.Molecule.remap). +- [Issue #462](https://github.com/openforcefield/openff-toolkit/issues/462): We can now instance the + [`Molecule`](openff.toolkit.topology.Molecule) from a QCArchive entry record instance or dictionary representation. -- `Issue #412 `_: We can now instance the - :py:class:`Molecule ` using - :py:meth:`Molecule.from_mapped_smiles `. This resolves +- [Issue #412](https://github.com/openforcefield/openff-toolkit/issues/412): We can now instance the + [`Molecule`](openff.toolkit.topology.Molecule) using + [`Molecule.from_mapped_smiles`](openff.toolkit.topology.Molecule.from_mapped_smiles). This resolves an issue caused by RDKit considering atom map indices to be a distinguishing feature of an atom, which led to erroneous definition of chirality (as otherwise symmetric substituents would be seen as different). We anticipate that this will reduce the number of times you need to - type ``allow_undefined_stereo=True`` when processing molecules that do not actually contain stereochemistrty. -- `Issue #513 `_: The - :py:meth:`Molecule.to_rdkit ` now re-sets the aromaticity model + type `allow_undefined_stereo=True` when processing molecules that do not actually contain stereochemistrty. +- [Issue #513](https://github.com/openforcefield/openff-toolkit/issues/513): The + [`Molecule.to_rdkit`](openff.toolkit.topology.Molecule.to_rdkit) now re-sets the aromaticity model after sanitizing the molecule. -- `Issue #500 `_: The - :py:meth:`Molecule.find_rotatable_bonds ` has been added - which returns a list of rotatable :py:class:`Bond ` instances for the molecule. -- `Issue #491 `_: We can now parse large molecules without hitting a match limit cap. -- `Issue #474 `_: We can now convert molecules to InChI and +- [Issue #500](https://github.com/openforcefield/openff-toolkit/issues/500): The + [`Molecule.find_rotatable_bonds`](openff.toolkit.topology.Molecule.find_rotatable_bonds) has been added + which returns a list of rotatable [`Bond`](openff.toolkit.topology.Bond) instances for the molecule. +- [Issue #491](https://github.com/openforcefield/openff-toolkit/issues/491): We can now parse large molecules without hitting a match limit cap. +- [Issue #474](https://github.com/openforcefield/openff-toolkit/issues/474): We can now convert molecules to InChI and InChIKey and from InChI. -- `Issue #523 `_: The - :py:meth:`Molecule.to_file ` method can now correctly write to ``MOL`` +- [Issue #523](https://github.com/openforcefield/openff-toolkit/issues/523): The + [`Molecule.to_file`](openff.toolkit.topology.Molecule.to_file) method can now correctly write to `MOL` files, in line with the supported file type list. -- `Issue #568 `_: The - :py:meth:`Molecule.to_file ` can now correctly write multi-model PDB files +- [Issue #568](https://github.com/openforcefield/openff-toolkit/issues/568): The + [`Molecule.to_file`](openff.toolkit.topology.Molecule.to_file) can now correctly write multi-model PDB files when using the RDKit backend toolkit. -Examples added -"""""""""""""" -- `PR #591 `_ and - `PR #533 `_: Adds an - `example notebook and utility to compute conformer energies `_. +### Examples added +- [PR #591](https://github.com/openforcefield/openff-toolkit/pull/591) and + [PR #533](https://github.com/openforcefield/openff-toolkit/pull/533): Adds an + [example notebook and utility to compute conformer energies](https://github.com/openforcefield/openff-toolkit/blob/master/examples/conformer_energies). This example is made to be reverse-compatible with the 0.6.0 OpenFF Toolkit release. -- `PR #472 `_: Adds an example notebook - `QCarchive_interface.ipynb `_ - which shows users how to instance the :py:class:`Molecule ` from +- [PR #472](https://github.com/openforcefield/openff-toolkit/pull/472): Adds an example notebook + [QCarchive_interface.ipynb](https://github.com/openforcefield/openff-toolkit/blob/master/examples/QCArchive_interface/QCarchive_interface.ipynb) + which shows users how to instance the [`Molecule`](openff.toolkit.topology.Molecule) from a QCArchive entry level record and calculate the energy using RDKit through QCEngine. -0.6.0 - Library Charges ------------------------ +## 0.6.0 - Library Charges This release adds support for a new SMIRKS-based charge assignment method, -`Library Charges `_. +[Library Charges](https://openforcefield.github.io/standards/standards/smirnoff/#librarycharges-library-charges-for-polymeric-residues-and-special-solvent-models). The addition of more charge assignment methods opens the door for new types of experimentation, but also introduces several complex behaviors and failure modes. Accordingly, we have made changes @@ -2172,104 +2108,98 @@ to generate charges for a molecule. More detailed explanation of the new errors keywords for overriding them are in the "Behavior Changed" section below. -With this release, we update ``test_forcefields/tip3p.offxml`` to be a working example of assigning LibraryCharges. -However, we do not provide any force field files to assign protein residue ``LibraryCharges``. +With this release, we update `test_forcefields/tip3p.offxml` to be a working example of assigning LibraryCharges. +However, we do not provide any force field files to assign protein residue `LibraryCharges`. If you are interested in translating an existing protein FF to SMIRNOFF format or developing a new one, please -feel free to contact us on the `Issue tracker `_ or open a -`Pull Request `_. +feel free to contact us on the [Issue tracker](https://github.com/openforcefield/openff-toolkit/issues) or open a +[Pull Request](https://github.com/openforcefield/openff-toolkit/pulls). -New features -"""""""""""" -- `PR #433 `_: Closes - `Issue #25 `_ by adding +### New features +- [PR #433](https://github.com/openforcefield/openff-toolkit/pull/433): Closes + [Issue #25](https://github.com/openforcefield/openff-toolkit/issues/25) by adding initial support for the - `LibraryCharges tag in the SMIRNOFF specification `_ + [LibraryCharges tag in the SMIRNOFF specification](https://openforcefield.github.io/standards/standards/smirnoff/#librarycharges-library-charges-for-polymeric-residues-and-special-solvent-models) using - :py:class:`LibraryChargeHandler `. + [`LibraryChargeHandler`](openff.toolkit.typing.engines.smirnoff.parameters.LibraryChargeHandler). For a molecule to have charges assigned using Library Charges, all of its atoms must be covered by - at least one ``LibraryCharge``. If an atom is covered by multiple ``LibraryCharge`` s, then the last - ``LibraryCharge`` matched will be applied (per the hierarchy rules in the SMIRNOFF format). + at least one `LibraryCharge`. If an atom is covered by multiple `LibraryCharge` s, then the last + `LibraryCharge` matched will be applied (per the hierarchy rules in the SMIRNOFF format). This functionality is thus able to apply per-residue charges similar to those in traditional protein force fields. At this time, there is no concept of "residues" or "fragments" during parametrization, so it is not possible to assign charges to `some` atoms in a molecule using - ``LibraryCharge`` s, but calculate charges for other atoms in the same molecule using a different + `LibraryCharge` s, but calculate charges for other atoms in the same molecule using a different method. To assign charges to a protein, LibraryCharges SMARTS must be provided for the residues and protonation states in the molecule, as well as for any capping groups and post-translational modifications that are present. - It is valid for ``LibraryCharge`` SMARTS to `partially` overlap one another. For example, a molecule - consisting of atoms ``A-B-C`` connected by single bonds could be matched by a SMIRNOFF - ``LibraryCharges`` section containing two ``LibraryCharge`` SMARTS: ``A-B`` and ``B-C``. If - listed in that order, the molecule would be assigned the ``A`` charge from the ``A-B`` ``LibraryCharge`` - element and the ``B`` and ``C`` charges from the ``B-C`` element. In testing, these types of + It is valid for `LibraryCharge` SMARTS to `partially` overlap one another. For example, a molecule + consisting of atoms `A-B-C` connected by single bonds could be matched by a SMIRNOFF + `LibraryCharges` section containing two `LibraryCharge` SMARTS: `A-B` and `B-C`. If + listed in that order, the molecule would be assigned the `A` charge from the `A-B` `LibraryCharge` + element and the `B` and `C` charges from the `B-C` element. In testing, these types of partial overlaps were found to frequently be sources of undesired behavior, so it is recommended - that users define whole-molecule ``LibraryCharge`` SMARTS whenever possible. + that users define whole-molecule `LibraryCharge` SMARTS whenever possible. -- `PR #455 `_: Addresses - `Issue #393 `_ by adding - :py:meth:`ParameterHandler.attribute_is_cosmetic ` +- [PR #455](https://github.com/openforcefield/openff-toolkit/pull/455): Addresses + [Issue #393](https://github.com/openforcefield/openff-toolkit/issues/393) by adding + [`ParameterHandler.attribute_is_cosmetic`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler.attribute_is_cosmetic) and - :py:meth:`ParameterType.attribute_is_cosmetic `, + [`ParameterType.attribute_is_cosmetic`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType.attribute_is_cosmetic), which return True if the provided attribute name is defined for the queried object but does not correspond to an allowed value in the SMIRNOFF spec. -Behavior changed -"""""""""""""""" -- `PR #433 `_: If a molecule +### Behavior changed +- [PR #433](https://github.com/openforcefield/openff-toolkit/pull/433): If a molecule can not be assigned charges by any charge-assignment method, an - ``openforcefield.typing.engines.smirnoff.parameters.UnassignedMoleculeChargeException`` - will be raised. Previously, creating a system without either ``ToolkitAM1BCCHandler`` or - the ``charge_from_molecules`` keyword argument to ``ForceField.create_openmm_system`` would - produce an OpenMM ``System`` where the molecule has zero charge on all atoms. However, given that we + `openforcefield.typing.engines.smirnoff.parameters.UnassignedMoleculeChargeException` + will be raised. Previously, creating a system without either `ToolkitAM1BCCHandler` or + the `charge_from_molecules` keyword argument to `ForceField.create_openmm_system` would + produce an OpenMM `System` where the molecule has zero charge on all atoms. However, given that we will soon be adding more options for charge assignment, it is important that failures not be silent. Molecules with zero charge can still be produced by setting the - ``Molecule.partial_charges`` array to be all zeroes, and including the molecule in the - ``charge_from_molecules`` keyword argument to ``create_openmm_system``. -- `PR #433 `_: Due to risks - introduced by permitting charge assignment using partially-overlapping ``LibraryCharge`` s, + `Molecule.partial_charges` array to be all zeroes, and including the molecule in the + `charge_from_molecules` keyword argument to `create_openmm_system`. +- [PR #433](https://github.com/openforcefield/openff-toolkit/pull/433): Due to risks + introduced by permitting charge assignment using partially-overlapping `LibraryCharge` s, the toolkit will now raise a - ``openforcefield.typing.engines.smirnoff.parameters.NonIntegralMoleculeChargeException`` + `openforcefield.typing.engines.smirnoff.parameters.NonIntegralMoleculeChargeException` if the sum of partial charges on a molecule are found to be more than 0.01 elementary charge units different than the molecule's formal charge. This exception can be overridden by providing - the ``allow_nonintegral_charges=True`` keyword argument to ``ForceField.create_openmm_system``. + the `allow_nonintegral_charges=True` keyword argument to `ForceField.create_openmm_system`. -Tests added -""""""""""" -- `PR #430 `_: Added test for +### Tests added +- [PR #430](https://github.com/openforcefield/openff-toolkit/pull/430): Added test for Wiberg Bond Order implemented in OpenEye Toolkits. Molecules taken from DOI:10.5281/zenodo.3405489 . Added by Sukanya Sasmal. -- `PR #569 `_: Added round-trip tests for more serialization formats (dict, YAML, TOML, JSON, BSON, messagepack, pickle). Note that some are unsupported, but the tests raise the appropriate error. +- [PR #569](https://github.com/openforcefield/openff-toolkit/pull/569): Added round-trip tests for more serialization formats (dict, YAML, TOML, JSON, BSON, messagepack, pickle). Note that some are unsupported, but the tests raise the appropriate error. -Bugfixes -"""""""" -- `PR #431 `_: Fixes an issue - where ``ToolkitWrapper`` objects would improperly search for functionality in the - ``GLOBAL_TOOLKIT_REGISTRY``, even though a specific ``ToolkitRegistry`` was requested for an +### Bugfixes +- [PR #431](https://github.com/openforcefield/openff-toolkit/pull/431): Fixes an issue + where `ToolkitWrapper` objects would improperly search for functionality in the + `GLOBAL_TOOLKIT_REGISTRY`, even though a specific `ToolkitRegistry` was requested for an operation. -- `PR #439 `_: Fixes - `Issue #438 `_, by replacing - call to NetworkX ``Graph.node`` with call to ``Graph.nodes``, per - `2.4 migration guide `_. - -Files modified -"""""""""""""" -- `PR #433 `_: Updates - the previously-nonfunctional ``test_forcefields/tip3p.offxml`` to a functional state +- [PR #439](https://github.com/openforcefield/openff-toolkit/pull/439): Fixes + [Issue #438](https://github.com/openforcefield/openff-toolkit/issues/438), by replacing + call to NetworkX `Graph.node` with call to `Graph.nodes`, per + [2.4 migration guide](https://networkx.github.io/documentation/stable/release/release_2.4.html). + +### Files modified +- [PR #433](https://github.com/openforcefield/openff-toolkit/pull/433): Updates + the previously-nonfunctional `test_forcefields/tip3p.offxml` to a functional state by updating it to the SMIRNOFF - 0.3 specification, and specifying atomic charges using the ``LibraryCharges`` tag. + 0.3 specification, and specifying atomic charges using the `LibraryCharges` tag. -0.5.1 - Adding the parameter coverage example notebook ------------------------------------------------------- +## 0.5.1 - Adding the parameter coverage example notebook This release contains a new notebook example, -`check_parameter_coverage.ipynb `_, +[check_parameter_coverage.ipynb](https://github.com/openforcefield/openff-toolkit/blob/master/examples/check_dataset_parameter_coverage/check_parameter_coverage.ipynb), which loads sets of molecules, checks whether they are parameterizable, and generates reports of chemical motifs that are not. It also fixes several simple issues, improves warnings and docstring text, @@ -2277,7 +2207,7 @@ and removes unused files. The parameter coverage example notebook goes hand-in-hand with the release candidate of our initial force field, -`openff-1.0.0-RC1.offxml `_ +[openff-1.0.0-RC1.offxml](https://github.com/openforcefield/openforcefields) , which will be temporarily available until the official force field release is made in October. Our goal in publishing this notebook alongside our first major refitting is to allow interested @@ -2289,264 +2219,251 @@ notebook can easily be cropped to communicate unparameterizable chemistry withou the full structure. The force field release candidate is in our new refit force field package, -`openforcefields `_. +[openforcefields](https://github.com/openforcefield/openforcefields). This package is now a part of the Open Force Field Toolkit conda recipe, along with the original -`smirnoff99Frosst `_ line of force fields. +[smirnoff99Frosst](https://github.com/openforcefield/smirnoff99Frosst) line of force fields. -Once the ``openforcefields`` conda package is installed, you can load the release candidate using: +Once the `openforcefields` conda package is installed, you can load the release candidate using: -``ff = ForceField('openff-1.0.0-RC1.offxml')`` +`ff = ForceField('openff-1.0.0-RC1.offxml')` The release candidate will be removed when the official force field, -``openff-1.0.0.offxml``, is released in early October. +`openff-1.0.0.offxml`, is released in early October. Complete details about this release are below. -Example added -""""""""""""" -- `PR #419 `_: Adds +### Example added +- [PR #419](https://github.com/openforcefield/openff-toolkit/pull/419): Adds an example notebook - `check_parameter_coverage.ipynb `_ + [check_parameter_coverage.ipynb](https://github.com/openforcefield/openff-toolkit/blob/master/examples/check_dataset_parameter_coverage/check_parameter_coverage.ipynb) which shows how to use the toolkit to check a molecule dataset for missing parameter coverage, and provides functionality to output tagged SMILES and 2D drawings of the unparameterizable chemistry. -New features -"""""""""""" -- `PR #419 `_: Unassigned - valence parameter exceptions now include a list of tuples of - :py:class:`TopologyAtom ` - which were unable to be parameterized (``exception.unassigned_topology_atom_tuples``) +### New features +- [PR #419](https://github.com/openforcefield/openff-toolkit/pull/419): Unassigned + valence parameter exceptions now include a list of tuples of `TopologyAtom` + which were unable to be parameterized (`exception.unassigned_topology_atom_tuples`) and the class of the - :py:class:`ParameterHandler ` - that raised the exception (``exception.handler_class``). -- `PR #425 `_: Implements + [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) + that raised the exception (`exception.handler_class`). +- [PR #425](https://github.com/openforcefield/openff-toolkit/pull/425): Implements Trevor Gokey's suggestion from - `Issue #411 `_, which + [Issue #411](https://github.com/openforcefield/openff-toolkit/issues/411), which enables pickling of - :py:class:`ForceFields ` + [`ForceFields`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) and - :py:class:`ParameterHandlers `. - Note that, while XML representations of ``ForceField``\ s are stable and conform to the SMIRNOFF - specification, the pickled ``ForceField``\ s that this functionality enables are not guaranteed + [`ParameterHandlers`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler). + Note that, while XML representations of `ForceField`\ s are stable and conform to the SMIRNOFF + specification, the pickled `ForceField`\ s that this functionality enables are not guaranteed to be compatible with future toolkit versions. -Improved documentation and warnings -""""""""""""""""""""""""""""""""""" -- `PR #425 `_: Addresses - `Issue #410 `_, by explicitly - having toolkit warnings print ``Warning:`` at the beginning of each warning, and adding +### Improved documentation and warnings +- [PR #425](https://github.com/openforcefield/openff-toolkit/pull/425): Addresses + [Issue #410](https://github.com/openforcefield/openff-toolkit/issues/410), by explicitly + having toolkit warnings print `Warning:` at the beginning of each warning, and adding clearer language to the warning produced when the OpenEye Toolkits can not be loaded. -- `PR #425 `_: Addresses - `Issue #421 `_ by +- [PR #425](https://github.com/openforcefield/openff-toolkit/pull/425): Addresses + [Issue #421](https://github.com/openforcefield/openff-toolkit/issues/421) by adding type/shape information to all Molecule partial charge and conformer docstrings. -- `PR #425 `_: Addresses - `Issue #407 `_ by +- [PR #425](https://github.com/openforcefield/openff-toolkit/pull/425): Addresses + [Issue #407](https://github.com/openforcefield/openff-toolkit/issues/421) by providing a more extensive explanation of why we don't use RDKit's mol2 parser for molecule input. -Bugfixes -"""""""" -- `PR #419 `_: Fixes - `Issue #417 `_ and - `Issue #418 `_, where - :py:meth:`RDKitToolkitWrapper.from_file ` - would disregard the ``allow_undefined_stereo`` kwarg and skip the first molecule +### Bugfixes +- [PR #419](https://github.com/openforcefield/openff-toolkit/pull/419): Fixes + [Issue #417](https://github.com/openforcefield/openff-toolkit/issues/417) and + [Issue #418](https://github.com/openforcefield/openff-toolkit/issues/418), where + [`RDKitToolkitWrapper.from_file`](openff.toolkit.utils.toolkits.RDKitToolkitWrapper.from_file) + would disregard the `allow_undefined_stereo` kwarg and skip the first molecule when reading a SMILES file. -Files removed -""""""""""""" -- `PR #425 `_: Addresses - `Issue #424 `_ by - deleting the unused files ``openforcefield/typing/engines/smirnoff/gbsaforces.py`` - and ``openforcefield/tests/test_smirnoff.py``. ``gbsaforces.py`` was only used internally - and ``test_smirnoff.py`` tested unsupported functionality from before the 0.2.0 release. +### Files removed +- [PR #425](https://github.com/openforcefield/openff-toolkit/pull/425): Addresses + [Issue #424](https://github.com/openforcefield/openff-toolkit/issues/424) by + deleting the unused files `openforcefield/typing/engines/smirnoff/gbsaforces.py` + and `openforcefield/tests/test_smirnoff.py`. `gbsaforces.py` was only used internally + and `test_smirnoff.py` tested unsupported functionality from before the 0.2.0 release. -0.5.0 - GBSA support and quality-of-life improvements ------------------------------------------------------ +## 0.5.0 - GBSA support and quality-of-life improvements This release adds support for the -`GBSA tag in the SMIRNOFF specification `_. -Currently, the ``HCT``, ``OBC1``, and ``OBC2`` models (corresponding to AMBER keywords -``igb=1``, ``2``, and ``5``, respectively) are supported, with the ``OBC2`` implementation being +[GBSA tag in the SMIRNOFF specification](https://openforcefield.github.io/standards/standards/smirnoff/#gbsa). +Currently, the `HCT`, `OBC1`, and `OBC2` models (corresponding to AMBER keywords +`igb=1`, `2`, and `5`, respectively) are supported, with the `OBC2` implementation being the most flexible. Unfortunately, systems produced using these keywords are not yet transferable to other simulation packages via ParmEd, so users are restricted to using OpenMM to simulate systems with GBSA. OFFXML files containing GBSA parameter definitions are available, and can be loaded in addition to existing parameter sets (for example, with the command -``ForceField('test_forcefields/smirnoff99Frosst.offxml', 'test_forcefields/GBSA_OBC1-1.0.offxml')``). +`ForceField('test_forcefields/smirnoff99Frosst.offxml', 'test_forcefields/GBSA_OBC1-1.0.offxml')`). A manifest of new SMIRNOFF-format GBSA files is below. Several other user-facing improvements have been added, including easier access to indexed attributes, -which are now accessible as ``torsion.k1``, ``torsion.k2``, etc. (the previous access method -``torsion.k`` still works as well). More details of the new features and several bugfixes are listed below. +which are now accessible as `torsion.k1`, `torsion.k2`, etc. (the previous access method +`torsion.k` still works as well). More details of the new features and several bugfixes are listed below. -New features -"""""""""""" -- `PR #363 `_: Implements - :py:class:`GBSAHandler `, +### New features +- [PR #363](https://github.com/openforcefield/openff-toolkit/pull/363): Implements + [`GBSAHandler`](openff.toolkit.typing.engines.smirnoff.parameters.GBSAHandler), which supports the - `GBSA tag in the SMIRNOFF specification `_. - Currently, only GBSAHandlers with ``gb_model="OBC2"`` support - setting non-default values for the ``surface_area_penalty`` term (default ``5.4*calories/mole/angstroms**2``), - though users can zero the SA term for ``OBC1`` and ``HCT`` models by setting ``sa_model="None"``. - No model currently supports setting ``solvent_radius`` to any value other than ``1.4*angstroms``. - Files containing experimental SMIRNOFF-format implementations of ``HCT``, ``OBC1``, and ``OBC2`` are + [GBSA tag in the SMIRNOFF specification](https://openforcefield.github.io/standards/standards/smirnoff/#gbsa). + Currently, only GBSAHandlers with `gb_model="OBC2"` support + setting non-default values for the `surface_area_penalty` term (default `5.4*calories/mole/angstroms**2`), + though users can zero the SA term for `OBC1` and `HCT` models by setting `sa_model="None"`. + No model currently supports setting `solvent_radius` to any value other than `1.4*angstroms`. + Files containing experimental SMIRNOFF-format implementations of `HCT`, `OBC1`, and `OBC2` are included with this release (see below). Additional details of these models, including literature references, are available on the - `SMIRNOFF specification page `_. + [SMIRNOFF specification page](https://openforcefield.github.io/standards/standards/smirnoff/#supported-generalized-born-gb-models). .. warning :: The current release of ParmEd - `can not transfer GBSA models produced by the Open Force Field Toolkit + [can not transfer GBSA models produced by the Open Force Field Toolkit to other simulation packages - `_. + ](https://github.com/ParmEd/ParmEd/blob/3.2.0/parmed/openmm/topsystem.py#L148-L150). These GBSA forces are currently only computable using OpenMM. -- `PR #363 `_: When using - :py:meth:`Topology.to_openmm() `, periodic +- [PR #363](https://github.com/openforcefield/openff-toolkit/pull/363): When using + [`Topology.to_openmm()`](openff.toolkit.topology.Topology.to_openmm), periodic box vectors are now transferred from the Open Force Field Toolkit Topology into the newly-created OpenMM Topology. -- `PR #377 `_: Single indexed parameters in - :py:class:`ParameterHandler ` - and :py:class:`ParameterType ` +- [PR #377](https://github.com/openforcefield/openff-toolkit/pull/377): Single indexed parameters in + [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) + and [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) can now be get/set through normal attribute syntax in addition to the list syntax. -- `PR #394 `_: Include element and atom name +- [PR #394](https://github.com/openforcefield/openff-toolkit/pull/394): Include element and atom name in error output when there are missing valence parameters during molecule parameterization. -Bugfixes -"""""""" -- `PR #385 `_: Fixes - `Issue #346 `_ by - having :py:meth:`OpenEyeToolkitWrapper.compute_partial_charges_am1bcc ` - fall back to using standard AM1-BCC if AM1-BCC ELF10 charge generation raises +### Bugfixes +- [PR #385](https://github.com/openforcefield/openff-toolkit/pull/385): Fixes + [Issue #346](https://github.com/openforcefield/openff-toolkit/issues/346) by + having `OpenEyeToolkitWrapper.compute_partial_charges_am1bcc` fall back to + using standard AM1-BCC if AM1-BCC ELF10 charge generation raises an error about "trans COOH conformers" -- `PR #399 `_: Fixes +- [PR #399](https://github.com/openforcefield/openff-toolkit/pull/399): Fixes issue where - :py:class:`ForceField ` - constructor would ignore ``parameter_handler_classes`` kwarg. -- `PR #400 `_: Makes + [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) + constructor would ignore `parameter_handler_classes` kwarg. +- [PR #400](https://github.com/openforcefield/openff-toolkit/pull/400): Makes link-checking tests retry three times before failing. -Files added -""""""""""" -- `PR #363 `_: Adds - ``test_forcefields/GBSA_HCT-1.0.offxml``, ``test_forcefields/GBSA_OBC1-1.0.offxml``, - and ``test_forcefields/GBSA_OBC2-1.0.offxml``, which are experimental implementations +### Files added +- [PR #363](https://github.com/openforcefield/openff-toolkit/pull/363): Adds + `test_forcefields/GBSA_HCT-1.0.offxml`, `test_forcefields/GBSA_OBC1-1.0.offxml`, + and `test_forcefields/GBSA_OBC2-1.0.offxml`, which are experimental implementations of GBSA models. These are primarily used in validation tests against OpenMM's models, and their version numbers will increment if bugfixes are necessary. -0.4.1 - Bugfix Release ----------------------- +## 0.4.1 - Bugfix Release This update fixes several toolkit bugs that have been reported by the community. Details of these bugfixes are provided below. It also refactors how -:py:class:`ParameterType ` +[`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) and -:py:class:`ParameterHandler ` +[`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) store their attributes, by introducing -:py:class:`ParameterAttribute ` +[`ParameterAttribute`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterAttribute) and -:py:class:`IndexedParameterAttribute `. +[`IndexedParameterAttribute`](openff.toolkit.typing.engines.smirnoff.parameters.IndexedParameterAttribute). These new attribute-handling classes provide a consistent backend which should simplify manipulation of parameters and implementation of new handlers. -Bug fixes -""""""""" -- `PR #329 `_: Fixed a +### Bug fixes +- [PR #329](https://github.com/openforcefield/openff-toolkit/pull/329): Fixed a bug where the two - :py:class:`BondType ` - parameter attributes ``k`` and ``length`` were treated as indexed attributes. (``k`` and - ``length`` values that correspond to specific bond orders will be indexed under - ``k_bondorder1``, ``k_bondorder2``, etc when implemented in the future) -- `PR #329 `_: Fixed a + [`BondType`](openff.toolkit.typing.engines.smirnoff.parameters.BondHandler.BondType) + parameter attributes `k` and `length` were treated as indexed attributes. (`k` and + `length` values that correspond to specific bond orders will be indexed under + `k_bondorder1`, `k_bondorder2`, etc when implemented in the future) +- [PR #329](https://github.com/openforcefield/openff-toolkit/pull/329): Fixed a bug that allowed setting indexed attributes to single values instead of strictly lists. -- `PR #370 `_: Fixed a +- [PR #370](https://github.com/openforcefield/openff-toolkit/pull/370): Fixed a bug in the API where - :py:class:`BondHandler `, - :py:class:`ProperTorsionHandler ` + [`BondHandler`](openff.toolkit.typing.engines.smirnoff.parameters.BondHandler), + [`ProperTorsionHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ProperTorsionHandler) , and - :py:class:`ImproperTorsionHandler ` + [`ImproperTorsionHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ImproperTorsionHandler) exposed non-functional indexed parameters. -- `PR #351 `_: Fixes - `Issue #344 `_, - in which the main :py:class:`FrozenMolecule ` +- [PR #351](https://github.com/openforcefield/openff-toolkit/pull/351): Fixes + [Issue #344](https://github.com/openforcefield/openff-toolkit/issues/344), + in which the main [`FrozenMolecule`](openff.toolkit.topology.FrozenMolecule) constructor and several other Molecule-construction functions ignored or did not - expose the ``allow_undefined_stereo`` keyword argument. -- `PR #351 `_: Fixes + expose the `allow_undefined_stereo` keyword argument. +- [PR #351](https://github.com/openforcefield/openff-toolkit/pull/351): Fixes a bug where a molecule which previously generated a SMILES using one cheminformatics toolkit returns the same SMILES, even though a different toolkit (which would generate a different SMILES for the molecule) is explicitly called. -- `PR #354 `_: Fixes +- [PR #354](https://github.com/openforcefield/openff-toolkit/pull/354): Fixes the error message that is printed if an unexpected parameter attribute is found while loading - data into a :py:class:`ForceField ` - (now instructs users to specify ``allow_cosmetic_attributes`` instead of ``permit_cosmetic_attributes``) -- `PR #364 `_: Fixes - `Issue #362 `_ by + data into a [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) + (now instructs users to specify `allow_cosmetic_attributes` instead of `permit_cosmetic_attributes`) +- [PR #364](https://github.com/openforcefield/openff-toolkit/pull/364): Fixes + [Issue #362](https://github.com/openforcefield/openff-toolkit/issues/362) by modifying - :py:meth:`OpenEyeToolkitWrapper.from_smiles ` + [`OpenEyeToolkitWrapper.from_smiles`](openff.toolkit.utils.toolkits.OpenEyeToolkitWrapper.from_smiles) and - :py:meth:`RDKitToolkitWrapper.from_smiles ` + [`RDKitToolkitWrapper.from_smiles`](openff.toolkit.utils.toolkits.RDKitToolkitWrapper.from_smiles) to make implicit hydrogens explicit before molecule creation. These functions also - now raise an error if the optional keyword ``hydrogens_are_explicit=True`` but the + now raise an error if the optional keyword `hydrogens_are_explicit=True` but the SMILES are interpreted by the backend cheminformatic toolkit as having implicit hydrogens. -- `PR #371 `_: Fixes - error when reading early SMIRNOFF 0.1 spec files enclosed by a top-level ``SMIRFF`` tag. +- [PR #371](https://github.com/openforcefield/openff-toolkit/pull/371): Fixes + error when reading early SMIRNOFF 0.1 spec files enclosed by a top-level `SMIRFF` tag. .. note :: - The enclosing ``SMIRFF`` tag is present only in legacy files. + The enclosing `SMIRFF` tag is present only in legacy files. Since developing a formal specification, the only acceptable top-level tag value in a SMIRNOFF data structure is - ``SMIRNOFF``. + `SMIRNOFF`. -Code enhancements -""""""""""""""""" -- `PR #329 `_: - :py:class:`ParameterType ` +### Code enhancements +- [PR #329](https://github.com/openforcefield/openff-toolkit/pull/329): + [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) was refactored to improve its extensibility. It is now possible to create new parameter types by using the new descriptors - :py:class:`ParameterAttribute ` + [`ParameterAttribute`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterAttribute) and - :py:class:`IndexedParameterAttribute `. -- `PR #357 `_: Addresses - `Issue #356 `_ by raising + [`IndexedParameterAttribute`](openff.toolkit.typing.engines.smirnoff.parameters.IndexedParameterAttribute). +- [PR #357](https://github.com/openforcefield/openff-toolkit/pull/357): Addresses + [Issue #356](https://github.com/openforcefield/openff-toolkit/issues/356) by raising an informative error message if a user attempts to load an OpenMM topology which is probably missing connectivity information. -Force fields added -"""""""""""""""""" -- `PR #368 `_: Temporarily adds - ``test_forcefields/smirnoff99frosst_experimental.offxml`` to address hierarchy problems, redundancies, SMIRKS - pattern typos etc., as documented in `issue #367 `_. - Will ultimately be propagated to an updated force field in the ``openforcefield/smirnoff99frosst`` repo. -- `PR #371 `_: Adds - ``test_forcefields/smirff99Frosst_reference_0_1_spec.offxml``, a SMIRNOFF 0.1 spec file enclosed by the legacy - ``SMIRFF`` tag. This file is used in backwards-compatibility testing. +### Force fields added +- [PR #368](https://github.com/openforcefield/openff-toolkit/pull/368): Temporarily adds + `test_forcefields/smirnoff99frosst_experimental.offxml` to address hierarchy problems, redundancies, SMIRKS + pattern typos etc., as documented in [issue #367](https://github.com/openforcefield/openff-toolkit/issues/367). + Will ultimately be propagated to an updated force field in the `openforcefield/smirnoff99frosst` repo. +- [PR #371](https://github.com/openforcefield/openff-toolkit/pull/371): Adds + `test_forcefields/smirff99Frosst_reference_0_1_spec.offxml`, a SMIRNOFF 0.1 spec file enclosed by the legacy + `SMIRFF` tag. This file is used in backwards-compatibility testing. -0.4.0 - Performance optimizations and support for SMIRNOFF 0.3 specification ----------------------------------------------------------------------------- +## 0.4.0 - Performance optimizations and support for SMIRNOFF 0.3 specification -This update contains performance enhancements that significantly reduce the time to create OpenMM systems for topologies containing many molecules via :py:meth:`ForceField.create_openmm_system `. +This update contains performance enhancements that significantly reduce the time +to create OpenMM systems for topologies containing many molecules via +`ForceField.create_openmm_system`. -This update also introduces the `SMIRNOFF 0.3 specification `_. +This update also introduces the [SMIRNOFF 0.3 specification](https://open-forcefield-toolkit.readthedocs.io/en/0.4.0/smirnoff.html). The spec update is the result of discussions about how to handle the evolution of data and parameter types as further functional forms are added to the SMIRNOFF spec. -We provide methods to convert SMIRNOFF 0.1 and 0.2 force fields written with the XML serialization (``.offxml``) to the SMIRNOFF 0.3 specification. +We provide methods to convert SMIRNOFF 0.1 and 0.2 force fields written with the XML serialization (`.offxml`) to the SMIRNOFF 0.3 specification. These methods are called automatically when loading a serialized SMIRNOFF data representation written in the 0.1 or 0.2 specification. This functionality allows the toolkit to continue to read files containing SMIRNOFF 0.2 spec force fields, and also implements backwards-compatibility for SMIRNOFF 0.1 spec force fields. @@ -2559,141 +2476,123 @@ This functionality allows the toolkit to continue to read files containing SMIRN -`SMIRNOFF 0.3 specification updates `_ -""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" +### [SMIRNOFF 0.3 specification updates](https://open-forcefield-toolkit.readthedocs.io/en/0.4.0/smirnoff.html) * The SMIRNOFF 0.3 spec introduces versioning for each individual parameter section, allowing asynchronous updates to the features of each parameter class. - The top-level ``SMIRNOFF`` tag, containing information like ``aromaticity_model``, ``Author``, and ``Date``, still has a version (currently 0.3). - But, to allow for independent development of individual parameter types, each section (such as ``Bonds``, ``Angles``, etc) now has its own version as well (currently all 0.3). -* All units are now stored in expressions with their corresponding values. For example, distances are now stored as ``1.526*angstrom``, instead of storing the unit separately in the section header. -* The current allowed value of the ``potential`` field for ``ProperTorsions`` and ``ImproperTorsions`` tags is no longer ``charmm``, but is rather ``k*(1+cos(periodicity*theta-phase))``. + The top-level `SMIRNOFF` tag, containing information like `aromaticity_model`, `Author`, and `Date`, still has a version (currently 0.3). + But, to allow for independent development of individual parameter types, each section (such as `Bonds`, `Angles`, etc) now has its own version as well (currently all 0.3). +* All units are now stored in expressions with their corresponding values. For example, distances are now stored as `1.526*angstrom`, instead of storing the unit separately in the section header. +* The current allowed value of the `potential` field for `ProperTorsions` and `ImproperTorsions` tags is no longer `charmm`, but is rather `k*(1+cos(periodicity*theta-phase))`. It was pointed out to us that CHARMM-style torsions deviate from this formula when the periodicity of a torsion term is 0, and we do not intend to reproduce that behavior. * SMIRNOFF spec documentation has been updated with tables of keywords and their defaults for each parameter section and parameter type. These tables will track the allowed keywords and default behavior as updated versions of individual parameter sections are released. -Performance improvements and bugfixes -""""""""""""""""""""""""""""""""""""" +### Performance improvements and bugfixes -* `PR #329 `_: Performance improvements when creating systems for topologies with many atoms. -* `PR #347 `_: Fixes bug in charge assignment that occurs when charges are read from file, and reference and charge molecules have different atom orderings. +* [PR #329](https://github.com/openforcefield/openff-toolkit/pull/329): Performance improvements when creating systems for topologies with many atoms. +* [PR #347](https://github.com/openforcefield/openff-toolkit/pull/347): Fixes bug in charge assignment that occurs when charges are read from file, and reference and charge molecules have different atom orderings. -New features -"""""""""""" +### New features -* `PR #311 `_: Several new experimental functions. +* [PR #311](https://github.com/openforcefield/openff-toolkit/pull/311): Several new experimental functions. - * Adds :py:meth:`convert_0_2_smirnoff_to_0_3 `, which takes a SMIRNOFF 0.2-spec data dict, and updates it to 0.3. - This function is called automatically when creating a ``ForceField`` from a SMIRNOFF 0.2 spec OFFXML file. - * Adds :py:meth:`convert_0_1_smirnoff_to_0_2 `, which takes a SMIRNOFF 0.1-spec data dict, and updates it to 0.2. - This function is called automatically when creating a ``ForceField`` from a SMIRNOFF 0.1 spec OFFXML file. + * Adds [`convert_0_2_smirnoff_to_0_3`](openff.toolkit.utils.utils.convert_0_2_smirnoff_to_0_3), which takes a SMIRNOFF 0.2-spec data dict, and updates it to 0.3. + This function is called automatically when creating a `ForceField` from a SMIRNOFF 0.2 spec OFFXML file. + * Adds [`convert_0_1_smirnoff_to_0_2`](openff.toolkit.utils.utils.convert_0_1_smirnoff_to_0_2), which takes a SMIRNOFF 0.1-spec data dict, and updates it to 0.2. + This function is called automatically when creating a `ForceField` from a SMIRNOFF 0.1 spec OFFXML file. * NOTE: The format of the "SMIRNOFF data dict" above is likely to change significantly in the future. - Users that require a stable serialized ForceField object should use the output of :py:meth:`ForceField.to_string('XML') ` instead. - * Adds :py:class:`ParameterHandler ` and :py:class:`ParameterType ` :py:meth:`add_cosmetic_attribute ` and :py:meth:`delete_cosmetic_attribute ` functions. - Once created, cosmetic attributes can be accessed and modified as attributes of the underlying object (eg. ``ParameterType.my_cosmetic_attrib = 'blue'``) - These functions are experimental, and we are interested in feedback on how cosmetic attribute handling could be improved. (`See Issue #338 `_) + Users that require a stable serialized ForceField object should use the output of [`ForceField.to_string('XML')`](openff.toolkit.typing.engines.smirnoff.ForceField.to_string) instead. + * Adds [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) and [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) [`add_cosmetic_attribute`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType.add_cosmetic_attribute) and [`delete_cosmetic_attribute`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType.delete_cosmetic_attribute) functions. + Once created, cosmetic attributes can be accessed and modified as attributes of the underlying object (eg. `ParameterType.my_cosmetic_attrib = 'blue'`) + These functions are experimental, and we are interested in feedback on how cosmetic attribute handling could be improved. ([See Issue #338](https://github.com/openforcefield/openff-toolkit/issues/338)) Note that if a new cosmetic attribute is added to an object without using these functions, it will not be recognized by the toolkit and will not be written out during serialization. - * Values for the top-level ``Author`` and ``Date`` tags are now kept during SMIRNOFF data I/O. + * Values for the top-level `Author` and `Date` tags are now kept during SMIRNOFF data I/O. If multiple data sources containing these fields are read, the values are concatenated using "AND" as a separator. -API-breaking changes -"""""""""""""""""""" -* :py:meth:`ForceField.to_string ` and :py:meth:`ForceField.to_file ` have had the default value of their ``discard_cosmetic_attributes`` kwarg set to False. -* :py:class:`ParameterHandler ` and :py:class:`ParameterType ` constructors now expect the ``version`` kwarg (per the SMIRNOFF spec change above) - This requirement can be skipped by providing the kwarg ``skip_version_check=True`` -* :py:class:`ParameterHandler ` and :py:class:`ParameterType ` functions no longer handle ``X_unit`` attributes in SMIRNOFF data (per the SMIRNOFF spec change above). -* The scripts in ``utilities/convert_frosst`` are now deprecated. - This functionality is important for provenance and will be migrated to the ``openforcefield/smirnoff99Frosst`` repository in the coming weeks. -* :py:class:`ParameterType ` ``._SMIRNOFF_ATTRIBS`` is now :py:class:`ParameterType ` ``._REQUIRED_SPEC_ATTRIBS``, to better parallel the structure of the ``ParameterHandler`` class. -* :py:class:`ParameterType ` ``._OPTIONAL_ATTRIBS`` is now :py:class:`ParameterType ` ``._OPTIONAL_SPEC_ATTRIBS``, to better parallel the structure of the ``ParameterHandler`` class. -* Added class-level dictionaries :py:class:`ParameterHandler ` ``._DEFAULT_SPEC_ATTRIBS`` and :py:class:`ParameterType ` ``._DEFAULT_SPEC_ATTRIBS``. - -0.3.0 - API Improvements ------------------------- +### API-breaking changes +* [`ForceField.to_string`](openff.toolkit.typing.engines.smirnoff.ForceField.to_string) and [`ForceField.to_file`](openff.toolkit.typing.engines.smirnoff.ForceField.to_file) have had the default value of their `discard_cosmetic_attributes` kwarg set to False. +* [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) and [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) constructors now expect the `version` kwarg (per the SMIRNOFF spec change above) + This requirement can be skipped by providing the kwarg `skip_version_check=True` +* [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) and [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) functions no longer handle `X_unit` attributes in SMIRNOFF data (per the SMIRNOFF spec change above). +* The scripts in `utilities/convert_frosst` are now deprecated. + This functionality is important for provenance and will be migrated to the `openforcefield/smirnoff99Frosst` repository in the coming weeks. +* [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) `._SMIRNOFF_ATTRIBS` is now [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) `._REQUIRED_SPEC_ATTRIBS`, to better parallel the structure of the `ParameterHandler` class. +* [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) `._OPTIONAL_ATTRIBS` is now [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) `._OPTIONAL_SPEC_ATTRIBS`, to better parallel the structure of the `ParameterHandler` class. +* Added class-level dictionaries [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) `._DEFAULT_SPEC_ATTRIBS` and [`ParameterType`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterType) `._DEFAULT_SPEC_ATTRIBS`. + +## 0.3.0 - API Improvements Several improvements and changes to public API. -New features -"""""""""""" +### New features -* `PR #292 `_: Implement ``Topology.to_openmm`` and remove ``ToolkitRegistry.toolkit_is_available`` -* `PR #322 `_: Install directories for the lookup of OFFXML files through the entry point group ``openforcefield.smirnoff_forcefield_directory``. The ``ForceField`` class doesn't search in the ``data/forcefield/`` folder anymore (now renamed ``data/test_forcefields/``), but only in ``data/``. +* [PR #292](https://github.com/openforcefield/openff-toolkit/pull/292): Implement `Topology.to_openmm` and remove `ToolkitRegistry.toolkit_is_available` +* [PR #322](https://github.com/openforcefield/openff-toolkit/pull/322): Install directories for the lookup of OFFXML files through the entry point group `openforcefield.smirnoff_forcefield_directory`. The `ForceField` class doesn't search in the `data/forcefield/` folder anymore (now renamed `data/test_forcefields/`), but only in `data/`. -API-breaking Changes -"""""""""""""""""""" -* `PR #278 `_: Standardize variable/method names -* `PR #291 `_: Remove ``ForceField.load/to_smirnoff_data``, add ``ForceField.to_file/string`` and ``ParameterHandler.add_parameters``. Change behavior of ``ForceField.register_X_handler`` functions. +### API-breaking Changes +* [PR #278](https://github.com/openforcefield/openff-toolkit/pull/278): Standardize variable/method names +* [PR #291](https://github.com/openforcefield/openff-toolkit/pull/291): Remove `ForceField.load/to_smirnoff_data`, add `ForceField.to_file/string` and `ParameterHandler.add_parameters`. Change behavior of `ForceField.register_X_handler` functions. -Bugfixes -"""""""" -* `PR #327 `_: Fix units in tip3p.offxml (note that this file is still not loadable by current toolkit) -* `PR #325 `_: Fix solvent box for provided test system to resolve periodic clashes. -* `PR #325 `_: Add informative message containing Hill formula when a molecule can't be matched in ``Topology.from_openmm``. -* `PR #325 `_: Provide warning or error message as appropriate when a molecule is missing stereochemistry. -* `PR #316 `_: Fix formatting issues in GBSA section of SMIRNOFF spec -* `PR #308 `_: Cache molecule SMILES to improve system creation speed -* `PR #306 `_: Allow single-atom molecules with all zero coordinates to be converted to OE/RDK mols -* `PR #313 `_: Fix issue where constraints are applied twice to constrained bonds +### Bugfixes +* [PR #327](https://github.com/openforcefield/openff-toolkit/pull/327): Fix units in tip3p.offxml (note that this file is still not loadable by current toolkit) +* [PR #325](https://github.com/openforcefield/openff-toolkit/pull/325): Fix solvent box for provided test system to resolve periodic clashes. +* [PR #325](https://github.com/openforcefield/openff-toolkit/pull/325): Add informative message containing Hill formula when a molecule can't be matched in `Topology.from_openmm`. +* [PR #325](https://github.com/openforcefield/openff-toolkit/pull/325): Provide warning or error message as appropriate when a molecule is missing stereochemistry. +* [PR #316](https://github.com/openforcefield/openff-toolkit/pull/316): Fix formatting issues in GBSA section of SMIRNOFF spec +* [PR #308](https://github.com/openforcefield/openff-toolkit/pull/308): Cache molecule SMILES to improve system creation speed +* [PR #306](https://github.com/openforcefield/openff-toolkit/pull/306): Allow single-atom molecules with all zero coordinates to be converted to OE/RDK mols +* [PR #313](https://github.com/openforcefield/openff-toolkit/pull/313): Fix issue where constraints are applied twice to constrained bonds -0.2.2 - Bugfix release ----------------------- +## 0.2.2 - Bugfix release This release modifies an example to show how to parameterize a solvated system, cleans up backend code, and makes several improvements to the README. -Bugfixes -"""""""" -* `PR #279 `_: Cleanup of unused code/warnings in main package ``__init__`` -* `PR #259 `_: Update T4 Lysozyme + toluene example to show how to set up solvated systems -* `PR #256 `_ and `PR #274 `_: Add functionality to ensure that links in READMEs resolve successfully +### Bugfixes +* [PR #279](https://github.com/openforcefield/openff-toolkit/pull/279): Cleanup of unused code/warnings in main package `__init__` +* [PR #259](https://github.com/openforcefield/openff-toolkit/pull/259): Update T4 Lysozyme + toluene example to show how to set up solvated systems +* [PR #256](https://github.com/openforcefield/openff-toolkit/pull/256) and [PR #274](https://github.com/openforcefield/openff-toolkit/pull/274): Add functionality to ensure that links in READMEs resolve successfully -0.2.1 - Bugfix release ----------------------- +## 0.2.1 - Bugfix release This release features various documentation fixes, minor bugfixes, and code cleanup. -Bugfixes -"""""""" -* `PR #267 `_: Add neglected ```` documentation to the SMIRNOFF 0.2 spec -* `PR #258 `_: General cleanup and removal of unused/inaccessible code. -* `PR #244 `_: Improvements and typo fixes for BRD4:inhibitor benchmark +### Bugfixes +* [PR #267](https://github.com/openforcefield/openff-toolkit/pull/267): Add neglected `` documentation to the SMIRNOFF 0.2 spec +* [PR #258](https://github.com/openforcefield/openff-toolkit/pull/258): General cleanup and removal of unused/inaccessible code. +* [PR #244](https://github.com/openforcefield/openff-toolkit/pull/244): Improvements and typo fixes for BRD4:inhibitor benchmark -0.2.0 - Initial RDKit support ------------------------------ +## 0.2.0 - Initial RDKit support This version of the toolkit introduces many new features on the way to a 1.0.0 release. -New features -"""""""""""" +### New features -* Major overhaul, resulting in the creation of the `SMIRNOFF 0.2 specification `_ and its XML representation -* Updated API and infrastructure for reference SMIRNOFF :class:`ForceField ` implementation -* Implementation of modular :class:`ParameterHandler ` classes which process the topology to add all necessary forces to the system. -* Implementation of modular :class:`ParameterIOHandler ` classes for reading/writing different serialized SMIRNOFF force field representations -* Introduction of :class:`Molecule ` and :class:`Topology ` classes for representing molecules and biomolecular systems -* New :class:`ToolkitWrapper ` interface to RDKit, OpenEye, and AmberTools toolkits, managed by :class:`ToolkitRegistry ` -* API improvements to more closely follow `PEP8 `_ guidelines +* Major overhaul, resulting in the creation of the [SMIRNOFF 0.2 specification](https://open-forcefield-toolkit.readthedocs.io/en/0.2.0/smirnoff.html) and its XML representation +* Updated API and infrastructure for reference SMIRNOFF [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceField) implementation +* Implementation of modular [`ParameterHandler`](openff.toolkit.typing.engines.smirnoff.parameters.ParameterHandler) classes which process the topology to add all necessary forces to the system. +* Implementation of modular [`ParameterIOHandler`](openff.toolkit.typing.engines.smirnoff.io.ParameterIOHandler) classes for reading/writing different serialized SMIRNOFF force field representations +* Introduction of [`Molecule`](openff.toolkit.topology.Molecule) and [`Topology`](openff.toolkit.topology.Topology) classes for representing molecules and biomolecular systems +* New [`ToolkitWrapper`](openff.toolkit.utils.toolkits.ToolkitWrapper) interface to RDKit, OpenEye, and AmberTools toolkits, managed by [`ToolkitRegistry`](openff.toolkit.utils.toolkits.ToolkitRegistry) +* API improvements to more closely follow [PEP8](https://www.python.org/dev/peps/pep-0008/) guidelines * Improved documentation and examples -0.1.0 ------ +## 0.1.0 -This is an early preview release of the toolkit that matches the functionality described in the preprint describing the SMIRNOFF v0.1 force field format: `[DOI] `_. +This is an early preview release of the toolkit that matches the functionality described in the preprint describing the SMIRNOFF v0.1 force field format: [[DOI]](https://doi.org/10.1101/286542). -New features -"""""""""""" +### New features This release features additional documentation, code comments, and support for automated testing. -Bugfixes -"""""""" +### Bugfixes Treatment of improper torsions -'''''''''''''''''''''''''''''' A significant (though currently unused) problem in handling of improper torsions was corrected. Previously, non-planar impropers did not behave correctly, as six-fold impropers have two potential chiralities. To remedy this, SMIRNOFF impropers are now implemented as three-fold impropers with consistent chirality. However, current force fields in the SMIRNOFF format had no non-planar impropers, so this change is mainly aimed at future work. -::: +``` diff --git a/docs/topology.md b/docs/topology.md index f428c418e..9de12f753 100644 --- a/docs/topology.md +++ b/docs/topology.md @@ -11,7 +11,7 @@ including offering serialization to a variety of standard formats (including [XM ## Primary objects -:::{eval-rst} +```{eval-rst} .. currentmodule:: openff.toolkit.topology .. autosummary:: :nosignatures: @@ -20,11 +20,11 @@ including offering serialization to a variety of standard formats (including [XM FrozenMolecule Molecule Topology -::: +``` ## Secondary objects -:::{eval-rst} +```{eval-rst} .. currentmodule:: openff.toolkit.topology .. autosummary:: :nosignatures: @@ -37,5 +37,5 @@ including offering serialization to a variety of standard formats (including [XM ImproperDict HierarchyScheme HierarchyElement -::: +``` diff --git a/docs/users/concepts.md b/docs/users/concepts.md index 0e17855a7..48c6f31d4 100644 --- a/docs/users/concepts.md +++ b/docs/users/concepts.md @@ -21,6 +21,6 @@ OpenFF [`ForceField`](openff.toolkit.typing.engines.smirnoff.forcefield.ForceFie : An object generated from an OFFXML file (or other source of SMIRNOFF data). Most information from the SMIRNOFF data source is stored in this object's several `ParameterHandler`s, however some top-level SMIRNOFF data is stored in the `ForceField` object itself. -OpenFF [`Interchange`](openff.interchange:index) +OpenFF [`Interchange`](inv:openff.interchange#index) : A `Topology` that has been parametrized by a `ForceField`. An `Interchange` contains all the information needed to calculate an energy or start a simulation. `Interchange` also provides methods to export this information to MD simulation engines. diff --git a/docs/users/developing.md b/docs/users/developing.md index 26ac73bf9..910bb0ce8 100644 --- a/docs/users/developing.md +++ b/docs/users/developing.md @@ -398,7 +398,7 @@ Some CI builds run using only RDKit as a backend, some run using only OpenEye To The CI matrix is currently as follows: -:::{eval-rst} +```{eval-rst} +-----------------------+------------+-----------+-------------+------------+-----------+-------------+ | | Linux | macOS | +-----------------------+------------+-----------+-------------+------------+-----------+-------------+ @@ -414,4 +414,4 @@ The CI matrix is currently as follows: +-----------------------+------------+-----------+-------------+------------+-----------+-------------+ | Python 3.12 and newer | Pending official releases and upstream support | +-----------------------+------------+-----------+-------------+------------+-----------+-------------+ -::: +``` diff --git a/docs/users/smirnoff.md b/docs/users/smirnoff.md index ef777d7ab..ffb9868e5 100644 --- a/docs/users/smirnoff.md +++ b/docs/users/smirnoff.md @@ -84,7 +84,7 @@ general or as specific as needed. [SMIRKS]: https://www.daylight.com/dayhtml/doc/theory/theory.smirks.html [standards repository]: https://openforcefield.github.io/standards/standards/smirnoff/ [`Interchange`]: openff.interchange.Interchange -[producing input files and data]: openff.interchange:using/output +[producing input files and data]: inv:openff.interchange#using/output :::{hint} This page is not the SMIRNOFF spec; it has been moved to the diff --git a/openff/toolkit/topology/molecule.py b/openff/toolkit/topology/molecule.py index 1606facf7..d371cdf83 100644 --- a/openff/toolkit/topology/molecule.py +++ b/openff/toolkit/topology/molecule.py @@ -4416,7 +4416,7 @@ def to_qcschema(self, multiplicity=1, conformer=0, extras=None): The kekule structure of the molecule is saved in two places on the returned Molecule: - * ``extras["canonical_isomeric_explicit_hydrogen_mapped_smiles"] + * ``extras["canonical_isomeric_explicit_hydrogen_mapped_smiles"]`` * ``identifiers["canonical_isomeric_explicit_hydrogen_mapped_smiles"]`` .. warning :: This API is experimental and subject to change. diff --git a/openff/toolkit/topology/topology.py b/openff/toolkit/topology/topology.py index 5ed376d60..4a9b3e37c 100644 --- a/openff/toolkit/topology/topology.py +++ b/openff/toolkit/topology/topology.py @@ -1567,7 +1567,7 @@ def from_pdb( All molecules in the PDB file have the following requirements: * Polymer molecules must use the standard atom names described in the - `PDB Chemical Component dictionary `_ + `PDB Chemical Component Dictionary `_ (PDB CCD). * There must be no missing atoms (all hydrogens must be explicit). * All particles must correspond to an atomic nucleus (particles in the @@ -1669,13 +1669,15 @@ def from_pdb( HierarchyElement ('B', '2', ' ', 'CYS') of iterator 'residues' containing 11 atom(s), HierarchyElement ('B', '3', ' ', 'NME') of iterator 'residues' containing 6 atom(s)] - Polymer systems can also be supported if _custom_substructures are given as a dict[str, list[str]], - where the keys are unique atom names and the values are lists of substructure smarts. The - substructure smarts must follow the same format as given in - "proteins/aa_residues_substructures_explicit_bond_orders_with_caps_explicit_connectivity.json": - ”[#D+:]” for monomer atoms and - ”[*:]” for adjacent neighboring atoms - (NOTE: This functionality is experimental!) + Polymer systems can also be supported if ``_custom_substructures`` are + given as a ``dict[str, list[str]]``, where the keys are unique atom + names and the values are lists of substructure SMARTS. The substructure + SMARTS must follow the same format as given in the `residue + substructure connectivity library + `_: + ``"[#D+:]"`` for monomer + atoms and ``"[*:]"`` for adjacent neighboring atoms + (NOTE: This functionality is experimental!) >>> PE_substructs = { ... "PE": [ diff --git a/openff/toolkit/typing/engines/smirnoff/forcefield.py b/openff/toolkit/typing/engines/smirnoff/forcefield.py index b4adc8c5c..94f236109 100644 --- a/openff/toolkit/typing/engines/smirnoff/forcefield.py +++ b/openff/toolkit/typing/engines/smirnoff/forcefield.py @@ -1239,6 +1239,15 @@ def label_molecules(self, topology): For each molecule, a dictionary of force types is returned, and for each force type, each force term is provided with the atoms involved, the parameter id assigned, and the corresponding SMIRKS. + .. todo:: + What is the most useful API for this method? + + - Should we instead accept :class:`Molecule` objects as input and + individually return labels? + - Should we attach the labels to the :class:`Molecule` object? + - Or should we label all interactions in a :class:`Topology` instead + of just labeling its ``unique_molecules``? + Parameters ---------- topology : openff.toolkit.topology.Topology @@ -1253,16 +1262,6 @@ def label_molecules(self, topology): ['HarmonicBondForce']`` gives details for the harmonic bond parameters for the first molecule. Each element is a list of the form: ``[ ( [ atom1, ..., atomN], parameter_id, SMIRKS), ... ]``. - - - .. todo:: - What is the most useful API for this method? - - Should we instead accept :class:`Molecule` objects as input and - individually return labels? - - Should we attach the labels to the :class:`Molecule` object? - - Or should we label all interactions in a :class:`Topology` instead - of just labeling its ``unique_molecules``? - """ from openff.toolkit import Topology from openff.toolkit.typing.engines.smirnoff.parameters import VirtualSiteHandler diff --git a/openff/toolkit/typing/engines/smirnoff/parameters.py b/openff/toolkit/typing/engines/smirnoff/parameters.py index 328f0aafe..a63f53a3f 100644 --- a/openff/toolkit/typing/engines/smirnoff/parameters.py +++ b/openff/toolkit/typing/engines/smirnoff/parameters.py @@ -94,6 +94,21 @@ _cal_mol_a2 = unit.calorie / unit.mole / unit.angstrom**2 +# Hack to make Sphinx happy without breaking changes +class _UNDEFINED: + """ + Marker type for an undeclared default parameter. + + Custom type used by ``ParameterAttribute`` to differentiate between ``None`` + and undeclared default. + """ + + pass + + +UNDEFINED = _UNDEFINED + + def _linear_inter_or_extrapolate(points_dict, x_query): """ Linearly interpolate or extrapolate based on a piecewise linear function @@ -320,10 +335,8 @@ class ParameterAttribute: """ - class UNDEFINED: - """Custom type used by ``ParameterAttribute`` to differentiate between ``None`` and undeclared default.""" - - pass + UNDEFINED = UNDEFINED + """Marker type for an undeclared default parameter.""" def __init__( self,