Home

Awesome

PLAMS - Python Library for Automating Molecular Simulation

Overview

PLAMS is a flexible and extensible toolkit for streamlining molecular simulation workflows.

It simplifies and automates the process of configuring, running and analyzing computational chemistry calculations. The key features of PLAMS are:

Quick Start

PLAMS is available to all users of AMS "out of the box" as part of the AMS Python Stack, which can be accessed with the $AMSBIN/amspython command.

For most use-cases, no specific installation outside of AMS is required. For usage outside of amspython, please see the installation guide below.

To get started with PLAMS, import scm.plams into your python script or jupyter notebook. Then, follow one of the examples to help create your script e.g.

    # water_opt.py
    from scm.plams import from_smiles, AMSJob
    from scm.input_classes import drivers, engines

    water = from_smiles("O")

    driver = drivers.AMS()
    driver.Task = "GeometryOptimization"
    driver.Properties.NormalModes = "Yes"
    driver.Engine = engines.ForceField()
    driver.Engine.Type = "UFF"

    job = AMSJob(molecule=water, settings=driver, name="water_opt")
    results = job.run()

    print("Optimized geometry:")
    print(results.get_main_molecule())

Running the command $AMSBIN/amspython water_opt.py produces the successful output:

    JOB water_opt RUNNING
    JOB water_opt FINISHED
    JOB water_opt SUCCESSFUL
    Optimized geometry:
      Atoms:
        1         O      -0.000360       0.403461       0.000000
        2         H      -0.783821      -0.202431       0.000000
        3         H       0.784180      -0.201030       0.000000
      Bonds:
       (1)--1.0--(2)
       (1)--1.0--(3)

For more advanced workflows including usage of other AMS engines, see the other examples.

Installation Guide

As mentioned, PLAMS and all its required and optional dependencies are included as part of the AMS python stack. This is the easiest way to use PLAMS, as it requires no additional installation process.

However, if you want to use PLAMS outside of amspython, since AMS2024.103 PLAMS is available on PyPI. and so can be installed via the pip python package installer.

To install the latest version of PLAMS into your python environment, simply run pip install plams. To install a specific version of PLAMS (e.g. 2025.101), run pip install plams==2025.101.

By default, PLAMS only installs a minimal set of required packages on installation using pip. For additional functionality, further optional packages are required. Since AMS2025, these are available for installation through extra dependency groups with pip.

The available groups are:

One or more of these can be installed using the command pip install 'plams[chem,analysis,ams]'.

Users of the AMS will also have to install the scm.amspipe package using the command pip install $AMSHOME/scripting/scm/amspipe.

License

See LICENSE.md for details.

Contributing

Contributions are welcome. See CONTRIBUTING.md for details.