From 77d3f887a672a9fec2abebb9a2a47723f82d4a5f Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 09:07:01 +0100 Subject: [PATCH 01/17] an initial test --- doc/source/conf.py | 1 + doc/source/index.rst | 1 + doc/source/scripts/gen_release_notes.py | 40 +++++++++++++++++++++++++ doc/source/scripts/generate_all.sh | 1 + environment.yml | 3 ++ 5 files changed, 46 insertions(+) create mode 100644 doc/source/scripts/gen_release_notes.py diff --git a/doc/source/conf.py b/doc/source/conf.py index 7f106f0bd..421aa1de5 100644 --- a/doc/source/conf.py +++ b/doc/source/conf.py @@ -84,6 +84,7 @@ def sort_authors(filename): "sphinxcontrib.bibtex", "matplotlib.sphinxext.plot_directive", "mdanalysis_sphinx_theme", + "myst_parser", ] bibtex_bibfiles = ["references.bib"] diff --git a/doc/source/index.rst b/doc/source/index.rst index 7e3235bde..e03002eb0 100644 --- a/doc/source/index.rst +++ b/doc/source/index.rst @@ -73,6 +73,7 @@ Wherever possible, do not take these conversations to private channels, includin examples/quickstart faq examples/README + releases .. toctree:: :maxdepth: 1 diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py new file mode 100644 index 000000000..0876c2fe3 --- /dev/null +++ b/doc/source/scripts/gen_release_notes.py @@ -0,0 +1,40 @@ +import pathlib +import os + +from github import Github + + +def gen_release_notes(filename): + git = Github(os.environ['GITHUB_TOKEN']) + repo = git.get_repo('MDAnalysis/mdanalysis') + releases = repo.get_releases() + + parent_directory = pathlib.Path(__file__).parent.parent + parent_directory.mkdir(exist_ok=True, parents=True) + filename = parent_directory / filename + + filetext = "# Release notes for the MDAnalysis library\n\n\n" + + # Should be ordered + for release in repo.get_releases(): + # MDAnalysis releases always follow a tag pattern of *-release_version + version = release.tag_name.split('-')[0] + + # Only write out version 2.x+ since those are the only ones that + # we can guarantee similarly written notes for + if version.split('.')[0] < 2: + continue + + if release.body.startswith('###'): + filetext += release.body[1:] + else: + filetext += release.body + + filetext += "\n\n" + + with open(filename, 'w') as f: + f.write(filetext) + + +if __name__ == "__main__": + gen_release_notes('releases.md') diff --git a/doc/source/scripts/generate_all.sh b/doc/source/scripts/generate_all.sh index 671073c24..cbd855de0 100755 --- a/doc/source/scripts/generate_all.sh +++ b/doc/source/scripts/generate_all.sh @@ -18,3 +18,4 @@ python "${GENPATH}/gen_topology_groupmethods.py" python "${GENPATH}/gen_topologyattr_defaults.py" python "${GENPATH}/gen_topologyparser_attrs.py" python "${GENPATH}/gen_unit_tables.py" +python "${GENPATH}/gen_release_notes.py" diff --git a/environment.yml b/environment.yml index 709cb78bf..d9bdcaf36 100644 --- a/environment.yml +++ b/environment.yml @@ -22,6 +22,7 @@ dependencies: - ipython - ipywidgets<8.0.0 - jupyter_contrib_nbextensions + - myst-parser - nbconvert # not called by any notebook explicitly but to download notebooks, or in nbsphinx - nbformat - nbsphinx @@ -51,6 +52,8 @@ dependencies: - nbval # developer tooling - pre-commit + # doc generation + - pygithub # mdanalysis and its tests and test data - git+https://github.com/MDAnalysis/mdanalysis@develop#egg=mdanalysis&subdirectory=package - git+https://github.com/MDAnalysis/mdanalysis@develop#egg=MDAnalysisTests&subdirectory=testsuite From 3f71781fcb47c74b464a7aeccddca616254bf68f Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 09:29:38 +0100 Subject: [PATCH 02/17] For now manually generate --- doc/source/releases.md | 452 ++++++++++++++++++++++++ doc/source/scripts/gen_release_notes.py | 4 +- doc/source/scripts/generate_all.sh | 1 - environment.yml | 2 - 4 files changed, 454 insertions(+), 5 deletions(-) create mode 100644 doc/source/releases.md diff --git a/doc/source/releases.md b/doc/source/releases.md new file mode 100644 index 000000000..2c50b0dbf --- /dev/null +++ b/doc/source/releases.md @@ -0,0 +1,452 @@ +# Release notes for the MDAnalysis library + + +## Release 2.6.1 of MDAnalysis + +This is a bugfix release of the 2.6.x version branch of MDAnalysis, it serves as an amendment to the earlier released version 2.6.0. + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.1/package/CHANGELOG) for more details. + +## Bug fixes and changes + +* Reverting the v2.6.0 behaviour, builds are now again made using the oldest supported NumPy version (NumPy 1.22.3 for Python 3.9-3.10, and 1.22.3 for Python 3.11) [PR #4261] +* Uses of numpy `in1d` have been replaced with `isin` in prepartion for NumPy 2.0 [PR #4255] +* Cython DEF statements have been replaced with compile time integer constants as DEF statements are now deprecated in Cython 3.0 [Issue #4237, PR #4246] +* Fix to element guessing code to more accurately interpret atom names split by numbers (i.e. N0A is now recognised as N rather than NA) [Issue #4167, PR #4168] +* Clarification of SurvivalProbability function documentation [Issue #4247, PR #4248]1 + +## New Contributors +* @pillose made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4168 + +## Release 2.6.0 of MDAnalysis + +This a minor release of MDAnalysis. + +This release of MDAnalysis is packaged under a [GPLv3+ license](https://www.gnu.org/licenses/gpl-3.0.en.html), additionally all contributions made from commit 44733fc214dcfdcc2b7cb3e3705258781bb491bd onwards are made under the [LGPLv2.1+ license](https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html). More details about these license changes will be provided in an upcoming blog post. + +The minimum supported NumPy version has been raised to 1.22.3 as per NEP29. Please note that package builds are now made with NumPy 1.25+ which offer backwards runtime compatibility with NEP29 supported versions of NumPy. + +Supported Python versions: + - 3.9, 3.10, 3.11 + +## Major changes: + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.0/package/CHANGELOG) and our [release blog post](https://www.mdanalysis.org/blog/#mdanalysis-2.6-is-out) for more details. + +#### Fixes: +* The -ffast-math compiler flag is no longer used by default at build time, avoiding inconsistent (although still scientifically correct) results seen in Intel MacOS systems when calling `AtomGroup.center_of_charge(..., unwrap=True). This also avoids potentially incorrect floating point results as [detailed here](https://moyix.blogspot.com/2022/09/someones-been-messing-with-my-subnormals.html). (https://github.com/MDAnalysis/mdanalysis/pull/4220) +* DATAWriter, CRD, PQR, and PDBQT files can now be correctly written to compressed files. Before this change, any attempt to write to a compressed format (gzip or bzip2) would lead to writing out an uncompressed file. (https://github.com/MDAnalysis/mdanalysis/pull/4163) +* Prevent accidental merging of bond/angle/dihedral types when they are defined as LAMMPS style string integers instead of tuples. This was leading to an incorrect number of bond/angle/dihedral types being written to lammps data files. (https://github.com/MDAnalysis/mdanalysis/pull/4003) + +#### Enhancements: +* An `exclude_same` argument has been added to `InterRDF` allowing pairs of atoms that share the same residue, segment or chain to be excluded from the calculation. (https://github.com/MDAnalysis/mdanalysis/pull/4161) +* LAMMPS reader now supports the `continuous` ChainReader option. (https://github.com/MDAnalysis/mdanalysis/pull/4170) +* AtomGroup representation now returns atom indices in the same order as they are stored in the AtomGroup. (https://github.com/MDAnalysis/mdanalysis/pull/4191) + +#### Changes: +* Package builds now use NumPy 1.25 or higher instead of the lowest supported NumPy version. (https://github.com/MDAnalysis/mdanalysis/pull/4198) +* As per NEP29, the minimum supported runtime version of NumPy has been increased to 1.22.3. (https://github.com/MDAnalysis/mdanalysis/pull/4160) +* The GSD package is now an optional dependency. (https://github.com/MDAnalysis/mdanalysis/pull/4174) +* The MDAnalysis package now only supports GSD versions 3.0.1 or above. (https://github.com/MDAnalysis/mdanalysis/pull/4153) +* MDAnalysis no longer officially supports 32 bit installations. (they are no longer tested in our continuous integration pipelines). Note: no code changes have been made to disable 32 bit, although it is known that new versions of most MDAnalysis core dependencies no longer release 32 bit compatible versions. (https://github.com/MDAnalysis/mdanalysis/pull/4176) +* The package license has been updated to [GPLv3+](https://www.gnu.org/licenses/gpl-3.0.en.html) to better reflect the compatibility of GPLv2+ with Apache and GPLv3 licensed codes. Additionally all new contributions from commit 44733fc214dcfdcc2b7cb3e3705258781bb491bd onwards are made under the [LGPLv2.1+ license](https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html). (https://github.com/MDAnalysis/mdanalysis/pull/4219) + +#### Deprecations: +* The misspelt `Boltzman_constant` entry in `MDAnalysis.units` is now deprecated in favour the correctly spelt `Boltzmann_constant`. (https://github.com/MDAnalysis/mdanalysis/pull/4230 and https://github.com/MDAnalysis/mdanalysis/pull/4214) +* `MDAnalysis.analysis.hole2` is now deprecated in favour of a new [HOLE2 MDAKit](https://www.mdanalysis.org/hole2-mdakit/). (https://github.com/MDAnalysis/mdanalysis/pull/4200) + +## New Contributors +* @MohitKumar020291 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4182 +* @Shubx10 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4184 +* @ztimol made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4191 + +## Release 2.5.0 of MDAnalysis + +This a minor release of MDAnalysis. + +The minimum Python version has been raised to 3.9 and NumPy to 1.21.0 as per NEP29. We also now package wheels for both linux and osx arm64 machines on PyPi. + +Supported Python versions: + - 3.9, 3.10, 3.11 + +### Major changes: + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.5.0/package/CHANGELOG) and our [release blog post](https://www.mdanalysis.org/blog/#mdanalysis-2.5-is-out) for more details. + +#### Fixes: + * Fixed an issue where transformations were not being properly applied to + Universes with multiple trajectories (i.e. using the ChainReader) + (Issue #3657 #4008 PR #3906) + * Fixed an issue with the the `heavy` distance_type for `WaterBridgeAnalysis` + where distance was not correctly assigned when more than one hydrogen + was bonded to a heavy atom (Issue #4040, PR #4066). + * PDB topology parser no longer fails when encountering unknown formal + charges and instead simply does not populate attribute (Issue #4027) + * Fixed an issue where using the `between` keyword of `HydrogenBondAnalysis` + led to incorrect donor-atom distances being returned (PR #4092, Issue #4091) + * Fixed an issue where chi1_selections() ignored atom names CG1 OG OG1 SG + and incorrectly returned `None` for amino acids CYS, ILE, SER, THR, VAL + (Issue #4108, PR #4109) + * Fix H5MD reader to read box vectors rather than returning `None` as the + dimensions (Issue #4075, PR #4076) + * Fix to allow reading NetCDF trajectories which do not have the `time` + variable defined (Issue #4073, PR #4074) + * Allows shape_parameter and asphericity to yield per residue quantities + (Issue #3002, PR #3905) + * Fix EDRReader failing when parsing single-frame EDR files (Issue #3999) + * Add 'PairIJ Coeffs' to the list of sections in LAMMPSParser.py + (Issue #3336) + * PDBReader now defaults atom values for ts.data['occupancy'] to 0.0, rather + than the previous default of 1.0. This now matches the default used when + setting Universe Topology attributes using the first frame's information (PR #3988) + +#### Enchancements: + * ARM64 (osx and linux) wheels are now provided via PyPi (Issue #4054) + * Addition of a new analysis class `analysis.atomicdistances.AtomicDistances` + to provide distances between two atom groups over a trajectory. + (Issue #3654, PR #4105) + * Add kwarg `n_frames` to class method `empty()` in + `MDAnalysis.core.universe`, enabling creation of a blank `Universe` with + multiple frames (PR #4140) + * PDBReader now populates ts.data['tempfactor'] with the tempfactor for + each atom *for each frame*. If an entry is missing for a given atom, + this will default to a `1.0` value. Note, this does not affect the + topology, i.e. `AtomGroup.tempfactors` is not dynamically updated. + (Issue #3825, PR #3988) + * Add writing u.trajectory.ts.data['molecule_tag'] as molecule tags to + LAMMPS data file (Issue #3548) + * Add `progressbar_kwargs` parameter to `AnalysisBase.run` method, allowing + to modify description, position etc of tqdm progressbars. (PR #4085) + * Add a nojump transformation, which unwraps trajectories so that particle + paths are continuous. (Issue #3703, PR #4031) + * Added AtomGroup TopologyAttr to calculate gyration moments (Issue #3904, + PR #3905) + * Add support for TPR files produced by Gromacs 2023 (Issue #4047) + * Add distopia distance calculation library bindings as a selectable backend + for `calc_bonds` in `MDA.lib.distances`. (Issue #3783, PR #3914) + * AuxReaders are now pickle-able and copy-able (Issue #1785, PR #3887) + * Add pickling support for Atom, Residue, Segment, ResidueGroup + and SegmentGroup. (PR #3953) + +#### Changes: + * As per NEP29 the minimum supported Python version has been raised to 3.9 + and NumPy has been raised to 1.21 (note: in practice later versions of NumPy + may be required depending on your architecture, operating system, or Python + version) (PRs #4115 and #3983). + * Add progress bars to track the progress of `mds.EinsteinMSD` _conclude() + methods (_conclude_simple() and _conclude_fft()) (Issue #4070, PR #4072) + * The deprecated direct indexing and `times` from the `results` attribute of + analysis.nucleicacids' NucPairDist and WatsonCrickDist classes has been + removed. Please use the `results.pair_distances` and `times` attributes + instead (Issue #3744) + * RDKitConverter changes (part of Issue #3996): + * moved some variables (`MONATOMIC_CATION_CHARGES `and + `STANDARDIZATION_REACTIONS`) out of the related functions to allow users + fine tuning them if necessary. + * changed the sorting of heavy atoms when inferring bond orders and + charges: previously only based on the number of unpaired electrons, now + based on this and the number of heavy atom neighbors. + * use RDKit's `RunReactantInPlace` for the standardization reactions, which + should result in a significant speed improvement as we don't need to use + bespoke code to transfer atomic properties from the non-standardized mol + to the standardized one. + +## New Contributors +* @mglagolev made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3959 +* @chrispfae made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4009 +* @ooprathamm made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4010 +* @MeetB7 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4022 +* @v-parmar made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4032 +* @MoSchaeffler made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4049 +* @jandom made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4043 +* @xhgchen made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4037 +* @DrDomenicoMarson made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4074 +* @AHMED-salah00 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4059 +* @schlaicha made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4076 +* @jvermaas made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4031 +* @SophiaRuan made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4072 +* @marinegor made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4085 +* @g2707 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4089 +* @DanielJamesEvans made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4109 + +## Release 2.4.3 of MDAnalysis + +This is a bugfix release of the 2.4.x version of MDAnalysis, it serves as an amendment to the earlier released version 2.4.2. + +### Bug fixes +* Fixed DCD reading for large (>2Gb) files (Issue #4039). This was broken for versions 2.4.0, 2.4.1 and 2.4.2. +* Fix element parsing from PSF files tests read via Parmed (Issue #4015) + +## Release 2.4.2 of MDAnalysis + +This is a bugfix release of the 2.4.x version of MDAnalysis, it serves as an amendment to the earlier released version 2.4.1. + +### Bug fixes + +* Fixed an issue where the arguments passed to np.histogramdd in `MDAnalysis.analysis.DensityAnalysis` were not compatible with the 1.24 release of NumPy (PR #3976) +* Fixed upcoming incompatibilities with NumPy 1.25 in `MDAnalysis.visualization.streamlines_3D` and `MDAnalysis.visualization.streamlines` where incorrect comparison of the truth of arrays would have led to failures (PR #3977) + +## Release 2.4.1 of MDAnalysis + +This is a bugfix release of the 2.4.x version of MDAnalysis, it serves as an amendment to the earlier released version 2.4.0. + +### Bug fixes + +* The minimum version of biopython has been raised to 1.80 for pip installs +* pytng has been added as an optional dependency + + +## Release 2.4.0 of MDAnalysis + +This a minor release of MDAnalysis, as per our once-every-three-months schedule. + +The minimum NumPy and Python versions remain largely unchanged, however the minimum version of `biopython` has been raised to 1.80. This is also the first release to officially support Python 3.11. + +Supported Python versions: + - 3.8, 3.9, 3.10, 3.11 + +### Major changes: + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.4.0/package/CHANGELOG) and our [release blog post](https://www.mdanalysis.org/blog/#mdanalysis-2.4-is-out) for more details. + +#### Fixes: + +#### Enchancements: +* As part of their [outreachy project](https://www.mdanalysis.org/2022/12/15/uma_outreachy/) @umak has started adding type annotations throughout the MDAnalysis codebase +* As part of their [GSoC project](https://www.mdanalysis.org/2022/11/20/bjarne_gsoc/) @BFedder has added an auxialliary reader for EDR files (PR #3749) +* As part of their [GSoC project](https://www.mdanalysis.org/2022/12/09/Aya-gsoc-final-report/) @aya9aladdin has fixed various issues with guessing and and attribute reading. This will be followed by the introduction of a new guesser system in a future release. +* A reader for TNG files has been added by @hmacdope, follow up on his previous [GSoC 2020](https://www.mdanalysis.org/2020/09/02/final-report-hugo/) work on creating a python library for reading TNG files (PR 3765) +* Addition of a new isolayer selection method (PR #3846) +* Various enchancements and fixes to the LAMMPS DUMP Parser (allowing box translation on reading, allowing coordinates to be unwrapped based on dump image flags, and importing of forces and velocities) (PR #3844) +* All readers now have a timeseries attribute (PR #3890) +* ReaderBase file formats now accept pathlib inputs (PR #3935) +* Added ability for hbond analysis to use types when resnames are not present (PR #3848) + +#### Changes: +* The deprecated setup.py `extra_requires` `AMBER` entry has been removed in favor of `extra_formats` (PR #3810) +* Various issues with the auxilliary reader, this should not be much more robust (PR #3749) +* The Cython headers have been moved to MDAnalysis.lib.libmdanalysis (PR #3913) +* The `MDAnalysis.analysis.align.sequence_alignment` now uses Bio.Align.PairwiseAligner instead of the deprecated Bio.pairwise2 (PR #3951) + +#### Deprecations: +* The MemoryReader's timeseries inclusive indexing will be changed to exclusive in version 3.0.0 (PR #3894) +* The `sequence_aligment()` method has been deprecated and will be removed in version 3.0.0 (PR #3951) +* MDAnalysis.analysis.nucleicacids' direct indexing of selection indices to obtain pair distances results has been deprecated in favor of accessing `results.pair_distances` (PR #3958) + +## New Contributors +* @jaclark5 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3846 +* @pgbarletta made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3876 +* @jfennick made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3832 +* @Hakarishirenai made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3956 + + + +## Release 2.3.0 of MDAnalysis + +This a minor release of MDAnalysis, as per our once-every-three-months schedule. + +The minimum NumPy version has been raised to 1.20.0 (1.21 for macosx-arm64) in line with [NEP29](https://numpy.org/neps/nep-0029-deprecation_policy.html). + + +Supported python versions: + - 3.8, 3.9, 3.10 + + +### Major changes: + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.3.0/package/CHANGELOG) and our [release blog post](https://www.mdanalysis.org/blog/#mdanalysis-2.3-is-out) for more details. + + +#### Fixes: + - Fixed reading error when dealing with corrupt PDB CONECT records, and an issue where MDAnalysis would write out unusable CONECT records with index>100000 (Issue #988). + + +#### Enhancements: + - Formal charges are now read from PDB files and stored in a `formalcharge` attribute (PR #3755). + - A new normalizing `norm` parameter for the `InterRDF` and `InterRDF_s` analysis methods (Issue #3687). + - Improved Universe serialization performance (Issue #3721, PR #3710). + + +#### Changes: + - To install optional packages for different file formats supported by MDAnalysis, use `pip install ./package[extra_formats]` (Issue #3701, PR #3711). + + +#### Deprecations: + - The `extra_requires` target `AMBER` for `pip install ./package[AMBER]` will be removed in 2.4.0. Use `extra_formats` (Issue #3701, PR #3711). + + +#### CZI EOSS Performance Improvements: + +A series of performance improvements to the MDAnalysis library's backend have been made as per planned work under MDAnalysis' CZI EOSS4 grant. Further details about these will be provided in a future blog post. + + - `MDAnalysis.lib.distances` now accepts `AtomGroups` as well as NumPy arrays (PR #3730). + - Timestep has been converted to a Cython Extension type (PR #3683). + +## Release 2.2.0 of MDAnalysis + +In line with NEP29, this version of MDAnalysis drops support for Python 3.7 and raises the minimum NumPy version to 1.19.0. Minimum version support has also been changed for the following packages; `networkx>=2.0`, `scipy>=1.5.0`, `gsd>=1.9.3`. Further details on MDAnalysis future support strategy and NEP29 will be released shortly. + +Supported python versions: + - 3.8, 3.9, 3.10 + +### Major changes: + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.2.0/package/CHANGELOG) and our [release blog post](https://www.mdanalysis.org/blog/#mdanalysis-2.2-is-out) for more changes and details. + +#### Enhancements: + - The `frames` argument was added to AnalysisBase-derived classes (i.e. modern analysis classes) allowing for specific frames to be defined when running an analysis. (PR #3415) + - DL_POLY classic HISTORY files are now supported (Issue #3678) + - Python wheels are now made available through PyPI for x86_64 architectures (Issue #1300, PR #3680) + - Added a `center_of_charge` attribute for AtomGroups (PR #3671) + - LinearDensity now work with UpdatingAtomGroups (Issue #2508, PR #3617) + - Addition of a PCA transformation and an associated inverse-PCA transformation was added to the PCA analysis class (PR #3596, Issue #2703) + - Major improvements to the RDKitConverter's accuracy (PR #3044) + - Accuracy of 99.14% when benchmarked against ChEMBL30 + - AtomGroups containing monatomic ion charges and edge cases with nitrogen, sulfur, phosphorus and conjugated systems should now have correctly assigned bond orders and charges. + - Addition of a new AnalysisBase derived Watson-Crick distance analysis class (PR #3611) + +#### Fixes: + - Fixed issues where calling the `copy` method of Readers did not preserve optional arguments (Issue #3664, PR #3685) + - Fixed several issues where iterating trajectories had undefined behaviour + - Iterating (not in memory) SingleFrame readers now reset modified trajectory attributes (Issue #3423) + - Iterating using defined indices did not rewind the trajectory (Issue #3416) + - Fixed issues with competing processes writing to an XTC offset file leading to offset corruption (Issue #1988, PR #3375) + - Fixed issue preventing OpenMMTopologyParsers from parsing systems with missing elements (Issue #3317, PR #3511) + - Fixed issue with encore.covariance.covariance_matrix not working when providing an external reference (Issue #3539, PR #3621) + - Fixed issue with broken code paths for "residues" and "segment" groupings for LinearDensity (Issue #3571, PR #3572) + - Improved the flexibility of MOL2 reading, allowing for optional columns (`subst_id`, `subst_name` and `charge`) not to be provided (Issue #3385, PR #3598) + - Fixed several issues related to converting AtomGroups to RDKit molecules (PR #3044): + - Atoms are now in the same order + - `atom.GetMonomerInfor().GetName()` now follows the guidelines for PDB files + - Using `NoImplicit=False` no longer throws a `SanitizationError` + - Fixed issues with incorrect reading of triclinic boxes from DUMP files (Issue #3386, PR #3403) + - Fixed issue with the BAT method modifying input coordinate data (Issue #3501) + +#### Changes: + - The number of matches allowed when doing a smarts selection has been increased from the default + 1000 to max(1000, n_atoms * 10), an additional set of `smarts_kwargs` can now also be passed + to override this behaviour (Issue #3469, PR #3470) + - The `fasteners` package is now a core dependency (PR #3375) + - LinearDensity now saves the histogram bin edges for easier plotting as `hist_bin_edges for + each dimension in the results dictionary (Issue #2508, PR #3617) + - ContactAnalysis now accepts AtomGroups (Issue #2666, PR #3565) + +#### Deprecations: + - The following results attribute for LinearDensity are now deprecated: (Issue #2508, PR #3617) + - `pos` is now `mass_density` + - `char` is now `charge_density` + - `std` entries are now `stddev` + +### Known test failures: + - Windows builds + * In some cases users may get permission errors with tests involving symlinks. This should not impact the behaviour of MDAnalysis but may impact the creation of temporary files when using HOLE2 (see: https://github.com/MDAnalysis/mdanalysis/issues/3556). + +## Release 2.1.0 of MDAnalysis + +In line with ongoing attempts to align with NEP29, this version of MDAnalysis drops support for Python 3.6 and raises the minimum NumPy version to 1.18.0. + +Please note that at time of release whilst all the MDAnalysis core functionality supports Python 3.10, some optional modules do not due to a lack of support by dependencies which they require. We hope that this support will gradually be added as more of these dependencies release new versions compatible with Python 3.10. + +Supported python versions: + - 3.7, 3.8, 3.9, 3.10 + +### Major changes: + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.1.0/package/CHANGELOG) and our [release blog post](https://www.mdanalysis.org/blog/#mdanalysis-2.1-is-out) for more changes and details. + +#### Enhancements: + - Addition of a new dielectric analysis module (PR #2118) + - The TPR parser now supports reading files from GROMACS 2022 (PR #3514) + - The H5MDReader can now load trajectories without a topology (PR #3466) + - Custom compiler flags can be used when building MDAnalysis from source (PR #3429) + - The RDKit reader now supports parsing R/S chirality (PR #3445) + - A new method to apply the minimum image convention to a collection of vectors, `minimize_vectors`, has been introduced (PR #3472) + +#### Fixes: + - Fixed various integer overflow issues in the distance calculation backend of MDAnalysis which would prevent calculations on large systems (Issues #3183, #3512). + - Fixed issues with the creation of VMD surfaces in HOLE2 when using a non-contiguous start/stop/step. + - Fixes reading of charges with the ITPParser (Issue #3419). + - Fixed issue with the creation of a Universe from a custom object which only provides a topology (Issue #3443). + - Fixed issue with accessing newly created values added via `add_Segment` or `add_Residue` (Issue #3437). + +#### Changes: + - `packaging` is now a core dependency of MDAnalysis. + - Indexing a Group (AtomGroup, ResidueGroup, SegmentGroup) with `None` now raises a `TypeError`. Prior to this indexing by `None` would incorrectly return the whole Group but claim to have a length of 1 atom (Issue #3092). + - The TRZReader now defaults to a `dt` value of 1.0 ps instead of the previous 0.0 ps (Issue #3257). + +#### Deprecations: + - The `pbc` keyword argument for various Group methods has been deprecated in favor of `wrap`. The deprecated keyword will be removed in version 3.0.0 (Issue #1760). + +### Known test failures: + - `pytest-xdist` and more than 4 workers + * Under these conditions a test related to logging for HydrogenBondAnalysis can fail. This is not thought to impact the validity of MDAnalysis. See here for more details: https://github.com/MDAnalysis/mdanalysis/issues/3543 + - Windows builds + * In some cases users may get permission errors with tests involving symlinks. This should not impact the behaviour of MDAnalysis but may impact the creation of temporary files when using HOLE2 (see: https://github.com/MDAnalysis/mdanalysis/issues/3556). + +## Release 2.0.0 of MDAnalysis + +This is the first version of MDAnalysis to solely support python 3.6+ + +Supported python versions: + - 3.6, 3.7, 3.8, 3.9 + +Please note that starting with the next minor version, MDAnalysis will be following [NEP29](https://numpy.org/neps/nep-0029-deprecation_policy.html). + +### Notes: +* This is a major release and introduces major advertised API breaks. Caution is advised when upgrading to 2.0.0. + +### Major changes: + +#### Enhancements: +- LAMMPSDumpReader can now read coordinates in all different LAMMPS coordinate conventions (Issue #3358) +- New `Results` class for storing analysis results (Issue #3115) +- New OpenMM coordinate and topology converters (Issue #2863, PR #2917) +- New `intra_bonds`,`intra_angles`, `intra_dihedrals`, etc... methods to return connections involve atoms within AtomGroups instead of including atoms outside of it (Issue #1264, #2821, PR #3200) +- Support for Groamcs 2021 TPR files (Issue #3180) +- Adds preliminary support for ppc64le and aarch64 [ARM] (Issue #3127, PR #2956 #3149) +- New selection operators (Issue #3054, PR #2927) +- New refactor of helix analysis class as `analysis.helix_analysis` (Issue #2452) +- New converter between RDKit molecules and MDAnalysis AtomGroup objects (Issue #2468). Also includes `from_smiles` Universe generator method, and the aromatic and smarts selection. +- New analysis method for calculating Mean Squared Dsiplacements (Issue #2438) +- New converter between Cartesian and Bond-Angle-Torsion coordinates (PR #2668) +- Universes and readers can now be `pickled` paving the way to easier parallel analyses (Issue #2723) +- New H5MDReader and H5MDWriter (Issue #762, #2866) + +#### Fixes: +- Fixes an issue where `select_atom`, AtomGroup.unique, ResidueGroup.unique, and SegmentGroup.unique did not sort the output atoms (Issues #3364 #2977) +- GRO files now only support unit cells defined with 3 or 9 entries (Issue #3305) +- Fixes the sometimes wrong sorting of atoms into fragments when unwrapping (Issue #3352) +- Fixes issue when atttempting to use/pass mean positions to PCA analysis (Issue #2728) +- Fixes support for DL_POLY HISTORY files that contain cell information even if there are no periodic boundary conditions (Issue #3314) +- Fixes issue with WaterBridgeAnalysis double counting waters (Issue #3119) +- PDBWriter will use chainID instead of segID (Issue #3144) +- PDBParser and PDBWriter now assign and use the element attribute (Issues #3030 #2422) +- AtomGroup.center now works correctly for compounds + unwrapping (Issue #2984) +- Documents and fixes the `density` keyword for `rdf.InterRDF_s` (Isuse #2811) +- Fixed Janin analysis residue filtering, including CYSH (Issue #2898) + +#### Changes: +- New converter API for all MDAnalysis converters under MDAnalysis.converters +- Timestep now stores information in 'C' memory layout instead of the previous 'F' default (PR #1738) +- `hbonds.hbond_analysis` has been remove din favour of `hydrogenbonds.hbond_analysis` (Issues #2739, #2746) +- TPRParser now loads TPR files with `tpr_resid_from_one=True` by deafult, which starts TPR resid indexing from 1 (instead of 0 as in previous MDAnalysis versions) (Issue #2364, PR #3152) +- `analysis.hole` has now been removed in favour of `analysis.hole2.hole` (Issue #2739) +- `Writer.write(Timestep)` and `Writer.write_next_timestep` have been removed. Please use `write()` instead (Issue #2739) +- Removes deprecated density_from_Universe, density_from_PDB, Bfactor2RMSF, and notwithin_coordinates_factory from MDAnalysis.analysis.density (Issue #2739) +- Changes the minimum numpy supported version to 1.16.0 (Issue #2827) +- Removes deprecated `waterdynamics.HydrogenBondLifetimes` (PR #2842) +- `hbonds.WaterBridgeAnalysis` has been moved to `hydrogenbonds.WaterBridgeAnalysis` (Issue #2739 PR #2913) + +#### Deprecations: +- The `bfactors` attribute is now aliased to `tempfactors` and will be removed in 3.0.0 (Issue #1901) +- `WaterBridgeAnalysis.generate_table()` now returns table information, with the `table` attribute being deprecated +- Various analysis result attributes which are now stored in `Results` will be deprecated in 3.0.0 (Issue #3261) +- In 3.0.0 the ParmEd classes will only be accessible from the `MDAnalysis.converters` module +- In 2.1.0 the TRZReader will default to a dt of 1.0 ps when failing to read it from the input TRZ trajectory + +See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.0.0/package/CHANGELOG) for more changes and details. + +### Known issues: + - Windows builds + * For some compilers (seen on MVC v.19xx), differences in floating point precision leads to PBC wrapping differing from expected outcomes. This leads to failures in the `MDAnalysisTests.lib.test_augment` tests. To our knowledge this does not significantly affect results (as all other tests pass). We will aim to fix this in version 2.1.0. + diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index 0876c2fe3..2f8fbc0cb 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -18,11 +18,11 @@ def gen_release_notes(filename): # Should be ordered for release in repo.get_releases(): # MDAnalysis releases always follow a tag pattern of *-release_version - version = release.tag_name.split('-')[0] + version = release.tag_name.split('-')[1] # Only write out version 2.x+ since those are the only ones that # we can guarantee similarly written notes for - if version.split('.')[0] < 2: + if int(version.split('.')[0]) < 2: continue if release.body.startswith('###'): diff --git a/doc/source/scripts/generate_all.sh b/doc/source/scripts/generate_all.sh index cbd855de0..671073c24 100755 --- a/doc/source/scripts/generate_all.sh +++ b/doc/source/scripts/generate_all.sh @@ -18,4 +18,3 @@ python "${GENPATH}/gen_topology_groupmethods.py" python "${GENPATH}/gen_topologyattr_defaults.py" python "${GENPATH}/gen_topologyparser_attrs.py" python "${GENPATH}/gen_unit_tables.py" -python "${GENPATH}/gen_release_notes.py" diff --git a/environment.yml b/environment.yml index d9bdcaf36..a56c26065 100644 --- a/environment.yml +++ b/environment.yml @@ -52,8 +52,6 @@ dependencies: - nbval # developer tooling - pre-commit - # doc generation - - pygithub # mdanalysis and its tests and test data - git+https://github.com/MDAnalysis/mdanalysis@develop#egg=mdanalysis&subdirectory=package - git+https://github.com/MDAnalysis/mdanalysis@develop#egg=MDAnalysisTests&subdirectory=testsuite From 20e93ad72cd732ad91e082c3a0bd94b446685e8e Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 09:58:47 +0100 Subject: [PATCH 03/17] re-gen file + some pre-commit fixes --- doc/source/releases.md | 12 ++++++------ doc/source/scripts/gen_release_notes.py | 16 ++++++++-------- 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/doc/source/releases.md b/doc/source/releases.md index 2c50b0dbf..f39ffc836 100644 --- a/doc/source/releases.md +++ b/doc/source/releases.md @@ -7,7 +7,7 @@ This is a bugfix release of the 2.6.x version branch of MDAnalysis, it serves as See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.1/package/CHANGELOG) for more details. -## Bug fixes and changes +### Bug fixes and changes * Reverting the v2.6.0 behaviour, builds are now again made using the oldest supported NumPy version (NumPy 1.22.3 for Python 3.9-3.10, and 1.22.3 for Python 3.11) [PR #4261] * Uses of numpy `in1d` have been replaced with `isin` in prepartion for NumPy 2.0 [PR #4255] @@ -15,7 +15,7 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.1/ * Fix to element guessing code to more accurately interpret atom names split by numbers (i.e. N0A is now recognised as N rather than NA) [Issue #4167, PR #4168] * Clarification of SurvivalProbability function documentation [Issue #4247, PR #4248]1 -## New Contributors +### New Contributors * @pillose made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4168 ## Release 2.6.0 of MDAnalysis @@ -29,7 +29,7 @@ The minimum supported NumPy version has been raised to 1.22.3 as per NEP29. Plea Supported Python versions: - 3.9, 3.10, 3.11 -## Major changes: +### Major changes: See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.0/package/CHANGELOG) and our [release blog post](https://www.mdanalysis.org/blog/#mdanalysis-2.6-is-out) for more details. @@ -55,7 +55,7 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.0/ * The misspelt `Boltzman_constant` entry in `MDAnalysis.units` is now deprecated in favour the correctly spelt `Boltzmann_constant`. (https://github.com/MDAnalysis/mdanalysis/pull/4230 and https://github.com/MDAnalysis/mdanalysis/pull/4214) * `MDAnalysis.analysis.hole2` is now deprecated in favour of a new [HOLE2 MDAKit](https://www.mdanalysis.org/hole2-mdakit/). (https://github.com/MDAnalysis/mdanalysis/pull/4200) -## New Contributors +### New Contributors * @MohitKumar020291 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4182 * @Shubx10 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4184 * @ztimol made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4191 @@ -151,7 +151,7 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.5.0/ bespoke code to transfer atomic properties from the non-standardized mol to the standardized one. -## New Contributors +### New Contributors * @mglagolev made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3959 * @chrispfae made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4009 * @ooprathamm made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4010 @@ -233,7 +233,7 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.4.0/ * The `sequence_aligment()` method has been deprecated and will be removed in version 3.0.0 (PR #3951) * MDAnalysis.analysis.nucleicacids' direct indexing of selection indices to obtain pair distances results has been deprecated in favor of accessing `results.pair_distances` (PR #3958) -## New Contributors +### New Contributors * @jaclark5 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3846 * @pgbarletta made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3876 * @jfennick made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3832 diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index 2f8fbc0cb..4d592ee05 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -1,12 +1,12 @@ -import pathlib import os +import pathlib from github import Github def gen_release_notes(filename): - git = Github(os.environ['GITHUB_TOKEN']) - repo = git.get_repo('MDAnalysis/mdanalysis') + git = Github(os.environ["GITHUB_TOKEN"]) + repo = git.get_repo("MDAnalysis/mdanalysis") releases = repo.get_releases() parent_directory = pathlib.Path(__file__).parent.parent @@ -18,23 +18,23 @@ def gen_release_notes(filename): # Should be ordered for release in repo.get_releases(): # MDAnalysis releases always follow a tag pattern of *-release_version - version = release.tag_name.split('-')[1] + version = release.tag_name.split("-")[1] # Only write out version 2.x+ since those are the only ones that # we can guarantee similarly written notes for - if int(version.split('.')[0]) < 2: + if int(version.split(".")[0]) < 2: continue - if release.body.startswith('###'): + if release.body.startswith("###"): filetext += release.body[1:] else: filetext += release.body filetext += "\n\n" - with open(filename, 'w') as f: + with open(filename, "w") as f: f.write(filetext) if __name__ == "__main__": - gen_release_notes('releases.md') + gen_release_notes("releases.md") From 5ce9f96f80be1a91f5f91eb00c88dcfd268d8d55 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 10:01:32 +0100 Subject: [PATCH 04/17] add releases.md to exclude list --- .pre-commit-config.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index a7457a5a6..73f6e98dc 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -5,7 +5,7 @@ repos: - id: check-yaml - id: end-of-file-fixer - id: trailing-whitespace - exclude: ^.*\.(pdb)$ + exclude: ^(.*\.(pdb)$)|doc/source/releases.md) - repo: https://github.com/pycqa/isort rev: 5.12.0 hooks: From 79db53d0b8133daf3fc63aba7261ff5bccecb8c7 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 10:14:42 +0100 Subject: [PATCH 05/17] fix exclude --- .pre-commit-config.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 73f6e98dc..b845d5aff 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -5,7 +5,7 @@ repos: - id: check-yaml - id: end-of-file-fixer - id: trailing-whitespace - exclude: ^(.*\.(pdb)$)|doc/source/releases.md) + exclude: ^(.*\.(pdb)|doc/source/releases.md)$ - repo: https://github.com/pycqa/isort rev: 5.12.0 hooks: From 3a47175751f77cfcce6592dd9290671486c59313 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 10:15:58 +0100 Subject: [PATCH 06/17] Fix long title --- doc/source/releases.md | 2 +- doc/source/scripts/gen_release_notes.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/doc/source/releases.md b/doc/source/releases.md index f39ffc836..fcd535a65 100644 --- a/doc/source/releases.md +++ b/doc/source/releases.md @@ -1,4 +1,4 @@ -# Release notes for the MDAnalysis library +# MDAnalysis Release Notes ## Release 2.6.1 of MDAnalysis diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index 4d592ee05..6a1ba27c3 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -13,7 +13,7 @@ def gen_release_notes(filename): parent_directory.mkdir(exist_ok=True, parents=True) filename = parent_directory / filename - filetext = "# Release notes for the MDAnalysis library\n\n\n" + filetext = "# MDAnalysis Release Notes\n\n\n" # Should be ordered for release in repo.get_releases(): From 9ecc4690fcd3f28b54a8b928d26281b5c5566ff3 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 10:24:09 +0100 Subject: [PATCH 07/17] add releases.md to exclude for eol fixer --- .pre-commit-config.yaml | 1 + 1 file changed, 1 insertion(+) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index b845d5aff..43aa0141f 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -4,6 +4,7 @@ repos: hooks: - id: check-yaml - id: end-of-file-fixer + exclude: ^(doc/source/releases.md) - id: trailing-whitespace exclude: ^(.*\.(pdb)|doc/source/releases.md)$ - repo: https://github.com/pycqa/isort From d3a1d4f4fa1a061951505de537b7ae892655fe19 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 10:27:17 +0100 Subject: [PATCH 08/17] Add extra instructions for releases - manual addition for now --- doc/source/preparing_releases_and_hotfixes.rst | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/doc/source/preparing_releases_and_hotfixes.rst b/doc/source/preparing_releases_and_hotfixes.rst index b4b24f962..b0593bdb7 100644 --- a/doc/source/preparing_releases_and_hotfixes.rst +++ b/doc/source/preparing_releases_and_hotfixes.rst @@ -176,6 +176,13 @@ Create a release of the UserGuide For now, the UserGuide is released at the same time as the core library. To make a release of the UserGuide you should: +#. Make a Pull Request with a re-generated ``releases.md`` which contains a copy of the GitHub release notes. This can be generated by doing: + + .. code-block:: bash + + cd doc/source/scripts + python gen_release_notes.py + #. Create a new release tag and upload them for the UserGuide repository. .. code-block:: bash From 1f66ddf21e0ecc3ff911ee56fd47a950f12293a8 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 11:25:47 +0100 Subject: [PATCH 09/17] Add gh handles as links --- doc/source/releases.md | 56 ++++++++++++------------- doc/source/scripts/gen_release_notes.py | 8 ++++ 2 files changed, 36 insertions(+), 28 deletions(-) diff --git a/doc/source/releases.md b/doc/source/releases.md index fcd535a65..233e385ce 100644 --- a/doc/source/releases.md +++ b/doc/source/releases.md @@ -16,7 +16,7 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.1/ * Clarification of SurvivalProbability function documentation [Issue #4247, PR #4248]1 ### New Contributors -* @pillose made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4168 +* [@pillose](https://github.com/pillose) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4168 ## Release 2.6.0 of MDAnalysis @@ -56,9 +56,9 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.6.0/ * `MDAnalysis.analysis.hole2` is now deprecated in favour of a new [HOLE2 MDAKit](https://www.mdanalysis.org/hole2-mdakit/). (https://github.com/MDAnalysis/mdanalysis/pull/4200) ### New Contributors -* @MohitKumar020291 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4182 -* @Shubx10 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4184 -* @ztimol made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4191 +* [@MohitKumar020291](https://github.com/MohitKumar020291) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4182 +* [@Shubx10](https://github.com/Shubx10) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4184 +* [@ztimol](https://github.com/ztimol) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4191 ## Release 2.5.0 of MDAnalysis @@ -152,22 +152,22 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.5.0/ to the standardized one. ### New Contributors -* @mglagolev made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3959 -* @chrispfae made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4009 -* @ooprathamm made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4010 -* @MeetB7 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4022 -* @v-parmar made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4032 -* @MoSchaeffler made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4049 -* @jandom made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4043 -* @xhgchen made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4037 -* @DrDomenicoMarson made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4074 -* @AHMED-salah00 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4059 -* @schlaicha made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4076 -* @jvermaas made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4031 -* @SophiaRuan made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4072 -* @marinegor made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4085 -* @g2707 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4089 -* @DanielJamesEvans made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4109 +* [@mglagolev](https://github.com/mglagolev) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3959 +* [@chrispfae](https://github.com/chrispfae) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4009 +* [@ooprathamm](https://github.com/ooprathamm) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4010 +* [@MeetB7](https://github.com/MeetB7) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4022 +* [@v](https://github.com/v)-parmar made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4032 +* [@MoSchaeffler](https://github.com/MoSchaeffler) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4049 +* [@jandom](https://github.com/jandom) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4043 +* [@xhgchen](https://github.com/xhgchen) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4037 +* [@DrDomenicoMarson](https://github.com/DrDomenicoMarson) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4074 +* [@AHMED](https://github.com/AHMED)-salah00 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4059 +* [@schlaicha](https://github.com/schlaicha) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4076 +* [@jvermaas](https://github.com/jvermaas) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4031 +* [@SophiaRuan](https://github.com/SophiaRuan) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4072 +* [@marinegor](https://github.com/marinegor) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4085 +* [@g2707](https://github.com/g2707) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4089 +* [@DanielJamesEvans](https://github.com/DanielJamesEvans) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/4109 ## Release 2.4.3 of MDAnalysis @@ -212,10 +212,10 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.4.0/ #### Fixes: #### Enchancements: -* As part of their [outreachy project](https://www.mdanalysis.org/2022/12/15/uma_outreachy/) @umak has started adding type annotations throughout the MDAnalysis codebase -* As part of their [GSoC project](https://www.mdanalysis.org/2022/11/20/bjarne_gsoc/) @BFedder has added an auxialliary reader for EDR files (PR #3749) -* As part of their [GSoC project](https://www.mdanalysis.org/2022/12/09/Aya-gsoc-final-report/) @aya9aladdin has fixed various issues with guessing and and attribute reading. This will be followed by the introduction of a new guesser system in a future release. -* A reader for TNG files has been added by @hmacdope, follow up on his previous [GSoC 2020](https://www.mdanalysis.org/2020/09/02/final-report-hugo/) work on creating a python library for reading TNG files (PR 3765) +* As part of their [outreachy project](https://www.mdanalysis.org/2022/12/15/uma_outreachy/) [@umak](https://github.com/umak) has started adding type annotations throughout the MDAnalysis codebase +* As part of their [GSoC project](https://www.mdanalysis.org/2022/11/20/bjarne_gsoc/) [@BFedder](https://github.com/BFedder) has added an auxialliary reader for EDR files (PR #3749) +* As part of their [GSoC project](https://www.mdanalysis.org/2022/12/09/Aya-gsoc-final-report/) [@aya9aladdin](https://github.com/aya9aladdin) has fixed various issues with guessing and and attribute reading. This will be followed by the introduction of a new guesser system in a future release. +* A reader for TNG files has been added by [@hmacdope](https://github.com/hmacdope), follow up on his previous [GSoC 2020](https://www.mdanalysis.org/2020/09/02/final-report-hugo/) work on creating a python library for reading TNG files (PR 3765) * Addition of a new isolayer selection method (PR #3846) * Various enchancements and fixes to the LAMMPS DUMP Parser (allowing box translation on reading, allowing coordinates to be unwrapped based on dump image flags, and importing of forces and velocities) (PR #3844) * All readers now have a timeseries attribute (PR #3890) @@ -234,10 +234,10 @@ See the [CHANGELOG](https://github.com/MDAnalysis/mdanalysis/blob/release-2.4.0/ * MDAnalysis.analysis.nucleicacids' direct indexing of selection indices to obtain pair distances results has been deprecated in favor of accessing `results.pair_distances` (PR #3958) ### New Contributors -* @jaclark5 made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3846 -* @pgbarletta made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3876 -* @jfennick made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3832 -* @Hakarishirenai made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3956 +* [@jaclark5](https://github.com/jaclark5) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3846 +* [@pgbarletta](https://github.com/pgbarletta) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3876 +* [@jfennick](https://github.com/jfennick) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3832 +* [@Hakarishirenai](https://github.com/Hakarishirenai) made their first contribution in https://github.com/MDAnalysis/mdanalysis/pull/3956 diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index 6a1ba27c3..010c68d4d 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -1,5 +1,6 @@ import os import pathlib +import re from github import Github @@ -32,6 +33,13 @@ def gen_release_notes(filename): filetext += "\n\n" + # replace all @ starting handles with github links + # \b doesn't work so we're using \s and getting extra whitespace + handles = set(re.findall(r'\s@\w+', filetext)) + for entry in handles: + new_word = f" [{entry[1:]}](https://github.com/{entry[2:]})" + filetext = filetext.replace(entry, new_word) + with open(filename, "w") as f: f.write(filetext) From a7ec0eb660748a707a14c835876bab51e1b9e354 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Sun, 1 Oct 2023 11:33:34 +0100 Subject: [PATCH 10/17] fix pre-commit --- doc/source/scripts/gen_release_notes.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index 010c68d4d..510c124c1 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -35,7 +35,7 @@ def gen_release_notes(filename): # replace all @ starting handles with github links # \b doesn't work so we're using \s and getting extra whitespace - handles = set(re.findall(r'\s@\w+', filetext)) + handles = set(re.findall(r"\s@\w+", filetext)) for entry in handles: new_word = f" [{entry[1:]}](https://github.com/{entry[2:]})" filetext = filetext.replace(entry, new_word) From efc7852e78a58640e642811f10cdc76ce190bee5 Mon Sep 17 00:00:00 2001 From: Irfan Alibay Date: Tue, 3 Oct 2023 17:41:43 +0100 Subject: [PATCH 11/17] Update environment.yml --- environment.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/environment.yml b/environment.yml index a56c26065..eeb99fc2f 100644 --- a/environment.yml +++ b/environment.yml @@ -52,6 +52,8 @@ dependencies: - nbval # developer tooling - pre-commit + # doc generation dependency + - pygithub # mdanalysis and its tests and test data - git+https://github.com/MDAnalysis/mdanalysis@develop#egg=mdanalysis&subdirectory=package - git+https://github.com/MDAnalysis/mdanalysis@develop#egg=MDAnalysisTests&subdirectory=testsuite From 0ebb2b9806aa757a7613640067d6aa89d90647a6 Mon Sep 17 00:00:00 2001 From: Irfan Alibay Date: Fri, 27 Oct 2023 11:33:31 +0100 Subject: [PATCH 12/17] how about this? --- .pre-commit-config.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index fbd0e7b37..5cfbd4c48 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -12,7 +12,7 @@ repos: - id: end-of-file-fixer exclude: ^(doc/source/releases.md) - id: trailing-whitespace - exclude: ^(.*\.(pdb)|doc/source/releases.md|ambr)$ + exclude: ^.*\.(pdb|doc/source/releases.md|ambr)$ - repo: https://github.com/pycqa/isort rev: 5.12.0 hooks: From 537001118404aa64f1e358a6766a3bf3f978fc5b Mon Sep 17 00:00:00 2001 From: IAlibay Date: Fri, 27 Oct 2023 11:48:21 +0100 Subject: [PATCH 13/17] remove unused variable --- doc/source/scripts/gen_release_notes.py | 1 - 1 file changed, 1 deletion(-) diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index 510c124c1..e1dd680b0 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -8,7 +8,6 @@ def gen_release_notes(filename): git = Github(os.environ["GITHUB_TOKEN"]) repo = git.get_repo("MDAnalysis/mdanalysis") - releases = repo.get_releases() parent_directory = pathlib.Path(__file__).parent.parent parent_directory.mkdir(exist_ok=True, parents=True) From 2a0f2de57490a8a33d6294b2951416126597ae4a Mon Sep 17 00:00:00 2001 From: IAlibay Date: Fri, 27 Oct 2023 11:49:52 +0100 Subject: [PATCH 14/17] type the one function --- doc/source/scripts/gen_release_notes.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index e1dd680b0..77a49e7b0 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -5,7 +5,7 @@ from github import Github -def gen_release_notes(filename): +def gen_release_notes(filename: str): git = Github(os.environ["GITHUB_TOKEN"]) repo = git.get_repo("MDAnalysis/mdanalysis") From 391c5fc49cb6ff1fbc480eb0c1207e5e9e2a5a56 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Fri, 27 Oct 2023 12:11:34 +0100 Subject: [PATCH 15/17] fix mypy --- doc/source/scripts/gen_release_notes.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/doc/source/scripts/gen_release_notes.py b/doc/source/scripts/gen_release_notes.py index 77a49e7b0..5c1a4661d 100644 --- a/doc/source/scripts/gen_release_notes.py +++ b/doc/source/scripts/gen_release_notes.py @@ -5,13 +5,13 @@ from github import Github -def gen_release_notes(filename: str): +def gen_release_notes(filename: str) -> None: git = Github(os.environ["GITHUB_TOKEN"]) repo = git.get_repo("MDAnalysis/mdanalysis") parent_directory = pathlib.Path(__file__).parent.parent parent_directory.mkdir(exist_ok=True, parents=True) - filename = parent_directory / filename + filename = parent_directory / filename # type: ignore filetext = "# MDAnalysis Release Notes\n\n\n" From 6c32aff9bb054814108269c31b4f9219b0f8ccb6 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Fri, 27 Oct 2023 12:12:13 +0100 Subject: [PATCH 16/17] Try fixing pre-commit --- .pre-commit-config.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 5cfbd4c48..3af852ad4 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -12,7 +12,7 @@ repos: - id: end-of-file-fixer exclude: ^(doc/source/releases.md) - id: trailing-whitespace - exclude: ^.*\.(pdb|doc/source/releases.md|ambr)$ + exclude: ^(.*\.(pdb|doc/source/releases.md|ambr))$ - repo: https://github.com/pycqa/isort rev: 5.12.0 hooks: From a3be306e13d24e99e6f95d200af432b4a508f646 Mon Sep 17 00:00:00 2001 From: IAlibay Date: Fri, 27 Oct 2023 12:31:39 +0100 Subject: [PATCH 17/17] this should match? --- .pre-commit-config.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 3af852ad4..66cabdb73 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -12,7 +12,7 @@ repos: - id: end-of-file-fixer exclude: ^(doc/source/releases.md) - id: trailing-whitespace - exclude: ^(.*\.(pdb|doc/source/releases.md|ambr))$ + exclude: ^.*\.(pdb|ambr)|^(doc\/source\/releases.md)$ - repo: https://github.com/pycqa/isort rev: 5.12.0 hooks: