Skip to main content

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.

ASI API specification.

Supported in:

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+

  1. Download and build DFTB+ from the branch with ASI API with shared library support.

  2. Set environment variables DFTBP_INCLUDE and DFTBP_LIB_DIR to folders with DFTB+ C-headers and libraries.

  3. Optionally export environment variables INSTALL_PREFIX and BUILD_PATH to set installation and building locations.

  4. Run make && make install from the root of the working copy of this repository.

  5. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

asi4py-1.3.18.tar.gz (17.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

asi4py-1.3.18-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

Details for the file asi4py-1.3.18.tar.gz.

File metadata

  • Download URL: asi4py-1.3.18.tar.gz
  • Upload date:
  • Size: 17.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.2

File hashes

Hashes for asi4py-1.3.18.tar.gz
Algorithm Hash digest
SHA256 c56c9a8a6ebaf80bf30ce7a023132bceac2d99814abb8b36fb7fc0f4b7cabb5e
MD5 6ec90ef286e87a58cefd06bb60dc2364
BLAKE2b-256 5635e5dfaa162ac1d0dae3c4278bbcaa177bdfb571f3d6c40c95d3de77ebd540

See more details on using hashes here.

File details

Details for the file asi4py-1.3.18-py3-none-any.whl.

File metadata

  • Download URL: asi4py-1.3.18-py3-none-any.whl
  • Upload date:
  • Size: 17.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.2

File hashes

Hashes for asi4py-1.3.18-py3-none-any.whl
Algorithm Hash digest
SHA256 cedcfc3f01da259176c8ac53bac5745bbf93f290b5e3ffdde080b6ab1d5f8065
MD5 bc5e0b1e4cec489e04d9e9bcae4a3842
BLAKE2b-256 b770b157c5f90b4f6206db2bf0537b269c0e78589e7f9af9f455492a4ccd482d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page