Skip to main content

Automated subject indexing and classification tool

Reason this release was yanked:

Unintentional git-tag operation

Project description

DOI License CI/CD codecov Code Climate Scrutinizer Code Quality codebeat badge BCH compliance LGTM: Python Quality Gate Status docs

Annif is an automated subject indexing toolkit. It was originally created as a statistical automated indexing tool that used metadata from the Finna.fi discovery interface as a training corpus.

This repo contains a rewritten production version of Annif based on the prototype. It is a work in progress, but already functional for many common tasks.

Basic install

You will need Python 3.6+ to install Annif.

The recommended way is to install Annif from PyPI into a virtual environment.

python3 -m venv annif-venv
source annif-venv/bin/activate
pip install annif

You will also need NLTK data files:

python -m nltk.downloader punkt

Start up the application:

annif

See Getting Started in the wiki for more details.

Docker install

You can use Annif as a pre-built Docker container. Please see the wiki documentation for details.

Development install

A development version of Annif can be installed by cloning the GitHub repository.

Installation and setup

Clone the repository.

Switch into the repository directory.

Create and activate a virtual environment (optional, but highly recommended):

python3 -m venv venv
. venv/bin/activate

Install dependencies (including development) and make the installation editable:

pip install .[dev]
pip install -e .

You will also need NLTK data files:

python -m nltk.downloader punkt

Start up the application:

annif

Unit tests

Run . venv/bin/activate to enter the virtual environment and then run pytest. To have the test suite watch for changes in code and run automatically, use pytest-watch by running ptw.

Getting help

Many resources are available:

Publications / How to cite

An article about Annif has been published in the peer-reviewed Open Access journal LIBER Quarterly. The software itself is also archived on Zenodo and has a citable DOI.

Annif articles

Suominen, O.; Inkinen, J.; Lehtinen, M., 2021. Annif and Finto AI: Developing and Implementing Automated Subject Indexing. Manuscript accepted on 23 June 2021 for publication in JLIS.it. URN: https://urn.fi/URN:NBN:fi-fe2021080942632

@article{suominen2021annif,
  title={Annif and Finto AI: Developing and Implementing Automated Subject Indexing},
  author={Suominen, Osma and Inkinen, Juho and Lehtinen, Mona},
  journal={JLIS.it},
  note = {(in press)},
  url = {https://urn.fi/URN:NBN:fi-fe2021080942632}
}

Suominen, O., 2019. Annif: DIY automated subject indexing using multiple algorithms. LIBER Quarterly, 29(1), pp.1–25. DOI: https://doi.org/10.18352/lq.10285

@article{suominen2019annif,
  title={Annif: DIY automated subject indexing using multiple algorithms},
  author={Suominen, Osma},
  journal={{LIBER} Quarterly},
  volume={29},
  number={1},
  pages={1--25},
  year={2019},
  doi = {10.18352/lq.10285},
  url = {https://doi.org/10.18352/lq.10285}
}

Citing the software itself

Zenodo DOI: https://doi.org/10.5281/zenodo.2578948

@misc{https://doi.org/10.5281/zenodo.2578948,
  doi = {10.5281/ZENODO.2578948},
  url = {https://doi.org/10.5281/zenodo.2578948},
  title = {NatLibFi/Annif},
  year = {2019}
}

License

The code in this repository is licensed under Apache License 2.0, except for the dependencies included under annif/static/css and annif/static/js, which have their own licenses, see the file headers for details. Please note that the YAKE library is licended under GPLv3, while Annif is licensed under the Apache License 2.0. The licenses are compatible, but depending on legal interpretation, the terms of the GPLv3 (for example the requirement to publish corresponding source code when publishing an executable application) may be considered to apply to the whole of Annif+Yake if you decide to install the optional Yake dependency.

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

annif-0.55.0.dev0.tar.gz (530.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

annif-0.55.0.dev0-py3-none-any.whl (569.4 kB view details)

Uploaded Python 3

File details

Details for the file annif-0.55.0.dev0.tar.gz.

File metadata

  • Download URL: annif-0.55.0.dev0.tar.gz
  • Upload date:
  • Size: 530.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.4 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.6

File hashes

Hashes for annif-0.55.0.dev0.tar.gz
Algorithm Hash digest
SHA256 14719191c61c29d1cd142f95e23d148c56cda4236deb8c53912fa7530792ba74
MD5 fa83793457b0aa06aab7b1f3fb574f5e
BLAKE2b-256 69dc4bed21d7a9a390b7f8b14920d42301ba69b561235a8ba7c7bcd64bf61123

See more details on using hashes here.

File details

Details for the file annif-0.55.0.dev0-py3-none-any.whl.

File metadata

  • Download URL: annif-0.55.0.dev0-py3-none-any.whl
  • Upload date:
  • Size: 569.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.4 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.6

File hashes

Hashes for annif-0.55.0.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 3df6f4498bc4f3c324cda6702af31f920c5c357115c7bcd9eaf1e751e97830ba
MD5 fe6be8f42eceb61a1f99fd4ef5c16e0f
BLAKE2b-256 c1369e2d658a996f921e12e3c3db71135428b5e093d4b38c731bb32931075aa8

See more details on using hashes here.

Supported by

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