Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Renaming to cpctools #85

Merged
merged 5 commits into from
Nov 16, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions Changelog.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,11 @@

Until we get to a release version you may encounter different broken interface problem each time we increase a minor version.

## Changes since v0.2.0

- Rename SOAPify to cpctools
- Clarify README

## Changes since v0.1.0rc0

- `SOAPify.HDF5er.isTrajectoryGroup` now returns `False` with Datasets
Expand Down
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
19 changes: 9 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,10 @@ 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"
ReadTheDocs = "https://cpctools.readthedocs.io/en/latest/"
Issues = "https://github.com/GMPavanLab/cpctools/issues"
Source = "https://github.com/GMPavanLab/cpctools"

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

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

Expand Down
2 changes: 1 addition & 1 deletion src/SOAPify/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,4 @@
from .engine import *
from .analysis import *

__version__ = "v0.1.0"
__version__ = "v0.2.0"