Notable changes to this project will be documented in this file. The format is based on Keep a Changelog.
The versioning for this project aligns with that of AMS. The format for this is the original year of the main release as a prefix, and an incremental postfix for each sub-release, starting at 101. In general, subsequent sub-releases after the main release contain only bug fixes. For example, 2024.101 is the major release of 2024, and 2024.102 is the first bugfix release.
This changelog is effective from the 2025 releases.
- Methods
get_system
,get_input_system
andget_main_system
toAMSResults
, which return an AMSChemicalSystem
instead of a PLAMSMolecule
AMSJob
can accept an AMSChemicalSystem
instead of a PLAMSMolecule
as an input system- Specific
ConfigSettings
and related settings classes with explicitly defined fields - Support for work functions:
AMSResults.get_work_function_results
andplot_work_function
- Example on
MoleculeFormats
- Script
generate_example.sh
to generate documentation pages from notebook examples - GitHub workflows for CI and publishing to PyPI
- Build using
pyproject.toml
, addition of extras groups to install optional dependencies - Logging of job summaries to CSV logfile
- Functions for optional packages (e.g. RDKit, ASE) are available even when these packages are not installed, but will raise an
MissingOptionalPackageError
when called AMSResults.get_main_ase_atoms
also includes atomic charges- Global
config
is initialized with aConfigSettings
instead of loading from the standardplams_defaults
file init
andfinish
functions are now optionalJob.status
is aJobStatus
string enum- Supercell and RDKit properties are no longer serialized to AMS input
- Restructuring of examples and conversion of various examples to notebooks
- Support for
networkx>=3
andase>=3.23
- Use standard library logger for
log
function
Molecule.properties.charge
is a numeric instead of string type when loading molecule from a fileMolecule.delete_all_bonds
removes the reference molecule from the removed bond instancesSingleJob.load
returns the correctly loaded jobAMSJob.check
handles aNoneType
status, returningFalse
plams
launch script is deprecated in favour of simply running withamspython
- Legacy
BANDJob
,DFTBJob
,UFFJob
,MOPACJob
,ReaxFFJob
,CSHessianADFJob
andADFJob
have been removed - Exception classes
AMSPipeDecodeError
,AMSPipeError
,AMSPipeInvalidArgumentError
,AMSPipeLogicError
,AMSPipeRuntimeError
,AMSPipeUnknownArgumentError
,AMSPipeUnknownMethodError
,AMSPipeUnknownVersionError
, were moved from scm.plams to scm.amspipe.