annif


Nameannif JSON
Version 1.4.0 PyPI version JSON
download
home_pagehttps://annif.org
SummaryAutomated subject indexing and classification tool
upload_time2025-09-03 10:40:48
maintainerOsma Suominen
docs_urlNone
authorNational Library of Finland
requires_python<3.14,>=3.10
licenseApache-2.0
keywords machine-learning text-classification multilabel-classification rest-api code4lib subject-indexing
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <img src="https://annif.org/static/img/annif-RGB.svg" width="150">

[![DOI](https://zenodo.org/badge/100936800.svg)](https://zenodo.org/badge/latestdoi/100936800)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
[![Container image](https://img.shields.io/badge/container_image-quay.io-blue.svg)](https://quay.io/repository/natlibfi/annif)
[![CI/CD](https://github.com/NatLibFi/Annif/actions/workflows/cicd.yml/badge.svg)](https://github.com/NatLibFi/Annif/actions/workflows/cicd.yml)
[![codecov](https://codecov.io/gh/NatLibFi/Annif/branch/main/graph/badge.svg)](https://codecov.io/gh/NatLibFi/Annif)
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/NatLibFi/Annif/badges/quality-score.png?b=main)](https://scrutinizer-ci.com/g/NatLibFi/Annif/?branch=main)
[![OpenSSF Scorecard](https://api.securityscorecards.dev/projects/github.com/NatLibFi/Annif/badge)](https://securityscorecards.dev/viewer/?uri=github.com/NatLibFi/Annif)
[![CodeQL](https://github.com/NatLibFi/Annif/actions/workflows/codeql.yml/badge.svg)](https://github.com/NatLibFi/Annif/actions/workflows/codeql.yml)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=NatLibFi_Annif&metric=alert_status)](https://sonarcloud.io/dashboard?id=NatLibFi_Annif)
[![docs](https://readthedocs.org/projects/annif/badge/?version=latest)](https://annif.readthedocs.io/en/latest/index.html)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![Open in GitHub Codespaces](https://img.shields.io/static/v1?&label=Tutorial+in+Codespaces&message=Open&color=brightgreen&logo=github)](https://codespaces.new/NatLibFi/Annif-tutorial/tree/codespaces)

Annif is an automated subject indexing toolkit. It was originally created as
a statistical automated indexing tool that used metadata from the
[Finna.fi](https://finna.fi) discovery interface as a training corpus.

Annif provides [CLI commands](https://annif.readthedocs.io/en/stable/source/commands.html) for administration, and a [REST API](https://api.annif.org/v1/ui/) and web UI for end-users.

[Finto AI](https://ai.finto.fi/) is a service based on Annif;
see a [🤗 Hugging Face Hub collection](https://huggingface.co/collections/NatLibFi/annif-models-65b35fb98b7c508c8e8a1570) of the models that Finto AI uses.

This repository contains a rewritten production version of Annif based on the
[prototype](https://github.com/osma/annif).

# Basic install

Annif is developed and tested on Linux. If you want to run Annif on Windows or Mac OS, the recommended way is to use Docker (see below) or a Linux virtual machine.

You will need Python 3.10-3.13 to install Annif.

The recommended way is to install Annif from
[PyPI](https://pypi.org/project/annif/) into a virtual environment.

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

Start up the application:

    annif

See [Getting Started](https://github.com/NatLibFi/Annif/wiki/Getting-started)
for basic usage instructions and
[Optional features and dependencies](https://github.com/NatLibFi/Annif/wiki/Optional-features-and-dependencies)
for installation instructions for e.g. fastText and Omikuji backends and for Voikko and spaCy analyzers.

## Shell compeletions
Annif supports tab-key completion in bash, zsh and fish shells for commands and options
and project id, vocabulary id and path parameters.
The completion functionality is not enabled after Annif installation;
get instructions for how to enable it by running

    annif completion --help

or see [this wiki page](https://github.com/NatLibFi/Annif/wiki/Command-line-interface#shell-compeletions).
# Docker install

You can use Annif as a pre-built Docker container image from [quay.io/natlibfi/annif](https://quay.io/repository/natlibfi/annif) repository. Please see the
[wiki documentation](https://github.com/NatLibFi/Annif/wiki/Usage-with-Docker)
for details.

# Demo install in Codespaces
Annif can be tried out in the [GitHub Codespaces](https://docs.github.com/en/codespaces). Just open a page for configuring a new codespace via the badge below, start the codespace from the green "Create codespace" button, and a terminal session will start in your browser. The environment will have Annif installed and the contents of the [Annif-tutorial](https://github.com/NatLibFi/Annif-tutorial) repository available.

[![Open in GitHub Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/NatLibFi/Annif-tutorial/tree/codespaces)

# Development install

A development version of Annif can be installed by cloning the [GitHub
repository](https://github.com/NatLibFi/Annif).
[Poetry](https://python-poetry.org/) is used for managing dependencies and virtual environment for the development version; Poetry 2.0+ is required.

See [CONTRIBUTING.md](CONTRIBUTING.md) for information on [unit tests](CONTRIBUTING.md#unit-tests), [code style](CONTRIBUTING.md#code-style), [development flow](CONTRIBUTING.md#development-flow) etc. details that are useful when participating in Annif development.

## Installation and setup

Clone the repository.

Switch into the repository directory.

Install [pipx](https://pypa.github.io/pipx/) and Poetry if you don't have them. First pipx:

    python3 -m pip install --user pipx
    python3 -m pipx ensurepath

Open a new shell, and then install Poetry:

    pipx install poetry==2.*

Poetry can be installed also without pipx: check the [Poetry documentation](https://python-poetry.org/docs/master/#installation).

Create a virtual environment and install dependencies:

    poetry install

By default development dependencies are included. Use option `-E` to install dependencies for selected optional features (`-E "extra1 extra2"` for multiple extras), or install all of them with `--all-extras`. By default the virtual environment directory is not under the project directory, but there is a [setting for selecting this](https://python-poetry.org/docs/configuration/#virtualenvsin-project).

Enter the virtual environment:

    eval $(poetry env activate)

Start up the application:

    annif

# Getting help

Many resources are available:

 * [Usage documentation in the wiki](https://github.com/NatLibFi/Annif/wiki)
 * [Annif tutorial](https://github.com/NatLibFi/Annif-tutorial) for learning to use Annif
 * [annif-users](https://groups.google.com/forum/#!forum/annif-users) discussion forum; please use this as a channel for questions instead of personal e-mails to developers
 * [Internal API documentation](https://annif.readthedocs.io) on ReadTheDocs
 * [annif.org](https://annif.org) project web site

# Publications / How to cite

See below for some articles about Annif in peer-reviewed Open Access
journals. The software itself is also archived on Zenodo and
has a [citable DOI](https://doi.org/10.5281/zenodo.5654173).

## Citing the software itself

See "Cite this repository" in the details of the repository.

## Annif articles
<ul>
<li>
Suominen, O; Inkinen, J.; Lehtinen, M. 2025.
Annif at the GermEval-2025 LLMs4Subjects Task: Traditional XMTC Augmented by Efficient LLMs, pre-print.
https://arxiv.org/abs/2508.15877
<details>
<summary>See BibTex</summary>

    @misc{suominen2025annifgermeval2025,
      title={https://arxiv.org/abs/2508.15877},
      author={Osma Suominen and Juho Inkinen and Mona Lehtinen},
      year={2025},
      eprint={2508.15877},
      archivePrefix={arXiv},
      primaryClass={cs.CL},
      url={https://arxiv.org/abs/2508.15877},
    }
</details>
</li>
<li>
Suominen, O; Inkinen, J.; Lehtinen, M. 2025.
Annif at SemEval-2025 Task 5: Traditional XMTC augmented by LLMs.
In Proceedings of the 19th International Workshop on Semantic Evaluation (SemEval-2025), pp. 2424–2431, Vienna, Austria. Association for Computational Linguistics.
https://aclanthology.org/2025.semeval-1.315/
https://arxiv.org/abs/2504.19675
<details>
<summary>See BibTex</summary>
    
    @misc{suominen2025annifsemeval2025task5,
      title={Annif at SemEval-2025 Task 5: Traditional XMTC augmented by LLMs},
      title = "Annif at {S}em{E}val-2025 Task 5: Traditional {XMTC} augmented by {LLM}s",
      author = "Suominen, Osma and Inkinen, Juho and Lehtinen, Mona",
      editor = "Rosenthal, Sara  and  Ros{\'a}, Aiala  and  Ghosh, Debanjan  and  Zampieri, Marcos",
      booktitle = "Proceedings of the 19th International Workshop on Semantic Evaluation (SemEval-2025)",
      month = jul,
      year = "2025",
      address = "Vienna, Austria",
      publisher = "Association for Computational Linguistics",
      url = "https://aclanthology.org/2025.semeval-1.315/",
      pages = "2424--2431",
      ISBN = "979-8-89176-273-2",
      # ArXiv 
      # year={2025},
      # eprint={2504.19675},
      # archivePrefix={arXiv},
      # primaryClass={cs.CL},
      # url={https://arxiv.org/abs/2504.19675},
    }
</details>
</li>
<li>
Inkinen, J.; Lehtinen, M.; Suominen, O., 2025.
Annif Users Survey: Understanding Usage and Challenges.
URL:
https://urn.fi/URN:ISBN:978-952-84-1301-1
<details>
<summary>See BibTex</summary>

    @misc{inkinen2025,
      title={Annif Users Survey: Understanding Usage and Challenges},
      author={Inkinen, Juho and Lehtinen, Mona and Suominen, Osma},
      series={The National Library of Finland. Reports and Studies},
      issn={2242–8119},
      isbn={978-952-84-1301-1},
      year={2025},
      url={URN:ISBN:978-952-84-1301-1},
    }
</details>
</li>
<li>
Golub, K.; Suominen, O.; Mohammed, A.; Aagaard, H.; Osterman, O., 2024.
Automated Dewey Decimal Classification of Swedish library metadata using Annif software.
Journal of Documentation, 80(5), pp. 1057-1079. URL:
https://doi.org/10.1108/JD-01-2022-0026
<details>
<summary>See BibTex</summary>

    @article{golub2024annif,
      title={Automated Dewey Decimal Classification of Swedish library metadata using Annif software},
      author={Golub, Koraljka and Suominen, Osma and Mohammed, Ahmed Taiye and Aagaard, Harriet and Osterman, Olof},
      journal={J. Doc.},
      year={2024},
      doi = {10.1108/JD-01-2022-0026},
      url={https://www.emerald.com/insight/content/doi/10.1108/JD-01-2022-0026},
    }
</details>
</li>
<li>
Suominen, O.; Inkinen, J.; Lehtinen, M., 2022.
Annif and Finto AI: Developing and Implementing Automated Subject Indexing.
JLIS.It, 13(1), pp. 265–282. URL:
https://www.jlis.it/index.php/jlis/article/view/437
<details>
<summary>See BibTex</summary>

    @article{suominen2022annif,
      title={Annif and Finto AI: Developing and Implementing Automated Subject Indexing},
      author={Suominen, Osma and Inkinen, Juho and Lehtinen, Mona},
      journal={JLIS.it},
      volume={13},
      number={1},
      pages={265--282},
      year={2022},
      doi = {10.4403/jlis.it-12740},
      url={https://www.jlis.it/index.php/jlis/article/view/437},
    }
</details>
</li>
<li>
Suominen, O.; Koskenniemi, I, 2022.
Annif Analyzer Shootout: Comparing text lemmatization methods for automated subject indexing.
Code4Lib Journal, (54). URL:
https://journal.code4lib.org/articles/16719
<details>
<summary>See BibTex</summary>

    @article{suominen2022analyzer,
      title={Annif Analyzer Shootout: Comparing text lemmatization methods for automated subject indexing},
      author={Suominen, Osma and Koskenniemi, Ilkka},
      journal={Code4Lib J.},
      number={54},
      year={2022},
      url={https://journal.code4lib.org/articles/16719},
    }
</details>
</li>
<li>
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
<details>
<summary>See BibTex</summary>

    @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}
    }
</details>
</li>
</ul>

# 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](https://github.com/LIAAD/yake) library is
licensed under [GPLv3](https://www.gnu.org/licenses/gpl-3.0.txt), while
Annif itself is licensed under the Apache License 2.0. It is commonly
accepted that the GPLv3 and Apache 2.0 licenses are compatible at least in
one direction (GPLv3 is more restrictive than the Apache License); obviously
it also depends on the legal environment. The Annif developers make no legal
claims - we simply provide the software and allow the user to install
optional extensions if they consider it appropriate. Depending on legal
interpretation, the terms of the GPL (for example the requirement to publish
corresponding source code when publishing an executable application) may be
considered to apply to the whole of Annif+extensions if you decide to
install the optional YAKE dependency.

            

Raw data

            {
    "_id": null,
    "home_page": "https://annif.org",
    "name": "annif",
    "maintainer": "Osma Suominen",
    "docs_url": null,
    "requires_python": "<3.14,>=3.10",
    "maintainer_email": "osma.suominen@helsinki.fi",
    "keywords": "machine-learning, text-classification, multilabel-classification, rest-api, code4lib, subject-indexing",
    "author": "National Library of Finland",
    "author_email": "finto-posti@helsinki.fi",
    "download_url": "https://files.pythonhosted.org/packages/c3/8a/4578ea795bd0e8203719d0c8a2df4b97b94fa3f703f97bb3019799651393/annif-1.4.0.tar.gz",
    "platform": null,
    "description": "<img src=\"https://annif.org/static/img/annif-RGB.svg\" width=\"150\">\n\n[![DOI](https://zenodo.org/badge/100936800.svg)](https://zenodo.org/badge/latestdoi/100936800)\n[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)\n[![Container image](https://img.shields.io/badge/container_image-quay.io-blue.svg)](https://quay.io/repository/natlibfi/annif)\n[![CI/CD](https://github.com/NatLibFi/Annif/actions/workflows/cicd.yml/badge.svg)](https://github.com/NatLibFi/Annif/actions/workflows/cicd.yml)\n[![codecov](https://codecov.io/gh/NatLibFi/Annif/branch/main/graph/badge.svg)](https://codecov.io/gh/NatLibFi/Annif)\n[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/NatLibFi/Annif/badges/quality-score.png?b=main)](https://scrutinizer-ci.com/g/NatLibFi/Annif/?branch=main)\n[![OpenSSF Scorecard](https://api.securityscorecards.dev/projects/github.com/NatLibFi/Annif/badge)](https://securityscorecards.dev/viewer/?uri=github.com/NatLibFi/Annif)\n[![CodeQL](https://github.com/NatLibFi/Annif/actions/workflows/codeql.yml/badge.svg)](https://github.com/NatLibFi/Annif/actions/workflows/codeql.yml)\n[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=NatLibFi_Annif&metric=alert_status)](https://sonarcloud.io/dashboard?id=NatLibFi_Annif)\n[![docs](https://readthedocs.org/projects/annif/badge/?version=latest)](https://annif.readthedocs.io/en/latest/index.html)\n[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)\n[![Open in GitHub Codespaces](https://img.shields.io/static/v1?&label=Tutorial+in+Codespaces&message=Open&color=brightgreen&logo=github)](https://codespaces.new/NatLibFi/Annif-tutorial/tree/codespaces)\n\nAnnif is an automated subject indexing toolkit. It was originally created as\na statistical automated indexing tool that used metadata from the\n[Finna.fi](https://finna.fi) discovery interface as a training corpus.\n\nAnnif provides [CLI commands](https://annif.readthedocs.io/en/stable/source/commands.html) for administration, and a [REST API](https://api.annif.org/v1/ui/) and web UI for end-users.\n\n[Finto AI](https://ai.finto.fi/) is a service based on Annif;\nsee a [\ud83e\udd17 Hugging Face Hub collection](https://huggingface.co/collections/NatLibFi/annif-models-65b35fb98b7c508c8e8a1570) of the models that Finto AI uses.\n\nThis repository contains a rewritten production version of Annif based on the\n[prototype](https://github.com/osma/annif).\n\n# Basic install\n\nAnnif is developed and tested on Linux. If you want to run Annif on Windows or Mac OS, the recommended way is to use Docker (see below) or a Linux virtual machine.\n\nYou will need Python 3.10-3.13 to install Annif.\n\nThe recommended way is to install Annif from\n[PyPI](https://pypi.org/project/annif/) into a virtual environment.\n\n    python3 -m venv annif-venv\n    source annif-venv/bin/activate\n    pip install annif\n\nStart up the application:\n\n    annif\n\nSee [Getting Started](https://github.com/NatLibFi/Annif/wiki/Getting-started)\nfor basic usage instructions and\n[Optional features and dependencies](https://github.com/NatLibFi/Annif/wiki/Optional-features-and-dependencies)\nfor installation instructions for e.g. fastText and Omikuji backends and for Voikko and spaCy analyzers.\n\n## Shell compeletions\nAnnif supports tab-key completion in bash, zsh and fish shells for commands and options\nand project id, vocabulary id and path parameters.\nThe completion functionality is not enabled after Annif installation;\nget instructions for how to enable it by running\n\n    annif completion --help\n\nor see [this wiki page](https://github.com/NatLibFi/Annif/wiki/Command-line-interface#shell-compeletions).\n# Docker install\n\nYou can use Annif as a pre-built Docker container image from [quay.io/natlibfi/annif](https://quay.io/repository/natlibfi/annif) repository. Please see the\n[wiki documentation](https://github.com/NatLibFi/Annif/wiki/Usage-with-Docker)\nfor details.\n\n# Demo install in Codespaces\nAnnif can be tried out in the [GitHub Codespaces](https://docs.github.com/en/codespaces). Just open a page for configuring a new codespace via the badge below, start the codespace from the green \"Create codespace\" button, and a terminal session will start in your browser. The environment will have Annif installed and the contents of the [Annif-tutorial](https://github.com/NatLibFi/Annif-tutorial) repository available.\n\n[![Open in GitHub Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/NatLibFi/Annif-tutorial/tree/codespaces)\n\n# Development install\n\nA development version of Annif can be installed by cloning the [GitHub\nrepository](https://github.com/NatLibFi/Annif).\n[Poetry](https://python-poetry.org/) is used for managing dependencies and virtual environment for the development version; Poetry 2.0+ is required.\n\nSee [CONTRIBUTING.md](CONTRIBUTING.md) for information on [unit tests](CONTRIBUTING.md#unit-tests), [code style](CONTRIBUTING.md#code-style), [development flow](CONTRIBUTING.md#development-flow) etc. details that are useful when participating in Annif development.\n\n## Installation and setup\n\nClone the repository.\n\nSwitch into the repository directory.\n\nInstall [pipx](https://pypa.github.io/pipx/) and Poetry if you don't have them. First pipx:\n\n    python3 -m pip install --user pipx\n    python3 -m pipx ensurepath\n\nOpen a new shell, and then install Poetry:\n\n    pipx install poetry==2.*\n\nPoetry can be installed also without pipx: check the [Poetry documentation](https://python-poetry.org/docs/master/#installation).\n\nCreate a virtual environment and install dependencies:\n\n    poetry install\n\nBy default development dependencies are included. Use option `-E` to install dependencies for selected optional features (`-E \"extra1 extra2\"` for multiple extras), or install all of them with `--all-extras`. By default the virtual environment directory is not under the project directory, but there is a [setting for selecting this](https://python-poetry.org/docs/configuration/#virtualenvsin-project).\n\nEnter the virtual environment:\n\n    eval $(poetry env activate)\n\nStart up the application:\n\n    annif\n\n# Getting help\n\nMany resources are available:\n\n * [Usage documentation in the wiki](https://github.com/NatLibFi/Annif/wiki)\n * [Annif tutorial](https://github.com/NatLibFi/Annif-tutorial) for learning to use Annif\n * [annif-users](https://groups.google.com/forum/#!forum/annif-users) discussion forum; please use this as a channel for questions instead of personal e-mails to developers\n * [Internal API documentation](https://annif.readthedocs.io) on ReadTheDocs\n * [annif.org](https://annif.org) project web site\n\n# Publications / How to cite\n\nSee below for some articles about Annif in peer-reviewed Open Access\njournals. The software itself is also archived on Zenodo and\nhas a [citable DOI](https://doi.org/10.5281/zenodo.5654173).\n\n## Citing the software itself\n\nSee \"Cite this repository\" in the details of the repository.\n\n## Annif articles\n<ul>\n<li>\nSuominen, O; Inkinen, J.; Lehtinen, M. 2025.\nAnnif at the GermEval-2025 LLMs4Subjects Task: Traditional XMTC Augmented by Efficient LLMs, pre-print.\nhttps://arxiv.org/abs/2508.15877\n<details>\n<summary>See BibTex</summary>\n\n    @misc{suominen2025annifgermeval2025,\n      title={https://arxiv.org/abs/2508.15877},\n      author={Osma Suominen and Juho Inkinen and Mona Lehtinen},\n      year={2025},\n      eprint={2508.15877},\n      archivePrefix={arXiv},\n      primaryClass={cs.CL},\n      url={https://arxiv.org/abs/2508.15877},\n    }\n</details>\n</li>\n<li>\nSuominen, O; Inkinen, J.; Lehtinen, M. 2025.\nAnnif at SemEval-2025 Task 5: Traditional XMTC augmented by LLMs.\nIn Proceedings of the 19th International Workshop on Semantic Evaluation (SemEval-2025), pp. 2424\u20132431, Vienna, Austria. Association for Computational Linguistics.\nhttps://aclanthology.org/2025.semeval-1.315/\nhttps://arxiv.org/abs/2504.19675\n<details>\n<summary>See BibTex</summary>\n    \n    @misc{suominen2025annifsemeval2025task5,\n      title={Annif at SemEval-2025 Task 5: Traditional XMTC augmented by LLMs},\n      title = \"Annif at {S}em{E}val-2025 Task 5: Traditional {XMTC} augmented by {LLM}s\",\n      author = \"Suominen, Osma and Inkinen, Juho and Lehtinen, Mona\",\n      editor = \"Rosenthal, Sara  and  Ros{\\'a}, Aiala  and  Ghosh, Debanjan  and  Zampieri, Marcos\",\n      booktitle = \"Proceedings of the 19th International Workshop on Semantic Evaluation (SemEval-2025)\",\n      month = jul,\n      year = \"2025\",\n      address = \"Vienna, Austria\",\n      publisher = \"Association for Computational Linguistics\",\n      url = \"https://aclanthology.org/2025.semeval-1.315/\",\n      pages = \"2424--2431\",\n      ISBN = \"979-8-89176-273-2\",\n      # ArXiv \n      # year={2025},\n      # eprint={2504.19675},\n      # archivePrefix={arXiv},\n      # primaryClass={cs.CL},\n      # url={https://arxiv.org/abs/2504.19675},\n    }\n</details>\n</li>\n<li>\nInkinen, J.; Lehtinen, M.; Suominen, O., 2025.\nAnnif Users Survey: Understanding Usage and Challenges.\nURL:\nhttps://urn.fi/URN:ISBN:978-952-84-1301-1\n<details>\n<summary>See BibTex</summary>\n\n    @misc{inkinen2025,\n      title={Annif Users Survey: Understanding Usage and Challenges},\n      author={Inkinen, Juho and Lehtinen, Mona and Suominen, Osma},\n      series={The National Library of Finland. Reports and Studies},\n      issn={2242\u20138119},\n      isbn={978-952-84-1301-1},\n      year={2025},\n      url={URN:ISBN:978-952-84-1301-1},\n    }\n</details>\n</li>\n<li>\nGolub, K.; Suominen, O.; Mohammed, A.; Aagaard, H.; Osterman, O., 2024.\nAutomated Dewey Decimal Classification of Swedish library metadata using Annif software.\nJournal of Documentation, 80(5), pp. 1057-1079. URL:\nhttps://doi.org/10.1108/JD-01-2022-0026\n<details>\n<summary>See BibTex</summary>\n\n    @article{golub2024annif,\n      title={Automated Dewey Decimal Classification of Swedish library metadata using Annif software},\n      author={Golub, Koraljka and Suominen, Osma and Mohammed, Ahmed Taiye and Aagaard, Harriet and Osterman, Olof},\n      journal={J. Doc.},\n      year={2024},\n      doi = {10.1108/JD-01-2022-0026},\n      url={https://www.emerald.com/insight/content/doi/10.1108/JD-01-2022-0026},\n    }\n</details>\n</li>\n<li>\nSuominen, O.; Inkinen, J.; Lehtinen, M., 2022.\nAnnif and Finto AI: Developing and Implementing Automated Subject Indexing.\nJLIS.It, 13(1), pp. 265\u2013282. URL:\nhttps://www.jlis.it/index.php/jlis/article/view/437\n<details>\n<summary>See BibTex</summary>\n\n    @article{suominen2022annif,\n      title={Annif and Finto AI: Developing and Implementing Automated Subject Indexing},\n      author={Suominen, Osma and Inkinen, Juho and Lehtinen, Mona},\n      journal={JLIS.it},\n      volume={13},\n      number={1},\n      pages={265--282},\n      year={2022},\n      doi = {10.4403/jlis.it-12740},\n      url={https://www.jlis.it/index.php/jlis/article/view/437},\n    }\n</details>\n</li>\n<li>\nSuominen, O.; Koskenniemi, I, 2022.\nAnnif Analyzer Shootout: Comparing text lemmatization methods for automated subject indexing.\nCode4Lib Journal, (54). URL:\nhttps://journal.code4lib.org/articles/16719\n<details>\n<summary>See BibTex</summary>\n\n    @article{suominen2022analyzer,\n      title={Annif Analyzer Shootout: Comparing text lemmatization methods for automated subject indexing},\n      author={Suominen, Osma and Koskenniemi, Ilkka},\n      journal={Code4Lib J.},\n      number={54},\n      year={2022},\n      url={https://journal.code4lib.org/articles/16719},\n    }\n</details>\n</li>\n<li>\nSuominen, O., 2019. Annif: DIY automated subject indexing using multiple\nalgorithms. LIBER Quarterly, 29(1), pp.1\u201325. DOI:\nhttps://doi.org/10.18352/lq.10285\n<details>\n<summary>See BibTex</summary>\n\n    @article{suominen2019annif,\n      title={Annif: DIY automated subject indexing using multiple algorithms},\n      author={Suominen, Osma},\n      journal={{LIBER} Quarterly},\n      volume={29},\n      number={1},\n      pages={1--25},\n      year={2019},\n      doi = {10.18352/lq.10285},\n      url = {https://doi.org/10.18352/lq.10285}\n    }\n</details>\n</li>\n</ul>\n\n# License\n\nThe code in this repository is licensed under Apache License 2.0, except for\nthe dependencies included under `annif/static/css` and `annif/static/js`,\nwhich have their own licenses; see the file headers for details.\n\nPlease note that the [YAKE](https://github.com/LIAAD/yake) library is\nlicensed under [GPLv3](https://www.gnu.org/licenses/gpl-3.0.txt), while\nAnnif itself is licensed under the Apache License 2.0. It is commonly\naccepted that the GPLv3 and Apache 2.0 licenses are compatible at least in\none direction (GPLv3 is more restrictive than the Apache License); obviously\nit also depends on the legal environment. The Annif developers make no legal\nclaims - we simply provide the software and allow the user to install\noptional extensions if they consider it appropriate. Depending on legal\ninterpretation, the terms of the GPL (for example the requirement to publish\ncorresponding source code when publishing an executable application) may be\nconsidered to apply to the whole of Annif+extensions if you decide to\ninstall the optional YAKE dependency.\n",
    "bugtrack_url": null,
    "license": "Apache-2.0",
    "summary": "Automated subject indexing and classification tool",
    "version": "1.4.0",
    "project_urls": {
        "Documentation": "https://github.com/NatLibFi/Annif/wiki",
        "Homepage": "https://annif.org",
        "Repository": "https://github.com/NatLibFi/Annif"
    },
    "split_keywords": [
        "machine-learning",
        " text-classification",
        " multilabel-classification",
        " rest-api",
        " code4lib",
        " subject-indexing"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "d57c67d0817ea7da2fa5901d337dedbdd7504554750f13d7b653e1c0451a043b",
                "md5": "59f6dae65edf947cf68d019a63b98a0b",
                "sha256": "33e985c26b4411f80a40faeb8ce7a9d5adf248245e0eff3a07d95d92873fefa4"
            },
            "downloads": -1,
            "filename": "annif-1.4.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "59f6dae65edf947cf68d019a63b98a0b",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<3.14,>=3.10",
            "size": 517180,
            "upload_time": "2025-09-03T10:40:44",
            "upload_time_iso_8601": "2025-09-03T10:40:44.889953Z",
            "url": "https://files.pythonhosted.org/packages/d5/7c/67d0817ea7da2fa5901d337dedbdd7504554750f13d7b653e1c0451a043b/annif-1.4.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "c38a4578ea795bd0e8203719d0c8a2df4b97b94fa3f703f97bb3019799651393",
                "md5": "dba2391b1acb6d1457c70ea7230c5347",
                "sha256": "5d05c8a949a76f40a03d5fbd89a5584c1cea50d46caa9165c32e5bee1f427e04"
            },
            "downloads": -1,
            "filename": "annif-1.4.0.tar.gz",
            "has_sig": false,
            "md5_digest": "dba2391b1acb6d1457c70ea7230c5347",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<3.14,>=3.10",
            "size": 481242,
            "upload_time": "2025-09-03T10:40:48",
            "upload_time_iso_8601": "2025-09-03T10:40:48.064483Z",
            "url": "https://files.pythonhosted.org/packages/c3/8a/4578ea795bd0e8203719d0c8a2df4b97b94fa3f703f97bb3019799651393/annif-1.4.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-09-03 10:40:48",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "NatLibFi",
    "github_project": "Annif",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "annif"
}
        
Elapsed time: 1.89300s