Metadata-Version: 2.4
Name: mkite_engines
Version: 25.11.3
Summary: engines for connecting messages to/from mkite
Author-email: Daniel Schwalbe-Koda <dskoda@ucla.edu>
Keywords: workflow,materials-science
Requires-Python: >=3.8
Description-Content-Type: text/markdown
License-File: LICENSE
License-File: NOTICE
Requires-Dist: pydantic>=2.0
Requires-Dist: redis
Requires-Dist: fakeredis
Dynamic: license-file

<div align="center">
  <img src="https://raw.githubusercontent.com/mkite-group/mkite_engines/main/docs/_static/mkite-engines.svg" width="400"><br>
</div>

# mkite_engines

mkite_engines implements interfaces that help distributing jobs to workers.
These interfaces are [producers and consumers](https://en.wikipedia.org/wiki/Producer%E2%80%93consumer_problem) of data, and are created to simplify data management and transfer between the production server and the task worker.

## Documentation

General tutorial for `mkite` and its plugins are available in the [main documentation](https://mkite.org).
Complete API documentation is pending.

## Installation

`mkite_engines` is essential to run all other components of mkite. To install this package, use pip:

```bash
pip install mkite_engines
```

Alternatively, for a development version, clone this repo and install it in editable form:

```bash
pip install -U git+https://github.com/mkite-group/mkite_engines
```

## Contributions

Contributions to the entire mkite suite are welcomed.
You can send a pull request or open an issue for this plugin or either of the packages in mkite.
When doing so, please adhere to the [Code of Conduct](CODE_OF_CONDUCT.md) in the mkite suite.

The mkite package was created by Daniel Schwalbe-Koda <dskoda@ucla.edu>.

### Citing mkite

If you use mkite in a publication, please cite the following paper:

```bibtex
@article{mkite2023,
    title = {mkite: A distributed computing platform for high-throughput materials simulations},
    author = {Schwalbe-Koda, Daniel},
    year = {2023},
    journal = {arXiv:2301.08841},
    doi = {10.48550/arXiv.2301.08841},
    url = {https://doi.org/10.48550/arXiv.2301.08841},
    arxiv={2301.08841},
}
```

## License

The mkite suite is distributed under the following license: Apache 2.0 WITH LLVM exception.

All new contributions must be made under this license.

SPDX: Apache-2.0, LLVM-exception

LLNL-CODE-848161
