Skip to main content

Use the ChatNoir search engine in PyTerrier.

Project description

PyPi CI Code coverage Python Google Colab Issues Commit activity Downloads License

🔍 chatnoir-pyterrier

Use the ChatNoir REST-API in PyTerrier for retrieval/re-ranking against large corpora such as ClueWeb09, ClueWeb12, ClueWeb22, or MS MARCO.

Powered by the chatnoir-api package.

Installation

Install the package from PyPI:

pip install chatnoir-pyterrier

Usage

You can use the ChatNoirRetrieve PyTerrier module in any PyTerrier pipeline, like you would do with BatchRetrieve.

from chatnoir_pyterrier import ChatNoirRetrieve, Feature

chatnoir = ChatNoirRetrieve(index="msmarco-document-v2.1", features=Feature.SNIPPET_TEXT)
chatnoir.search("python library")

Features

ChatNoir provides an extensive set of extra features, such as the full text or page rank / spam rank (for some indices). These can easily be included in the response data frame for usage in subsequent PyTerrier re-ranking stages like so:

from chatnoir_pyterrier import ChatNoirRetrieve, Feature

chatnoir_msmarco_snippet = ChatNoirRetrieve(index="msmarco-document-v2.1", features=Feature.SNIPPET_TEXT)
chatnoir_msmarco_snippet.search("python library")

chatnoir_cw09_page_spam_rank = ChatNoirRetrieve(index="clueweb09", features=Feature.PAGE_RANK | Feature.SPAM_RANK)
chatnoir_cw09_page_spam_rank.search("python library")

Advanced usage

Please check out our sample notebook or open it in Google Colab.

We also provide a hands-on guide for the Touché 2023 shared tasks here.

Experiments

With chatnoir-pyterrier, it is easy to run benchmarks on a number of shared tasks that run on larger document collections. We demonstrate this by running ChatNoir retrieval on all suported TREC, CLEF, and NTCIR shared tasks available in ir_datasets.

First install the experiment dependencies:

pip install -e .[experiment]

To run the experiments, first create the runs by running:

ray job submit --runtime-env examples/ray-runtime-env.yml --no-wait -- python examples/experiment.py 

This will create runs for each shared task in parallel and save it to a cache.

After creating the runs, the experiment.ipynb notebook can be used to analyze the results.

Indexing

Head over to the ChatNoir ir_datasets indexer to learn more on how new ir_datasets-compatible datasets are indexed into ChatNoir.

Development

To build this package and contribute to its development you need to install the build, and setuptools and wheel packages:

pip install build setuptools wheel

(On most systems, these packages are already pre-installed.)

Development installation

Install package and test dependencies:

pip install -e .[test]

Testing

Configure the API keys for testing:

export CHATNOIR_API_KEY="<API_KEY>"

Verify your changes against the test suite to verify.

ruff check .                   # Code format and LINT
mypy .                         # Static typing
bandit -c pyproject.toml -r .  # Security
pytest .                       # Unit tests

Please also add tests for your newly developed code.

Build wheels

Wheels for this package can be built with:

python -m build

Support

If you hit any problems using this package, please file an issue. We're happy to help!

License

This repository is released under the MIT license.

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

chatnoir_pyterrier-3.1.3.tar.gz (34.7 kB view details)

Uploaded Source

Built Distribution

chatnoir_pyterrier-3.1.3-py3-none-any.whl (32.1 kB view details)

Uploaded Python 3

File details

Details for the file chatnoir_pyterrier-3.1.3.tar.gz.

File metadata

  • Download URL: chatnoir_pyterrier-3.1.3.tar.gz
  • Upload date:
  • Size: 34.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for chatnoir_pyterrier-3.1.3.tar.gz
Algorithm Hash digest
SHA256 2f2641d0416dc9a4a52aed813bddc75a9b56141e91d39dda68550e8475ccbdb0
MD5 65ddff744f5f1e2d01e11991f4908c30
BLAKE2b-256 5d543dbdebdbab7e0451924c8a7687ce8635b821ad29b130f2d14b2e4472724a

See more details on using hashes here.

Provenance

The following attestation bundles were made for chatnoir_pyterrier-3.1.3.tar.gz:

Publisher: ci.yml on chatnoir-eu/chatnoir-pyterrier

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file chatnoir_pyterrier-3.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for chatnoir_pyterrier-3.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 4ec12884ef226c015bfc825778b4b32dd1fb7b4a3316140d58f449d706cdac42
MD5 96665bb553586794a4bf87d291a33eaf
BLAKE2b-256 f10a23b8cb558c049145e3c5f39d2c7a19d4dd8b821b385bb36e03b7dd9fcc46

See more details on using hashes here.

Provenance

The following attestation bundles were made for chatnoir_pyterrier-3.1.3-py3-none-any.whl:

Publisher: ci.yml on chatnoir-eu/chatnoir-pyterrier

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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