A Python wrapper for Atomic Simulation Interface API
Project description
Atomic Similation Interface (ASI) API
Atomic Simulation Interface (ASI) is a native C-style API that includes functions for export and import of data structures that are used in electronic structure calculations and for classical molecular dynamics simulations. ASI aims to be a uniform, generic and efficient interface for connecting various computational chemistry and materials science codes in multiscale simulation workflows, such as QM/MM, QM/ML, QM/QM. ASI specifies functions, data types and calling conventions for export and import of density matrices, overlap and Hamiltonian matrices, electrostatic potential, atomic coordinates, charges, total energy and forces.
ASI API specification
ASI API is specified as a C header file asi.h
. Codes implementing ASI API must provide linkable library with definitions of functions from asi.h
. Depending on particular usage of the implementaions, some functions can be ommited or implemented as stubs, if they are not going to used. To use Python ASI wrapper it is necessary to have all functions from asi.h
defined, but of course stub definitions can be used.
Supported in:
- DFTB+: in separate branch.
- FHI-aims: in the main branch.
Building
FHI-aims
FHI-aims has embedded support of ASI API. Just build latest version of FHI-aims as a shared library and use with your code.
DFTB+
-
Download and build DFTB+ from the branch with ASI API with shared library support.
-
Set environment variables
DFTBP_INCLUDE
andDFTBP_LIB_DIR
to folders with DFTB+ C-headers and libraries. -
Optionally export environment variables
INSTALL_PREFIX
andBUILD_PATH
to set installation and building locations. -
Run
make && make install
from the root of the working copy of this repository. -
The shared library implementing ASI API for DFTB+ will be in
${INSTALL_PREFIX}/lib
.
Testing
Use Makefile
in tests
folder to build native tests. Set environment variables in the header of tests/Makefile
to link with proper ASI API implementaions.
To run tests go to tests/testcases
and run run_dftbp_tests.sh
or run_aims_tests.sh
to run test.
Usage
See tests/src
for examples of usage in native code.
See tests/python
for examples of usage in Python scripts.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file asi4py-1.3.12.tar.gz
.
File metadata
- Download URL: asi4py-1.3.12.tar.gz
- Upload date:
- Size: 16.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1886587b53498fb4534cbb5353f651980ca23244dd2b4101479db064847c5061 |
|
MD5 | c4d94f90f4b433915d4cb48acd1b3f50 |
|
BLAKE2b-256 | 864df3761cc43302205adb095dd5a67be035940ffa900e9a93e2ac6742458b79 |
File details
Details for the file asi4py-1.3.12-py3-none-any.whl
.
File metadata
- Download URL: asi4py-1.3.12-py3-none-any.whl
- Upload date:
- Size: 15.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d91f88d1eaa779a7bf1baa8483b2e57272e9217daec6f858f9a0a18dfb50ad7f |
|
MD5 | 4b11d52d0089fc86ce4561616b246d7c |
|
BLAKE2b-256 | b0e28b8413567eae6736d5aaaea0110b89b0a6be8e8a122685976083dc4834d7 |