Skip to content

Commit

Permalink
Update README + pyproject.toml.
Browse files Browse the repository at this point in the history
  • Loading branch information
andrewtarzia committed Nov 16, 2023
1 parent 3217ad1 commit 4a4c05d
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 48 deletions.
54 changes: 16 additions & 38 deletions Readme.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# cpctools: SOAPify and SOAPify.HDF5er
# cpctools

![PyPI - License](https://img.shields.io/pypi/l/cpctools)
[![PyPI](https://img.shields.io/pypi/v/cpctools)](https://pypi.org/project/cpctools/)
Expand All @@ -9,65 +9,43 @@
[![Coverage Status](https://coveralls.io/repos/github/GMPavanLab/SOAPify/badge.svg?branch=main)](https://coveralls.io/github/GMPavanLab/SOAPify?branch=main)
[![Powered by MDAnalysis](https://img.shields.io/badge/powered%20by-MDAnalysis-orange.svg?logoWidth=16&logo=)](https://www.mdanalysis.org)

SOAPify is a python 3.8/3.9/3.10 library aimed at simplifying the analysis of Molecular Dynamics simulation using the Smooth Overlap of Atomic Position (SOAP) in the context that includes the time along the geometrical information of the frames of the simulation.

SOAPify uses `h5py` to store the trajectories, the SOAP fingerprints, and the analysis results in a binary format.
### **We are no longer developing in this project. Future works will be in [dynsight](https://github.com/GMPavanLab/dynsight).**

SOAPify also offers a suite for (simple) state analysis for your simulations.

## How To Install
`cpctools` is a python 3.8/3.9/3.10 library aimed at simplifying the analysis of Molecular Dynamics simulations.

To install the stable version of SOAPify just type:
```bash
pip install cpctools
```
_cpctools_ stands for **C**omputational **P**hysical **C**hemistry **TOOLS**, or, if you prefer, for **C**hemical **P**hysics **C**omputational **TOOLS**.

If you want to use _dscribe_ or _quippy_ for calculating the SOAP features you should install them separately, since they are quite heavy packages on their own, and usually you would use only one of these packages:
It contains two packages, `SOAPify` and `SOAPify.HDF5er`.

```bash
pip install "dscribe<=1.2.2,>1.2.0"
pip install "quippy-ase==0.9.10"
```
`cpctools` uses `h5py` to store the trajectories, the SOAP fingerprints, and the analysis results in a binary format, facilitated by `HDF5er`.

### Installing the latest version
The documentation is available on [read the docs](https://cpctools.readthedocs.io/en/latest/). There you can consult the documentation for each available version of the package.

We always recommend to install your code in a dedicated environment:
## How To Install

To install the stable version of `cpctools` just type:
```bash
python3 -m venv /path/to/new/venv --prompt SOAPify
source /path/to/new/venv/bin/activate
pip install --upgrade pip
pip install cpctools
```

Then to install SOAPify you can simply go to the repository directory and run the following:
```bash
cd /path/to/SOAPify/directory
pip install .
```
or if you do not want to download the repo, you can have pip install from source:
```bash
pip install 'cpctools @ git+https://github.com/GMPavanLab/SOAPify.git'
```
Or if you desire an older version you can install it from a tag:
If you want to use _dscribe_ or _quippy_ for calculating the SOAP features you should install them separately, since they are quite heavy packages on their own, and usually you would use only one of these packages:

```bash
pip install 'cpctools @ git+https://github.com/GMPavanLab/[email protected]'
pip install "dscribe<=1.2.2,>1.2.0"
pip install "quippy-ase==0.9.10"
```

We have a (very basic) [documentation](https://gmpavanlab.github.io/SOAPify/SOAPify.html) of the latest version available on the GitHub pages.

A more complete history of the documentation is available on [read the docs](https://soapify.readthedocs.io/en/latest/). There you can consult the documentation for each available version of the package.


## SOAPify
---
### package: SOAPify

This package contains:
- a toolbox to calculate the [SOAP fingerprints](https://doi.org/10.1103/PhysRevB.87.184115) of a system of atoms. The principal aim is to simplify the setup of the calculation. This toolbox depends on `dscribe` or `quippy` and 'unify' the output of the two codes.
- a toolbox to calculate the distances between SOAP fingerprints
- a simple analysis tool for trajectories of classified atoms


## SOAPify.HDF5er
### package: SOAPify.HDF5er

This package is a toolbox to create [hdf5 files](https://www.hdfgroup.org/) with [h5py](https://www.h5py.org/) from the trajectory and topology files. The format we use **do not** align with [h5md](https://www.nongnu.org/h5md/h5md.html)

Expand Down
16 changes: 6 additions & 10 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ build-backend = "hatchling.build"

[project]
name = "cpctools"
description = "A package for creating and studying SOAP fingerprints"
description = "A package for analysing molecular systems"
readme = "Readme.md"
requires-python = "<3.11,>=3.8"
license = "MIT"
Expand All @@ -18,9 +18,9 @@ classifiers = [
"Programming Language :: Python :: 3.10",
]
dependencies = [
"ase==3.22.1",
"ase==3.22.1",
"MDAnalysis==2.4.2",
"h5py==3.8.0",
"h5py==3.8.0",
"Deprecated==1.2.13",
"numpy<1.24,>=1.18", #problems with numba and f90wrap
]
Expand All @@ -37,7 +37,7 @@ docs = [
"sphinx_gallery==0.12.2",
"ipython"
]
dscribe=["dscribe >1.2.0, <=12.2",]
dscribe=["dscribe >1.2.0, <=1.2.2",]
quippy=["quippy-ase==0.9.10",]
tests = [
"coverage[toml]",
Expand All @@ -47,11 +47,7 @@ tests = [


[project.urls]
Homepage = "https://github.com/GMPavanLab/SOAPify"
Documentation = "https://gmpavanlab.github.io/SOAPify/"
ReadTheDocs = "https://soapify.readthedocs.io/en/latest/"
Issues = "https://github.com/GMPavanLab/SOAPify/issues"
Source = "https://github.com/GMPavanLab/SOAPify"
Homepage = "https://github.com/GMPavanLab/cpctools"

#TODO: define some cli scripts that can be useful!
[project.scripts]
Expand Down Expand Up @@ -85,7 +81,7 @@ cleanbuild = 'cd docs && make clean build'

[tool.hatch.envs.livedocs]
template="docs"
extra-dependencies = [
extra-dependencies = [
"sphinx-autobuild",
]

Expand Down

0 comments on commit 4a4c05d

Please sign in to comment.