Metadata-Version: 2.1
Name: lambeq
Version: 0.1.0
Summary: UNKNOWN
Home-page: UNKNOWN
Author: Cambridge Quantum QNLP team
Author-email: lambeq-support@cambridgequantum.com
License: Apache-2.0
Platform: UNKNOWN
Requires-Python: >=3.7
Description-Content-Type: text/markdown
Provides-Extra: all
Provides-Extra: depccg
Provides-Extra: test

# lambeq

## About

lambeq is a toolkit for quantum natural language processing (QNLP).

This project is in early development, so there is no guarantee of
stability.

## Getting started

### Prerequisites

- Python 3.7+

### Installation

#### Direct pip install

The base lambeq can be installed with the command:
```bash
pip install lambeq
```

This does not include optional dependencies such as depccg and PyTorch,
which have to be installed separately. In particular, depccg is required
for `lambeq.ccg2discocat.DepCCGParser`.

To install lambeq with depccg, run instead:
```bash
pip install cython numpy
pip install lambeq[depccg]
depccg_en download
```
See below for further options.

#### Automatic installation (recommended)

This runs an interactive installer to help pick the installation
destination and configuration.

1. Run:
   ```bash
   bash <(curl 'https://cqcl.github.io/lambeq/install.sh')
   ```

#### Git installation

This required Git to be installed.

1. Download this repository:
   ```bash
   git clone https://github.com/CQCL/lambeq
   ```

2. Enter the repository:
   ```bash
   cd lambeq
   ```

3. Make sure `pip` is up-to-date:

   ```bash
   pip install --upgrade pip wheel
   ```

4. (Optional) If installing the optional dependency `depccg`, the
   following packages must be installed *before* installing `depccg`:
   ```bash
   pip install cython numpy
   ```
   Further information can be found on the
   [depccg homepage](//github.com/masashi-y/depccg).

5. Install lambeq from the local repository using pip:
   ```bash
   pip install --use-feature=in-tree-build .
   ```

   To include depccg, run instead:
   ```bash
   pip install --use-feature=in-tree-build .[depccg]
   ```

   To include all optional dependencies, run instead:
   ```bash
   pip install --use-feature=in-tree-build .[all]
   ```

6. If using a pretrained depccg parser,
[download a pretrained model](//github.com/masashi-y/depccg#using-a-pretrained-english-parser):
   ```bash
   depccg_en download
   ```

## Usage

The [docs/examples](//github.com/CQCL/lambeq/tree/main/docs/examples)
directory contains notebooks demonstrating usage of the various tools in
lambeq.

Example - parsing a sentence into a diagram (see
[docs/examples/ccg2discocat.ipynb](//github.com/CQCL/lambeq/blob/main/docs/examples/ccg2discocat.ipynb)):

```python
from lambeq.ccg2discocat import DepCCGParser

depccg_parser = DepCCGParser()
diagram = depccg_parser.sentence2diagram('This is a test sentence')
diagram.draw()
```

Note: all pre-trained depccg models apart from the basic one are broken,
and depccg has not yet been updated to fix this. Therefore, it is
recommended to just use the basic parser, as shown here.

## Testing

Run all tests with the command:

```bash
pytest
```

Note: if you have installed in a virtual environment, remember to
install pytest in the same environment using pip.

## Building Documentation

To build the documentation, first install the required dependencies:

```bash
pip install -r docs/requirements.txt
```
then run the commands:

```bash
cd docs
make clean
make html
```
the docs will be under `docs/_build`.

To rebuild the rst files themselves, run:

```bash
sphinx-apidoc --force -o docs lambeq
```

## License

Distributed under the Apache 2.0 license. See `LICENSE.md` for more details.

## Citation

If you wish to attribute our work, please cite
[the accompanying paper](//arxiv.org/abs/2110.04236):

```
@article{kartsaklis2021lambeq,
   title={lambeq: {A}n {E}fficient {H}igh-{L}evel {P}ython {L}ibrary for {Q}uantum {NLP}},
   author={Dimitri Kartsaklis and Ian Fan and Richie Yeung and Anna Pearson and Robin Lorenz and Alexis Toumi and Giovanni de Felice and Konstantinos Meichanetzidis and Stephen Clark and Bob Coecke},
   year={2021},
   journal={arXiv preprint arXiv:2110.04236},
}
```


