1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224
|
# Spglib
[![CI Status][ci-badge]][ci-link]
[![Documentation Status][rtd-badge]][rtd-link]
[![Codecov Status][codecov-badge]][codecov-link]
![License Status][license-badge]
![CMake Status][cmake-badge]
[![Python Versions][python-version]][pypi-link]
[![Release Status][release-badge]][release-link]
[![Conda Status][conda-badge]][conda-link]
[![PyPI Status][pypi-badge]][pypi-link]
[![Fedora Status][fedora-badge]][fedora-link]
[![Homebrew Status][homebrew-badge]][homebrew-link]
[![Spack Status][spack-badge]][spack-link]
[![Vcpkg Status][vcpkg-badge]][vcpkg-link]
[![PyPI Downloads][pypi-downloads]][pypi-link]
[![Conda Downloads][conda-downloads]][conda-link]
C library for finding and handling crystal symmetries
<!-- TOC -->
- [Spglib](#spglib)
- [What does Spglib do?](#what-does-spglib-do)
- [Requirements](#requirements)
- [How to use Spglib](#how-to-use-spglib)
- [How install the python library](#how-install-the-python-library)
- [How to manually compile](#how-to-manually-compile)
- [How to run test](#how-to-run-test)
- [How to cite Spglib](#how-to-cite-spglib)
- [Contributing](#contributing)
- [Documentation](#documentation)
<!-- TOC -->
## What does Spglib do?
A crystal structure is given to a spglib function to obtain symmetry
information. `spg_get_dataset` is the function that returns most fruitful
space group information. This returns the result in the C-structure
`SpglibDataset`. We don't know the length of symmetry operations to be returned,
the memory spaces are allocated dynamically, which means we have to free them.
by `spg_free_dataset`. To tolerate tiny distortion of crystal structure,
it has to be specified when calling symmetry search function. The following
pages show the details.
- [Crystal structure format](https://spglib.github.io/spglib/variable.html)
- [Functions](https://spglib.github.io/spglib/api.html)
- [Spglib dataset](https://spglib.github.io/spglib/dataset.html)
```C
#include <assert.h>
#include "spglib.h"
int main(void) {
SpglibDataset *dataset;
// Wurtzite structure (P6_3mc)
double lattice[3][3] = {
{3.111, -1.5555, 0}, {0, 2.6942050311733885, 0}, {0, 0, 4.988}};
double position[4][3] = {
{1.0 / 3, 2.0 / 3, 0.0},
{2.0 / 3, 1.0 / 3, 0.5},
{1.0 / 3, 2.0 / 3, 0.6181},
{2.0 / 3, 1.0 / 3, 0.1181},
};
int types[4] = {1, 1, 2, 2};
int num_atom = 4;
double symprec = 1e-5;
// SplibDataset has to be freed after use.
dataset = spg_get_dataset(lattice, position, types, num_atom, symprec);
// Obtain data in SpglibDataset.
// The space group number 186 corresponds to the wurtzite-type (P6_3mc).
// See https://www.cryst.ehu.es/cgi-bin/cryst/programs/nph-table
assert(dataset->spacegroup_number == 186);
// Deallocate SpglibDataset, otherwise induce memory leak.
spg_free_dataset(dataset);
}
```
## Requirements
- C standard: As of version 2.1.0, Spglib explicitly enforces a minimum standard of
[C11](https://en.cppreference.com/w/c/11)
## How to use Spglib
We currently only officially support conda and pip packaging of spglib, with plans
to expand to FedoraProject in the near future. We are looking for additional
contributors to package on other linux distributions. For the systems that are not
yet officially supported please look at the instructions for [manual compilation](#how-to-manually-compile)
The main interface for spglib is the C api, but we also officially support Fortran
and Python interfaces. For a minimal example of how to use this library please
check the provided [examples](example/README.md)
### How install the python library
Spglib is available on PyPi, so it can be installed as:
```console
$ pip install spglib
```
Alternatively you can install the conda package that bundles the C and Fortran libraries
```console
$ conda install -c conda-forge spglib
```
This python library will default to the system installed Spglib library detected,
specified via `LD_LIBRARY_PATH` on Linux or `DYLD_LIBRARY_PATH` on MacOS, otherwise
defaulting to a bundled version.
For more details and how to build the python project from source, see the
[python documentation](python/README.rst).
### How to manually compile
The minimum configuration, build and install instructions are as follows:
```console
$ cmake . -B ./build
$ cmake --build ./build
$ cmake --install ./build
```
For more details on configuration options and how to link your project check
the [cmake documentation](cmake/README.md). A minimal example project using
spglib is available at [example](example/README.md).
## How to run test
The C library tests are incorporated in the CMake projects and enabled by default.
To execute these tests, run the following command with the appropriate path to the
build directory
```console
$ ctest --test-dir ./build
```
Additionally, there are python tests that cover more use-cases.
See the [README](python/README.rst) in the python folder for more details
## How to cite Spglib
If you use spglib in your research, please consider citing the following work:
- [Atsushi Togo, Kohei Shinohara and Isao Tanaka, Spglib: a software library for crystal symmetry search, Sci. Technol. Adv. Mater., Meth. 4, 2384822-2384836 (2024)](https://www.tandfonline.com/doi/full/10.1080/27660400.2024.2384822) (open access)
```
@article{spglib,
author = {Atsushi Togo, Kohei Shinohara and Isao Tanaka},
title = {Spglib: a software library for crystal symmetry search},
journal = {Sci. Technol. Adv. Mater., Meth.},
volume = {4},
number = {1},
pages = {2384822--2384836},
year = {2024},
doi = {10.1080/27660400.2024.2384822},
url = {https://doi.org/10.1080/27660400.2024.2384822},
}
```
If you use functions to search for magnetic symmetry operations in spglib, please also consider citing the following work:
- [Kohei Shinohara, Atsushi Togo, and Isao Tanaka, Algorithms for magnetic symmetry operation search and identification of magnetic space group from magnetic crystal structure, Acta Cryst. A 79, 390-398 (2023)](https://onlinelibrary.wiley.com/iucr/doi/10.1107/S2053273323005016) (open access)
```
@article{spglibv2,
author = "Shinohara, Kohei and Togo, Atsushi and Tanaka, Isao",
title = "{Algorithms for magnetic symmetry operation search and identification of magnetic space group from magnetic crystal structure}",
journal = "Acta Cryst. A",
year = "2023",
volume = "79",
number = "5",
pages = "390--398",
month = "Sep",
doi = {10.1107/S2053273323005016},
url = {https://doi.org/10.1107/S2053273323005016},
}
```
## Contributing
We welcome any contribution from the core development of the library to documentation
improvements. See [Contributing.md](Contributing.md) for more details.
## Documentation
See [https://spglib.readthedocs.io/](https://spglib.readthedocs.io/) for further
documentation. See the [documentation](docs/README.md) for more information on
how to contribute to the documentation.
[ci-badge]: https://github.com/spglib/spglib/actions/workflows/ci.yaml/badge.svg?branch=develop&event=push
[ci-link]: https://github.com/spglib/spglib/actions/workflows/ci.yaml?query=branch%3Adevelop+event%3Apush
[cmake-badge]: https://img.shields.io/badge/CMake-3.25-blue?logo=data:image/svg%2bxml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGRhdGEtbmFtZT0iTGF5ZXIgMiIgdmlld0JveD0iMCAwIDU0NS41IDU0NS45Ij48cGF0aCBkPSJNNTQ2IDUzNCAyODIgOWwzOSA0MzQgMjI1IDkxeiIgZGF0YS1uYW1lPSJyZWQgcmlnaHQiIHN0eWxlPSJmaWxsOiNmMzI3MzU7c3Ryb2tlLXdpZHRoOjAiLz48cGF0aCBkPSJNNTI1IDU0NiAxNzAgNDAzIDEgNTQ2aDUyNHoiIGRhdGEtbmFtZT0iZ3JlZW4gYm90dG9tIiBzdHlsZT0ic3Ryb2tlLXdpZHRoOjA7ZmlsbDojM2VhZTJiIi8+PHBhdGggZD0iTTI2MyAwIDAgNTIybDI4OC0yNDRMMjYzIDB6IiBkYXRhLW5hbWU9ImJsdWUgbGVmdCIgc3R5bGU9ImZpbGw6IzAwNjhjNztzdHJva2Utd2lkdGg6MCIvPjxwYXRoIGQ9Im0yOTEgMjk5LTEwNSA4OSAxMTcgNDgtMTItMTM3eiIgZGF0YS1uYW1lPSJncmF5IGNlbnRlciIgc3R5bGU9ImZpbGw6I2RjZTNlYztzdHJva2Utd2lkdGg6MCIvPjwvc3ZnPg==
[codecov-badge]: https://codecov.io/gh/spglib/spglib/graph/badge.svg?token=G91xAWu1JT
[codecov-link]: https://codecov.io/gh/spglib/spglib
[conda-badge]: https://img.shields.io/conda/vn/conda-forge/spglib
[conda-downloads]: https://img.shields.io/conda/d/conda-forge/spglib?label=conda
[conda-link]: https://anaconda.org/conda-forge/spglib
[fedora-badge]: https://img.shields.io/fedora/v/spglib
[fedora-link]: https://src.fedoraproject.org/rpms/spglib
[homebrew-badge]: https://img.shields.io/homebrew/v/spglib
[homebrew-link]: https://formulae.brew.sh/formula/spglib
[license-badge]: https://img.shields.io/github/license/spglib/spglib
[pypi-badge]: https://img.shields.io/pypi/v/spglib
[pypi-downloads]: https://img.shields.io/pypi/dm/spglib?label=pypi
[pypi-link]: https://pypi.python.org/pypi/spglib
[python-version]: https://img.shields.io/pypi/pyversions/spglib
[release-badge]: https://img.shields.io/github/v/release/spglib/spglib
[release-link]: https://github.com/spglib/spglib/releases
[rtd-badge]: https://img.shields.io/readthedocs/spglib
[rtd-link]: https://spglib.readthedocs.io/en/latest/?badge=latest
[spack-badge]: https://img.shields.io/spack/v/spglib
[spack-link]: https://packages.spack.io/package.html?name=spglib
[vcpkg-badge]: https://img.shields.io/vcpkg/v/spglib
[vcpkg-link]: https://vcpkg.io/en/package/spglib
|