Metadata-Version: 2.4
Name: flowchem
Version: 1.1.0.post3
Summary: Flowchem is a library to control instruments and devices commonly found in chemistry labs via an interoperable web API.
Author-email: Dario Cambié <2422614+dcambie@users.noreply.github.com>, Jakob Wolf <75418671+JB-Wolf@users.noreply.github.com>, Wei-Hsin Hsu <98024191+cynthiabour@users.noreply.github.com>, Samuel Saraiva <88909409+samuelvitorsaraiva@users.noreply.github.com>
Maintainer-email: Jakob Wolf <75418671+JB-Wolf@users.noreply.github.com>, Samuel Saraiva <88909409+samuelvitorsaraiva@users.noreply.github.com>
License-Expression: MIT
Project-URL: homepage, https://github.com/automatedchemistry/flowchem
Project-URL: documentation, https://flowchem.readthedocs.io
Project-URL: repository, https://github.com/automatedchemistry/flowchem
Keywords: chemistry,automation,laboratory,science
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Development Status :: 5 - Production/Stable
Classifier: Operating System :: OS Independent
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: aioserial>=1.3.1
Requires-Dist: anyio
Requires-Dist: asyncua>=1.0.2
Requires-Dist: bronkhorst-propar>=1.1.0
Requires-Dist: click<=8.1.3
Requires-Dist: fastapi>=0.100.0
Requires-Dist: ifaddr>=0.2.0
Requires-Dist: loguru>=0.7.0
Requires-Dist: lxml>=4.9.2
Requires-Dist: numpy
Requires-Dist: packaging>=23.1
Requires-Dist: pint!=0.21,>=0.16.1
Requires-Dist: pydantic[email]>=2.0.2
Requires-Dist: pyserial>=3
Requires-Dist: requests
Requires-Dist: rich_click>=1.6.1
Requires-Dist: tomli; python_version < "3.11"
Requires-Dist: uvicorn>=0.19.0
Requires-Dist: zeroconf>=0.71.0
Requires-Dist: python-multipart>=0.0.20
Provides-Extra: all
Requires-Dist: black>=26.3.1; extra == "all"
Requires-Dist: data-science-types; extra == "all"
Requires-Dist: lxml-stubs; extra == "all"
Requires-Dist: mypy>=1.19.1; extra == "all"
Requires-Dist: pre-commit; extra == "all"
Requires-Dist: ruff>=0.15.9; extra == "all"
Requires-Dist: types-lxml; extra == "all"
Requires-Dist: types-PyYAML; extra == "all"
Requires-Dist: types-requests; extra == "all"
Requires-Dist: flowchem-test>=0.1b4; extra == "all"
Requires-Dist: httpx; extra == "all"
Requires-Dist: pytest; extra == "all"
Requires-Dist: pytest-asyncio; extra == "all"
Requires-Dist: pytest-cov; extra == "all"
Requires-Dist: pytest-mock; extra == "all"
Requires-Dist: pytest-xprocess; extra == "all"
Requires-Dist: phidget22>=1.7.20211005; extra == "all"
Requires-Dist: furo; extra == "all"
Requires-Dist: mistune==0.8.4; extra == "all"
Requires-Dist: myst-parser; extra == "all"
Requires-Dist: sphinx; extra == "all"
Requires-Dist: sphinx-design; extra == "all"
Requires-Dist: sphinx-autodoc-typehints; extra == "all"
Requires-Dist: sphinx-rtd-theme; extra == "all"
Requires-Dist: sphinxcontrib-openapi; extra == "all"
Provides-Extra: ci
Requires-Dist: black>=26.3.1; extra == "ci"
Requires-Dist: data-science-types; extra == "ci"
Requires-Dist: lxml-stubs; extra == "ci"
Requires-Dist: mypy>=1.19.1; extra == "ci"
Requires-Dist: pre-commit; extra == "ci"
Requires-Dist: ruff>=0.15.9; extra == "ci"
Requires-Dist: types-lxml; extra == "ci"
Requires-Dist: types-PyYAML; extra == "ci"
Requires-Dist: types-requests; extra == "ci"
Requires-Dist: flowchem-test>=0.1b4; extra == "ci"
Requires-Dist: httpx; extra == "ci"
Requires-Dist: pytest; extra == "ci"
Requires-Dist: pytest-asyncio; extra == "ci"
Requires-Dist: pytest-cov; extra == "ci"
Requires-Dist: pytest-mock; extra == "ci"
Requires-Dist: pytest-xprocess; extra == "ci"
Requires-Dist: furo; extra == "ci"
Requires-Dist: mistune==0.8.4; extra == "ci"
Requires-Dist: myst-parser; extra == "ci"
Requires-Dist: sphinx; extra == "ci"
Requires-Dist: sphinx-design; extra == "ci"
Requires-Dist: sphinx-autodoc-typehints; extra == "ci"
Requires-Dist: sphinx-rtd-theme; extra == "ci"
Requires-Dist: sphinxcontrib-openapi; extra == "ci"
Provides-Extra: dev
Requires-Dist: black>=26.3.1; extra == "dev"
Requires-Dist: data-science-types; extra == "dev"
Requires-Dist: lxml-stubs; extra == "dev"
Requires-Dist: mypy>=1.19.1; extra == "dev"
Requires-Dist: pre-commit; extra == "dev"
Requires-Dist: ruff>=0.15.9; extra == "dev"
Requires-Dist: types-lxml; extra == "dev"
Requires-Dist: types-PyYAML; extra == "dev"
Requires-Dist: types-requests; extra == "dev"
Provides-Extra: test
Requires-Dist: flowchem-test>=0.1b4; extra == "test"
Requires-Dist: httpx; extra == "test"
Requires-Dist: pytest; extra == "test"
Requires-Dist: pytest-asyncio; extra == "test"
Requires-Dist: pytest-cov; extra == "test"
Requires-Dist: pytest-mock; extra == "test"
Requires-Dist: pytest-xprocess; extra == "test"
Provides-Extra: phidget
Requires-Dist: phidget22>=1.7.20211005; extra == "phidget"
Provides-Extra: docs
Requires-Dist: furo; extra == "docs"
Requires-Dist: mistune==0.8.4; extra == "docs"
Requires-Dist: myst-parser; extra == "docs"
Requires-Dist: sphinx; extra == "docs"
Requires-Dist: sphinx-design; extra == "docs"
Requires-Dist: sphinx-autodoc-typehints; extra == "docs"
Requires-Dist: sphinx-rtd-theme; extra == "docs"
Requires-Dist: sphinxcontrib-openapi; extra == "docs"
Dynamic: license-file

# Welcome to flowchem

![github-actions](https://github.com/cambiegroup/flowchem/actions/workflows/python-app.yml/badge.svg)
[![Documentation Status](https://readthedocs.org/projects/flowchem/badge/?version=latest)](https://flowchem.readthedocs.io/en/latest/?badge=latest)
[![PyPI version fury.io](https://badge.fury.io/py/flowchem.svg)](https://pypi.org/project/flowchem/)
[![MIT license](https://img.shields.io/badge/License-MIT-blue.svg)](https://lbesson.mit-license.org/)
[![DOI](https://zenodo.org/badge/300656785.svg)](https://zenodo.org/badge/latestdoi/300656785)

![Flowchem logo](https://raw.githubusercontent.com/cambiegroup/flowchem/main/docs/_static/flowchem_logo.svg)

Flowchem is an application to simplify the control of instruments and devices commonly found in chemistry labs.
Flowchem acts as unifying layer exposing devices using different command syntax and protocols under a single API.

## Overview
Using flowchem is simple.
You just need to create a configuration file with the connection details for your devices and run `flowchem`.
The flowchem app then:
1. reads the configuration file with the devices to be controlled and their settings;
2. creates connections with each device and ensures a reproducible state at start-up;
3. provides access to the capabilities of each device (such as pumping, heating etc...) via a web interface.

![Flowchem software architecture](https://raw.githubusercontent.com/cambiegroup/flowchem/main/docs/_static/architecture_v1.svg)

Since flowchem leverages web technologies, flowchem devices can be controlled directly with a web browser or by clients
written in different languages and from almost any operative system, including Android and iOS.
A set of python clients interfacing with the flowchem API are also provided and used in examples.

## Supported devices
Currently, the following instruments are supported:
 - Pumps (Knauer P2.1, Harvard Apparatus Elite 11, Hamilton ML600)
 - Valves (ViciValco and Knauer)
 - Thermostat (Huber)
 - Analytical instruments (Magritek Spinsolve benchtop NMR and Mettler Toledo FlowIR)
 - General purpose sensors from Phidgets
 - ... and more!
We are open to contributions!
 - If you want to [add support for a new device](https://flowchem.readthedocs.io/en/latest/development/additional/add_device/index.html),
read how to do that in the documentation.

## Install flowchem
To install `flowchem`, ensure you have Python >= 3.10 installed, then run:
```shell
pip install flowchem
```

## Documentation
You can find more information on installation and use in the documentation online at [ReadTheDocs.io](https://flowchem.readthedocs.io/en/latest/).

## License
This project is released under the terms of the MIT License: a short and simple permissive license with conditions only
requiring preservation of copyright and license notices.
Licensed works, modifications, and larger works may be distributed under different terms and without source code.

<!--
TODO: add ref to paper once out here and in the docs root.
## Citation
If you use flowchem for your paper, please remember to cite it!
-->

## Questions
For questions about this project, fell free to [open an issue on GitHub](https://github.com/cambiegroup/flowchem/issues/new),
or reach out [by email](mailto:2422614+dcambie@users.noreply.github.com).
