#query-language #linguistic #search-engine #annis #visualization #graph #back-end

graphannis

This is a new backend implementation of the ANNIS linguistic search and visualization system

88 releases (46 stable)

new 3.6.0 Jan 14, 2025
3.5.1 Sep 25, 2024
3.4.0 Aug 20, 2024
3.3.3 Jul 12, 2024
0.1.0 Apr 6, 2018

#184 in Text processing

Download history 138/week @ 2024-09-26 58/week @ 2024-10-03 50/week @ 2024-10-10 66/week @ 2024-10-17 18/week @ 2024-10-24 40/week @ 2024-10-31 51/week @ 2024-11-07 53/week @ 2024-11-14 36/week @ 2024-11-21 130/week @ 2024-11-28 758/week @ 2024-12-05 519/week @ 2024-12-12 102/week @ 2024-12-19 57/week @ 2024-12-26 163/week @ 2025-01-02 183/week @ 2025-01-09

576 downloads per month
Used in 5 crates

Apache-2.0

1MB
27K SLoC

graphANNIS DOI Automated tests

This is a new backend implementation of the ANNIS linguistic search and visualization system (http://corpus-tools.org/annis/).

Only a sub-set of the ANNIS Query Language (AQL) from ANNIS version 3 (based on PostgreSQL) is supported yet. More operators can be added in the future, but the ones missing are the ones which have been used less frequent. There is a tutorial in the Developer Guide on how to embed graphANNIS in your own application.

The basic design ideas and data models are described in detail in the PhD-thesis "ANNIS: A graph-based query system for deeply annotated text corpora". The thesis describes a prototype implementation in C++ and not Rust, but the design ideas are the same. Notable differences/enhancements compared to the thesis are:

  • Graph storages implement querying inverse edges and finding reachable nodes based on them: this allows to implement inverse operators (e.g. for precedence) and switching operands in situations where it was not possible before.
  • The data model has been simplified: the inverse coverage component and inverse edges in the left-/right-most token component have been removed.
  • Additional query language features are now supported.

Documentation

Developing graphANNIS

You need to install Rust to compile the project. We recommend installing the following Cargo subcommands for developing annis-web:

Execute tests

You can run the tests with the default cargo test command. To calculate the code coverage, you can use cargo-llvm-cov:

cargo llvm-cov --open --all-features --ignore-filename-regex '(tests?\.rs)|(capi/.*)'

Performing a release

You need to have cargo-release installed to perform a release. Execute the follwing cargo command once to install it.

cargo install cargo-release

To perform a release, switch to the main branch and execute:

cargo release [LEVEL] --execute

The level should be patch, minor or major depending on the changes made in the release. Running the release command will also trigger a CI workflow to create release binaries on GitHub.

3rd party dependencies

This software depends on several 3rd party libraries. These are documented in the "third-party-licenses.html" file in this folder.

Language bindings

Author(s)

Dependencies

~16–28MB
~430K SLoC