diff --git a/_data/releases.yml b/_data/releases.yml index bdd875f..d8500bd 100644 --- a/_data/releases.yml +++ b/_data/releases.yml @@ -24,6 +24,10 @@ ### RELEASE VERSIONS ### +- version: "29.3" + date: 2023-09-26 + status: stable + - version: "29.2" date: 2023-09-19 status: stable diff --git a/releases/29.3/docs/admin-guide.html b/releases/29.3/docs/admin-guide.html new file mode 100644 index 0000000..fbcf8f4 --- /dev/null +++ b/releases/29.3/docs/admin-guide.html @@ -0,0 +1,5601 @@ + + + + + + + + +INCEpTION Administrator Guide + + + + + + + + + + + + + + + + + +
+
+
+
+

This guide covers handling INCEpTION from an administrator’s perspective.

+
+
+
+

Installation

+
+
+
+

You can run INCEpTION on any major platform supporting Java, i.e. Linux, macOS or Windows. +However, we do not provide explicit support for setting up a production-ready instance of each of these +platforms.

+
+
+

This guide assumes Debian 9.1 (Stretch). It may also work on Ubuntu with some modifications, but we +do not test this. Instructions for other Linux distributions and other platforms (i.e. macOS and +Windows) likely deviate significantly.

+
+
+

It is further assumed that the user www-data already exists on the system and that it shall be used to run the application.

+
+
+

All commands assume that you are logged in as the root user.

+
+
+ + + + + +
+ + +If you cannot log in as root but have to use sudo to become root, then the recommended way + to do that is using the command sudo su -. +
+
+
+
+
+

System Requirements

+
+ + ++++ + + + + + + +
Table 1. Requirements for users

Browser

Chrome or Safari

+ + ++++ + + + + + + + + + + +
Table 2. Requirements to run the standalone version

Operating System

Linux (64bit), macOS (64bit), Windows (64bit)

Java Runtime Environment

version 11 or higher

+ + ++++ + + + + + + + + + + + + + + + + + + +
Table 3. Requirements run the server version

Operating System

Linux (64bit), macOS (64bit), Windows (64bit)

Java Runtime Environment

version 11 or higher

Apache Tomcat (or compatible)

version 9.0 or higher (Servlet API 4.0.0)

MariaDB Server (or compatible)

version 10.5 or higher

+
+ + + + + +
+ + +MariaDB is an open source drop-in replacement for MySQL. So generally, you can also use MySQL instead of MariaDB. Also, as far as we know, we do not use any fancy features of MariaDB 10.5 and did in fact until recently always use MySQL 5. So you can probably also use an older version of MariaDB or MySQL…​ but why should you? Think of all the unfixed bugs and consider also upgrading your database if you do a fresh installation of INCEpTION - or use Docker. +
+
+
+
+
+

Install Java

+
+
+

You can install a Java 11 JDK using the following commands.

+
+
+
+
$ apt-get update
+$ apt-get install openjdk-11-jdk
+
+
+
+
+
+

Application home folder

+
+
+

The INCEpTION home folder is the place where INCEpTION’s configuration file settings.properties +resides and where INCEpTION stores its data. By default, this is a (hidden) folder called .inception in +the home directory of the user running INCEpTION. However, you can override the location of the +home folder using the system property inception.home.

+
+
+
Passing a custom home folder location to INCEpTION when starting from the command line
+
+
$ java -Dinception.home="/srv/inception" -jar inception-app-webapp-29.3-standalone.jar
+
+
+
+

If you want to use a settings.properties file, you need to place it into the INCEpTION home folder yourself. +While the home folder is automatically created if it does not exist, the settings.properties is not +automatically created by the application. +Mind that if you are using a dedicated database server +(recommended), then INCEpTION also stores some data in the dedicated database. This is important when +you plan to perform a backup, as both the home folder and the database content need to be +included in the backup.

+
+
+

Now, let’s go through the steps of setting up a home folder for INCEpTION and creating a +configuration file instructing INCEpTION to access a dedicated database.

+
+
+
    +
  • +

    Create INCEpTION home folder. This is the directory where INCEpTION settings files and projects (documents, annotations, etc.) are stored

    +
    +
    +
    $ mkdir /srv/inception
    +
    +
    +
  • +
  • +

    Create and edit /srv/inception/settings.properties to define the database connection as well as internal backup properties:

    +
    +
    +
    database.url=jdbc:mariadb://localhost:3306/inception?useSSL=false&serverTimezone=UTC&useUnicode=yes&characterEncoding=UTF-8
    +database.username=inception
    +database.password=t0t4llYSecreT
    +
    +
    +
  • +
  • +

    Fix permissions in INCEpTION home folder

    +
    +
    +
    $ chown -R www-data:www-data /srv/inception
    +
    +
    +
  • +
+
+
+
+
+

Database

+
+
+

INCEpTION uses a SQL database to store project and user data.

+
+
+

INCEpTION uses by default an embedded HSQLDB database. However, we recommend using the embedded +database only for testing purposes. For production use, we recommend using a MariaDB server (or compatible). The reason +for this is, that:

+
+
+
    +
  • +

    some users have reported that HSQLDB databases may become corrupt when the computer crashes +(note that this could probably also happen with MariaDB, but we did so far not have any reports +about this);

    +
  • +
  • +

    most INCEpTION developers use MariaDB (or compatible) when running INCEpTION on their +servers;

    +
  • +
  • +

    in the past, we had cases where we described in-place upgrade procedures that required performing +SQL commands to change the data model as part of the upgrade. We promise to try avoiding this in +the future. However, in case we offer advice on fixing anything directly in the database, this +advice will refer to a MariaDB database.

    +
  • +
+
+
+

We try to keep the data model simple, so there should be no significant requirements to the database +being used. Theoretically, it should be possible to use any JDBC-compatible database after adding a +corresponding driver to the classpath and configuring INCEpTION to use the driver in the +settings.properties file.

+
+
+

MariaDB

+
+

For production use of INCEpTION, it is highly recommended to use a MariaDB database. In this +section, we briefly describe how to install a MariaDB server and how to prepare it for use with +the application.

+
+
+ + + + + +
+ + +MariaDB is an open-source drop-in replacement for MySQL. As a matter of fact, most of the commands and configuration files still use mysql in many places - so do not be confused if you read a lot about MySQL below despite working with MariaDB. +
+
+
+

Prepare database

+
+
    +
  • +

    Install MariaDB

    +
    +
    +
    $ apt-get install mariadb-server
    +
    +
    +
  • +
+
+
+
    +
  • +

    When first setting up your database make sure your MariaDB server is configured for 4 Byte UTF-8 (utf8mb4, utf8mb4_bin) to ensure that all unicode characters can be represented (e.g. emojis).

    +
    + + + + + +
    + + +Upgrading an existing database installation to 4 Byte UTF-8: Changing the character-set and collation later can lead to serious trouble, so make sure you have a backup of your database. In that case, you might also need to perform some additional migration steps. We do not provide a database migration guide here, but if you search e.g. for mariadb convert utf8 to utf8mb4 (or mysql for that matter), you should find several. +
    +
    +
    + + + + + +
    + + +utf8mb4_bin vs. utf8mb4_unicode_ci: If you search for UTF-8 support in MariaDB, you will generally find the recommendation to use utf8mb4_unicode_ci as the collation. This, however, is a case-insensitive collation. INCEpTION is usually case-sensitive. If you used a case-insensitive collation in the database, you could not create two projects, one being called MY PROEJCT and the other being called my project, but instead of a nice error from INCEpTION, you would get an ugly error from the database. That is why we recommend using the case-sensitive utf8mb4_bin for the database. +
    +
    +
    +

    Check that character-set-server, default-character-set are set to utf8mb4 and collation-server is set to utf8mb4_unicode_ci by logging into MariaDB with

    +
    +
    +
    +
    $ mysql -u root -p
    +
    +
    +
    +

    and running

    +
    +
    +
    +
    mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';
    +
    +
    +
    +

    If this is not the case add the following lines to your MariaDB config file (most likely /etc/mysql/my.cnf or in /etc/mysql/mariadb.conf.d):

    +
    +
    +
    +
    [client]
    +default-character-set = utf8mb4
    +
    +[mysql]
    +default-character-set = utf8mb4
    +
    +[mysqld]
    +character-set-client-handshake = FALSE
    +character-set-server = utf8mb4
    +collation-server = utf8mb4_bin
    +innodb_large_prefix=true
    +innodb_file_format=barracuda
    +innodb_file_per_table=1
    +innodb_strict_mode=1
    +innodb_default_row_format='dynamic'
    +
    +
    +
  • +
  • +

    now set up the inception database. First login to MariaDB

    +
    +
    +
    $ mysql -u root -p
    +
    +
    +
  • +
  • +

    create a database

    +
    +
    +
    mysql> CREATE DATABASE inception DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;
    +
    +
    +
  • +
  • +

    create a database user called inception with the password t0t4llYSecreT which is later used by the application to access the database (instructions for the settings.properties file in the Home Folder section).

    +
    +
    +
    mysql> CREATE USER 'inception'@'localhost' IDENTIFIED BY 't0t4llYSecreT';
    +mysql> GRANT ALL PRIVILEGES ON inception.* TO 'inception'@'localhost';
    +mysql> FLUSH PRIVILEGES;
    +
    +
    +
  • +
+
+
+ + + + + +
+ + +For production use, make sure you choose a different, secret, and secure password. +
+
+
+
+

Configuration options

+
+

This section explains some settings that can be added to the database.url in the +settings.properties file when using MariaDB. Settings are separated from the host name and database name with a ? character and multiple settings are separated using the & character, e.g.:

+
+
+
+
database.url=jdbc:mariadb://localhost:3306/inception?useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8
+
+
+
+

To suppress the warning about non-SSL database connections with recent MySQL databases, append the +following setting to the database.url:

+
+
+
+
useSSL=false
+
+
+
+

You might also need to add the following if the respective connection error occurs:

+
+
+
+
allowPublicKeyRetrieval=true
+
+
+
+

Recent MySQL drivers may refuse to work unless a database server timezone has been specified. The +easiest way to do this is to add the following setting to the database.url:

+
+
+
+
serverTimezone=UTC
+
+
+
+

If you plan to use 4 Byte UTF-8 encoding for project name and tagset/tag name, make sure both of the following settings for MySQL database are configured:

+
+
+
    +
  • +

    in the settings.properties file, make sure that database.url includes

    +
    +
    +
    useUnicode=true&characterEncoding=UTF-8
    +
    +
    +
    + + + + + +
    + + +If you use older versions of MariaDB or MySQL (< 8), you may have to set the following property in the settings.properties file: +
    +
    +
    +
    +
    spring.datasource.hikari.connectionInitSql=SET NAMES utf8mb4 COLLATE utf8mb4_bin;
    +
    +
    +
  • +
  • +

    change the my.conf MariaDB database configuration file if necessary to use utf8mb4 as default character set and utf8mb4_bin for collation (see Preparing the database).

    +
  • +
+
+
+
+

Using MySQL instead of MariaDB

+
+

INCEpTION only includes the MariaDB JDBC driver. According to the MariaDB documentation, this driver is also compatible with MySQL servers. However, additional settings may be necessary when connecting to a MySQL server.

+
+
+

If you want to use INCEpTION with MySQL instead of MariaDB, you may also have to explicitly define the database driver. The MariaDB driver should also work for MySQL databases, but if you use a mysql JDBC URL (like e.g. dbc:mysql://localhost:3306/inception), you need to explicitly define the driver in the settings.properties file:

+
+
+
+
database.driver=org.mariadb.jdbc.Driver
+
+
+
+

In most cases, INCEpTION can auto-configure the database dialect to use. However, in some cases, this auto-detection may fail - in particular when using MySQL. For example, when using INCEpTION with MySQL 8, it may be necessary to explicitly add a database dialect configuration to the settings.properties file:

+
+
+
+
database.dialect=org.hibernate.dialect.MySQL8Dialect
+
+
+
+

Finally, recent versions of MySQL may need this setting to avoid schema validation to fail during startup:

+
+
+
+
spring.jpa.properties.hibernate.globally_quoted_identifiers=true
+
+
+
+
+
+

HSQLDB (embedded)

+
+

INCEpTION displays a warning in the user interface when an embedded database is being used. +It is not recommended to used an embedded database for various reasons:

+
+
+
    +
  • +

    HSQLDB databases are known to run a risk of becoming corrupt in case of power failures which may +render the application inaccessible and your data difficult to recover.

    +
  • +
  • +

    In very rare cases it may be necessary to fix the database content which is more inconvenient +for embedded databases.

    +
  • +
+
+
+

In case that you really want to run INCEpTION with an embedded database in production, +you probably want to disable this warning. To do so, please add the following entry to +the settings.properties file:

+
+
+
+
warnings.embeddedDatabase=false
+
+
+
+
+
+
+

Running via embedded Tomcat (JAR)

+
+
+

The INCEpTION standalone JAR with an embedded Tomcat server and can be easily set up as a UNIX service. +This is the recommended way of running INCEpTION on a server.

+
+
+

The instructions below expect a Debian Linux system. +Details may vary on other OSes and Linux distributions.

+
+
+

Installing as a service

+
+

To set it up as a service, you can do the following steps. +For the following example, we assume that you install INCEpTION in /srv/inception:

+
+
+
    +
  • +

    Copy the standalone JAR file inception-app-standalone-29.3.jar to /srv/inception/inception.jar. +Note the change of the filename to inception.jar.

    +
  • +
  • +

    Create the file /srv/inception/inception.conf with the following content

    +
    +
    +
    JAVA_OPTS="-Djava.awt.headless=true -Dinception.home=/srv/inception"
    +
    +
    +
  • +
  • +

    In the previous step, you have already created the /srv/inception/settings.properties file. +You may optionally configure the Tomcat port using the following line

    +
    +
    +
    server.port=18080
    +
    +
    +
    +

    If you need to do additional configurations of the embedded Tomcat, best refer to the documentation of Spring Boot itself.

    +
    +
  • +
  • +

    We will run INCEpTION as the user www-data. +Change the owner/group of /srv/inception/inception.jar to www-data. +Do NOT run INCEpTION as root.

    +
    +
    +
    $ chown www-data:www-data /srv/inception/inception.jar
    +
    +
    +
  • +
  • +

    Make the JAR file executable:

    +
    +
    +
    $ chmod +x /srv/inception/inception.jar
    +
    +
    +
  • +
  • +

    Create a file /etc/systemd/system/inception.service with the following content:

    +
    +
    +
    [Unit]
    +Description=INCEpTION
    +
    +[Service]
    +ExecStart=/srv/inception/inception.jar
    +User=www-data
    +
    +[Install]
    +WantedBy=multi-user.target
    +
    +
    +
  • +
  • +

    Enable the INCEpTION service using

    +
    +
    +
    $ systemctl enable inception
    +
    +
    +
  • +
  • +

    Start INCEpTION using

    +
    +
    +
    $ systemctl start inception
    +
    +
    +
  • +
  • +

    Check the log output

    +
    +
    +
    $ journalctl -u inception
    +
    +
    +
  • +
  • +

    Stop INCEpTION using

    +
    +
    +
    $ systemctl stop inception
    +
    +
    +
  • +
+
+
+ + + + + +
+ + +If you encounter strange errors, e.g. {status=203/EXEC} and INCEpTION starts when directly executing the jar but not via systemd, then we recommend to disable SELinux. +
+
+
+
+

Loading extra Java libraries

+
+

When running an application from a fat JAR (i.e. using java -jar …​), there is no way that you can specify extra libraries for the application to load (e.g. a database driver). +Therefore, +INCEpTION offers a special approach that works around this limitation.

+
+
+

In order to have the application load additional JAR files during startup, create a folder lib in the application home folder. +Place any JARs that you want to load into that folder.

+
+
+

To check if the loading works as expected, you can add the parameter -Dloader.debug=true when starting up INCEpTION.

+
+
+
+
+
+

Running the behind a reverse proxy (JAR)

+
+
+

These are optional instructions if you want to run INCEpTION behind an Apache HTTPD, Nginx or Caddy web-server instead of accessing it directly.

+
+
+

These guides assumes Debian 9.1 (Stretch) as the operating system. +For the optional SSL configuration, it further assumes that you want to use Let’s Encrypt as a CA for obtaining valid SSL certificates.

+
+
+

The setup for INCEpTION itself is the same for Apache, Nginx and Caddy:

+
+
+
    +
  • +

    Add the following lines to /srv/inception/settings.properties (replacing your.public.domain.name.com with the public domain name of your reverse proxy):

    +
    +
    +
    # Port INCEpTION is listening on
    +server.port=8080
    +
    +# If your reverse proxy is running on the same host as {product-name},
    +# you can use the next line to prevent direct access to INCEpTION from other hosts
    +server.address=127.0.0.1
    +
    +# In our examples, we run {product-name} at `your.public.domain.name.com/inception`
    +# If you want to Run {product-name} directly under the host name without an
    +# additional path, remove this line
    +server.servlet.context-path=/inception
    +
    +# Tell {product-name} which URL your users will enter into their browsers to access it.
    +# Make sure you have an entry with and an entry without the protocol.
    +# If you also allow unencrypted http (not recommended) then also add a line with
    +# the http protocol
    +wicket.core.csrf.accepted-origins[0]=your.public.domain.name.com
    +wicket.core.csrf.accepted-origins[1]=https://your.public.domain.name.com
    +
    +
    +
  • +
+
+
+

CSRF protection

+
+

Depending on your situation, you may get an error message such as this when trying to use +INCEpTION.

+
+
+
+
+

Whitelabel Error Page This application has no explicit mapping for /error, so you are seeing this as a fallback.

+
+
+

Fri Nov 29 14:01:15 BRT 2019 There was an unexpected error (type=Bad Request, status=400). +Origin does not correspond to request

+
+
+
+
+

If this is the case, then CSRF protection is kicking in. +Check that the following lines are in your settings.properties file (see Settings, replace the server name and URL with your own):

+
+
+
+
wicket.core.csrf.accepted-origins[0]=your.public.domain.name.com
+wicket.core.csrf.accepted-origins[1]=https://your.public.domain.name.com
+
+
+
+ + + + + +
+ + +You could disable CSRF completely, but this is obviously not the recommended approach. To disable CSRF, add wicket.core.csrf.enabled=false to the settings.properties file. +
+
+
+
+

Apache HTTPD as reverse proxy

+
+
+
+ + + + + +
+ + +Make sure you have read the general instructions for running behind + a reverse proxy and have configured your settings file accordingly, otherwise you will not be able + to properly use INCEpTION via the reverse proxy! +
+
+
+
+
+

This assumes that you already have the following packages installed:

+
+
+
    +
  • +

    Apache Web Server

    +
  • +
  • +

    mod_proxy

    +
  • +
  • +

    mod_proxy_http

    +
  • +
  • +

    mod_wstunnel

    +
  • +
+
+
+

You can enable the two modules with

+
+
+
+
$ a2enmod proxy proxy_http wstunnel
+
+
+
+

and check that they are enabled with

+
+
+
+
$ apachectl -M
+
+
+
+
    +
  • +

    Edit /etc/apache2/conf-available/inception.local.conf (alternatively, you may want to configure a new virtual host for INCEpTION)

    +
    +
    +
    ProxyPreserveHost On
    +
    +<Proxy http://localhost/inception >
    +  Order Deny,Allow
    +  Deny from none
    +  Allow from all
    +</Proxy>
    +
    +ProxyPass /inception/ws ws://localhost:8080/inception/ws
    +ProxyPass /inception http://localhost:8080/inception
    +ProxyPassReverse /inception https://your.public.domain.name.com/inception
    +
    +
    +
  • +
  • +

    Enable the configuration with

    +
    +
    +
    $ a2enconf inception.local
    +
    +
    +
  • +
  • +

    Restart Apache web server

    +
    +
    +
    $ service apache2 restart
    +
    +
    +
  • +
+
+
+

Obtaining a Let’s Encrypt certificate

+
+

The Certification Authority (CA) Let’s Encrypt provides free TLS/SSL certificates. +These certificates allow for secure HTTPS connections on web servers. +Let’s Encrypt provides the software Certbot which automates the obtaining process for Apache.

+
+
+ +
+
+
+
$ sudo a2enmod ssl
+
+
+
+
    +
  • +

    Install Certbot preconfigured for Apache

    +
  • +
+
+
+
+
$ apt-get install python-certbot-apache -t stretch-backports
+
+
+
+
    +
  • +

    Obtain the certificates for your domain example.com

    +
  • +
+
+
+
+
$ certbot --apache certonly -d example.com
+
+
+
+
    +
  • +

    You will be prompted to enter your e-mail address and asked to agree to the terms of service. +Certificate renewal information will be sent to this e-mail. +If the certification process is successful it will yield the information where your certificates can be found.

    +
  • +
+
+
+
+
IMPORTANT NOTES:
+ - Congratulations! Your certificate and chain have been saved at
+   /etc/letsencrypt/live/example.com/fullchain.pem. Your cert will
+   expire on 2019-04-22. To obtain a new or tweaked version of this
+   certificate in the future, simply run certbot again with the
+   "certonly" option. To non-interactively renew *all* of your
+   certificates, run "certbot renew"
+ - Your account credentials have been saved in your Certbot
+   configuration directory at /etc/letsencrypt. You should make a
+   secure backup of this folder now. This configuration directory will
+   also contain certificates and private keys obtained by Certbot so
+   making regular backups of this folder is ideal.
+ - If you like Certbot, please consider supporting our work by:
+
+   Donating to ISRG / Let's Encrypt:   https://letsencrypt.org/donate
+   Donating to EFF:                    https://eff.org/donate-le
+
+
+
+ + + + + +
+ + +Certificates issued by Let’s Encrypt are valid for 90 days. +You will receive an expiry notification to the e-mail address you provided during the certification process. +
+
+
+
    +
  • +

    Run Certbot with the command renew to renew all certificates that are due. +You can also create a cron job for this purpose. +The command for renewal is

    +
  • +
+
+
+
+
$ certbot --apache renew
+
+
+
+
    +
  • +

    You can simulate the certificate renewal process with the command

    +
  • +
+
+
+
+
$ certbot --apache renew --dry-run
+
+
+
+
    +
  • +

    The directory /etc/letsencrypt/live/example.com/ now contains the necessary certificates to proceed

    +
  • +
+
+
+
+
$ ls /etc/letsencrypt/live/example.com
+Output:
+cert.pem  chain.pem  fullchain.pem  privkey.pem
+
+
+
+

Then the configuration of the web server only needs this:

+
+
+
+
<VirtualHost *:443>
+    ServerName example.com
+    DocumentRoot /var/www/html
+    SSLEngine on
+    SSLCertificateFile /etc/letsencrypt/live/example.com/fullchain.pem
+    SSLCertificateKeyFile /etc/letsencrypt/live/example.com/privkey.pem
+    Include /etc/letsencrypt/options-ssl-apache.conf
+</VirtualHost>
+
+<VirtualHost *:80>
+    ServerName example.com
+    Redirect / https://example.com/
+    RewriteEngine on
+    RewriteCond %{SERVER_NAME} =example.com
+    RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent]
+</VirtualHost>
+
+
+
+
+
+

NGINX as reverse proxy

+
+
+
+ + + + + +
+ + +Make sure you have read the general instructions for running behind + a reverse proxy and have configured your settings file accordingly, otherwise you will not be able + to properly use INCEpTION via the reverse proxy! +
+
+
+
+
+

This section describes using NGINX as a web server serving as a reverse proxy for INCEpTION. +It further assumes that you want to use Let’s Encrypt as a CA for obtaining valid SSL certificates.

+
+
+
    +
  • +

    You can install NGINX by typing

    +
  • +
+
+
+
+
$ apt-get update
+$ apt-get install nginx
+
+
+
+
    +
  • +

    Verify the installation with

    +
  • +
+
+
+
+
$ systemctl status nginx
+Output:
+● nginx.service - A high-performance web server and a reverse proxy server
+   Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
+   Active: active (running) since Mon 2019-01-21 14:42:01 CET; 20h ago
+     Docs: man:nginx(8)
+  Process: 7947 ExecStop=/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /run/nginx.pid (code=exited, status=0/SUCCESS)
+  Process: 7953 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
+  Process: 7950 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
+ Main PID: 7955 (nginx)
+    Tasks: 9 (limit: 4915)
+   CGroup: /system.slice/nginx.service
+           ├─7955 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
+           ├─7956 nginx: worker process
+
+
+
+
    +
  • +

    You can stop, start or restart NGINX with

    +
  • +
+
+
+
+
$ systemctl stop nginx
+
+$ systemctl start nginx
+
+$ systemctl restart nginx
+
+
+
+

Obtaining a Let’s Encrypt certificate

+
+

The Certification Authority (CA) Let’s Encrypt provides free TLS/SSL certificates. +These certificates allow for secure HTTPS connections on web servers. +Let’s Encrypt provides the software Certbot which automates the obtaining process for NGINX.

+
+
+ +
+
+
+
$ apt-get install python-certbot-nginx -t stretch-backports
+
+
+
+
    +
  • +

    Obtain the certificates for your domain example.com

    +
  • +
+
+
+
+
$ certbot --nginx certonly -d example.com
+
+
+
+
    +
  • +

    You will be prompted to enter your e-mail address and asked to agree to the terms of service. +Certificate renewal information will be sent to this e-mail. +If the certification process is successful it will yield the information where your certificates can be found.

    +
  • +
+
+
+
+
IMPORTANT NOTES:
+ - Congratulations! Your certificate and chain have been saved at
+   /etc/letsencrypt/live/example.com/fullchain.pem. Your cert will
+   expire on 2019-04-22. To obtain a new or tweaked version of this
+   certificate in the future, simply run certbot again with the
+   "certonly" option. To non-interactively renew *all* of your
+   certificates, run "certbot renew"
+ - Your account credentials have been saved in your Certbot
+   configuration directory at /etc/letsencrypt. You should make a
+   secure backup of this folder now. This configuration directory will
+   also contain certificates and private keys obtained by Certbot so
+   making regular backups of this folder is ideal.
+ - If you like Certbot, please consider supporting our work by:
+
+   Donating to ISRG / Let's Encrypt:   https://letsencrypt.org/donate
+   Donating to EFF:                    https://eff.org/donate-le
+
+
+
+ + + + + +
+ + +Certificates issued by Let’s Encrypt are valid for 90 days. +You will receive an expiry notification to the e-mail address you provided during the certification process. +
+
+
+
    +
  • +

    Run Certbot with the command renew to renew all certificates that are due. +You can also create a cron job for this purpose. +The command for renewal is

    +
  • +
+
+
+
+
$ certbot --nginx renew
+
+
+
+
    +
  • +

    You can simulate the certificate renewal process with the command

    +
  • +
+
+
+
+
$ certbot --nginx renew --dry-run
+
+
+
+
    +
  • +

    The directory /etc/letsencrypt/live/example.com/ now contains the necessary certificates to proceed

    +
  • +
+
+
+
+
$ ls /etc/letsencrypt/live/example.com
+Output:
+cert.pem  chain.pem  fullchain.pem  privkey.pem
+
+
+
+
+

Putting it all together

+
+

By now you should have

+
+
+
    +
  • +

    INCEpTION running on port 8080

    +
  • +
  • +

    NGINX running with default configurations on port 80

    +
  • +
  • +

    your issued SSL certificates

    +
  • +
+
+
+ + + + + +
+ + +If you are running INCEpTION on a different port than 8080, please make sure to adjust the configurations below accordingly! +
+
+
+

We will now configure NGINX to proxy pass all traffic received at example.com/inception to our INCEpTION instance.

+
+
+

Create a new virtual host for your domain. +Inside of /etc/nginx/sites-available/ create a new file for your domain (e.g. example.com). +Paste the following contents:

+
+
+
+
# Server block for insecure http connections on port 80. Redirect to https on port 443
+server {
+        listen          80;
+        listen          [::]:80;
+        server_name     example.com;
+        return          301 https://$server_name$request_uri;
+}
+
+# Server block for secure https connections
+server {
+        listen 443 ssl;
+        listen [::]:443 ssl;
+        server_name inception.example.com;
+
+        ssl on;
+
+        # Replace certificate paths
+        ssl_certificate         /etc/letsencrypt/live/example.com/fullchain.pem;
+        ssl_certificate_key     /etc/letsencrypt/live/example.com/privkey.pem;
+        ssl_trusted_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
+
+        # Modern SSL Config from
+        # https://mozilla.github.io/server-side-tls/ssl-config-generator/
+        ssl_protocols TLSv1.2;
+        ssl_ciphers 'ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256';
+        ssl_prefer_server_ciphers on;
+        ssl_session_timeout 1d;
+        ssl_session_tickets off;
+        add_header Strict-Transport-Security max-age=15768000;
+        ssl_stapling on;
+        ssl_stapling_verify on;
+
+        ignore_invalid_headers off; #pass through headers from INCEpTION which are considered invalid by NGINX server.
+
+        # Change body size if needed. This defines the maximum upload size for files.
+        client_max_body_size    10M;
+
+        # Uncommend this for a redirect from example.com to example.com/inception
+        #location / {
+        #    return 301 https://$host/inception;
+        #}
+
+        location /inception/ws {
+            proxy_pass http://127.0.0.1:8080;
+            proxy_http_version 1.1;
+            proxy_set_header Upgrade $http_upgrade;
+            proxy_set_header Connection "Upgrade";
+            proxy_set_header Host $host;
+        }
+
+        location ^~ /inception/ {
+            proxy_pass http://127.0.0.1:8080/inception/;
+            proxy_redirect http://inception.example.com/ /;
+            proxy_http_version 1.1;
+
+            proxy_set_header   Host             $host;
+            proxy_set_header   X-Real-IP        $remote_addr;
+            proxy_set_header   X-Forwarded-For  $remote_addr;
+            proxy_set_header   X-Forwarded-Proto $scheme;
+            proxy_max_temp_file_size 0;
+
+            proxy_connect_timeout      180;
+            proxy_send_timeout         180;
+            proxy_read_timeout         180;
+
+            proxy_temp_file_write_size 64k;
+
+            # Required for new HTTP-based CLI
+            proxy_request_buffering off;
+            proxy_buffering off; # Required for HTTP-based CLI to work over SSL
+            proxy_set_header Connection ""; # Clear for keepalive
+    }
+
+    # Deny access to Apache .htaccess files. They have no special meaning for NGINX and might leak sensitive information
+    location ~ /\.ht {
+            deny all;
+    }
+}
+
+
+
+

Create a symlink for the new configuration file to the folder for accessible websites:

+
+
+
+
$ ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/example.com
+
+
+
+

Test if the NGINX configuration file works without restarting (and possibly breaking) the webserver:

+
+
+
+
$ nginx -t
+Output:
+nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
+nginx: configuration file /etc/nginx/nginx.conf test is successful
+
+
+
+

If the config works restart the webserver to enable the new site

+
+
+
+
$ service nginx restart
+
+
+
+
+
+

Caddy as a reverse proxy

+
+
+
+ + + + + +
+ + +Make sure you have read the general instructions for running behind + a reverse proxy and have configured your settings file accordingly, otherwise you will not be able + to properly use INCEpTION via the reverse proxy! +
+
+
+
+
+

This section describes using Caddy as a web server serving as a reverse proxy for INCEpTION. +It further assumes that you want to use the builting funcionality to use Let’s Encrypt as a CA for obtaining valid SSL certificates.

+
+
+
    +
  • +

    You can install caddy by following the steps in Caddy. +We assume that you will use the default Systemd configuration that comes with e.g. installing Caddy via apt. +Also, we assume that the host you are running Caddy on has a valid DNS entry and is reachable from the internet.

    +
  • +
  • +

    Verify the installation with

    +
  • +
+
+
+
+
$ systemctl status caddy
+● caddy.service - Caddy
+   Loaded: loaded (/lib/systemd/system/caddy.service; enabled; vendor preset: enabled)
+   Active: active (running) since Wed 2022-04-27 23:17:14 CEST; 2 weeks 5 days ago
+     Docs: https://caddyserver.com/docs/
+ Main PID: 3541 (caddy)
+      CPU: 8min 36.550s
+   CGroup: /system.slice/caddy.service
+           └─3541 /usr/bin/caddy run --environ --config /etc/caddy/Caddyfile
+
+
+
+
    +
  • +

    You can stop, start or restart Caddy with

    +
  • +
+
+
+
+
$ systemctl stop caddy
+
+$ systemctl start caddy
+
+$ systemctl restart caddy
+
+
+
+
    +
  • +

    Edit the Caddyfile under /etc/caddy/Caddyfile and paste the following (and adjust it to your own needs):

    +
  • +
+
+
+
+
example.com
+
+handle_path "/inception" {
+    reverse_proxy 127.0.0.1:8080
+}
+
+
+
+

After you restart the Caddy service, you now have a running reverse proxy with automatic HTTPS certificates!

+
+
+
+
+
+

Running via Docker

+
+
+

Quick start

+
+

If you have Docker installed, you can run INCEpTION using

+
+
+
+
$ docker run -it --name inception -p8080:8080 ghcr.io/inception-project/inception:29.3
+
+
+
+

The command downloads INCEpTION from GitHub and starts it on port 8080. If this port is not +available on your machine, you should provide another port to the -p parameter.

+
+
+

The logs will be printed to the console. To stop the container, press CTRL-C.

+
+
+

To run the INCEpTION docker in the background use

+
+
+
+
$ docker run -d --name inception -p8080:8080 ghcr.io/inception-project/inception:29.3
+
+
+
+

Logs are accessible by typing

+
+
+
+
$ docker logs inception
+
+
+
+ + + + + +
+ + +Use docker run only the first time that you run INCEpTION. If you try it a second time, Docker + will complain about the name inception already being in use. If you follow Docker`s suggestion + to delete the container, you will loose all your INCEpTION data. Further below, we explain how + you can store your data outside the container in a folder on your host. +
+
+
+

When you want to run INCEpTION again later, use the command

+
+
+
+
$ docker start -ai inception
+
+
+
+

or for the background mode

+
+
+
+
$ docker start inception
+
+
+
+
+

Storing data on the host

+
+

If you follow the quick start instructions above, INCEpTION will store all its data inside the docker +container. This is normally not what you want because as soon as you delete the container, all data +is gone. That means for example that you cannot easily upgrade to a new version of the INCEpTION +docker image when one is released.

+
+
+

To store your data on your host computer, first create a folder where you want to store your data. +For example, if you are on Linux, you could create a folder /srv/inception:

+
+
+
+
$ mkdir /srv/inception
+
+
+
+

When you run INCEpTION via Docker, you then mount this folder into the container:

+
+
+
+
$ docker run -it --name inception -v /srv/inception:/export -p8080:8080 ghcr.io/inception-project/inception:29.3
+
+
+
+
+

Settings file

+
+

The dockerized INCEpTION expects the settings.properties file in the /export folder. Instead of +injecting a custom settings.properties file into the container, it is strongly recommender to +use the instructions above (Storing data on the host) to mount a folder from the host system to +/export then to place the into the mounted folder settings.properties. Thus, if you follow +the instructions above, the settings file would go to /srv/inception/settings.properties on the host +system.

+
+
+
+

Connecting to a dedicated database

+
+

By default, INCEpTION uses an embedded SQL database to store its metadata (not the texts, +annotations and knowledge bases, these are stored in files on disk). For production use, it is highly +recommended to use a dedicated database server (i.e. MariaDB or compatible) instead of the embedded +SQL database.

+
+
+
+

Docker Compose

+
+

Using Docker Compose, you can manage multiple related containers. This section illustrates how to use +Docker Compose to jointly set up a INCEpTION container as well as a database container (i.e. +this one).

+
+
+

The following Compose script sets these containers up.

+
+
+
Docker Compose script
+
+
##
+# docker-compose up [-d]
+# docker-compose down
+##
+version: '2.4'
+
+networks:
+  inception-net:
+
+services:
+  db:
+    image: "mariadb:10.7"
+    environment:
+      - MYSQL_RANDOM_ROOT_PASSWORD=yes
+      - MYSQL_DATABASE=inception
+      - MYSQL_USER=${DBUSER:-inception}
+      - MYSQL_PORT=3306
+      - MYSQL_PASSWORD=${DBPASSWORD:-inception}
+    volumes:
+      - ${INCEPTION_DB_HOME:-db-data}:/var/lib/mysql
+    command: ["--character-set-server=utf8mb4", "--collation-server=utf8mb4_bin"]
+    healthcheck:
+      test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost", "-p${DBPASSWORD:-inception}", "-u${DBUSER:-inception}"]
+      interval: 20s
+      timeout: 10s
+      retries: 10
+    networks:
+      inception-net:
+
+  app:
+    image: "${INCEPTION_IMAGE:-ghcr.io/inception-project/inception}:${INCEPTION_VERSION:-29.3}"
+    ports:
+      - "${INCEPTION_PORT:-8080}:8080"
+    environment:
+      - INCEPTION_DB_DIALECT=org.hibernate.dialect.MariaDB103Dialect 
+      - INCEPTION_DB_DRIVER=org.mariadb.jdbc.Driver
+      - INCEPTION_DB_URL=jdbc:mariadb://db:3306/inception?useSSL=false&useUnicode=true&characterEncoding=UTF-8
+      - INCEPTION_DB_USERNAME=${DBUSER:-inception}
+      - INCEPTION_DB_PASSWORD=${DBPASSWORD:-inception}
+      - JAVA_OPTS=-Dspring.jpa.properties.hibernate.dialect.storage_engine=innodb
+    volumes:
+      - ${INCEPTION_HOME:-app-data}:/export
+    depends_on:
+      db:
+        condition: service_healthy
+    restart: unless-stopped
+    networks:
+      inception-net:
+      
+volumes:
+  app-data:
+  db-data:
+
+
+
+

Place the script into any folder, change to that folder, and issue the following command to start +the containers.

+
+
+
+
$ docker-compose -p inception up -d
+
+
+
+

This will start two docker containers: inception_db_1, and inception_app_1. +You can check the logs of each by running

+
+
+
+
$ docker logs inception_db_1
+$ docker logs inception_app_1
+
+
+
+

The actual name of these containers might vary. A list of running containers can be retrieved by

+
+
+
+
$ docker ps
+
+
+
+

The data of the containers will be stored in Docker volumes. If you shut the containers down and +start them again later, the data will still be there - try it out!

+
+
+
+
$ docker-compose -p inception down
+
+
+
+

You can list the Docker volumes on your system using

+
+
+
+
$ docker volume ls
+
+
+
+

If you want to provide a custom settings.properties file, you can also choose to mount the data volume +to your hosts file system instead of to a Docker volume by setting the INCEPTION_HOME environment +variable to the path you want to store your data in and where you will also put the settings.properties +file. You can also choose to override the default location for the database data by setting the +INCEPTION_DB_HOME environment variable.

+
+
+
+
$ export INCEPTION_HOME=/srv/inception/app-data
+$ export INCEPTION_DB_HOME=/srv/inception/db-data
+$ docker-compose -f docker-compose.yml -p inception up
+
+
+
+

If you are running Docker on Linux, the data of the volumes should end up on the file system anyway +in a special folder used by Docker. You can figure out which folder that is using +docker volume inspect …​. However, if you are running Docker on macOS or Windows, the data is likely to +live in a special virtual machine that is owned by Docker and it will not be easily accessible unless +you mount the data to folders on your host.

+
+
+ + + + + +
+ + +Mind that you cannot arbitrarily switch between volume-managed and host-stored data. Choose wisely. +
+
+
+

Java options

+
+

You can pass additional options to the Java runtime by extending the JAVA_OPTS variable in the +Docker Compose script. To increase the available memory (RAM) to e.g. 4Gb, append -Xmx4g.

+
+
+
+
- JAVA_OPTS=-Dspring.jpa.properties.hibernate.dialect.storage_engine=innodb -Xmx4g
+
+
+
+

There is a lot more that you can do using Docker and Docker Compose. Please see the docker-compose reference for details.

+
+
+
+
+
+
+

Unsupervised installation

+
+
+

To perform an unsupervised installations of INCEpTION, you can:

+
+
+
    +
  • +

    set a custom password for the default admin account

    +
  • +
  • +

    create the admin account with the ROLE_REMOTE

    +
  • +
  • +

    enable/disable telemetry support to avoid the admin being asked on the first login

    +
  • +
+
+
+
Custom default admin user/password
+

To set a custom default admin user name and password, add the following line to the settings.properties +file. If no custom user name is set, the default admin is used.:

+
+
+
+
security.default-admin-username=mastermind
+security.default-admin-password={bcrypt}XXXXXX
+
+
+
+

To obtain an encrypted password, you can use tools such as the +online bcrypt generator. Replace the XXXXXX in the example +above with the output from the tool - keep the {bcrypt} prefix!

+
+
+

You could also create a user in INCEpTION, set the password you desire, and then look at the +database table users (easiest if you are using MariaDB or MySQL).

+
+
+
Enable remote API access for the admin user
+

If you want your installation to be remotely manageable directly from the outset using the admin +account, you can add the following line:

+
+
+
+
security.default-admin-remote-access=true
+
+
+
+

Mind that the remote API still needs to be enabled separately.

+
+
+
Enable/disable telemetry
+

You can use either of the following two lines to enable or disable telemetry submission and avoid +the admin user being asked about telemetry submission on the first login.

+
+
+
+
telemetry.auto-respond=ACCEPT
+telemetry.auto-respond=REJECT
+
+
+
+
+
+

Logging

+
+
+
+

INCEpTION comes with a default logging configuration that should serve well in a normal +production environment, either on a server or running as a desktop application. However, for +more advanced scenarios, it may be useful to customize the logging configuration.

+
+
+
+
+

Set specific log levels

+
+
+

Maybe you do not want to user a completely custom logging configuration and only wish to get a bit +more information in a particular part of the application. In this case, you can specify the log +level for particular packages or classes either by declaring logging properties either as system +property (-D) argument when starting INCEpTION or by adding them to the settings.properties +file. For example, if you wanted to get more information on the authentication process, you could +use the following properties:

+
+
+
+
logging.level.org.springframework.security=TRACE
+logging.level.de.tudarmstadt.ukp.inception.security=TRACE
+
+
+
+
+
+

Custom logging

+
+
+

A custom logging configuration can be specified when starting up INCEpTION using the parameter +-Dlogging.config=/path/to/your/log4.xml. This should be a standard Log4J2 configuration file. +A good starting point is the default configuration used by INCEpTION which can be found in our code repository.

+
+
+
+
+

Logging in JSON format

+
+
+

If you would like to integrate the logging output of INCEpTION with something like LogStash and +Kibana, you may want log output to be in a properly interpretable JSON format, instead of the usual +plain text format. INCEpTION comes with several JSON configurations that are compatible with +popular tools like LogStash and others. You can activate it by adding the following sections to a custom log4j2.xml file in the Appenders sections and in the Root logger.

+
+
+
+
<Configuration ...>
+  <!-- ... -->
+
+  <Appenders>
+    <!-- ... -->
+
+    <RollingFile name="RollingFileAppender" fileName = "logs/inception.log"
+                 filePattern="app-%d{MM-dd-yy-HH-mm-ss}-%i.log.gz">
+        <JsonTemplateLayout eventTemplateUri="classpath:LogstashJsonEventLayoutV1.json"/>
+      <Policies>
+        <SizeBasedTriggeringPolicy size = "20 MB" />
+      </Policies>
+    </RollingFile>
+
+    <!-- ... -->
+  </Appenders>
+
+  <Loggers>
+    <!-- ... -->
+
+    <Root level="warn">
+      <!-- ... -->
+
+      <AppenderRef ref="RollingFileAppender" />
+    </Root>
+  </Loggers></Configuration>
+
+
+
+

The following bundled default configurations that are part of the log4j-layout-template-json library +are available in INCEpTION:

+
+
+
    +
  • +

    EcsLayout.json

    +
  • +
  • +

    GcpLayout.json

    +
  • +
  • +

    GelfLayout.json

    +
  • +
  • +

    JsonLayout.json

    +
  • +
  • +

    LogstashJsonEventLayoutV1.json

    +
  • +
  • +

    StackTraceElementLayout.json

    +
  • +
+
+
+
+
+

Monitoring

+
+

Available metrics

+
+
+

We expose some metrics of the running INCEpTION instance via JMX. These are currently

+
+
+
    +
  • +

    the number of active as well as enabled users

    +
  • +
  • +

    the overall number of documents

    +
  • +
  • +

    the number of enabled recommenders

    +
  • +
  • +

    the number of annotation documents i.e. documents being annotated per user

    +
  • +
+
+
+

To make the metrics available spring.jmx.enabled=true +and monitoring.metrics.enabled=true +must be set in the settings.properties file +(see Application home folder on this file).

+
+
+
+
+

Setting up metrics exporter

+
+
+

To export the metrics so they can be queried by the monitoring solution Prometheus, +you can e.g. use the JMX exporter as a java agent.

+
+
+

The JMX exporter can be run as a .jar file that should be placed together with its config.yml +file next to the INCEpTION .jar file. An example config.yml file that exposes metrics from +INCEpTION but not webanno brat metrics (metrics associated with brat rendering) and conforms JMX metric +names to Prometheus Naming conventions is:

+
+
+
+
ssl: false
+whitelistObjectNames: ["de.tudarmstadt.ukp.inception.recommendation.metrics:*",
+"de.tudarmstadt.ukp.clarin.webanno.api.dao.metrics:*", "de.tudarmstadt.ukp.clarin.webanno.security.metrics:*"]
+blacklistObjectNames: ["de.tudarmstadt.ukp.clarin.webanno.brat.metrics:*"]
+lowercaseOutputName: true
+lowercaseOutputLabelNames: true
+rules:
+  - pattern: 'de.tudarmstadt.ukp.inception.recommendation.metrics<name=recommendationMetricsImpl, type=RecommendationMetricsImpl><>(\w+): (\d+)'
+    name: inception_$1
+    value: $2
+    help: "Inception metric $1"
+    type: GAUGE
+    attrNameSnakeCase: true
+
+  - pattern: 'de.tudarmstadt.ukp.clarin.webanno.([\.\w]+).metrics<name=(\w+), type=(\w+)><>(\w+): (\d+)'
+    name: webanno_$4
+    value: $5
+    help: "Inception metric $4"
+    type: GAUGE
+    attrNameSnakeCase: true
+
+
+
+

The following line will run the JMX exporter for the JVM that runs the inception.jar. +The exporter will expose the metrics on the http-endpoint localhost:9404. +Make sure to use a port, 9404 in this case, that is not open to the public +(only to the local network that your Prometheus instance runs in).

+
+
+
+
java -javaagent:./jmx_prometheus_javaagent-0.13.0.jar=9404:config.yaml -jar inception.jar
+
+
+
+

The JMX exporter will also automatically expose JVM metrics in the java.lang namespace +which can be used to e.g. monitor memory usage:

+
+
+
    +
  • +

    jvm_memory_bytes_used: Used bytes of a given JVM memory area.

    +
  • +
  • +

    jvm_memory_bytes_committed: Committed (bytes) of a given JVM memory area. This means (opposed to max memory) +that this memory is available to the JVM.

    +
  • +
+
+
+

and others.

+
+
+
+
+

Sentry

+
+
+

In order to use Sentry as an error tracker, you will need to provide the Sentry SDK your Sentry project’s Data Source Name (DSN) and other settings in INCEpTION’s settings.properties file. The Sentry SDK will be deactivated unless a DSN is provided.

+
+ ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
SettingDescriptionDefaultExample(s)

sentry.dsn

The DSN tells the Sentry SDK where to send events.

null

https://examplePublicKey@o0.ingest.sentry.io/0 https://examplePublicKey@sentry.your-org.com/N

sentry.environment

Set the application environment that will be sent with each event.

production

prod

sentry.enable-tracing

Enable transaction tracing used for performance monitoring.

false

true

sentry.traces-sample-rate

Adjust the procentage of transaction sent to Sentry.

1.0

0.2

sentry.send-default-pii

By default, the Sentry SDK do not purposefully send Personally Identifiable Information (PII) to your Sentry server.

off

on

+
+

By default, only unhandled exceptions are sent to Sentry. This behavior can be tuned through configuring the sentry.exception-resolver-order property. For example, setting it to -2147483647 (the value of org.springframework.core.Ordered#HIGHEST_PRECEDENCE) ensures exceptions that have been handled by exception resolvers with higher order are sent to Sentry - including ones handled by @ExceptionHandler annotated methods.

+
+
+

More option that can be overwritten are listed in the official Sentry SDK ducumentation.

+
+
+
+
+

Scheduling

+
+
+

The default schedule for pulling of Prometheus is 10s, however it is necessary to make this a longer +interval to avoid overwhelming your INCEpTION instance with requests for metrics. +You will need to do this in your Prometheus config file.

+
+
+
+
+

Upgrading

+
+

Upgrade paths

+
+
+

There are in principle three ways to upgrade INCEpTION to a new version:

+
+
+
    +
  • +

    In-place update - in this scenario, you simply stop the application, replace the existing +INCEpTION JAR file with the new version, and then start the application again. The benefit +of this approach is, that is is very fast. The downside is, that in case anything goes wrong, you +cannot simply go back to using the old version. You need to make sure that you have a proper +backup of the application home folder and the database (if you use an external database) because +the in-place update might migrate your data and after you might no longer be able to use it with +an older version (e.g. if you replace the JAR again with an older version). The steps for +performing an in-place upgrade are specifed in the respective section below.

    +
  • +
  • +

    Migrating to a fresh installation - in this scenario, you would set up a fresh installation +of the new INCEpTION version using a different application home folder and a different database +than your existing installation. After that, you would move the data of the old installation over +to the new installation, e.g. by copying the contents of the old application home/database over +into the new ones. When you start the fresh installation then, it will find the data you just +copied over, automatically perform a database migration if there were any changes in the database +schema, and then start up. The benefit of this approach is that in case anything does wrong during +the upgrade or in case there is a critical problem with the new version, you can always go back +to using the old installation and e.g. retry the update again at a later time. The steps for +setting up a new instance are specified in the installation instructions. The steps for copying +the data over to the new instance are the same as for performing a backup.

    +
  • +
  • +

    Copying projects to a fresh installation - in this scenario, you would export all projects +from your existing installation. Then you would set up a new installation using a fresh +application home folder/database. Finally, you would import all the exported projects into this +new installation. The only situation where this type of upgrade procedure is necessary is, when +you want to change the database backend, e.g. if you want to switch from an embedded database to +an external database. Otherwise, there is typically no benefit in following this approach. +It would only be necessary if a new INCEpTION release would completely break its database +schema and not offer an automatic migration. This typically does never happen since INCEpTION +has support for automatic database migrations these days. Also note that none of the user’s +passwords are migrated in this way. When you import the projects in the new installation, you need +to enable the import missing users option and after all projects have been imported, you need +to go through each of the users, enable them, set their roles and set a new password for them. +Or alternatively, you could copy the contents of the database tables users and authorities +from the old database into the new one.

    +
  • +
+
+
+

The release notes generally indicate that it is possible to perform an in-place upgrade of the +application. However, before doing an upgrade, it is recommended to create a backup of the +application and data to allow coming back to a working system if case of a problem during the +upgrade. Mind that the upgrade is only completed once the new version has successfully started +because during startup, the application may make changes to the database schema or to the data on +disk.

+
+
+

Also, for certain versions there might be special considerations to be aware of when performing the +upgrade. Always be sure to check the section below as well as the release notes of every version +between the version you are upgrading from up to and including the version you are upgrading to.

+
+
+
+
+

Backup your data

+
+
+
    +
  • +

    Make a copy of your INCEpTION application home folder

    +
  • +
  • +

    If you are using an external database like MariaDB, make a backup of your INCEpTION database, +e.g. using the mysqldump command.

    +
  • +
+
+
+ + + + + +
+ + +Make sure that you can actually re-create a working installation by restoring your backup. + I.e. restore your database export into a fresh database and point a new INCEpTION installation + at using your home folder copy and the restored database and then start the application and check + that everything is there and working. A backup which cannot be successfully restored is worthless. +
+
+
+
+
+

Performing an in-place upgrade

+
+
+
    +
  • +

    Stop the INCEpTION service

    +
  • +
  • +

    Replace the inception.jar file with the new version

    +
  • +
  • +

    Ensure that the file has the right owner/group (usually www-data)

    +
  • +
  • +

    Start the INCEpTION service again

    +
  • +
+
+
+
+
+

Upgrade notes

+
+
+

This section summarizes important upgrade notes from the release history of INCEpTION. If you upgrade from any version X, carefully read all the upgrade notes for versions later than X. In particular, if any of the upgrade notes mentions that an intermediate upgrade to that version must be made before going to a higher version, then first perform all required intermediate upgrades in order.

+
+
+ + + + + +
+ + +It is a good idea to back up your installation and data before an upgrade. Also make sure that + you can actually re-create a working installation by restoring your backup. A backup which cannot be + successfully restored is worthless. +
+
+
+

INCEpTION 25.0

+
+

Manual intervention for external pre-authentication users

+
+

If you use the external pre-authentication feature of INCEpTION (i.e. if you run it behind an +authenticating reverse proxy), you need to perform a manual maintenance step. As of this version, +all users that are created via external pre-authentication are added to the realm preauth. Any +existing users that were created via pre-authentication need to be moved to this realm manually, +otherwise they will not be able to log in anymore.

+
+
+

This migration can be performed by invoking INCEpTION from the command line as:

+
+
+
+
java -jar inception-app-webapp-29.3-standalone.jar users migrate-preauthenticated-users --dry-run
+
+
+
+

This command only works if INCEpTION is configured for external pre-authentication. If you keep +the settings.properties file in a non-standard location, you need to specify the the respective +path using -Dinception.home=/PATH/TO/FOLDER_CONTAINING_SETTINGS_PROPERTIES before the -jar in the +command.

+
+
+

The command will migrate all users that have no password (i.e. the password in the database is +null or an empty encrypted password was stored) and which do also not have ROLE_REMOTE. A user +with no password cannot log in via the login form. The remote API does not support external +pre-authentication and always uses the database for authentication. So if the user either has a +password or ROLE_REMOTE, it will not be migrated.

+
+
+

The command as shown above will operate in dry-run mode and will only print the results of the +migration without actually performing it. You should look at the results to see if you are ok with +them. Then, remove the --dry-run argument and run the command again to actually perform the +migration.

+
+
+

The alternative to using this command is to directly update the respective user records in the +users table in the database by setting the realm of all externally pre-authenticated users to +preauth.

+
+
+
+

Configuration property names changed

+
+

The following configuration property names from the settings.properties file have changed. When you +start INCEpTION, warnings will be logged if the old names are used until you rename the +respective properties in your settings.properties file. In a future version, the old names will +not be supported anymore and the warnings will be removed.

+
+ +++++ + + + + + + + + + + + + + + + + + + + +
Old nameNew nameDescription

login.message

security.login.message

Custom message to appear on the login page.

login.max-concurrent-sessions

security.login.max-concurrent-sessions

Maximum number of concurrently logged-in users.

+
+
+
+

INCEpTION 24.0

+
+

PDF editor

+
+

This version includes a new PDF editor and a new PDF format. The old PDF editor and PDF format +still exist, but have been renamed to PDF (legacy). When starting new projects, these old formats +should no longer be used as they have known and unfixable bugs. The new PDF format that is simply +called PDF is much more robust.

+
+
+
+

Compression

+
+

This version has the ability to compress CAS files on disk. This feature is turned on by default. +If you experience problems and have the feeling that they might be caused by the compression feature, +you can turn it off by adding cas-storage.compressed-cas-serialization=false to the settings.properties. +The compression typically reduces the size of the CAS file down to around 60% of its actual size.

+
+
+

The compression algorithm being used is Snappy. +On many platforms, a native implementation is used automatically. If no native implementation is +available, a pure-java implementation is used. Due to the reduced size, saving a CAS will take +consume less I/O bandwidth which typically the overall time required to persist a CAS to storage +despite the additional overhead of compression.

+
+
+

The compression setting takes effect whenever a CAS is written to disk. Changing it does not +immediately (de)compress existing CAS files. Instead, they will be slowly converted to being +(de)compressed over time as they are updated by the system as part of normal operations.

+
+
+

Decompressing CAS files is supported starting with INCEpTION 23.9. If you have compressed +CAS files, you cannot downgrade to an older version than 23.9. Also, you cannot import projects +containing compressed CAS files into versions older than 23.9.

+
+
+
+

Full-text indices

+
+

This version includes a new version of Apache Lucene which is used for maintaining the full text +indices used for searching in knowledge bases and also used by the annotation search sidebar.

+
+
+

The indices of the knowledge bases should continue to work normally after the upgrade. If you +encounter problems, you can manually trigger an index rebuild by selecting the knowledge base +in the project settings and using the Rebuild index button. Note that rebuilding full text +indices only works for local knowledge bases.

+
+
+

The indices used by the annotation search sidebar will not function until they are rebuilt. The +system will automatically trigger the rebuild process when the annotation page is used. However, +in particular for large projects, rebuilding the indices can take very long.

+
+
+

For installations with many or large projects, it is recommended to perform an offline index rebuild. +First ensure that INCEpTION is not running. Then run INCEpTION from the command line as follows:

+
+
+
+
$ java -jar inception-app-webapp-24.0-standalone.jar search reindex
+
+
+
+

This command will rebuild the annotation search indices of all projects which depending on the +number of projects and their size can add up to several hours (although for most people, it +should be pretty fast). When the process is complete, you can restart INCEpTION as usual. Do not try +to start INCEpTION while the process is still running.

+
+
+
+
+

INCEpTION 22.0

+
+

This version brings a new project export page which uses WebSocket. If INCEpTION is deployed behind a reverse proxy, this technical changes requires updating the reverse proxy configuration. The admin guide includes an updated section on deploying behind nginx and Apache HTTPD reverse proxies. Additionally, the CSRF settings in the INCEpTION settings.properties file need to be updated. The required settings are also described in the admin guide in the section for deploying behind a reverse proxy.

+
+
+

If you have trouble reconfiguring your reverse proxy for WebSocket, it is still possible to switch back to the old export page by adding the following line to the settings.properties file:

+
+
+
+
dashboard.legacy-export=true
+
+
+
+ + + + + +
+ + +The setting to switch back to the old export page will be removed in later versions. Also, INCEpTION will make more use of the WebSocket protocol in the future. If you have trouble updating your reverse proxy configuration to support WebSocket, please let us know. +
+
+
+
+

INCEpTION 21.0.1

+
+

If you are using MySQL or MariaDB, please ensure that default row format is set to dynamic, otherwise, you may get an error like this during upgrade:

+
+
+
+
Error creating bean with name 'liquibase' defined in class path resource
+[org/springframework/boot/autoconfigure/liquibase/LiquibaseAutoConfiguration$LiquibaseConfiguration.class]:
+Invocation of init method failed; nested exception is liquibase.exception.LiquibaseException:
+liquibase.exception.MigrationFailedException:
+Migration failed for change set de/tudarmstadt/ukp/inception/preferences/model/db-changelog.xml::20210925-1::INCEpTION Team:
+Reason: liquibase.exception.DatabaseException: (conn=242839) Index column size too large. The maximum column size is 767 bytes.
+[Failed SQL: (1709) ALTER TABLE `inception-testing`.default_project_preference ADD CONSTRAINT UK_default_project_preference_name_project UNIQUE (project, name)]
+
+
+
+

To set the default row format, you can add these settings to your MySQL/MariaDB config file and then restart the database:

+
+
+
+
innodb_strict_mode=1
+innodb_default_row_format='dynamic'
+
+
+
+

If you upgrade from a version older than 20.0, please check the update notes for INCEpTION 20.0.

+
+
+
+

INCEpTION 20.0

+
+
    +
  • +

    🎉 New versioning. INCEpTION has come a long way and the time has come to reflect that in the version. So as of this release, we are dropping the the zero from the version!

    +
  • +
  • +

    ⚠️ Database driver changed. The MySQL driver is no longer bundled, only the MariaDB driver is shipped. If you have manually configured a DB driver and dialect in the settings.properties, comment them out. In the JDBC connection string replace mysql with mariadb. The MariaDB driver should also work with a MySQL database. If you use Docker Compose, make sure to remove the INCEPTION_DB_DIALECT and INCEPTION_DB_DRIVER and update the INCEPTION_DB_URL to start with jdbc:mariadb: instead of jdbc:mysql:. For additional details, please check the section on MariaDB configuration in the admin guide.

    +
  • +
  • +

    ⚠️ Increased disk usage. Internal backup for CAS (annotation) files enabled to keep 2 backups with min 24h in between - this change increases disk usage! If you operate with low disk space, consider disabling the internal backup.

    +
  • +
+
+
+
+

INCEpTION 0.16.0

+
+

For deployments using AJP and Apache Webserver 2.5 or higher: to use the advanced AJP secret, see the updated section on running INCEpTION behind a reverse proxy in the admin guide.. +For deployments using AJP and Apache Webserver 2.4 or lower: you need to disable the AJP secret by setting server.ajp.port (replaces tomcat.ajp.port) and server.ajp.address properties as described in the admin guide and also set server.ajp.secret-required=false.

+
+
+
+

INCEpTION 0.15.2

+
+

For deployments via WAR-file on Apache Tomcat, Apache Tomcat 9.0. is now necessary. Note that we do not recommend a WAR deployment and do not distribute a pre-built WAR file.

+
+
+
+

INCEpTION 0.12.0

+
+

If you are running INCEpTION behind a reverse proxy and have so far had a line like server.contextPath=/XXX in your settings.properties file, please replace it with server.servlet.context-path=/XXX.

+
+
+
+
+
+

Remote API

+
+
+
+
+
+ + + + + +
+ + +To use this functionality, you need to enable it first by adding remote-api.enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

In order to programmatically manage annotation project, a REST-like remote API is offered. This API +is disabled by default. In order to enable it, add the setting remote-api.enabled=true to the +settings.properties file.

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 4. Remote API settings
SettingDescriptionDefaultExample

remote-api.enabled

Enable remote API

false

true

remote-api.http-basic.enabled

Enable HTTP basic authentication

true

false

remote-api.oauth2.enabled

Enable HTTP basic authentication

false

true

remote-api.oauth2.realm

Client ID used by the OAuth2 IdP (mandatory if OAuth2 is enabled)

none

inception-client

remote-api.oauth2.user-name-attribute

Claim containing the username

sub

preferred_username

+
+

Once the remote API is enabled, it becomes possible to assign the role ROLE_REMOTE to a user. Create a new user, e.g. remote-api via the user management page and assign at least the roles ROLE_USER and ROLE_REMOTE. Most of the actions accessible through the remote API require administrator access, so adding the ROLE_ADMIN is usually necessary as well.

+
+
+

Once the remote API has been enabled, it offers a convenient and self-explanatory web-based user interface under <APPLICATION_URL>/swagger-ui.html which can be accessed by any user with the role ROLE_REMOTE. Here, you can browse the different operations, their parameters, and even try them out directly via a web browser. The actual AERO remote API uses <APPLICATION_URL/api/aero/v1 as the +base URL for its operations.

+
+ +
+

The third-party Python library pycaprio can be used +to facilitate accessing the remote API.

+
+
+
+
+

OAuth2 authentication

+
+
+

The remote API can be used using OAuth2 authentication. A client is expected to obtain a JWT token +from an OAuth2 endpoint. INCEpTION will verify that token using the public key of the OAuth2 +endpoint and if the token is valid, access is granted. It is required that the user associated with +then token has been created before in INCEpTION. Contrary to OAuth2 logins to the web interface, +logins to the remote API do not automatically create users.

+
+
+

Let’s consider you are using Keycloak as the OAuth2 provider. First, you would set up a realm in +Keycloak as described in OAuth2 authentication. Assuming you followed the example, +you would now open the inception-client client in the clients panel of the inception-demo +realm. There, you have to enable the Service Accounts toggle and save.

+
+
+

In the settings.properties file, you need to add the following settings to enable OAuth2 login to +the remote API:

+
+
+
+
remote-api.oauth2.enabled=true
+remote-api.oauth2.realm=inception-demo
+remote-api.oauth2.user-name-attribute=preferred_username
+spring.security.oauth2.resourceserver.jwt.issuer-uri=http://localhost:8180/realms/inception-demo
+
+
+
+

Note that you must also have configured OAuth2 authentication for logins to the web interface, +otherwise the next step of creating a user will not be possible.

+
+
+

Enabling the Service Accounts option in Keycloak will allow obtaining a JWT token using a +client ID and client credentials. You can find these credentials in the Credentials tab of the +inception-client client in Keycloak. The preferred username of this service user is automatically +set to inception-client-service-user by Keycloak.

+
+
+

Finally, to allow the inception-client-service-user to use the remote API, you need to create that +user in INCEpTION. Go to the user management section in INCEpTION and create a user named +inception-client-service-user. Assign at least the roles ROLE_REMOTE and ROLE_USER to the new user +and set the realm to external:inception-client.

+
+
+ + + + + +
+ + +Pycaprio does currently not support OAuth2 + authentication - only HTTP basic authentication. +
+
+
+
+
+

Webhooks

+
+
+

Webhooks allow INCEpTION to notify external services about certain events. For example, an +external service can be triggered when an annotator marks a document as finished or when all +documents in a project have been completely curated.

+
+
+

Webhooks are declared in the settings.properties file. For every webhook, it is necessary to +specify an URL (url) and a set of topics (topics) about with the remote service listening at the +given URL is notified. If the remote service is accessible via https and the certificate is not +known to the JVM running INCEpTION, the certificate verification can be disabled +(verify-certificates).

+
+
+

The following topics are supported:

+
+
+
    +
  • +

    DOCUMENT_STATE - events related to the change of a document state such as when any user starts +annotating or curating the document.

    +
  • +
  • +

    ANNOTATION_STATE - events related to the change of an annotation state such as when a user +starts or completes the annotation of a document.

    +
  • +
  • +

    PROJECT_STATE - events related to the change of an entire project such as when all documents +have been curated.

    +
  • +
+
+
+
Example webhook configuration
+
+
webhooks.globalHooks[0].url=http://localhost:3333/
+webhooks.globalHooks[0].topics[0]=DOCUMENT_STATE
+webhooks.globalHooks[0].topics[1]=ANNOTATION_STATE
+webhooks.globalHooks[0].topics[2]=PROJECT_STATE
+webhooks.globalHooks[0].verify-certificates=false
+
+
+
+ + + + + +
+ + +You can test receiving WebHooks e.g. using pyserv or netcat. +
+
+
+

Authentication headers

+
+

If the recipient of the webhook requires an authentication header, you can configure the header and +its value.

+
+
+
+
webhooks.globalHooks[0].auth-header=Bearer
+webhooks.globalHooks[0].auth-header-value=MY-SECRET-TOKEN
+
+
+
+
+

Retries

+
+

In some cases, the recipient of a webhook notification may be temporarily unavailable. It is possible to retry the delivery of a notification several times before giving up. By default, +only one delivery attempt is made (webhooks.retry-count=0). However, you can configure up to three additional attempts with a delay of up to 5000ms between them.

+
+
+
+
webhooks.retry-count=3
+webhooks.retry-delay=5000
+
+
+
+ + + + + +
+ + +Events being triggered while INCEpTION is being shut down may not trigger any webhook deliveries. +
+
+
+
+

Bulk changes

+
+

When performing bulk changes of annotation states (i.e. via the workload management page), no +individual ANNOTATION_STATE events are generated. The document and project states are re-calculated +after the bulk change and depending on whether the bulk action had any effect on them, +DOCUMENT_STATE and/or PROJECT_STATE events are generated.

+
+
+
+

Message examples

+
+

When a webhook is triggered, it sends a HTTP POST request to the configured URL. The X-AERO-Notification header indicates the topic and the body of the request is a JSON structure providing +details about the state change. The JSON in the examples below have been pretty-printed for your +convenient - the actual messages are not pretty-printed.

+
+
+
Example PROJECT_STATE
+
+
{
+  "timestamp": 1234567890,
+  "projectId": 123,
+  "projectName": "Example project",
+  "projectPreviousState": "CURATION-IN-PROGRESS",
+  "projectState": "ANNOTATION-IN-PROGRESS"
+}
+
+
+
+
Example DOCUMENT_STATE
+
+
{
+  "timestamp": 1234567890,
+  "projectId": 123,
+  "projectName": "Example project",
+  "documentId": 565,
+  "documentName": "document.txt",
+  "documentPreviousState": "CURATION-IN-PROGRESS",
+  "documentState": "ANNOTATION-IN-PROGRESS"
+}
+
+
+
+
Example ANNOTATION_STATE
+
+
{
+  "timestamp": 1234567890,
+  "projectId": 123,
+  "projectName": "Example project",
+  "documentId": 565,
+  "documentName": "document.txt",
+  "user": "annotator1",
+  "annotationUser": "annotator1",
+  "annotationPreviousState": "COMPLETE",
+  "annotationState": "COMPLETE",
+  "annotatorAnnotationState": "IN_PROGRESS",
+  "annotatorComment":"Test comment"
+}
+
+
+
+

In the ANNOTATION_STATE message, we have two fields containing a user name: user and annotationUser. +Usually, these two fields will be the same. They differ if a user changes the state of a document +of another user. An example is when a curator marks the curation of a document as finished. In this +case, the curator’s username is in the field user while the annotationUser field has the value +CURATION_USER.

+
+
+

The effective annotation state can be found in the annotationState field. However, it can be the +case that a manager has overridden the state, e.g. because an annotator forgot to mark a document +as finished. The annotatorAnnotationState field contains the state that was (implicitly) set by the +annotator.

+
+
+

The annotatorComment field contains the comment that annotators can set when closing a document +and is typically used to report a problem with the document. Thus, it can typically be found only +when the annotatorState is COMPLETE (document closed as successful) or LOCKED (document closed +as not successful).

+
+
+
+
+
+

Settings

+
+
+
+

Application settings are managed via a file called settings.properties which must reside in the +application home folder. This file is optional and might need to be created first in the Application home folder. If the file does not exist, default values are assumed.

+
+
+
+
+

General Settings

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 5. General settings
SettingDescriptionDefaultExample

warnings.unsupportedBrowser

Warn about unsupported browser

true

false

security.login.message

Custom message to appear on the login page, such as project web-site, annotation guideline link, …​ The message supports markdown syntax.

unset

<span style="color:red; font-size: 200%;">Use are your own risk.</span>

user.profile.accessible

Whether regular users can access their own profile to change their password and other profile information. This setting has no effect when running in pre-authentication mode.

false

true

user-selection.hideUsers

Whether the list of users show in the users tab of the project settings is restricted. If this setting is enable, the full name of a user has to be entered into the input field before the user can be added. If this setting is disabled, it is possible to see all enabled users and to add any of them to the project.

false

true

commands.open-browser

Execute this command instead of the operating-systems’s default command to open the browser window when running in standalone mode. %u is replaced with the INCEpTION URL.

unset

/usr/bin/open %u -a "/Applications/Google Chrome.app"

plugins.enabled

Whether to enable the ability to install plugins into INCEpTION (experimental).

false

true

ui.error-page.hide-details

Disable display of information about operating system, Java version, etc. on the error page. While this information is useful for local users when reporting bugs, security-conscious administrators running {application-name} as a service may want to enable hiding the details to avoid information about their system being exposed.

false

true

+
+
+
+

Database connection

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 6. Database settings in the settings.properties file
SettingDescriptionDefaultExample

database.url

JDBC connection string

HSQLDB location in application home

jdbc:mariadb://localhost:3306/inception?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC

database.username

Database username

sa

user

database.password

Database password

unset

pass

database.dialect

Database dialect

unset (auto detected)

org.hibernate.dialect.MariaDB53Dialect

database.driver

Database driver

unset (auto detected)

org.mariadb.jdbc.Driver

database.initial-pool-size

Initial database connection pool size

4

database.min-pool-size

Minimum database connection pool size

4

database.max-pool-size

Maximum database connection pool size

10

warnings.embeddedDatabase

Warn about using an embedded database

true

false

+
+

The basic database connection details can also be configured via environment variables. When these +environment variables are present, they are preferred over the settings.properties file. +The following environment variables can be used:

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 7. Database configuration via environment variables
SettingDescriptionDefaultExample

INCEPTION_DB_URL

JDBC connection string

HSQLDB location in application home

jdbc:mariadb://localhost:3306/inception?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC

INCEPTION_DB_USERNAME

Database username

sa

user

INCEPTION_DB_PASSWORD

Database password

unset

pass

INCEPTION_DB_DIALECT

Database dialect

unset (auto detected)

org.hibernate.dialect.MariaDB53Dialect

INCEPTION_DB_DRIVER

Database driver

unset (auto detected)

org.mariadb.jdbc.Driver

+
+
+
+

Server Settings

+
+
+

These settings relate to the embedded web server in the JAR version of INCEpTION.

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 8. Server settings
SettingDescriptionDefaultExample

server.port

Port on which the server listens

8080

18080

server.address

IP address on which the server listens

0.0.0.0

127.0.0.1

server.ajp.port

Port for AJP connector

-1 (disabled)

8009

server.ajp.address

IP address on which the AJP connector listens

127.0.0.1

0.0.0.0

server.ajp.secret-required

Whether AJP connections require a shared secret

true

false

server.ajp.secret

Shared secret for AJP connections

unset

some secret string of your choice

+
+ + + + + +
+ + +The application is based on Spring Boot and using an embedded Tomcat server. You can configure + additional aspects of the embedded web server using default Spring Boot configuration settings. +
+
+
+
+
+

Authentication

+
+
+

This section describes the different authentication mechanisms supported by INCEpTION.

+
+
+ + + + + +
+ + +A user can only log in through one mechanism, either as a local user or an external user. + If you are using SAML/OAuth2, then the users are bound to one particular IdP. If a user with the same + name tries to log in via another mechanism or IdP, the login will be rejected. If you plan to use + multiple login mechanisms or IdPs at the same time, you must ensure that the user IDs are unique + across all the mechanisms and IdPs or that a given user always uses the same login mechanism. +
+
+
+

OAuth2 authentication

+
+

INCEpTION can authenticate a user against a OAuth2/OIDC-compatible identity provider. OAuth2/OIDC providers can be configured alongside the usual form-based login and SAML2. +It is not compatible with the external pre-authentication and does not require setting the auth.mode property.

+
+
+

The following example configuration declares an OAuth2 service connection named inception-client +which uses a Keycloak instance configured for OAuth2 running at +http://localhost:8180/realms/inception-demo. The OAuth2 support of INCEpTION should work with +any OAuth2/OIDC-compatible identity provider. For more details, please +refer to the Spring Security OAuth2 documentation.

+
+
+
Example: Authenticate against a local Keycloak
+
+
spring.security.oauth2.client.registration.inception-client.client-name=Keycloak
+spring.security.oauth2.client.registration.inception-client.client-id=inception-client
+spring.security.oauth2.client.registration.inception-client.client-secret=ENCRYPTED_CLIENT_SECRET
+spring.security.oauth2.client.registration.inception-client.scope=openid, profile
+spring.security.oauth2.client.registration.inception-client.authorization-grant-type=authorization_code
+spring.security.oauth2.client.registration.inception-client.redirect-uri=http://localhost:8080/login/oauth2/code/inception-client
+spring.security.oauth2.client.provider.inception-client.issuer-uri=http://localhost:8180/realms/inception-demo
+spring.security.oauth2.client.provider.inception-client.user-name-attribute=preferred_username
+
+
+
+ + + + + +
+ + +The following instructions run Keycloak in development mode. This is not meant for + production, only for testing. For how to properly set up a production-level Keycloak server, please + refer to the official documentation of Keycloak. +
+
+
+

If you want to try this with a local testing instance of Keycloak, you can do this:

+
+
+
    +
  • +

    Download Keycloak

    +
  • +
  • +

    Run it using ./kc.sh start-dev --http-port 8180

    +
  • +
  • +

    Configure a new realm called inception-demo

    +
  • +
  • +

    Define a new client inception-client and set the Valid redirection URI to http://localhost:8080/login/oauth2/code/inception-client.

    +
  • +
  • +

    Replace the ENCRYPTED_CLIENT_SECRET in the example configuration above with the client secret from +the Credentials tab of the client in Keycloak.

    +
  • +
  • +

    Add a new user in the Manage users area in Keycloak.

    +
  • +
+
+
+

When you restart INCEpTION and access the login page now, it should offer a login option called +Keycloak. You can change the label of that option by changing the +security.oauth2.client.registration.inception-client.client-name setting.

+
+
+
+

SAML authentication

+
+

INCEpTION can authenticate a user against a SAML2-compatible identity provider. SAML +providers can be configured alongside the usual form-based login and OAuth2. +It is not compatible with the external pre-authentication +and does not require setting the auth.mode property.

+
+
+

The following example configuration declares a SAML2 service connection named inception-client +which uses a Keycloak instance configured for SAML2 running at +http://localhost:8180/realms/inception-demo. The SAML support of INCEpTION should work with +any SAML2-compatible identity provider. For more details, please +refer to the Spring Security SAML2 documentation.

+
+
+
Example: Authenticate against a local Keycloak
+
+
spring.security.saml2.relyingparty.registration.inception-client.assertingparty.entity-id=http://localhost:8180/realms/inception-demo
+spring.security.saml2.relyingparty.registration.inception-client.assertingparty.verification.credentials[0].certificate-location=file:/srv/inception/keycloak-saml-idp.crt
+spring.security.saml2.relyingparty.registration.inception-client.assertingparty.singlesignon.url=http://localhost:8180/realms/inception-demo/protocol/saml
+spring.security.saml2.relyingparty.registration.inception-client.assertingparty.singlesignon.sign-request=false
+
+
+
+ + + + + +
+ + +The following instructions run Keycloak in development mode. This is not meant for + production, only for testing. For how to properly set up a production-level Keycloak server, please + refer to the official documentation of Keycloak. +
+
+
+

If you want to try this with a local testing instance of Keycloak, you can do this:

+
+
+ +
+
+

The keycloak-saml-idp.crt file needs to be constructed by you. Once the configuration is complete +in Keycloak, you can access http://localhost:8180/realms/inception-demo/protocol/saml/descriptor to obtain +an XML file which contains the certificate in the ds:X509Certificate element. You need to copy this +certificate string (usually staring with MIIC into a text file with the following structure:

+
+
+
Certificate file structure
+
+
-----BEGIN CERTIFICATE-----
+MIIC...
+-----END CERTIFICATE-----
+
+
+
+

Save this file at the location indicated by the …​.verification.credentials.certificate-location key, +(here /srv/inception/keycloak-saml-idp.crt).

+
+
+

When you restart INCEpTION and access the login page now, it should offer a login option called +inception-client. The SAML authentication does not allow defining the provider name shown on the login page independently from the registration ID. The registration ID (here inception-client) is defined in between the registration +and assertingparty parts of the configuration keys.

+
+
+

Client certificate (optional)

+
+

You can provide INCEpTION with a certificate so the IdP can verify that authentication requests are +really coming from it.

+
+
+
    +
  • +

    First, we generate a certificate and a key file using (we are using a 2048-bit key here, but you might care +to use a longer key)

    +
    +
    +
    openssl req -x509 -newkey rsa:2048 -keyout /srv/inception/inception.key -out /srv/inception/inception.crt -sha256 -days 365 -nodes -subj "/CN=inception-demo"
    +
    +
    +
  • +
  • +

    In order to upload these, both need to be in one PEM file, so we concatenate the two files:

    +
    +
    +
    cat /srv/inception/inception-saml.key /srv/inception/inception-saml.crt > /srv/inception/inception-saml.pem
    +
    +
    +
  • +
  • +

    Open the previously defined client in Keycloak (e.g. http://localhost:8080/saml2/service-provider-metadata/inception-client)

    +
  • +
  • +

    Set Client signature Required to Off and save the settings

    +
  • +
  • +

    Now a new tab Keys should appear at the top. Switch to it.

    +
  • +
  • +

    Click on Import and select PEM as the format, then upload the file /srv/inception/inception.pem

    +
  • +
  • +

    Enable request signing in the settings.properties file

    +
    +
    +
    spring.security.saml2.relyingparty.registration.inception-client.assertingparty.singlesignon.sign-request=true
    +
    +
    +
  • +
  • +

    Configure the certificates for INCEpTION to sign its requests

    +
    +
    +
    spring.security.saml2.relyingparty.registration.inception-client.signing.credentials[0].private-key-location=file:/srv/inception/inception-saml.key
    +spring.security.saml2.relyingparty.registration.inception-client.signing.credentials[0].certificate-location=file:/srv/inception/inception-saml.crt
    +
    +
    +
  • +
+
+
+
+
+

Auto-login

+
+

When configuring the application for SAML/OAuth2, the user will still be required to choose an identity +provider via the login page (and is also given the opportunity to log in via form-based login there).

+
+
+

If you would like to automatically login through a particular SAML identity provider, you +can configure this by setting the security.auto-login property to the registration ID of the +respective provider that you configured using the spring.security.saml2.relyingparty.registration…​. or spring.security.oauth2.client…​ properties.

+
+
+

This setting is useful for single-sign-on scenarios where only a single identity provider is used.

+
+ ++++++ + + + + + + + + + + + + + + + + +
SettingDescriptionDefaultExample

security.login.auto-login

Auto-login using given identity provider

<none>

inception-client (cf. example above)

+
+ + + + + +
+ + +In case it may be necessary to bypass the auto-login, e.g. to allow signing in via credentials, + navigate to …​/login.html?skipAutoLogin=true. Make sure to do this in a fresh browser session that is + not yet logged into the application. +
+
+
+
+

External pre-authentication

+
+

INCEpTION can be used in conjunction with header-based external per-authentication. In this mode, +the application looks for a special HTTP header (by default remote_user) and if that header exists, +it is taken for granted that this user has been authenticated. The application will check its internal +database if a user by the given name exists, otherwise it will create the user.

+
+
+

Pre-authentication can be enabled by setting the property auth.mode to preauth. When enabling +pre-authentication mode, the default roles for new users can be controlled using the +auth.preauth.newuser.roles property. The ROLE_USER is always added, even if not specified +explicitly. Adding also the role ROLE_PROEJCT_CREATOR allows all auto-created users also to +create their own projects.

+
+
+

Since the default administrator user is not created in pre-authentication, it is useful to also +declare at least one user as an administrator. This is done through the property +auth.user.<username>.roles where <username> must be replaced with the name of the user. +The example below shows how the user Franz is given administrator permissions.

+
+
+

In order to log out, one can specify an URL to redirect to after the session is cleared on the side +of INCEpTION.

+
+
+
Example: Authenticate using the remote_user header, new users can create projects, user Franz is always admin.
+
+
auth.mode                     = preauth
+auth.preauth.header.principal = remote_user
+auth.preauth.newuser.roles    = ROLE_PROJECT_CREATOR
+auth.user.Franz.roles         = ROLE_ADMIN
+
+
+
+ + + + + +
+ + +The roles specified through auth.preauth.newuser.roles are saved in the database when a + user logs in for the first time and can be changed after creation through the user interface. +
+
+
+ + + + + +
+ + +The roles added through auth.user.<username>.roles properties are not saved in the + database and cannot be edited through the user interface. +
+
+ ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
SettingDescriptionDefaultExample

auth.mode

Authentication mode

database

preauth

auth.preauth.header.principal

Principal header

remote_user

some other header

auth.preauth.newuser.roles

Default roles for new users (comma separated)

<none>

ROLE_PROJECT_CREATOR

auth.preauth.logoutUrl

URL to call after logging out to also sign out of external authentication

<none>

https://your-idp.com/Shibboleth.sso/Logout

auth.user.<username>.roles

Extra roles for user (comma separated)

<none>

ROLE_ADMIN

+
+
+

Policy

+
+

You have several options of configuring which types of usernames and passwords are accepted. +Note that these values are only enforced when creating new users or updating passwords. They +will not invalidate existing usernames or passwords. Length restrictions and patterns are checked +independently. If either fails, the username or password is rejected.

+
+
+ + + + + +
+ + +When external pre-authentication is used, these settings are ignored. +
+
+
+ + + + + +
+ + +In addition to the restrictions imposed here, INCEpTION may impose additional restrictions. + E.g. certain usernames are not allowed and certain characters are also not allowed to appear in usernames. +
+
+ ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
SettingDescriptionDefaultExample

security.minimum-password-length

Minimum number of characters a password can have

8

(max 128)

security.maximum-password-length

Maximum number of characters a password can have

32

(max 128)

security.minimum-username-length

Minimum number of characters a username can have

4

(max 128)

security.maximum-username-length

Maximum number of characters a username can have

64

(max 128)

security.username-pattern

Regular expression for valid usernames

.*

[a-zA-Z0-9]+

security.password-pattern

Regular expression for valid passwords

.*

(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*\p{Punct}).*

+
+
+
+
+

Internal annotation backup

+
+
+

INCEpTION stores its annotations internally in files. Whenever a user +performs an action on a document, the file is updated. It is possible to configure INCEpTION +to keep internal backups of these files, e.g. to safeguard against certain types of crashes or bugs.

+
+
+ + + + + +
+ + +This internal backup is not a replacement for a proper backup. It affects only the annotation +files - not the project data, knowledge bases, or other kinds of data. Also, the annotation data is +not directly re-usable by INCEpTION without additional information that is contained in the +database! +
+
+
+
Example internal backup
+
+
# Delete annotation backups older than 30 days (60 * 60 * 24 * 30 = 30 days)
+backup.keep.time=2592000
+
+# At least 5 minutes must pass between two annotation backups (60 * 5 = 5 minutes)
+backup.interval=300
+
+# Keep at most 10 backups for each annotation backup
+backup.keep.number=10
+
+
+
+

The internal backups are controlled through three properties:

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 9. Database settings in the settings.properties file
SettingDescriptionDefaultExample

backup.interval

Time between backups (seconds)

172800 (60 * 60 * 24 = 24 hours)

0 (disabled)

backup.keep.number

Maximum number of backups to keep

2

0 (unlimited)

backup.keep.time

Maximum age of backups to keep (seconds)

0 (unlimited)

2592000 (60 * 60 * 24 * 30 = 30 days)

+
+

The interval controls the minimum time between changes to a document that needs to have elapsed in +order for a new backup to be created. Setting the interval to 0 disables the internal backups.

+
+
+

When backups are enabled, either or both of the properties backup.keep.number and +backup.keep.time should be changed as well, because their default values will cause the +backups to be stored indefinitely and they will eventually fill up the disk.

+
+
+

The properties backup.keep.number and backup.keep.time control how long backups are keep +and the maximal number of backups to keep. These settings are effective simultaneously.

+
+
+
Example: Make backups every 5 minutes and keep 10 backups irrespective of age
+
+
backup.interval    = 300
+backup.keep.number = 10
+backup.keep.time   = 0
+
+
+
+
Example: Make backups every 5 minutes and all not older than 7 days (60 * 60 * 24 * 7 seconds)
+
+
backup.interval    = 300
+backup.keep.number = 0
+backup.keep.time   = 604800
+
+
+
+
Example: Make backups every 5 minutes and keep at most 10 backups that are not older than 7 days
+
+
backup.interval    = 300
+backup.keep.number = 10
+backup.keep.time   = 604800
+
+
+
+
+
+

CAS storage

+
+
+

This section describes settings related to the storage of CAS data objects (i.e. annotations).

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + +
Table 10. CAS cache settings in the settings.properties file
SettingDescriptionDefaultExample

cas-storage.compressed-cas-serialization

Whether to compress annotation files

true

false

cas-storage.file-system-timestamp-accuracy

For file systems where timestamps are not exact, this can be used to configure some leniency. This setting should be used with extreme caution. If an editor accesses an annotation file that is out-of-sync with the editor, this can lead to unexpected behavior. However, when deploying INCEpTION e.g. on certain cloud storage facilitites, the file system timestamps may not be exact down to the millisecond, +this it may be helpful to configure a slight leniency here.

0

500ms

+
+

The compression setting takes effect whenever a CAS is written to disk. Changing it does not +immediately (de)compress existing CAS files. Instead, they will be slowly converted to being +(de)compressed over time as they are updated by the system as part of normal operations.

+
+
+

CAS cache

+
+

To speed up interactions, INCEpTION keeps a cache annotation data in memory. +This cache can be tuned using the following properties:

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 11. CAS cache settings in the settings.properties file
SettingDescriptionDefaultExample

cas-storage.cache.shared-cas-cache-size

Number of shared read-only CASes to keep in memory

10-5000 (depending on heap size)

20000

cas-storage.cache.idle-cas-eviction-delay

Periodic interval in which the system should check if CASes can be removed from the memory cache

5m

30s

cas-storage.cache.min-idle-cas-time

Time a CAS should at least remain cached in memory to avoid loading from disk

5m

30s

cas-storage.cache.cas-borrow-wait-timeout

Time for an exclusive action to wait for another exclusive action to finish

3m

5m

+
+
+
+
+

Document Im-/Export

+
+
+

Control the importing and exporting of documents:

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + +
Table 12. Document import/export settings in the settings.properties file
SettingDescriptionDefaultExample

document-import.max-tokens

Token-count limit for imported documents

2000000

0 (no limit)

document-import.max-sentences

Sentence-count limit for imported documents

20000

0 (no limit)

+
+
+
+

Custom header icons

+
+
+

INCEpTION allows adding custom icons to the page header. You can declare such custom icons in the settings.properties file as shown in the example below. Each declaration begins with the prefix style.header.icon. followed by an identifier (here myOrganization and mySupport). The suffixes .linkUrl and .imageUrl indicate the URL of the target page and of the icon image respectively. Images are automatically resized via CSS. However, to keep loading times low, you should point to a reasonably small image.

+
+
+

The order of the icons is controlled by the ID, not by the order in the configuration file!

+
+
+
Example: Custom header icon
+
+
style.header.icon.myOrganization.linkUrl=http://my.org
+style.header.icon.myOrganization.imageUrl=http://my.org/logo.png
+style.header.icon.mySupport.linkUrl=http://my.org/support
+style.header.icon.mySupport.imageUrl=http://my.org/help.png
+
+
+ ++++++ + + + + + + + + + + + + + + + + +
SettingDescriptionDefaultExample

style.header.icon…​

Icons/links to display in the page header. For details, see below.

unset

+
+
+
+

Project dashboard

+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 13. Project dashboard settings in the settings.properties file
SettingDescriptionDefaultExample

ui.dashboard.accessible-by-roles

System roles able to access project dashboards

ANNOTATOR, CURATOR, MANAGER

MANAGER

+
+ + + + + +
+ + +To specify multiple values of the ui.dashboard.accessible-by-roles in a settings.properties + file, multiple lines need to be added like ui.dashboard.accessible-by-roles[0]=ANNOTATOR, + ui.dashboard.accessible-by-roles[1]=CURATOR, etc. +
+
+
+ + + + + +
+ + +Project managers can always access the project dashboard, even if they are not included in the + ui.dashboard.accessible-by-roles setting. +
+
+
+
+
+

Theming

+
+
+

There are two options of theming INCEpTION.

+
+
+

The recommended approach is placing a file named theme.css into the application home folder. If +this file is present, it is automatically loaded on all pages of the application. You can place +custom styles into the file and make them override the default styles.

+
+
+

There is also the option to place a file called bootstrap.css into the application folder. If that +file is present, the built-in customized Bootstrap styles of INCEpTION are not loaded and this +file is loaded instead. For the application to work, the custom bootstrap.css must be fully +compatible with the built-in styles. To create such a file, obtain the scss files from the +inception-bootstrap module for the INCEpTION version that you are using, adjust +them, and use SCSS to compile them from the root bootstrap.scss file into a customized +bootstrap.css file.

+
+
+ + + + + +
+ + +New versions of INCEpTION may come with changes to the CSS styles being used without + any special announcement. If you use theming, be sure to thoroughly review if your custom styles still + work with new versions. Best keep any changes minimal. +
+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 14. Theming settings
SettingDescriptionDefaultExample

ui.dark-mode.enabled

Whether to enable the ability switch between light and dark mode (experimental).

false

true

+
+
+
+

Annotation editor

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 15. Settings related to the brat editor
SettingDescriptionDefaultExample

annotation.default-preferences.auto-scroll

Whether to scroll the annotation being edited into the center of the page

true

annotation.default-preferences.page-size

The number of sentences to display per page

5

ui.brat.single-click-selection

Whether to select annotations with a single click

false

+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 16. Settings related to string features
SettingDescriptionDefaultExample

annotation.feature-support.string.combo-box-threshold

If the tagset is larger than the threshold, an combo-box field is used instead of a radio-choice.

6

16

annotation.feature-support.string.auto-complete-threshold

If the tagset is larger than the threshold, an auto-complete field is used instead of a standard combobox.

75

100

annotation.feature-support.string.auto-complete-max-results

When an auto-complete field is used, this determines the maximum number of items shown in the dropdown menu.

100

1000

+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + +
Table 17. Settings related to link features
SettingDescriptionDefaultExample

annotation.feature-support.link.auto-complete-threshold

If the tagset is larger than the threshold, an auto-complete field is used instead of a standard combobox.

75

100

annotation.feature-support.link.auto-complete-max-results

When an auto-complete field is used, this determines the maximum number of items shown in the dropdown menu.

100

1000

+
+

PDF Editor Settings

+
+

This section describes the global settings related to the PDF annotation editor module.

+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 18. Knowledge base settings overview
SettingDescriptionDefaultExample

ui.pdf.enabled

enable/disable KB support

true

false

+
+
+

PDF Editor Settings (legacy)

+
+
+
+ + + + + +
+ + +Legacy feature. To use this functionality, you need to enable it first by adding ui.pdf-legacy.enabled=true to the settings.properties file. +
+
+
+

Support for this feature will be removed in a future version. The replacement is PDF Editor Settings.

+
+
+
+
+

This section describes the global settings related to the legacy PDF annotation editor module.

+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 19. Knowledge base settings overview
SettingDescriptionDefaultExample

ui.pdf-legacy.enabled

enable/disable KB support

false

true

+
+
+

Editable Segmentation Settings

+
+
+
+ + + + + +
+ + +Experimental feature. Highly experimental. Expect strange things to happen if you start +adding/removing/changing segmentation annotations (i.e. sentences or tokens). +
+
+
+
+
+

This section describes the global settings related to the support for editable segmentation annotations (i.e. sentences or tokens).

+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 20. Knowledge base settings overview
SettingDescriptionDefaultExample

ui.sentence-layer-editable=true

Enable/disable editing sentences

false

true

+
+
+
+
+

Document Metadata Settings

+
+
+

This section describes the global settings related to the document metadata annotation support.

+
+
+ + + + + +
+ + +Disabling document metadata support prevents new document metadata layers from being + created, but it does not prevent the use of existing document metadata layers layers in order + not to break existing projects. +
+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 21. Knowledge base settings overview
SettingDescriptionDefaultExample

documentmetadata.enabled

Enable/disable search

false

true

+
+
+
+

Concept Linking

+
+
+

There are several configurable parameters related to the Concept Linking functionality:

+
+
+
Cache size
+

This parameter controls the size of the Candidate Cache, which stores a set of candidates for a mention. +Increasing the cache size will reduce the number of queries that have to be made against the KB +and therefore increase average retrieval time.

+
+
+
Candidate Frequency Threshold
+

This parameter controls after how many concepts the ranking approach should take into account by +selecting the n most frequent concepts. Increasing this parameter will lead to a longer ranking time, +since more candidates are considered for ranking.

+
+
+
Mention Context Size
+

This parameter declares the size k of the context, where the context is defined as the words +included in a window with k words to both left and right.

+
+
+
Candidate Retrieval Limit
+

This parameter defines how many concepts should be retrieved for the Candidate Retrieval step. +Increasing this parameter will lead to a longer time to retrieve candidates from the KB.

+
+
+
Semantic Signature Query Limit
+

This parameter defines how many concepts should be retrieved for the Semantic Signature of a candidate. +Increasing this parameter will lead to a longer time to retrieve concepts for constructing the Semantic Signature.

+
+
+
Candidate Display Limit
+

This parameter regulates how many candidates will be displayed for a mention in the Concept Selector UI.

+
+
+

If no value for a parameter is specified, its default value is used. The default values are shown as +examples of how the parameters can be configured below:

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 22. Concept linking settings overview
SettingDescriptionDefaultExample

inception.entity-linking.cacheSize

Cache size

1024

-

inception.entity-linking.candidateQueryLimit

Candidate Retrieval Limit

2500

-

inception.entity-linking.mentionContextSize

Mention Context Size

5

-

inception.entity-linking.candidateDisplayLimit

Candidate Display Limit

100

-

inception.entity-linking.signatureQueryLimit

Semantic Signature Query Limit

2147483647

-

+
+

Resources

+
+

In order to improve the quality of suggestions, several additional resources can be incorporated. +These are to be put into the .inception/resources folder. These include:

+
+
+
    +
  • +

    properties_with_labels.txt

    +
    +
      +
    • +

      List of properties, each line containing information for one property, tab-separated

      +
    • +
    +
    +
  • +
+
+ ++++++++ + + + + + + + + + + + + + + + + + + +

ID

Label

Description

Aliases

Data type

Count

P6

head of government

head of the executive power of this town, city, municipality, state, + country, or other governmental body

government headed by, executive power headed by, president, chancellor

wikibase-item

17,592

+
+
    +
  • +

    property_blacklist.txt

    +
    +
      +
    • +

      A list of properties that are filtered when computing the Semantic Signature, one property ID per line, +e.g. P1005, P1014

      +
    • +
    +
    +
  • +
  • +

    stopwords-en.txt

    +
    +
      +
    • +

      A list of stopwords, one stopword per line, e.g. i, me

      +
    • +
    +
    +
  • +
  • +

    wikidata_entity_freqs.map

    +
    +
      +
    • +

      Each line consists of a the ID of a concept and its frequency in the KB, tab-separated, +e.g. Q4664130 409104, Q30 205747

      +
    • +
    +
    +
  • +
+
+
+
+
+
+

Knowledge Base Settings

+
+
+

This section describes the global settings related to the knowledge base module.

+
+
+
Default max results
+

This parameter determines the default value for the maximum number of results that can be retrieved from a SPARQL query. +The queries are used to retrieve concepts, statements, properties, etc. from the knowledge base. +The maximum number of results can also be configured separately for each knowledge base in the project settings.

+
+
+
Hard max results
+

A hard limit for the Max results parameter.

+
+
+

If no value for the parameter is specified, its default value is used. The default value is shown as +an example of how the parameter can be configured below:

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 23. Knowledge base settings overview
SettingDescriptionDefaultExample

knowledge-base.enabled

enable/disable KB support

true

false

knowledge-base.default-max-results

default result limit for SPARQL query

1000

10000

knowledge-base.hard-max-results

hard limit for the maximum number of results from a query

10000

5000

knowledge-base.cache-size

number of items (classes, instances and properties) to cache

100000

500000

knowledge-base.cache-expire-delay

time before items are expunged from the cache

15m

1h

knowledge-base.cache-refresh-delay

time before items are asynchronously refreshed

5m

30m

knowledge-base.render-cache-size

number of items (classes, instances and properties) to cache during rendering

10000

50000

knowledge-base.render-cache-expire-delay

time before items are expunged from the render cache

10m

1h

knowledge-base.render-cache-refresh-delay

time before items are asynchronously refreshed when rendering

1m

5m

knowledge-base.remove-orphans-on-start

whether to delete orphaned KBs on start

false

true

+
+ + + + + +
+ + +Disabling the knowledge base support will lead to the loss of concept linked features from + documents/projects that were using them. If you wish to run the application without knowledge base + support, it is strongly recommended to disable the feature immediately after the installation and + not after any projects have potentially started using it. +
+
+
+
+
+

Scheduler Settings

+
+
+

This section describes the global settings related to the scheduler.

+
+
+
Number of threads
+

This parameter determines the number of threads the scheduler uses. It should be less than hardware +threads available on the machine that runs INCEpTION. The higher the number, the more tasks can be +run in parallel.

+
+
+
Queue size
+

This parameter determines the maximum number of tasks that can be waiting in the scheduler queue. If +the queue is full, then no new tasks can be scheduled until running tasks are completed.

+
+
+

If no value for the parameter is specified, its default value is used. The default value is shown as +an example of how the parameter can be configured below:

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + +
Table 24. Scheduler settings overview
SettingDescriptionDefaultExample

inception.scheduler.numberOfThreads

Number of threads that run tasks

4

8

inception.scheduler.queueSize

Maximum number of tasks waiting for execution

100

200

+
+
+
+ +
+
+

This section describes the global settings related to the external document repository support.

+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 25. Document repository settings overview
SettingDescriptionDefaultExample

external-search.enable

Enable/disable document repository support

true

false

+
+
+
+

Recommender Settings

+
+
+

This section describes the global settings related to the recommender module.

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 26. Recommender settings overview
SettingDescriptionDefaultExample

recommender.enabled

enable/disable recommender support

true

false

recommender.evaluation-page.enabled

enable/disable evaluation page

true

false

recommender.sidebar.enabled

enable/disable recommender sidebar on annotation page

true

false

+
+

String Matching Recommender for Relations Settings

+
+

You can enable the String recommender for relations in your INCEpTION instance.

+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 27. String Matching Relation Recommnder Settings
SettingDescriptionDefaultExample

recommender.string-matching.relation

enable/disable String relation recommender

false

true

+
+
+

External Recommender Settings

+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 28. External recommender settings
SettingDescriptionDefaultExample

recommender.external.enabled

enable/disable external recommender support

true

false

recommender.external.connect-timeout

duration of connect timeout

30s

3m

recommender.external.read-timeout

duration of read timeout

30s

3m

+
+
+
+
+

Invite Links Settings

+
+
+
+
+ + + + + +
+ + +Experimental feature. +
+
+
+
+
+

You can enable invite links for your INCEpTION instance. This will allow project managers to +generate invite links for their project which will expire automatically after one year or at a +chosen date. They can also be deleted or regenerated by the manager. Any user of your instance can +use this invite link to access the project. She will automatically be added to the project with +annotator rights when following it.

+
+
+

Optionally, users can be invited using a password-less login. In this mode, the user logging in +simply chooses a login name and a project-bound password-less account for this user is created. +The user can only login to this account via the invite link. When the project is deleted, all the +project-bound accounts are deleted as well. The project-bound accounts internally use a randomized +user ID which allows projects projects with such accounts to be exported and imported into other +instances.

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 29. Invite Links settings
SettingDescriptionDefaultExample

sharing.invites.enabled

enable/disable invite links

false

true

sharing.invites.guests-enabled

enable/disable guest annotators

false

true

sharing.invites.invite-base-url

base URL used to generate invite links, e.g. when running behind a reverse proxy

unset

https://public.mydomain.com/inception

+
+
+
+

Versioning Settings

+
+
+
+
+ + + + + +
+ + +Experimental feature. +
+
+
+
+
+

You can enable versioning for projects in your INCEpTION instance. +Project managers can create snapshots of all documents in the project as well as its layer configuration via the versioning panel. +This is done via a git repository stored in the .inception folder. +This git repository can also be used to push to a remote repository, e.g. saving on Github or Gitlab.

+
+ + ++++++ + + + + + + + + + + + + + + + + +
Table 30. Versioning settings
SettingDescriptionDefaultExample

versioning.enabled

enable/disable versioning

false

true

+
+
+
+

Websocket Settings

+
+
+
+
+ + + + + +
+ + +Experimental feature. +
+
+
+
+
+

You can enable websocket support for your instance which allows to push messages to the client browser. This can e.g. be information for Admin users on recently logged events.

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 31. Websocket settings
SettingDescriptionDefaultExample

websocket.enabled

enable/disable websocket support/endpoint

false

true

websocket.logged-events.enabled

enable/disable push messages for logged events

false

true

websocket.recommender-events.enabled

enable/disable push messages for recommender events

true

false

+
+
+
+ + + \ No newline at end of file diff --git a/releases/29.3/docs/admin-guide/scripts/docker-compose-mysql8.yml b/releases/29.3/docs/admin-guide/scripts/docker-compose-mysql8.yml new file mode 100644 index 0000000..9aa9ed1 --- /dev/null +++ b/releases/29.3/docs/admin-guide/scripts/docker-compose-mysql8.yml @@ -0,0 +1,51 @@ +## +# docker-compose up [-d] +# docker-compose down +## +version: '2.4' + +networks: + inception-net: + +services: + db: + image: "mysql:8" + environment: + - MYSQL_RANDOM_ROOT_PASSWORD=yes + - MYSQL_DATABASE=inception + - MYSQL_USER=${DBUSER:-inception} + - MYSQL_PORT=3306 + - MYSQL_PASSWORD=${DBPASSWORD:-inception} + volumes: + - ${INCEPTION_DB_HOME:-db-data}:/var/lib/mysql + command: ["--character-set-server=utf8mb4", "--collation-server=utf8mb4_bin"] + healthcheck: + test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost", "-p${DBPASSWORD:-inception}", "-u${DBUSER:-inception}"] + interval: 20s + timeout: 10s + retries: 10 + networks: + inception-net: + + app: + image: "${INCEPTION_IMAGE:-ghcr.io/inception-project/inception}:${INCEPTION_VERSION:-{revnumber}}" + ports: + - "${INCEPTION_PORT:-8080}:8080" + environment: + - INCEPTION_DB_DIALECT=org.hibernate.dialect.MySQL8Dialect + - INCEPTION_DB_DRIVER=org.mariadb.jdbc.Driver + - INCEPTION_DB_URL=jdbc:mysql://db:3306/inception?useSSL=false&useUnicode=true&characterEncoding=UTF-8 + - INCEPTION_DB_USERNAME=${DBUSER:-inception} + - INCEPTION_DB_PASSWORD=${DBPASSWORD:-inception} + volumes: + - ${INCEPTION_HOME:-app-data}:/export + depends_on: + db: + condition: service_healthy + restart: unless-stopped + networks: + inception-net: + +volumes: + app-data: + db-data: \ No newline at end of file diff --git a/releases/29.3/docs/admin-guide/scripts/docker-compose.yml b/releases/29.3/docs/admin-guide/scripts/docker-compose.yml new file mode 100644 index 0000000..3f94f58 --- /dev/null +++ b/releases/29.3/docs/admin-guide/scripts/docker-compose.yml @@ -0,0 +1,52 @@ +## +# docker-compose up [-d] +# docker-compose down +## +version: '2.4' + +networks: + inception-net: + +services: + db: + image: "mariadb:10.7" + environment: + - MYSQL_RANDOM_ROOT_PASSWORD=yes + - MYSQL_DATABASE=inception + - MYSQL_USER=${DBUSER:-inception} + - MYSQL_PORT=3306 + - MYSQL_PASSWORD=${DBPASSWORD:-inception} + volumes: + - ${INCEPTION_DB_HOME:-db-data}:/var/lib/mysql + command: ["--character-set-server=utf8mb4", "--collation-server=utf8mb4_bin"] + healthcheck: + test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost", "-p${DBPASSWORD:-inception}", "-u${DBUSER:-inception}"] + interval: 20s + timeout: 10s + retries: 10 + networks: + inception-net: + + app: + image: "${INCEPTION_IMAGE:-ghcr.io/inception-project/inception}:${INCEPTION_VERSION:-{revnumber}}" + ports: + - "${INCEPTION_PORT:-8080}:8080" + environment: + - INCEPTION_DB_DIALECT=org.hibernate.dialect.MariaDB103Dialect + - INCEPTION_DB_DRIVER=org.mariadb.jdbc.Driver + - INCEPTION_DB_URL=jdbc:mariadb://db:3306/inception?useSSL=false&useUnicode=true&characterEncoding=UTF-8 + - INCEPTION_DB_USERNAME=${DBUSER:-inception} + - INCEPTION_DB_PASSWORD=${DBPASSWORD:-inception} + - JAVA_OPTS=-Dspring.jpa.properties.hibernate.dialect.storage_engine=innodb + volumes: + - ${INCEPTION_HOME:-app-data}:/export + depends_on: + db: + condition: service_healthy + restart: unless-stopped + networks: + inception-net: + +volumes: + app-data: + db-data: \ No newline at end of file diff --git a/releases/29.3/docs/developer-guide.html b/releases/29.3/docs/developer-guide.html new file mode 100644 index 0000000..328ef99 --- /dev/null +++ b/releases/29.3/docs/developer-guide.html @@ -0,0 +1,3798 @@ + + + + + + + + +INCEpTION Developer Guide + + + + + + + + + + + + + + + + + +
+
+
+
+

This document targets developers working on INCEpTION.

+
+
+
+

Introduction

+
+
+
+

This document describes how INCEpTION internally works and how it can be extended +to fit your use case or project. It is targeted to software developers. At first, +we will give a brief overview of the used technology in INCEpTION, then describe +how to setup the working environment including version control, IDE and software +requirements. Then, the architecture itself with core services and extension points +is presented.

+
+
+
+
+

Core technology

+
+
+

INCEpTION is written as a Java application and heavily relies on Spring Boot. Its +user interface is a web application that is powered by Apache Wicket. +The Natural Language Processing components are mostly based on +DKPro Core. This includes the +tokenization, import and export to many different standard formats, as well as +recommenders i.e. machine learning tools that provide annotation support. The internal +data format heavily relies on UIMA and its +CAS format.

+
+
+
+
+

System Requirements

+
+ + ++++ + + + + + + +
Table 1. Requirements for users

Browser

Chrome or Safari

+ + ++++ + + + + + + + + + + +
Table 2. Requirements to run the standalone version

Operating System

Linux (64bit), macOS (64bit), Windows (64bit)

Java Runtime Environment

version 11 or higher

+ + ++++ + + + + + + + + + + + + + + + + + + +
Table 3. Requirements run the server version

Operating System

Linux (64bit), macOS (64bit), Windows (64bit)

Java Runtime Environment

version 11 or higher

Apache Tomcat (or compatible)

version 9.0 or higher (Servlet API 4.0.0)

MariaDB Server (or compatible)

version 10.5 or higher

+
+ + + + + +
+ + +MariaDB is an open source drop-in replacement for MySQL. So generally, you can also use MySQL instead of MariaDB. Also, as far as we know, we do not use any fancy features of MariaDB 10.5 and did in fact until recently always use MySQL 5. So you can probably also use an older version of MariaDB or MySQL…​ but why should you? Think of all the unfixed bugs and consider also upgrading your database if you do a fresh installation of INCEpTION - or use Docker. +
+
+
+
+

Setup

+
+
+
+

This section covers setting up a development environment.

+
+
+
+
+

Source code management

+
+
+

We use git as our source code management system and collaborate via the INCEpTION +repository on GitHub.

+
+
+

Development workflow

+
+

Every feature or bug fix needs to be tracked in an issue on GitHub. Development is done in branches. +Based on the milestone (see the issue description on GitHub), the new branch is either created from +master (if the code should be in the next major release) or from a bugfix release branch +(if the code should be in the next minor release). In order to get the code in production, +you need to create a pull request on GitHub of your branch into the target branch (as described before).

+
+
+

In order to contribute to INCEpTION, you need to create a pull request. This section briefly +guides you through the best way of doing this:

+
+
+
    +
  • +

    Every feature or bug fix needs to be tracked in an issue on GitHub. If there is no issue for the +feature yet, create an issue first.

    +
  • +
  • +

    Create a branch based on the branch to which you wish to contribute. Normally, you should create +this branch from the master branch of the respective project. In the case that you want to fix a bug in +the latest released version, you should consider to branch off the latest maintenance branch (e.g. +0.10.x). If you are not sure, ask via the issue you have just created. Do not make changes directly +to the master or maintenance branches. The name of the branch should be e.g. +feature/[ISSUE-NUMBER]-[SHORT-ISSUE-DESCRIPTION] or bugfix/[ISSUE-NUMBER]-[SHORT-ISSUE-DESCRIPTION].

    +
  • +
  • +

    Now you make changes to your branch. When committing to your branch, use the format shown below +for your commit messages. Note that # normally introduces comments in git. You may have to reconfigure +git before attempting an interactive rebase and switch it to another comment character.

    +
    +
    +
    #[ISSUE NUMBER] - [ISSUE TITLE]
    +[EMPTY LINE]
    +- [CHANGE 1]
    +- [CHANGE 2]
    +- [...]
    +
    +
    +
  • +
+
+
+

You can create the pull request any time after your first commit. I.e. you do not have to wait until +you are completely finished with your implementation. Creating a pull request early tells other +developers that you are actively working on an issue and facilitates asking questions about and +discussing implementation details.

+
+
+
+

Git configuration

+
+

Before committing, make sure that you specified your email and name in the git config so +that commits can be attributed to you. This can e.g. be done as described in the +Git Documentation.

+
+
+

All sources files are stored using UNIX line endings. If you develop on Windows, you have to +set the core.autocrlf configuration setting to input to avoid accidentally submitting Windows +line endings to the repository. Using input is a good strategy in most cases, thus you should +consider setting this as a global (add --global) or even as a system (--system) setting.

+
+
+
Configure git line ending treatment
+
+
C:\> git config --global core.autocrlf input
+
+
+
+

After changing this setting, best do a fresh clone and check-out of the project.

+
+
+
+
+
+

Code style

+
+
+

We use a style for formatting the source code in INCEpTION. Our approach consists of two steps:

+
+
+
    +
  • +

    DKPro code formatting profile - the profile configures your IDE to auto-format the code according to +our guidelines as you go.

    +
  • +
  • +

    Checkstyle - this tool is used to check if the source code is actually formatted according to our +guidelines. It is run as part of a Maven build and the build fails if the code is not formatted +properly.

    +
  • +
+
+
+

Here is a brief summary of the formatting rules:

+
+
+
    +
  • +

    no tabs, only spaces

    +
  • +
  • +

    indenting using 4 spaces in Java files and 2 spaces in XML files

    +
  • +
  • +

    maximum 100 characters per line (with a few exceptions)

    +
  • +
  • +

    curly braces on the next line for class/method declarations, same line for logic blocks (if/for/…​)

    +
  • +
  • +

    parameter names start with a (e.g. void foo(String aValue))

    +
  • +
+
+
+
+
+

Setting up for the development in Eclipse

+
+
+

This is a guide to setting up a development environment using Eclipse on Mac OS X. The +procedure should be similar for other operation systems.

+
+
+

First, you need to follow some steps of the Administrator Installation Guide. +It is recommended to configure a MySQL-server.

+
+
+

We recommend you start from a Eclipse IDE for Java Developers package.

+
+
+

Use a JDK

+
+

On Linux or OS X, having a full JDK installed on your system is generally sufficient. You can skip +on to the next section.

+
+
+

On Windows, you need to edit the eclipse.ini file and directly before the -vmargs line, you +have to add the following two lines. Mind to replace C:/Program Files/Java/jdk11 with the actual +location of the JDK/version on your system. Without this, Eclipse will complain that the +jdk.tools:jdk.tools artifact would be missing.

+
+
+
Force Eclipse to run on a JDK
+
+
-vm
+C:/Program Files/Java/jdk11/jre/bin/server/jvm.dll
+
+
+
+
+

Eclipse Plug-ins

+
+
    +
  • +

    Maven Integration: m2e , already comes pre-installed with the Eclipse IDE for Java Developers. +If you use another edition of Eclipse which does not have m2e pre-installed, go to Help→Install +New Software, select "--All available sites--" and choose Collaboration → m2e - Maven Integration +for Eclipse

    +
  • +
  • +

    Apache UIMA tools: go to Help→Install New Software, select "Add…​" and add the update site: http://www.apache.org/dist/uima/eclipse-update-site/ as a location. Install the Apache UIMA Eclipse tooling and runtime support.

    +
  • +
  • +

    Eclipse Web Development Tooling: go to Help→Install New Software, select "--All available +sites--" and select the following plug-ins for installation from the section Web, XML, Java EE +and OSGi Enterprise Development:

    +
    +
      +
    • +

      Eclipse Java Web Developer Tools

      +
    • +
    • +

      Eclipse Web Developer Tools

      +
    • +
    • +

      Eclipse XML Editors and Tools: already comes pre-installed in newer Eclipse versions

      +
    • +
    +
    +
  • +
+
+
+
+

Eclipse Workspace Settings

+
+
    +
  • +

    You should check that Text file encoding is UTF-8 in Preferences → General → Workspace.

    +
  • +
  • +

    You need to enable Java annotation preprocessors. Go to Preferences → Maven → Annotation Processing +and set the Annotation Processing Mode to Automatic.

    +
  • +
+
+
+
+

Importing INCEpTION into the Workspace

+
+

Checkout out the INCEpTION git repository with your favorite git client. If you use the command-line +client, use the command

+
+
+
+
$ git clone https://github.com/inception-project/inception.git
+
+
+
+

In Eclipse, go to File → Import, choose Existing Maven projects, and select the folder to which +you have cloned INCEpTION. Eclipse should automatically detect all modules.

+
+
+
+

Setting up Checkstyle and Formatting

+
+

We use a style for formatting the source code in INCEpTION (see Checkstyle and Formatting. +The following section describes how to use it with Eclipse.

+
+
+

First, obtain the DKPro code formatting profile from the DKPro website (Section "Code style"). In Eclipse, go to Preferences → Java → Code Style → Formatter to import the file. Apparently, the files can also be used with IntelliJ via the [Eclipse Code Formatter](https://plugins.jetbrains.com/plugin/6546-eclipse-code-formatter) plugin.

+
+
+ + + + + +
+ + +The parameter prefix a needs to be configured manually. In Eclipse go to + Preferences → Java → Code Style set the prefix list column in the parameters row to a. +
+
+
+

Second, install the Checkstyle plugin for Eclipse as well as the Maven Checkstyle plugin for Eclipse. +These plugins make Eclipse automatically pick up the checkstyle configuration from the Maven project +and highlight formatting problems directly in the source code editor.

+
+
+ +
+
+ + + + + +
+ + +Should the steps mentioned above not have been sufficient, close all the INCEpTION projects + in Eclipse, then remove them form the workspace (not from the disk), delete any .checkstyle files + in the INCEpTION modules, and then re-import them into Eclipse again using Import→Existing Maven + projects. During the project import, the Checkstyle configuration plugin for M2Eclipse should + properly set up the .checkstyle files and activate checkstyle.
+ If the Maven project update cannot be completed due to missing .jars, execute a Maven install via right click on the inception project Run as → + Maven build…​, enter the goal install and check Skip Tests. Alternatively, use the command mvn clean install -DskipTests. +
+
+
+
+
+
+

Setting up for the development in IntelliJ IDEA

+
+
+

This is a guide to setting up a development environment using IntelliJ IDEA. We assume that the +Community Version is used, but this guide should also apply to the Enterprise Version.

+
+
+

After checking out INCEpTION from GitHub, open IntelliJ and import the project. The easiest +way is to go to File → Open and the select the pom.xml in the INCEpTION root directory. +IntelliJ IDEA will then guide you through the import process, the defaults work out of the box. +INCEpTION can now be started via running inception-app-webapp/src/main/java/de/tudarmstadt/ukp/inception/INCEpTION.java.

+
+
+

If you get errors that certain classes are not found, then open a terminal, go to the INCEpTION +repository root and run

+
+
+
+
mvn clean install -DskipTests=true -Dcheckstyle.skip=true
+
+
+
+

Alternatively, you can run the clean and install Maven goals from IntelliJ manually.

+
+
+

If you get an error that the command line is too long, please go to Run → Edit Configurations → Modify Options → Shorten Command Line in IntelliJ IDEA and select the option @argfile (Java 9+) - java @argfile className [args].

+
+
+

Checkstyle and Formatting

+
+

We use a style for formatting the source code in INCEpTION (see Checkstyle and Formatting. +The following section describes how to use it with IntelliJ IDEA.

+
+
+

First, install the Checkstyle-IDEA plugin. +In File | Settings | Other Settings | Checkstyle, navigate to the Checkstyle tab. Start to add +a new configuration file by clicking on the + on the right, navigate to +inception-build/src/main/resources/inception/checkstyle.xml and apply the changes. Make sure to +check the box next to the newly created configuration and apply it as well.

+
+
+

In order to achieve the same formatting and import order as Eclipse, install the +Eclipse Code Formatter. +Download the DKPro Eclipse Code Style file. +In File | Settings | Other Settings | Eclipse Code Formatter, create a new profile using this +file.

+
+
+

Also make sure to enable auto import optimization in File | Settings | Editor | General | Auto Import.

+
+
+

To format your source code on save, we also recommend to install the +Save Actions plugin and configure it +accordingly.

+
+
+
+

IntelliJ IDEA Tomcat Integration

+
+

This requires IntelliJ IDEA Ultimate. Using Tomcat allows editing HTML,CSS and JavaScript on the fly without restarting +the application. First, download Apache Tomcat from http://tomcat.apache.org/ (we’re using version 8.5). +Then, you need to create a Tomcat server runtime configuration in Run | Edit Configurations…. Click on the ` icon, +select `Tomcat Server -> Local`. Click on the `Deployment` tab and then on the ` icon to select an artifact to deploy. +Choose the exploded war version. Select the Server tab, navigate to the path of your Tomcat server, and update the +on Update action to Update classes and resources for both. Make sure that all port settings are different. +You now can start or debug your web application via Tomcat. If starting throws a permission error, make sure that +the mentioned file, e.g. catalina.sh is marked as executable.

+
+
+

Experimental: If desired, you can also use hot-code replacement via HotswapAgent. +This allows you to change code, e.g. adding methods without needing to restart the Tomcat server. +For this, follow the excellent HotSwap IntelliJ IDEA plugin guide.

+
+
+
+

Building documentation

+
+

The documentation can be built using a support class in inception-doc/src/test/java/de/tudarmstadt/ukp/inception/doc/GenerateDocumentation.java. +To make it usable from Intellij IDEA, you need to build the whole project at least once. Run the +class. If it fails, alter the run configuration and add a new environment variable INTELLIJ=true +and check that the working directory is the INCEpTION root directory. The resulting documentation +will be in target/doc-out.

+
+
+
+
+
+

Running INCEpTION

+
+
+

To run INCEpTION from your IDE, locate the class de.tudarmstadt.ukp.inception.INCEpTION and run it +as a Java application. This runs INCEpTION as a Spring Boot application using an embedded +web server - similar to running the compiled JAR file from the command line. You may want to define +the following system properties in your launch configuration:

+
+ +++++ + + + + + + + + + + + + + + + + + + + +
SettingValueDescription

inception.home

/home/username/inception-dev (adjust to your situation)

Location to store the application data

wicket.core.settings.general.configuration-type

development

Enable the development mode. This e.g. disables caches so that changes to HTML files in the IDE directly reflect in the running application.

+
+
+

Architecture

+
+
+
+

INCEpTION uses a standard 3-layer architecture with the presentation layer using Wicket +at the top, the business layer heavily relying on Spring Boot and the data layer which is +interfaced with Hibernate at the bottom.

+
+
+
+
+

Wicket pages

+
+
+

Wicket can only inject components that are interfaces. A pattern for these cases is to create an +ExampleComponent interface and implement it in an ExampleComponentImpl class.

+
+
+
+
+

Services

+
+
+

Services encode the core logic of INCEpTION. They can be injected into Wicket pages and +other services to interact with the rest of the application. Services can inject Spring +components via autowiring. A good example of a service can e.g. be seen in the +SchedulingService.java.

+
+
+
+
+

Database

+
+
+

The database can be accessed via Hibernate. The schema itself +and migrations are managed by Liquibase.

+
+
+

Migration

+
+

When changing the database schema, migrations from the current schema to the new one +need to be defined. They describe how the schema needs to be modified. This way, +INCEpTION can be upgraded to newer versions without needing to manually alter the +database schema. The migration process determines the current version of the schema +and only applies transformations from there to the newest one. Each module defines its +own data base tables and migrations in a file called db-changelog.xml. These are +automatically discovered by Liquibase and used when starting INCEpTION.

+
+
+
+
+
+

Modules

+
+

Documents

+
+
+

Source documents

+
+

The original document uploaded by a user into a project. The document is preserved in its original +format.

+
+
+
+

Annotation documents

+
+

Annotations made by a particular user on a document. The annotation document is persisted separately +from the original document. There is one annotation document per user per document. Within the tool, +a CAS data structure is used to represent the annotation document.

+
+
+
+
+
+

Annotation Schema

+
+
+

Layers

+
+

The layers mechanism allows supporting different types of annotation layers, e.g. span layers, +relation layers or chain layers. It consists of the following classes and interfaces:

+
+
+
    +
  • +

    The LayerSupport interface provides the API for implementing layer types.

    +
  • +
  • +

    The LayerSupportRegistry interface and its default implementation LayerSupportRegistryImpl +serve as an access point to the different supported layer types.

    +
  • +
  • +

    The LayerType class which represents a short summary of a supported layer type. It is used +when selecting the type of a feature in the UI.

    +
  • +
  • +

    The TypeAdapter interface provides methods to create, manipulate or delete annotations on the +given type of layer.

    +
  • +
+
+
+

To add support for a new type of layer, create a Spring component class which implements the +LayerSupport interface. Note that a single layer support class can handle multiple layer types. +However, it is generally recommended to implement a separate layer support for every layer type. +Implement the following methods:

+
+
+
    +
  • +

    getId() to return a unique identifier for the new layer type. Typically the Spring bean name +is returned here.

    +
  • +
  • +

    getSupportedLayerTypes() to return a list of all the supported layer types handled by the new +layer support. This values returned here are used to populate the layer type choice when creating +a new layer in the project settings.

    +
  • +
  • +

    accepts(AnnotationLayer) to return true for any annotation layer that is handled by the new +layer support. I.e. AnnotationLayer.getType() must return a layer type identifier that was produced +by the given layer support.

    +
  • +
  • +

    generateTypes(TypeSystemDescription, AnnotationLayer) to generate the UIMA type system for the given +annotation layer. This is a partial type system which is merged by the application with the +type systems produced by other layer supports as well as with the base type system of the +application itself (i.e. the DKPro Core type system and the internal types).

    +
  • +
  • +

    getRenderer(AnnotationLayer) to return an early-stage renderer for the annotations on the +given layer.

    +
  • +
+
+
+ + + + + +
+ + +The concept of layers is not yet fully modularized. Many parts of the application will only + know how to deal with specific types of layers. Adding a new layer type should not crash the + application, but it may also not necessarily be possible to actually use the new layer. In + particular, changes to the TSV format may be required to support new layer types. +
+
+
+

Span layer

+
+

A span layer allows to create annotations over spans of text.

+
+
+

If attachType is set, then an annotation can only be created over the same span on which an +annotation of the specified type also exists. For span layers, setting attachFeature is mandatory +if a attachType is defined. The attachFeature indicates the feature on the annotation of the +attachType layer which is to be set to the newly created annotation.

+
+
+

For example, the Lemma layer has the attachType set to Token and the attachFeature set to +lemma. This means, that a new lemma annotation can only be created where a token already exists +and that the lemma feature of the token will point to the newly created lemma annotation.

+
+
+

Deleting an annotation that has other annotations attached to it will also cause the attached +annotations to be deleted.

+
+
+ + + + + +
+ + +This case is currently not implemented because it is currently not allowed to + create spans that attach to other spans. The only span type for which this is relevant + is the Token type which cannot be deleted. +
+
+
+
+

Relation layer

+
+

A relation layer allows to draw arcs between span annotations. The attachType is mandatory for +relation types and specifies which type of annotations arcs can be drawn between.

+
+
+

Arcs can only be drawn between annotations of the same layer. It is not possible to draw an arc +between two spans of different layers.

+
+
+

Only a single relation layer can attach to any given span layer.

+
+
+

If the annotation_feature is set, then the arc is not drawn between annotations of the layer +indicated by annotation_type, but between annotations of the type specified by the feature. E.g. +for a dependency relation layer, annotation_type would be set to Token and annotation_feature +to pos. The Token type has no visual representation in the UI. However, the pos feature points +to a POS annotation, which is rendered and between which the dependency relation arcs are then +drawn.

+
+
+

Deleting an annotation that is the endpoint of a relation will also delete the relation. In the case +that annotation_feature, this is also the case if the annotation pointed to is deleted. E.g. if +a POS annotation in the above example is deleted, then the attaching relation annotations are also +deleted.

+
+
+
+

Document Metadata

+
+

A document metadata layer can be used to create annotations that apply to an entire document +instead of to a specific span of text.

+
+
+

Document metadata types inherit from the UIMA AnnotationBase type (text annotations inherit from +Annotation). As such, they do not have begin/end offsets.

+
+
+
+

Layers Behaviors

+
+

Layer behaviors allow to customize the way a layer of a particular span behaves, e.g. whether +a span is allowed to cross sentence boundaries, whether it anchors to characters or tokens, +whether the tree of relations among annotations is valid, etc. +The layer behaviors tie in with the specific LayerSupport implementations. The mechanism itself +consists of the following classes and interfaces:

+
+
+
    +
  • +

    The LayerBehavior interface provides the API necessary for registering new behaviors. There are +abstract classes such as SpanLayerBehavior or RelationLayerBehavior which provide the APIs for +behaviors of specific layer types.

    +
  • +
  • +

    The LayerBehaviorRegistry and its default implementation LayerBehaviorRegistryImpl +serve as an access point to the different supported layer behaviors. +Any Spring component implementing the LayerBehavior interface is +loaded, and will be named in the logs when the web app is launched. The classpath scanning +used to locate Spring beans is limited to specific Java packages, e.g. any packages starting +with de.tudarmstadt.ukp.clarin.webanno.

    +
  • +
+
+
+

A layer behavior may have any of the following responsibilities:

+
+
+
    +
  • +

    Ensure that new annotations that are created conform with the behavior. This is done via the +onCreate method. If the annotation to be created does not conform with the behavior, the +method can cancel the creation of the annotation by throwing an AnnotationException.

    +
  • +
  • +

    Highlight annotations not conforming with the behavior. This is relevant when importing +pre-annotated files or when changing the behavior configuration of an existing layer. The +relevant method is onRender. If an annotation does not conform with the behavior, a error +marker should be added for problematic annotation. This is done by creating a VComment +which attaches an error message to a specified visual element, then adding that to the +response VDocument. Note that onRender is unlike onCreate and onValidate in that it +only has indirect access to the CAS: it is passed a mapping from AnnotationFS instances to +their corresponding visual elements, and can use .getCAS() on the FS. The annotation layer +can be identified from the visual element with .getLayer().getName().

    +
  • +
  • +

    Ensure that documents being marked as finished conform with the behavior. This is done +via the onValidate method, which returns a list of LogMessage, AnnotationFS pairs +to report errors associated with each FS.

    +
  • +
+
+
+
+
+

Features

+
+

The features mechanism allows supporting different types of annotation features, e.g. string +features, numeric features, boolean features, link features, etc. +It consists of the following classes and interfaces:

+
+
+
    +
  • +

    The FeatureSupport interface provides the API for implementing feature types.

    +
  • +
  • +

    The FeatureSupportRegistry interface and its default implementation FeatureSupportRegistryImpl +serve as an access point to the different supported feature types.

    +
  • +
  • +

    The FeatureType class which represents a short summary of a supported feature type. It is used +when selecting the type of a feature in the UI.

    +
  • +
  • +

    The TypeAdapter interface provides methods to create, manipulate or delete annotations on the +given type of layer.

    +
  • +
+
+
+

To add support for a new type of feature, create a Spring component class which implements the +FeatureSupport interface. Note that a single feature support class can handle multiple feature types. +However, it is generally recommended to implement a separate layer support for every feature type. +Implement the following methods:

+
+
+
    +
  • +

    getId() to return a unique identifier for the new feature type. Typically the Spring bean name +is returned here.

    +
  • +
  • +

    getSupportedFeatureTypes() to return a list of all the supported feature types handled by the new +feature support. This values returned here are used to populate the feature type choice when +creating a new feature in the project settings.

    +
  • +
  • +

    accepts(AnnotationLayer) to return true for any annotation layer that is handled by the new +layer support. I.e. AnnotationLayer.getType() must return a layer type identifier that was produced +by the given layer support.

    +
  • +
  • +

    generateFeature(TypeSystemDescription, TypeDescription, AnnotationFeature) add the UIMA feature +definition for the given annotation feature to the given type.

    +
  • +
+
+
+

If the new feature has special configuration settings, then implement the following methods:

+
+
+
    +
  • +

    readTraits(AnnotationFeature) to extract the special settings form the given annotation feature +definition. It is expected that the traits are stored as a JSON string in the traits field +of AnnotationFeature. If the traits field is null, a new traits object must be returned.

    +
  • +
  • +

    writeTraits(AnnotationFeature, T) to encode the layer-specific traits object into a JSON string +and store it in the traits field of AnnotationFeature.

    +
  • +
  • +

    createTraitsEditor(String, IModel<AnnotationFeature> to create a custom UI for the special feature +settings. This UI is shown below the standard settings in the feature detail editor on the +Layers tab of the project settings.

    +
  • +
+
+
+
+
+
+ +
+
+

The search module contains the basic methods that implement the search service and search +functionalities of INCEpTION.

+
+
+

The SearchService and SearchServiceImpl classes define and implement the search service as a Spring component, allowing other modules of INCEpTION to create an index for a given project, and to perform queries over that index.

+
+
+

The indexes have two different aspects: the conceptual index, represented by the Index class, and the physical index, represented by a particular physical implementation of an index. This allows different search providers to be used by INCEpTION. Currently, the default search implementation uses Mtas (https://github.com/meertensinstituut/mtas), a Lucene / Solr based index engine that allows to annotate not only raw texts but also different linguistic annotations.

+
+
+

Every search provider is defined by its own index factory, with a general index registry to hold all the available search providers.

+
+
+

Mtas Index

+
+

The Mtas index is implemented in the MtasDocumentIndex and MtasDocumentIndexFactory classes. Furthermore, the MtasUimaParser class provides a parser to be used by Lucene when adding a new document to the index.

+
+
+
    +
  • +

    MtasDocumentIndexFactory

    +
  • +
+
+
+

The factory allows to build a new MtasDocumentIndex through the getNewIndex method, which is called by the search service.

+
+
+
    +
  • +

    MtasDocumentIndex

    +
  • +
+
+
+

This class holds the main functionalities of a Mtas index. Its methods are called by the search service and allow to create, open close and drop a Mtas index. It allows to add or delete a document from an index, as well as to perform queries on the index.

+
+
+

Each index is related to only one project, and every project can have only one index from a given search provider.

+
+
+

When adding a document to a Mtas index, the Lucene engine will use the class MtasUimaParser in order to find out which are the tokens and annotations to be indexed.

+
+
+
    +
  • +

    MtasUimaParser

    +
  • +
+
+
+

The parser is responsible for creating a new TokenCollection to be used by Lucene, whenever a new document is being indexed. The token collection consists of all the tokens and annotations found in the document, which are transformed into Mtas tokens in order to be added to the Lucene index. The parser scans the document CAS and goes through all its annotations, finding out which ones are related to the annotation layers in the document’s project - those are the annotations to be indexed. Currently, the parser only indexes span type annotations.

+
+
+
+
+
+

Recommendation

+
+
+

For information on the different recommenders, please refer to user guide.

+
+
+

Implementing a custom recommender

+
+

This section describes the overall design of internal recommenders in INCEpTION and gives a +tutorial on how to implement them. Internal recommenders are created by implementing relevant +Java interfaces and are added via Maven dependencies. These are then picked up during application +startup by the Spring Framework.

+
+
+

For this tutorial, we will add a recommender for named entities that uses the data majority label for +predicting, i.e. it predicts always the label that appears most often in the training data. The full +code for this example can be found in the inception-example-imls-data-majority module.

+
+
+

Setting up the environment

+
+

To get started, check out the most recent source code of INCEpTION from +Github and import it as a Maven project in the IDE +of your choice. Add a new module to the INCEpTION project itself, we will call it +inception-example-imls-data-majority.

+
+
+

In the root pom.xml of the INCEpTION project, add your recommender as a dependency. Update +the version of the dependency entry you just created to the version you find in the pom.xml of the +INCEpTION project. It should look like this:

+
+
+
+
<dependencies>
+…
+    <dependency>
+        <groupId>de.tudarmstadt.ukp.inception.app</groupId>
+        <artifactId>inception-imls-data-majority</artifactId>
+        <version>29.3</version>
+    </dependency>
+…
+</dependencies>
+
+
+
+

Add the same entry in inception-app-webapp, but omit the version number. It then uses automatically the +version in the parent POM file. Also add it to usedDependencies there.

+
+
+

To add a new recommender to INCEpTION, two classes need to be created. These are +described in the following.

+
+
+
+

Implementing the RecommendationEngine

+
+

Recommenders give suggestions for possible annotations to the user. In order to do that, +they need to be able be to trained on existing annotations, predict annotations in a document and +be evaluated for a performance estimate. This is what the RecommendationEngine abstract class is for. +It defines the methods that are used to train, test and evaluate a machine learning algorithm and offers +several helper methods. Instances of this class often wrap external machine learning packages like +OpenNLP or Deeplearning4j.

+
+
+

Recommenders in INCEpTION heavily rely on Apache UIMA types and features. +A recommender is configured for a certain layer and a certain feature. A layer can be seen as the +type of annotation you want to to, e.g. POS, NER. Layers correspond to UIMA types. A feature is +one piece of information that should be annotated, e.g. the POS tag. One layer can have many features. +When extending RecommendationEngine, the predicted layer/type can be obtained by getPredictedType, +the feature to predict respectively by getPredictedFeature.

+
+
+

Annotations are given to a recommender in the form of a +UIMA CAS. One CAS corresponds to one +document in INCEpTION. Annotations from a CAS can be read and manipulated via the +CasUtil.

+
+
+

We start by creating a new class de.tudarmstadt.ukp.inception.recommendation.imls.datamajority.DataMajorityNerRecommender that implements RecommendationEngine. +Please see the JavaDoc of the respective methods for their semantics.

+
+
+
Class and member definition for the DataMajorityNerRecommender
+
+
public class DataMajorityNerRecommender
+    extends RecommendationEngine
+{
+    public static final Key<DataMajorityModel> KEY_MODEL = new Key<>("model");
+
+    private static final Class<Token> DATAPOINT_UNIT = Token.class;
+
+    private final Logger log = LoggerFactory.getLogger(getClass());
+
+    public DataMajorityNerRecommender(Recommender aRecommender)
+    {
+        super(aRecommender);
+    }
+
+    /**
+     * Given training data in {@code aCasses}, train a model. In order to save data between runs,
+     * the {@code aContext} can be used. This method must not mutate {@code aCasses} in any way.
+     * 
+     * @param aContext
+     *            The context of the recommender
+     * @param aCasses
+     *            The training data
+     * @throws RecommendationException
+     *             if there was a problem during training
+     */
+    public abstract void train(RecommenderContext aContext, List<CAS> aCasses)
+        throws RecommendationException;
+
+    /**
+     * Given text in a {@link CAS}, predict target annotations. These should be written into
+     * {@link CAS}. In order to restore data from e.g. previous training, the
+     * {@link RecommenderContext} can be used.
+     * 
+     * @param aContext
+     *            The context of the recommender
+     * @param aCas
+     *            The training data
+     * @throws RecommendationException
+     *             if there was a problem during prediction
+     */
+    public void predict(RecommenderContext aContext, CAS aCas) throws RecommendationException
+    {
+        predict(aContext, aCas, 0, aCas.getDocumentText().length());
+    }
+
+    /**
+     * Given text in a {@link CAS}, predict target annotations. These should be written into
+     * {@link CAS}. In order to restore data from e.g. previous training, the
+     * {@link RecommenderContext} can be used.
+     * <p>
+     * Depending on the recommender, it may be necessary to internally extend the range in which
+     * recommendations are generated so that recommendations that partially overlap the prediction
+     * range may also be generated.
+     * 
+     * @param aContext
+     *            The context of the recommender
+     * @param aCas
+     *            The training data
+     * @param aBegin
+     *            Begin of the range in which predictions should be generated.
+     * @param aEnd
+     *            End of the range in which predictions should be generated.
+     * @return Range in which the recommender generated predictions. No suggestions in this range
+     *         should be inherited.
+     * @throws RecommendationException
+     *             if there was a problem during prediction
+     */
+    public abstract Range predict(RecommenderContext aContext, CAS aCas, int aBegin, int aEnd)
+        throws RecommendationException;
+
+    /**
+     * Evaluates the performance of a recommender by splitting the data given in {@code aCasses} in
+     * training and test sets by using {@code aDataSplitter}, training on the training set and
+     * measuring performance on unseen data on the training set. This method must not mutate
+     * {@code aCasses} in any way.
+     * 
+     * @param aCasses
+     *            The CASses containing target annotations
+     * @param aDataSplitter
+     *            The splitter which determines which annotations belong to which set
+     * @return Scores available through an EvaluationResult object measuring the performance of
+     *         predicting on the test set
+     * @throws RecommendationException
+     *             if there was a problem during evaluation
+     */
+    public abstract EvaluationResult evaluate(List<CAS> aCasses, DataSplitter aDataSplitter)
+        throws RecommendationException;
+
+    private static class DataMajorityModel
+    {
+        private final String majorityLabel;
+        private final double score;
+        private final int numberOfAnnotations;
+
+        private DataMajorityModel(String aMajorityLabel, double aScore, int aNumberOfAnnotations)
+        {
+            majorityLabel = aMajorityLabel;
+            score = aScore;
+            numberOfAnnotations = aNumberOfAnnotations;
+        }
+    }
+
+    private static class Annotation
+    {
+        private final String label;
+        private final double score;
+        private final String explanation;
+        private final int begin;
+        private final int end;
+
+        private Annotation(String aLabel, int aBegin, int aEnd)
+        {
+            this(aLabel, 0, 0, aBegin, aEnd);
+        }
+
+        private Annotation(String aLabel, double aScore, int aNumberOfAnnotations, int aBegin,
+                int aEnd)
+        {
+            label = aLabel;
+            score = aScore;
+            explanation = "Based on " + aNumberOfAnnotations + " annotations";
+            begin = aBegin;
+            end = aEnd;
+        }
+    }
+}
+
+
+
+

For the constructor, we take the Recommender object which contains the recommender configuration, +e.g. the layer and the name of the feature to recommend. The next step is to implement the required +methods.

+
+
+

DataMajorityModel and Annotation are internal data classes to simplify the code.

+
+
+
RecommenderContext
+
+

Instances of RecommendationEngine itself are stateless. If data like trained models need to be +saved and loaded, it can be saved in the RecommenderContext that is given in the interface methods. +When needed again, e.g. for prediction, it then can be loaded again. The Key class is used in order +to ensure type safety.

+
+
+
+
Training
+
+

Training consists of extracting annotations followed by training and saving the model. The +platform needs to know whether the recommender is ready for prediction, this is done by +overriding RecommendationEngine::isReadyForPrediction.

+
+
+
Training routine
+
+
@Override
+public TrainingCapability getTrainingCapability()
+{
+    return TRAINING_REQUIRED;
+}
+
+@Override
+public void train(RecommenderContext aContext, List<CAS> aCasses) throws RecommendationException
+{
+    List<Annotation> annotations = extractAnnotations(aCasses);
+
+    DataMajorityModel model = trainModel(annotations);
+    aContext.put(KEY_MODEL, model);
+}
+
+@Override
+public boolean isReadyForPrediction(RecommenderContext aContext)
+{
+    return aContext.get(KEY_MODEL).map(Objects::nonNull).orElse(false);
+}
+
+
+
+

Extracting annotations itself is done by iterating over all documents and selecting all annotations +for each. Here, we need to use the layer name and feature for which the recommender is configured +to extract the correct annotations.

+
+
+
Extracting annotations from the documents
+
+
private List<Annotation> extractAnnotations(List<CAS> aCasses)
+{
+    List<Annotation> annotations = new ArrayList<>();
+
+    for (CAS cas : aCasses) {
+        Type annotationType = CasUtil.getType(cas, layerName);
+        Feature predictedFeature = annotationType.getFeatureByBaseName(featureName);
+
+        for (AnnotationFS ann : CasUtil.select(cas, annotationType)) {
+            String label = ann.getFeatureValueAsString(predictedFeature);
+            if (isNotEmpty(label)) {
+                annotations.add(new Annotation(label, ann.getBegin(), ann.getEnd()));
+            }
+        }
+    }
+
+    return annotations;
+}
+
+
+
+

The training itself is done by counting the number of occurrences for each label that was seen in the +documents. The label is then the one which occurred the most in the training documents.

+
+
+
Training the model
+
+
private DataMajorityModel trainModel(List<Annotation> aAnnotations)
+    throws RecommendationException
+{
+    Map<String, Integer> model = new HashMap<>();
+    for (Annotation ann : aAnnotations) {
+        int count = model.getOrDefault(ann.label, 0);
+        model.put(ann.label, count + 1);
+    }
+
+    Map.Entry<String, Integer> entry = model.entrySet().stream()
+            .max(Map.Entry.comparingByValue()).orElseThrow(
+                    () -> new RecommendationException("Could not obtain data majority label"));
+
+    String majorityLabel = entry.getKey();
+    int numberOfAnnotations = model.values().stream().reduce(Integer::sum).get();
+    double score = (float) entry.getValue() / numberOfAnnotations;
+
+    return new DataMajorityModel(majorityLabel, score, numberOfAnnotations);
+}
+
+
+
+

We also compute a dummy score here which is displayed in the UI and used for e.g. active learning.

+
+
+
+
Predicting
+
+

The first thing we do when predicting is to load the model we saved during training. For every +candidate in the document, we assign the majority label, create a new annotation and add it to the CAS. +From there, it will be read by INCEpTION and displayed to the user.

+
+
+
Predicting annotations for a CAS
+
+
@Override
+public Range predict(RecommenderContext aContext, CAS aCas, int aBegin, int aEnd)
+    throws RecommendationException
+{
+    DataMajorityModel model = aContext.get(KEY_MODEL).orElseThrow(
+            () -> new RecommendationException("Key [" + KEY_MODEL + "] not found in context"));
+
+    // Make the predictions
+    Type tokenType = CasUtil.getAnnotationType(aCas, DATAPOINT_UNIT);
+    Collection<AnnotationFS> candidates = selectOverlapping(aCas, tokenType, aBegin, aEnd);
+    List<Annotation> predictions = predict(candidates, model);
+
+    // Add predictions to the CAS
+    Type predictedType = getPredictedType(aCas);
+    Feature scoreFeature = getScoreFeature(aCas);
+    Feature scoreExplanationFeature = getScoreExplanationFeature(aCas);
+    Feature predictedFeature = getPredictedFeature(aCas);
+    Feature isPredictionFeature = getIsPredictionFeature(aCas);
+
+    for (Annotation ann : predictions) {
+        AnnotationFS annotation = aCas.createAnnotation(predictedType, ann.begin, ann.end);
+        annotation.setStringValue(predictedFeature, ann.label);
+        annotation.setDoubleValue(scoreFeature, ann.score);
+        annotation.setStringValue(scoreExplanationFeature, ann.explanation);
+        annotation.setBooleanValue(isPredictionFeature, true);
+        aCas.addFsToIndexes(annotation);
+    }
+
+    return new Range(candidates);
+}
+
+
+
+

For a document, we consider possible candidates for a named entity to be tokens that are upper case. +In a real recommender, the step of candidate extraction should be more elaborate than that, but for this +tutorial, it is sufficient.

+
+
+

When making predictions, we also set the score feature to put a number on the quality of the annotation. +The UIMA score feature to set can be obtained by calling getScoreFeature inside a RecommendationEngine. +When creating predictions, make sure to call annotation.setBooleanValue(isPredictionFeature, true); so +that INCEpTION knows it is a prediction, not a real annotation. In addition, we provide an explanation for +the score through the UIMA feature obtained by calling getScoreExplanationFeature inside a RecommendationEngine.

+
+
+
Making the predictions
+
+
private List<Annotation> predict(Collection<AnnotationFS> candidates, DataMajorityModel aModel)
+{
+    List<Annotation> result = new ArrayList<>();
+    for (AnnotationFS token : candidates) {
+        String tokenText = token.getCoveredText();
+        if (tokenText.length() > 0 && !Character.isUpperCase(tokenText.codePointAt(0))) {
+            continue;
+        }
+
+        int begin = token.getBegin();
+        int end = token.getEnd();
+
+        Annotation annotation = new Annotation(aModel.majorityLabel, aModel.score,
+                aModel.numberOfAnnotations, begin, end);
+        result.add(annotation);
+    }
+
+    return result;
+}
+
+
+
+

We use the dummy score here from the training as the recommender score.

+
+
+
+
Evaluating
+
+

When configuring a recommender, it can be specified that it needs to achieve a certain score +before the recommendations are shown to the user. For that, the platform regularly evaluates +recommenders in the background. We use macro-averaged F1-score as an evaluation score. +In code, the evaluation is implemented in the evaluate method.

+
+
+

Evaluation is done on a set of documents. In order to properly divide the annotations into training +and test set, a DataSplitter is given which tells you to which data set an annotation belongs.

+
+
+

For the actual evaluation, we collect the true label and the predicted majority label in a +LabelPair for each true label. A stream of these instances can then be collected with +the use of an EvaluationResultCollector as an EvaluationResult object - the result of the +evaluation. This object provides access to calculations for token-based accuracy, macro-averaged +precision, recall and F1-score. This F1-score is later used for +comparison with the user-defined threshold to activate the recommender.

+
+
+
Evaluating the recommender
+
+
@Override
+public EvaluationResult evaluate(List<CAS> aCasses, DataSplitter aDataSplitter)
+    throws RecommendationException
+{
+    List<Annotation> data = extractAnnotations(aCasses);
+    List<Annotation> trainingData = new ArrayList<>();
+    List<Annotation> testData = new ArrayList<>();
+
+    for (Annotation ann : data) {
+        switch (aDataSplitter.getTargetSet(ann)) {
+        case TRAIN:
+            trainingData.add(ann);
+            break;
+        case TEST:
+            testData.add(ann);
+            break;
+        case IGNORE:
+            break;
+        }
+    }
+
+    int trainingSetSize = trainingData.size();
+    int testSetSize = testData.size();
+    double overallTrainingSize = data.size() - testSetSize;
+    double trainRatio = (overallTrainingSize > 0) ? trainingSetSize / overallTrainingSize : 0.0;
+
+    if (trainingData.size() < 1 || testData.size() < 1) {
+        log.info("Not enough data to evaluate, skipping!");
+        EvaluationResult result = new EvaluationResult(DATAPOINT_UNIT.getSimpleName(),
+                getRecommender().getLayer().getUiName(), trainingSetSize, testSetSize,
+                trainRatio);
+        result.setEvaluationSkipped(true);
+        return result;
+    }
+
+    DataMajorityModel model = trainModel(trainingData);
+
+    // evaluation: collect predicted and gold labels for evaluation
+    EvaluationResult result = testData.stream()
+            .map(anno -> new LabelPair(anno.label, model.majorityLabel))
+            .collect(toEvaluationResult(DATAPOINT_UNIT.getSimpleName(),
+                    getRecommender().getLayer().getUiName(), trainingSetSize, testSetSize,
+                    trainRatio));
+
+    return result;
+}
+
+
+
+
+
+

RecommendationFactory

+
+

The RecommendationFactory is used to create a new recommender instance. It also defines for which +types of layers and features the recommender itself can be used. Here, we decided to only support +token span layers without cross sentence annotations.

+
+
+
The RecommendationFactory
+
+
@ExportedComponent
+@Component
+public class DataMajorityRecommenderFactory
+    extends RecommendationEngineFactoryImplBase<Void>
+{
+    // This is a string literal so we can rename/refactor the class without it changing its ID
+    // and without the database starting to refer to non-existing recommendation tools.
+    public static final String ID = "de.tudarmstadt.ukp.inception.recommendation.imls.datamajority.de.tudarmstadt.ukp.inception.recommendation.imls.datamajority.DataMajorityNerRecommender";
+
+    @Override
+    public String getId()
+    {
+        return ID;
+    }
+
+    @Override
+    public RecommendationEngine build(Recommender aRecommender)
+    {
+        return new DataMajorityNerRecommender(aRecommender);
+    }
+
+    @Override
+    public String getName()
+    {
+        return "Data Majority Recommender";
+    }
+
+    @Override
+    public boolean accepts(AnnotationLayer aLayer, AnnotationFeature aFeature)
+    {
+        if (aLayer == null || aFeature == null) {
+            return false;
+        }
+
+        return (asList(SINGLE_TOKEN, TOKENS).contains(aLayer.getAnchoringMode()))
+                && !aLayer.isCrossSentence() && SPAN_TYPE.equals(aLayer.getType())
+                && CAS.TYPE_NAME_STRING.equals(aFeature.getType()) || aFeature.isVirtualFeature();
+    }
+}
+
+
+
+
+
+

External recommender

+
+

Overview

+
+

This section describes the External Recommender API for INCEpTION. An external recommender is a +classifier whose functionality is exposed via a HTTP web service. It can predict annotations for +given documents and optionally be trained on new data. This document describes the endpoints a web +service needs to expose so it can be used with INCEpTION. The documents that are exchanged are in +form of a UIMA CAS. For sending, they have to be serialized to CAS XMI. For receiving, it has to be +deserialized back. There are two main libraries available that manage CAS handling, one is the +Apache UIMA Java SDK, the other one dkpro-cassis (Python).

+
+
+
+

API Endpoints

+
+
Predict annotations for a single document
+
+
+
POST /predict
+
+
+
+
Description
+
+

Sends a CAS together with information about the layer and feature to predict to the external recommender. The external recommender then returns the CAS annotated with predictions.

+
+
+
+
Parameters
+ ++++++ + + + + + + + + + + + + + + + + +
TypeNameDescriptionSchema

Body

body
+required

Document CAS for which annotations will be predicted

PredictRequest

+
+
+
Responses
+ +++++ + + + + + + + + + + + + + + +
HTTP CodeDescriptionSchema

200

Successful prediction

PredictResponse

+
+
+
Consumes
+
+
    +
  • +

    application/json

    +
  • +
+
+
+
+
Produces
+
+
    +
  • +

    application/json

    +
  • +
+
+
+
+
Tags
+
+
    +
  • +

    predict

    +
  • +
+
+
+
+
Example HTTP request
+
+Request path +
+
+
/predict
+
+
+
+
+Request body +
+
+
{
+  "metadata" : {
+    "layer" : "de.tudarmstadt.ukp.dkpro.core.api.ner.type.NamedEntity",
+    "feature" : "value",
+    "projectId" : 1337,
+    "anchoringMode" : "tokens",
+    "crossSentence" : false
+  },
+  "document" : {
+    "xmi" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <xmi:XMI xmlns:tcas=\"http:///uima/tcas.ecore\" xmlns:xmi=\"http://www.omg.org/XMI\" xmlns:cas=\"http:///uima/cas.ecore\" xmlns:cassis=\"http:///cassis.ecore\" xmi:version=\"2.0\"> <cas:NULL xmi:id=\"0\"/> <tcas:DocumentAnnotation xmi:id=\"8\" sofa=\"1\" begin=\"0\" end=\"47\" language=\"x-unspecified\"/> <cas:Sofa xmi:id=\"1\" sofaNum=\"1\" sofaID=\"mySofa\" mimeType=\"text/plain\" sofaString=\"Joe waited for the train . The train was late .\"/> <cas:View sofa=\"1\" members=\"8\"/> </xmi:XMI>",
+    "documentId" : 42,
+    "userId" : "testuser"
+  },
+  "typeSystem" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <typeSystemDescription xmlns=\"http://uima.apache.org/resourceSpecifier\"> <types> <typeDescription> <name>uima.tcas.DocumentAnnotation</name> <description/> <supertypeName>uima.tcas.Annotation</supertypeName> <features> <featureDescription> <name>language</name> <description/> <rangeTypeName>uima.cas.String</rangeTypeName> </featureDescription> </features> </typeDescription> </types> </typeSystemDescription>"
+}
+
+
+
+
+
+
Example HTTP response
+
+Response 200 +
+
+
{
+  "document" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <xmi:XMI xmlns:tcas=\"http:///uima/tcas.ecore\" xmlns:xmi=\"http://www.omg.org/XMI\" xmlns:cas=\"http:///uima/cas.ecore\" xmlns:cassis=\"http:///cassis.ecore\" xmi:version=\"2.0\"> <cas:NULL xmi:id=\"0\"/> <tcas:DocumentAnnotation xmi:id=\"8\" sofa=\"1\" begin=\"0\" end=\"47\" language=\"x-unspecified\"/> <cas:Sofa xmi:id=\"1\" sofaNum=\"1\" sofaID=\"mySofa\" mimeType=\"text/plain\" sofaString=\"Joe waited for the train . The train was late .\"/> <cas:View sofa=\"1\" members=\"8\"/> </xmi:XMI>"
+}
+
+
+
+
+
+
+
Train recommender on a set of documents
+
+
+
POST /train
+
+
+
+
Description
+
+

Sends a list of CASses to the external recommender for training. No response body is expected.

+
+
+
+
Parameters
+ ++++++ + + + + + + + + + + + + + + + + +
TypeNameDescriptionSchema

Body

body
+required

List of documents CAS whose annotations will be used for training

Train

+
+
+
Responses
+ +++++ + + + + + + + + + + + + + + + + + + + +
HTTP CodeDescriptionSchema

204

Successful training

No Content

429

Too many training requests have been sent, the sender should wait a while until the next request

No Content

+
+
+
Consumes
+
+
    +
  • +

    application/json

    +
  • +
+
+
+
+
Tags
+
+
    +
  • +

    train

    +
  • +
+
+
+
+
Example HTTP request
+
+Request path +
+
+
/train
+
+
+
+
+Request body +
+
+
{
+  "metadata" : {
+    "layer" : "de.tudarmstadt.ukp.dkpro.core.api.ner.type.NamedEntity",
+    "feature" : "value",
+    "projectId" : 1337,
+    "anchoringMode" : "tokens",
+    "crossSentence" : false
+  },
+  "documents" : [ {
+    "xmi" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <xmi:XMI xmlns:tcas=\"http:///uima/tcas.ecore\" xmlns:xmi=\"http://www.omg.org/XMI\" xmlns:cas=\"http:///uima/cas.ecore\" xmlns:cassis=\"http:///cassis.ecore\" xmi:version=\"2.0\"> <cas:NULL xmi:id=\"0\"/> <tcas:DocumentAnnotation xmi:id=\"8\" sofa=\"1\" begin=\"0\" end=\"47\" language=\"x-unspecified\"/> <cas:Sofa xmi:id=\"1\" sofaNum=\"1\" sofaID=\"mySofa\" mimeType=\"text/plain\" sofaString=\"Joe waited for the train . The train was late .\"/> <cas:View sofa=\"1\" members=\"8\"/> </xmi:XMI>",
+    "documentId" : 42,
+    "userId" : "testuser"
+  } ],
+  "typeSystem" : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <typeSystemDescription xmlns=\"http://uima.apache.org/resourceSpecifier\"> <types> <typeDescription> <name>uima.tcas.DocumentAnnotation</name> <description/> <supertypeName>uima.tcas.Annotation</supertypeName> <features> <featureDescription> <name>language</name> <description/> <rangeTypeName>uima.cas.String</rangeTypeName> </featureDescription> </features> </typeDescription> </types> </typeSystemDescription>"
+}
+
+
+
+
+
+
+
+

Definitions

+
+
Document
+ +++++ + + + + + + + + + + + + + + + + + + + + + + + + +
NameDescriptionSchema

documentId
+optional

Identifier for this document. It is unique in the context of the project.
+Example : 42

integer

userId
+optional

Identifier for the user for which recommendations should be made.
+Example : "testuser"

string

xmi
+optional

CAS as XMI
+Example : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <xmi:XMI xmlns:tcas=\"http:///uima/tcas.ecore\" xmlns:xmi=\"http://www.omg.org/XMI\" xmlns:cas=\"http:///uima/cas.ecore\" xmlns:cassis=\"http:///cassis.ecore\" xmi:version=\"2.0\"> <cas:NULL xmi:id=\"0\"/> <tcas:DocumentAnnotation xmi:id=\"8\" sofa=\"1\" begin=\"0\" end=\"47\" language=\"x-unspecified\"/> <cas:Sofa xmi:id=\"1\" sofaNum=\"1\" sofaID=\"mySofa\" mimeType=\"text/plain\" sofaString=\"Joe waited for the train . The train was late .\"/> <cas:View sofa=\"1\" members=\"8\"/> </xmi:XMI>"

string

+
+
+
Metadata
+ +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameDescriptionSchema

anchoringMode
+required

Describes how annotations are anchored to tokens. Is one of 'characters', 'singleToken', 'tokens', 'sentences'.
+Example : "tokens"

string

crossSentence
+required

True if the project supports cross-sentence annotations, else False
+Example : false

boolean

feature
+required

Feature of the layer which should be predicted
+Example : "value"

string

layer
+required

Layer which should be predicted
+Example : "de.tudarmstadt.ukp.dkpro.core.api.ner.type.NamedEntity"

string

projectId
+required

The id of the project to which the document(s) belong.
+Example : 1337

integer

+
+
+
PredictRequest
+ +++++ + + + + + + + + + + + + + + + + + + + + + + + + +
NameDescriptionSchema

document
+required

Example : "Document"

Document

metadata
+required

Example : "Metadata"

Metadata

typeSystem
+required

Type system XML of the CAS
+Example : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <typeSystemDescription xmlns=\"http://uima.apache.org/resourceSpecifier\"> <types> <typeDescription> <name>uima.tcas.DocumentAnnotation</name> <description/> <supertypeName>uima.tcas.Annotation</supertypeName> <features> <featureDescription> <name>language</name> <description/> <rangeTypeName>uima.cas.String</rangeTypeName> </featureDescription> </features> </typeDescription> </types> </typeSystemDescription>"

string

+
+
+
PredictResponse
+ +++++ + + + + + + + + + + + + + + +
NameDescriptionSchema

document
+required

CAS with annotations from the external recommender as XMI
+Example : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <xmi:XMI xmlns:tcas=\"http:///uima/tcas.ecore\" xmlns:xmi=\"http://www.omg.org/XMI\" xmlns:cas=\"http:///uima/cas.ecore\" xmlns:cassis=\"http:///cassis.ecore\" xmi:version=\"2.0\"> <cas:NULL xmi:id=\"0\"/> <tcas:DocumentAnnotation xmi:id=\"8\" sofa=\"1\" begin=\"0\" end=\"47\" language=\"x-unspecified\"/> <cas:Sofa xmi:id=\"1\" sofaNum=\"1\" sofaID=\"mySofa\" mimeType=\"text/plain\" sofaString=\"Joe waited for the train . The train was late .\"/> <cas:View sofa=\"1\" members=\"8\"/> </xmi:XMI>"

string

+
+
+
Train
+ +++++ + + + + + + + + + + + + + + + + + + + + + + + + +
NameDescriptionSchema

documents
+required

CAS as XMI
+Example : [ "Document" ]

< Document > array

metadata
+required

Example : "Metadata"

Metadata

typeSystem
+required

Type system XML of the CAS
+Example : "<?xml version=\"1.0\" encoding=\"UTF-8\"?> <typeSystemDescription xmlns=\"http://uima.apache.org/resourceSpecifier\"> <types> <typeDescription> <name>uima.tcas.DocumentAnnotation</name> <description/> <supertypeName>uima.tcas.Annotation</supertypeName> <features> <featureDescription> <name>language</name> <description/> <rangeTypeName>uima.cas.String</rangeTypeName> </featureDescription> </features> </typeDescription> </types> </typeSystemDescription>"

string

+
+
+
+

Encoding annotation suggestions

+
+

This section explains how annotation suggestions can be encoded in the response to a predict call.

+
+
+

Note that a recommender can only produce suggestions for one feature on one layer. The name of the layer and feature are contained in the request to the predict call and only suggestions generated for that specific layer and feature will be processed by INCEpTION when the call returns.

+
+
+

For the purpose of producing annotation suggestions, this specific layer is extended with additional features that can be set. Some of these features start with the name of the feature (we use <FEATURE_NAME> as a placeholder for the actual feature name below) to be predicted and then add a suffix:

+
+
+
    +
  • +

    inception_internal_predicted: this boolean feature indicates that an annotation was added by the external recommender. It allows the system to distinguish between annotations that already existed in the document and annotations that the recommender has created. Only annotations where this flag is set to true will be processed by INCEpTION.

    +
  • +
  • +

    <FEATURE_NAME>: this feature takes the label that the external recommender assigns.

    +
  • +
  • +

    <FEATURE_NAME>_score (optional): this floating-point (double) feature can be used to indicate the score assigned to a predicted label.

    +
  • +
  • +

    <FEATURE_NAME>_score_explanation (optional): this string feature can be used to provide an explanation for the score. This explanation is shown on the annotation page when the user inspects a particular suggestion (note that not all editors may support displaying explanations).

    +
  • +
  • +

    <FEATURE_NAME>_auto_accept (optional): this feature can be set to on-first-access to force-accept an annotation into a document when an annotator accesses a document for the first time. This should only be used in conjunction with non-trainable recommenders and with the option Wait for suggestions from non-trainable recommenders when opening document in the recommender project settings. Thus, when an annotator opens a document for the first time, the system would wait for recommendations by non-trainable (pre-trained) recommenders and then directly accept any of the suggestions that the recommender has marked to uto-accept on-first-access. When the annotator resets a document via the action bar, this procedure is also followed. This provides a convenient way of "pre-annotating" documents with the help of external recommenders. Note though that an annotator has to actually open a document in order for this process to trigger.

    +
  • +
+
+
+
+
+
+
+

Active Learning

+
+
+

The active learning module aims to guide the user through recommendations in such a way that the +the judgements made by the user are most informative to the recommenders. The goal is to reduce +the required user interactions to a minimum. The module consists of the following classes and +interfaces:

+
+
+
    +
  • +

    The ActiveLearningService interface and its default implementation ActiveLearningServiceImpl +which provide access to the ranked suggestions.

    +
  • +
  • +

    The ActiveLearningStrategy interface which allows plugging in different sampling strategies.

    +
  • +
  • +

    The UncertaintySamplingStrategy class which is currently the only sampling strategy available.

    +
  • +
  • +

    The ActiveLearningSidebar class which provides the active learning sidebar for the annotation +page. Here the user can accept/reject/correct/skip suggestions.

    +
  • +
+
+
+

The active learning module relies on the recommendation module for the actual annotation +recommendations. This means that the active learning module does not directly make use of the +user feedback. If suggestions are accepted, they are used in the next train/predict run of the +recommendation module as training data. The active learning module then samples the new annotation +suggestions from this run and updates the order in which it offers the suggestions to the user.

+
+
+
+Diagram +
+
+
+
Events
+
    +
  • +

    ActiveLearningSuggestionOfferedEvent - active learning has pointed the user at a recommentation

    +
  • +
  • +

    ActiveLearningRecommendationEvent - user has accepted/rejected a recommendation

    +
  • +
  • +

    ActiveLearningSessionStartedEvent - user has opened an active learning session

    +
  • +
  • +

    ActiveLearningSessionCompletedEvent - user has closed the active learning session

    +
  • +
+
+
+

Sampling strategies

+
+

Uncertainty sampling

+
+

Currently, there is only a single sampling strategy, namely the UncertaintySamplingStrategy. It +it compares the scores of the annotation suggestion. The smaller the difference between +the best and the second best score, the earlier the suggestion is proposed to the user. The +scores produced by different recommenders can be on different scales and are therefore +not really comparable. Thus, the strategy only compares suggestions from the same recommender to +each other. So if recommender A produces two suggestions X and Y, they are compared to each other. +However, if there are two recommenders A and B producing each one suggestion X and Y, then X and Y +are not compared to each other.

+
+
+
+
+
+
+

Event Log

+
+
+

The event logging module allows catching Spring events and logging them them to the +database. It consists of the following classes and interfaces:

+
+
+
    +
  • +

    The EventRepository interface and its default implementation EventRepositoryImpl which +serve as the data access layer for logged events.

    +
  • +
  • +

    The EventLoggingListener which hooks into Spring, captures events, and then uses the +EventRepository to log them.

    +
  • +
  • +

    The EventLoggingAdapter interface. Spring components implementing this interface are +used to extract information from Spring events and to convert them into a format +suitable to be logged.

    +
  • +
  • +

    The LoggedEvent entity class which maps the logged events to the database.

    +
  • +
  • +

    The LoggedEventExporter and ExportedLoggedEvent which are used to export/import the +event log as part of a project export/import.

    +
  • +
+
+
+

The log module comes with a number of adapters for common events such as annotation +manipulation, changes to the project configuration, etc. Any event for which no specific +adapter exists is handled using the GenericEventAdapter which logs only general +information (e.g. the timestamp, current user, type of event) but no event-specific +details (e.g. current project, current document, or even more specific details). Note that +even the GenericEventAdapter skips logging certain Spring events related to session +management, authorization, and the Spring context life-cycle.

+
+
+

Event Logging Adapters

+
+

New logging adapters should be created in the module which provides the event they are logging. +Logging adapters for events generated outside INCEpTION (i.e. in upstream code) are usually +added to the log module itself.

+
+
+

To add support for a logging a new event, create a Spring component class which implements the +EventLoggingAdapter interface. Implement the following methods depending on the context in which +the event is triggered:

+
+
+
    +
  • +

    getProject(Event) if the event is triggered in the context of a specific project (applies to most +events);

    +
  • +
  • +

    getDocument(Event) if the event is related to a specific source document (e.g. applies to +events triggered during annotation).

    +
  • +
  • +

    getDocument(Event) if the event is related to a specific annotator (e.g. applies to +events triggered during annotation).

    +
  • +
+
+
+

The methods getEvent, getUser and getCreated normally do not need to be implemented.

+
+
+

Most event adapters implement the getDetails method. This method must return a JSON string which +contains any relevant information about the event not covered by the methods above. E.g. for an +annotation manipulation event, it would contain information helping to identify the annotation and +the state before and after the manipulation. In order to generate this JSON string, the adapter +typically contains an inner class called Details to which the detail information from the event +is copied and which is then serialized to JSON using JSONUtil.toJsonString(…​).

+
+
+
+
+
+

Knowledge base

+
+
+

Schema mapping

+
+

An IRI Schema defines the following attributes that are used for making queries in a knowledge base.

+
+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 4. Schema Mapping Attributes
AttributeDescriptionExample Value

Class IRI

Class of resources that are classes.

rdfs:Class

Subclass IRI

Property that defines a subclass of relation between classes.

rdfs:subClassOf

Type IRI

Property that defines which class a resource belongs to

rdf:type

Label IRI

Property that defines a human readable label for a class or instance

rdfs:label

Description IRI

Property that defines a description for a class or instance

rdfs:comment

Property IRI

Class of resources that are properties

rdf:Property

Subproperty IRI

Property that defines a subproperty of relation between properties.

rdfs:subPropertyOf

Property Label IRI

Property that defines a human readable label for a property

rdfs:label

Property Description IRI

Property that defines a description for a property

rdfs:comment

+
+

There are multiple classes in the knowledge base module that model the IRI Schema of a knowledge +base. All the classes share that they have a single class-attribute for each IRI in the IRI Schema. +However each class has a different use case. The relevant classes are shown here.

+
+
+ + + + + +
+ + +If the structure of the general IRI Schema is changed (e.g. a new attribute is added) all + the classes need to be adjusted.* +
+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + +
Table 5. Knowledge base & schema mapping classes
ClassUsage

KnowledgeBase

General model for a knowledge base in frontend and backend components.

KnowledgeBaseProfile and KnowledgeBaseMapping

Read pre-configured knowledge base profiles from a yaml file. + The actual IRI Schema is modeled in KnowledgeBaseMapping.java. + The yaml file is located at: …​/inception-kb/src/main/resources/de/tudarmstadt/ukp/inception/kb/knowledgebase-profiles.yaml

SchemaProfile

Defines some specific IRI Schemas (e.g RDF, WIKIDATA, SKOS).

ExportedKnowledgeBase

Export a knowledge base configuration when a project is exported.

+
+
+
+
+

Concept Linking

+
+
+

The concept linking module is used to find items from a knowledge base that match a certain query +and context. It is used e.g. by the ConceptFeatureEditor to display items which match a concept +mention and it can use the mention’s context to rank (and optimally disambiguate) the candidate +items. It can also be used for non-contextualized queries, e.g. via the search field on the +knowledge base browsing page. The module consists of the following classes and interfaces:

+
+
+
    +
  • +

    The ConceptLinkingService interface and its default implementation ConceptLinkingServiceImpl which +is the main entry point for locating KB items.

    +
  • +
  • +

    The EntityRankingFeatureGenerator interface. Spring beans which implement this interface are +automatically picked up by the ConceptLinkingServiceImpl and used to rank candidates.

    +
  • +
+
+
+

Ranking

+
+

Feature generators

+
+

The module currently uses primarily the LevenshteinFeatureGenerator which calculate the Levenshtein +distance between the mention text and the KB item label as well as between the query text (e.g. +entered into the auto-complete field of the ConceptFeatureEditor) and the KB item label.

+
+
+
+

Ranking strategy

+
+

The ranking method is currently hard-coded in ConceptLinkingServiceImpl.baseLineRankingStrategy().

+
+
+
+
+

Named entity linking recommender

+
+

The module also includes the NamedEntityLinker recommender which can be used to generate annotation +recommendations. It gets triggered for any NamedEntity annotations and suggests which KB items to +link them to.

+
+
+
+
+
+

External Editors

+
+
+

This section introduces the mechanism for registering external editors in INCEpTION. An external +editor is an editor plugin implemented in JavaScript / TypeScript.

+
+
+

In order to use an external editor, create a folder editors in the INCEpTION home folder, then +within that folder create another folder for the editor plugin. The name of the folder will be the +identifier of the editor plugin (e.g. if you would later rename the folder, the editor ID saved +in the editor user preference would become invalid).

+
+
+

Within the editor folder, create a plugin descriptor file named plugin.json. This file contains all +important information required by INCEpTION to use the editor.

+
+
+

The way the plugin descriptor needs to be set up depends mainly on whether the editor plugin takes +care of rendering the full document or only the annotations. However, some settings are generic +for any type of editor plugin:

+
+
+
    +
  • +

    name: the human-readable name for the editor

    +
  • +
  • +

    factory: the JavaScript expression to access the annotation editor factory provided by the plugin

    +
  • +
+
+
+

Document-rendering editors

+
+

A document-rendering editor loads the document and annotation data from the backend and then renders +the document including the annotations. This is typically the case for editors using SVG to display +the document. The editor has the ability to define the layout of the document in such a ways that +the annotations fit nicely.

+
+
+

For document-rendering editors, the plugin.json file offers the following settings:

+
+
+
    +
  • +

    view: the HTML file used as a template for the editor plugin. The value must start with plugin: +followed by a path to the HTML file within the plugin. E.g. if a template file editor.html is next +to the plugin.json file in the same folder, use plugin:editor.html.

    +
  • +
+
+
+

The external editor mechanism loads the template file within an IFrame that is embedded in the +annotation page. Any CSS or JavaScript files needed by the plugin must be referenced by the template +file using a relative location. For example let’s assume a file editor.html which needs to load +a editor.css style sheet and an editor.js JavaScript file:

+
+
+
+
<meta charset="utf-8">
+<title>DoccanoSequenceEditor demo</title>
+<script src="./editor.js"></script>
+<link rel="stylesheet" href="./editor.css">
+<div id="editor"/>
+
+
+
+
Example plugin.json for document-rendering editors
+
+
{
+  "name": "My editor",
+  "factory": "MyEditor.default.factory()"
+  "view": "plugin:editor.html"
+}
+
+
+
+
+

Editors using server-side document views

+
+

Some annotation editors overlay their annotations on an already existing document view. For example, +annotations could be overlaid on a HTML or PDF document. In this case, the external editor mechanism +can be configured to use a particular DocumentView plugin on the server to render the document and +to display it within an IFrame that is embedded in the annotation page. The editor plugin JavaScript +and CSS stylesheet files required are then injected into this IFrame as well.

+
+
+
+
{
+  "name": "My editor",
+  "factory": "MyEditor.factory()",
+  "view": "iframe:cas+html,
+  "scripts": [ "editor.js" ],
+  "stylesheets": [ "editor.css" ],
+}
+
+
+
+
+

Views

+
+

Currently supported views are:

+
+
+
    +
  • +

    iframe:cas+xml: Renders XML contained in the CAS into a generic XML IFrame in the editor area.

    +
  • +
  • +

    iframe:cas+xhtml+xml: Renders XML contained in the CAS into an XHTML+XML IFrame in the editor area. +HTML head and body elements are added automatically. The XML is rendered into the body.

    +
  • +
+
+
+
+

Policies

+
+

Every editor should provide a policy.yaml right next to the plugin.json. The policy.yaml declares +all elements and attributes that are supported by the editor. This policy file should be written as +a safelist, i.e. it should say exactly what is permitted instead of saying what is not allowed. +Allowing the wrong elements and attributes may cause security problems, e.g. if they can contain +executable JavaScript or load data from remote locations.

+
+
+

There are several elements like script, meta, applet, link, iframe as well as a which are +and JavaScript event attributes always filtered out.

+
+
+

If an editor does not provide a policy.yaml file, a default built-in policy is used which allows +most HTML formatting elements.

+
+
+
Example policy.yaml file
+
+
name: Example policy
+version: 1.0
+case_sensitive: false
+default_attribute_action: DROP
+default_element_action: DROP
+debug: false
+policies:
+  - { elements: ["html"], action: "PASS" }
+  - { elements: ["p", "div"], action: "PASS" }
+  - { elements: ["tr", "th"], action: "PASS" }
+  - { attributes: ["class"], action: "PASS" }
+  - { attributes: ["style"], action: "DROP" }
+  - {
+      attributes: ["title"],
+      matching: "[a-zA-Z0-9]*",
+      on_elements: ["div"],
+      action: "PASS",
+    }
+
+
+
+

There are two types of policies: element policies, and attribute policies.

+
+
+

Element policies

+
+

An element policy must contain the key elements which takes a list of element names and the key +action which can be either PASS or DROP. If an element is dropped, all child elements are +also dropped. Text within the child elements is replaced by an equivalent amount of space such that +offsets are not affected.

+
+
+

Note that the root element of your documents should always be allowed to PASS, otherwise the +document may fail to render.

+
+
+

It is possible to preserve elements within dropped elements by explicitly allowing the nested +elements to PASS.

+
+
+
+
policies:
+  - { elements: ["root", "child2"], action: "PASS" }
+  - { elements: ["child1"], action: "DROP" }
+
+
+
+

Using this policy, a document <root><child1><child2>text</child2></child1/></root> will be transformed +to <root><child2>text</child2></root>.

+
+
+
+

Attribute policies

+
+

An attribute policy must contain the key attributes which takes a list of attribute names, +and the key action which can be either PASS or DROP. Optionally it may contain the the key +onElements which takes a list of element names. If this key is present, the policy only affects +the attributes on the given elements, otherwise the policy affects all elements globally. Also, the +key matching can be optionally included to affect only attributes whose value matches the regular +expression provided as the value to matching.

+
+
+

When declaring attribute policies, the order matters. E.g. you should declare more specific policies +(e.g. such having a onElements or matching key) before less specific or global policies.

+
+
+
+

Debugging

+
+

To debug the rules, you can set the key debug to true and reload your editor in the browser. +Restarting the whole application is not required. When inspecting the content of the editor IFrame +in the browser’s developer tools, you will see that elements and attributes matched by a DROP +policy have been prefixed with MASKED- instead of being fully dropped. Do not forget to set +debug back to false or to remove the key for actual use.

+
+
+
+
+

Editor implementation

+
+

Editors can be implemented in JavaScript or languages that can be compiled to JavaScript such as +TypeScript. To facilitate the implementation, INCEpTION provides a set of interface definitions for +TypeScript, in particular AnnotationEditorFactory and AnnotationEditor.

+
+
+

To make use of these, set up a package.json file next to the plugin.json file. In the package.json +file, add @inception-project/inception-js-api as a dependency. The example below also already includes +TypeScript and ESBuild as dependencies.

+
+
+
+
{
+  "name": "My Editor",
+  "version": "0.0.1",
+  "scripts": {
+    "build": "esbuild src/main.ts --target=es6 --bundle --sourcemap --global-name=MyEditor --outfile=editor.js"
+  },
+  "dependencies": {
+    "@inception-project/inception-js-api": "*"
+  },
+  "devDependencies": {
+    "esbuild": "^0.13.12",
+    "typescript": "^4.4.2"
+  }
+}
+
+
+
+ + + + + +
+ + +The @inception-project/inception-js-api module should eventually be available from the NPMJS. However, if you + have INCEpTION checked out locally, you may want to build your editor against the latest local version. To do this, + first build INCEpTION once e.g. using mvn clean install or within your IDE. Then go to the folder + inception-application/inception/inception-js-api/src/main/ts in your checkout and run npm link. After that, go to the + folder containing your editor plugin and run npm link "@inception-project/inception-js-api" there. +
+
+
+

The minimal editor implementation consists of three JavaScript/TypeScript files:

+
+
+
    +
  • +

    main.ts: the entry point into your editor module. It is referenced by the build script in the +package.json file and provides access to your editor factory.

    +
  • +
  • +

    MyEditorFactory.ts: a factory class implementing the AnnotationEditorFactory interface which facilitates +access to your editor for the external editor mechanism. In particular, it provides means of +instantiating and destroying an editor instance.

    +
  • +
  • +

    MyEditor.ts: the actual editor class implementing the AnnotationEditor interface.

    +
  • +
+
+
+
Example main.ts file skeleton
+
+
import { MyEditorFactory } from './MyEditorFactory';
+
+const INSTANCE = new MyEditorFactory();
+
+export function factory(): MyEditorFactory {
+  return INSTANCE;
+}
+
+
+
+
Example MyEditorFactory.ts file skeleton
+
+
import type { AnnotationEditorFactory, AnnotationEditorProperties, DiamClientFactory } from "@inception-project/inception-js-api"
+
+const PROP_EDITOR = "__editor__";
+
+export class MyEditorFactory implements AnnotationEditorFactory {
+  public async getOrInitialize(element: HTMLElement, diam : DiamClientFactory, props: AnnotationEditorProperties): Promise<RecogitoEditor> {
+    if (element[PROP_EDITOR] != null) {
+      return element[PROP_EDITOR];
+    }
+
+    const ajax = diam.createAjaxClient(props.diamAjaxCallbackUrl);
+    const bodyElement = document.getElementsByTagName("body")[0];
+    element[PROP_EDITOR] = new MyEditor(bodyElement, ajax);
+    return element[PROP_EDITOR];
+  }
+
+  public destroy(element: HTMLElement) {
+    if (element[PROP_EDITOR] != null) {
+      element[PROP_EDITOR].destroy();
+    }
+  }
+}
+
+
+
+
Example MyEditor.ts file skeleton
+
+
import type { AnnotationEditor, DiamAjax } from "@inception-project/inception-js-api";
+
+const ANNOTATIONS_SERIALIZER = "Brat"; // The annotation format requested from the server
+
+export class RecogitoEditor implements AnnotationEditor {
+  private ajax: DiamAjax;
+
+  public constructor(element: HTMLElement, ajax: DiamAjax) {
+    this.ajax = ajax;
+
+    // Add editor code here - usually the editor code would be in a set of additional classes which would be
+    // instantiated and configured here and be bound to the given HTML element. Also, you would typically
+    // register event handlers here that call methods like `createAnnotation` and `selectAnnotation` below, e.g.
+    // when marking some text or clicking on an existing annotation.
+
+    this.loadAnnotations();
+  }
+
+  public loadAnnotations(): void {
+    this.ajax.loadAnnotations(ANNOTATIONS_SERIALIZER)
+      .then(data => {
+        // Place code here that causes your editor to re-render itself using the data received from the server
+      });
+  }
+
+  public destroy(): void {
+    // Depending on your editor implementation, it may be necessary to clean up stuff, e.g. to prevent memory leaks.
+    // Do these cleanup actions here.
+  }
+
+  private createAnnotation(annotation): void {
+    // This is an example event handler to be called by your editor. For example, it could pick up start and end offsets
+    // of the text to be annotated as well as the annotated text itself and send these to the server using the DIAM AJAX API
+    // that was injected by the exsternal editor mechanism. The server will update its state and send a `loadAnnotations()`
+    // call to the browser to trigger a re-rendering.
+    this.ajax.createSpanAnnotation([[annotation.begin, annotation.end]], annotation.text);
+  }
+
+  private selectAnnotation(annotation): void {
+    // This is an example event handler to be called by your editor. For example, it could pick up the annotation ID from
+    // the selected annotation and send it to the server using the DIAM AJAX API that was injected by the external editor
+    // mechanism. The server will update its state and send a `loadAnnotations()` call to the browser to trigger a re-rendering.
+    this.ajax.selectAnnotation(annotation.id);
+  }
+}
+
+
+
+
+
+
+

PDF Annotation Editor

+
+
+

The PDF-Editor module allows the view and annotation of PDF documents.

+
+
+

The module consists of several parts:

+
+
+
    +
  • +

    the VisualPdfReader is using pdfbox to extract the text from the PDF files. During this process, +it keeps track of the positions of each glyph (the "visual model") and also includes this +information as annotations in the CAS. The org.dkpro.core.api.pdf.type.PdfPage type encodes +information about page boundaries while the org.dkpro.core.api.pdf.type.PdfChunk type encodes +information about short sequences of glyphs that have the same orientation and script direction +(typically belonging to the same word).

    +
  • +
  • +

    the PdfDocumentFrameView is using pdf.js to display the PDF file in the browser. It provides +endpoints for the browser to access the PDF as well as for obtaining the visual model.

    +
  • +
  • +

    the PdfAnnotationEditor which builds on the PdfDocumentFrameView and includes the client-side +JavaScript code (loosely based on PDFAnno). For the communication of the editor with the +backend, the INCEpTION JS editor API (DIAM) is used.

    +
  • +
+
+
+
+
+

PDF Annotation Editor (legacy)

+
+
+
+
+ + + + + +
+ + +Legacy feature. To use this functionality, you need to enable it first by adding ui.pdf-legacy.enabled=true to the settings.properties file. +
+
+
+

Support for this feature will be removed in a future version. The replacement is PDF Annotation Editor.

+
+
+
+
+

The PDF-Editor module allows the view and annotation of PDF documents. +This is implemented using PDFAnno, PDFExtract and DKPro PDF Reader. +The choice for PDFAnno and other implementation choices +are explained in the following.

+
+
+

Selecting a PDF Annotation Tool

+
+

There are only few requirements to a PDF annotation tool for integration into +INCEpTION. +It must provide support for span and relation annotations and +it should also be lightweight and easily modifiable to fit into INCEpTION.

+
+
+

There are two PDF annotation tools up for discussion. +The first one is PDFAnno and the second +is Hypothes.is. +Both tools are web-based and open source software available on GitHub.

+
+
+

PDFAnno is a lightweight annotation tool that only supports the PDF format. +It was created specifically to solve the lack of free open source software for +annotating PDF documents which is also capable of creating relations between +annotations. This is described in the publication about PDFAnno by +Shindo et al.

+
+
+

Hypothes.is is a project that was created to provide an annotation layer +over the web. The idea is to be able to create annotations for all content +available on the internet and to share it with other people. +Hence Hypothes.is provides the functionality to annotate PDF documents.

+
+
+

PDFAnno compared to Hypothes.is comes with a smaller code base and is less +complex. +Both editors feature span annotations, however only PDFAnno provides the +functionality to create relations between span annotations which is required +in INCEpTION. +As Hypothes.is was designed to share annotations with others a login mechanism +is part of the software.

+
+
+

PDFAnno provides relations, is more lightweight and does not have a login +functionality, which would have to be removed. +Hence PDFAnno fits the requirements better than Hypothes.is and was +chosen as the PDF annotation tool for integration into INCEpTION.

+
+
+
+

Differences in PDF Document Text Extractions

+
+

PDFAnno uses PDF.js to render PDF documents +in the browser. +The tool PDFExtract is used +to extract information about the PDF document text. +It produces a file in which each line contains information about one +character of the text. +Information includes the page, the character and the position coordinates of the +character in the PDF document, in the given order and separated by a tab character. +An example:

+
+
+
+
1  E  0 1 2 3
+1  x  4 5 6 7
+1  a  8 9 10 11
+1  m  12 13 14 15
+1  p  16 17 18 19
+1  l  20 21 22 23
+1  e  24 25 26 27
+2  [MOVE_TO]  28 29
+2  NO_UNICODE  30 31 32 33
+
+
+
+

There are also draw operations included which are of no relevance for the use in +INCEpTION. +Characters which have no unicode mapping have the value NO_UNICODE. +The PDFExtract file does not contain information about any whitespaces that +occur in the PDF document text. +PDFAnno requires the PDF document and the PDFExtract file to work. +The PDF document can be obtained from the INCEpTION backend. +To also provide the PDFExtract file, the tool was slightly modified so that it +can be used as a library in INCEpTION.

+
+
+

PDFAnno provides an API for handling annotations. +It is possible to import a list of annotations by providing an URL for download. +This list has to be in the TOML format. +Span annotations require the begin and end positions of the characters it covers. +This positions are equal to the line number of characters in the PDFExtract +file. +A span annotation example in TOML format:

+
+
+
+
[[span]]
+id = "1"
+page = 1
+label = ""
+color = "#ff00ff"
+text = "Example"
+textrange = [1, 7]
+
+
+
+

The Brat editor used in INCEpTION works only on plain text. +For PDF documents this plain text is obtained by the use of DKPro PDF Reader. +The reader extracts the text information from the PDF document and performs +operations to ensure correct text ordering and to replace certain character +sequences with substitutes from a substitution table.

+
+
+

As the extractions between PDFAnno and INCEpTION differ a mapping of +those representations must be implemented to ensure annotations can be exchanged +between the frontend and the backend and are usable across all editor modes.

+
+
+
+

Preparing Representations

+
+

To use a mapping method between the text representation of PDFAnno and +INCEpTION at first they must be preprocessed to have a similar structure.

+
+
+

As the PDFExtract file does not only contain the text string, first +the characters of the file need to be obtained and appended to a +string. All draw operations and NO_UNICODE lines are ignored. +As DKPro PDF Reader uses a substitution table to sanitize the document text, +the same substitution table is used to sanitize the obtained string.

+
+
+

The PDFExtract file does not contain any whitespaces present in the document +text, however DKPro PDF Reader preserves them. +The whitespaces are removed from the DKPro PDF Reader string to have a similar +structure to the PDFExtract sanitized string content.

+
+
+
+matching +
+
Figure 1. Mapping Process (left) with examples (right)
+
+
+

Even though both representations now are in a similar shape it can still happen +that the content in both strings differs. +For example ordering of text areas could be messed up which can especially happen +for PDF documents that contain multiple text columns on one page. +As both representations are not equal even after preprocessing, a mapping algorithm +has to be implemented to find the text of annotations from one representation in the +respective other representation.

+
+
+
+

Mapping Annotations

+
+

There are multiple ways to achieve a mapping between PDFAnno and INCEpTION for +annotations. Two methods were tested during development: exact string search +with context and sequence alignment.

+
+
+

The first option is to make an exact search for the annotation text. +However as annotations often cover only one token an exact +search for the annotation text would result in multiple occurrences. +To get a unique result it is required to add context to the annotation text. +As this still can yield multiple occurrences, context is expanded until a unique +mapping or no mapping at all is found. +Performing this for all annotations results in a lot of string search operations. +However the performance can be improved by searching for all annotations in the +target string at once with the help of the +Aho-Corasick algorithm.

+
+
+

Another approach is to use sequence alignment methods which are popular in +bioinformatics. +PDF document texts are rather large and most sequence alignment algorithms +require O(M x N) memory space, where M and N are the size of the two sequences. +This results in a large memory consumption on computing the alignment, hence an +algorithm should be used that works with less memory. +Such an algorithm is Hirschbergs algorithm. +It consumes only O(min(M,N)) memory.

+
+
+

The advantage of the sequence alignment method would be a direct mapping between +the representation of PDFExtract and DKPro PDF Reader. +However, during testing for larger documents, for example 40 pages, the duration +until Hirschbergs algorithm finished was too long and would be unsatisfying for a user. +The exact string search however takes increasingly longer to compute mappings the +larger the document is and the more annotations have to be mapped. +As discussed the Aho-Corasick algorithm reduces the time. However, this still does not +scale well for larger documents. +To overcome this issue a page wise rendering of annotations was introduced. +When navigating through the PDF document in PDFAnno annotations are rendered +dynamically per page. +In detail, this means whenever the user moves through the document, the current +page changes and the user stops movement for 500 ms, the annotations for the +previous, current and next page are rendered. +This way large documents can be handled by the PDF editor without long wait times +for the user.

+
+
+

The exact string search seemed to perform well in terms of finding matching +occurrences for annotations in both directions. +For the manually tested documents all annotations were found and matched.

+
+
+
+inception pdf editor +
+
Figure 2. PDF Editor Architecture
+
+
+
+
+
+

File Formats

+
+
+

This section explains how to support different type of file formats for importing and exporting +annotated texts. The file format supports are mainly based on DKPro-Core-compatible reader and +writer UIMA components. They are then simply made known to the application via a FormatSupport +implementation.

+
+
+

The extension mechanism consists of the following classes and interfaces:

+
+
+
    +
  • +

    The FormatSupport interface which provides the API necessary to make file formats known to the +application. It providse means to fetch the format ID and the human-readable format name shown +in the UI. It also allows to create reader and/or writer components. Various implementations of +this interface are included with the application, e.g. the WebAnnoTsv3FormatSupport.

    +
  • +
  • +

    The ImportExportService interface and its implementation ImportExportServiceImpl which provide +access to the registered format supports and also offers methods to import and export annotated +text in any of the formats.

    +
  • +
+
+
+
+
+

Repository

+
+
+

The repository is a folder below the INCEpTION home folder which contains most of the +applications data that is not stored in the database. This includes in particular the original +documents imported into the application as well as annotations made by the users.

+
+
+

The source document data is managed by the DocumentService while the annotated documents are managed +by the CasStorageService.

+
+
+
+
+

┣ <project ID>.log - project log file
+┗ project
+  ┗ <project ID> - data related to the project with the given ID
+    ┣ document - managed by the CasStorageService
+    ┃  ┗ <document ID>
+    ┃    ┗ annotation
+    ┃      ┣ INITIAL_CAS.ser - initial converted version of the source document
+    ┃      ┣ <user ID>.ser
+    ┃      ┗ <user ID>.ser.<timestamp>.bak - backups of the user’s annotations (if enabled)
+    ┣ source - managed by the DocumentService
+    ┃  ┗ <original file> - original source file
+    ┗ settings
+      ┗ <user ID> - user-specific preferences
+        ┗ annotation.properties - annotation preferences

+
+
+
+
+
+

include::./developer-guide/release.adoc

+
+
+
+
+

Appendices

+
+

Appendix A: System Properties

+
+ ++++++ + + + + + + + + + + + + + + + + +
SettingDescriptionDefaultExample

wicket.core.settings.general.configuration-type

Enable Wicket debug mode

deployment

development

+
+
+
+ + + \ No newline at end of file diff --git a/releases/29.3/docs/developer-guide/images/diag-a06cf7943ca7daddfb1cc80682508375.png b/releases/29.3/docs/developer-guide/images/diag-a06cf7943ca7daddfb1cc80682508375.png new file mode 100644 index 0000000..9288f52 Binary files /dev/null and b/releases/29.3/docs/developer-guide/images/diag-a06cf7943ca7daddfb1cc80682508375.png differ diff --git a/releases/29.3/docs/developer-guide/images/inception-pdf-editor.png b/releases/29.3/docs/developer-guide/images/inception-pdf-editor.png new file mode 100644 index 0000000..aeabfb7 Binary files /dev/null and b/releases/29.3/docs/developer-guide/images/inception-pdf-editor.png differ diff --git a/releases/29.3/docs/developer-guide/images/matching.png b/releases/29.3/docs/developer-guide/images/matching.png new file mode 100644 index 0000000..6f8ecdb Binary files /dev/null and b/releases/29.3/docs/developer-guide/images/matching.png differ diff --git a/releases/29.3/docs/inception-logo.png b/releases/29.3/docs/inception-logo.png new file mode 100644 index 0000000..a014e0e Binary files /dev/null and b/releases/29.3/docs/inception-logo.png differ diff --git a/releases/29.3/docs/user-guide.html b/releases/29.3/docs/user-guide.html new file mode 100644 index 0000000..ceb133e --- /dev/null +++ b/releases/29.3/docs/user-guide.html @@ -0,0 +1,11949 @@ + + + + + + + + +INCEpTION User Guide + + + + + + + + + + + + + + + + + +
+

Getting Started

+
+
+
+

This Getting Started Guide helps new users to install, start and work with INCEpTION. +It gives a quick overview (estimated time for reading only: approx. 20-30 minutes) on the key functionalities in order to get familiar with the tool. +It excludes special cases and details due to simplicity and focuses on the first steps. See our documentation for further reading on any topic. +You are already in the User Guide document. +The main documentation of this User Guide starts right after the Getting Started section: Core Functionalities.

+
+
+

For quick overviews, also see our tutorial videos e.g. covering an Introduction, an Overview, Recommender Basics and Entity Linking. +Getting Started will refer to them wherever it might be helpful.

+
+
+ + + + + +
+ + +Boxes: In Getting Started, these boxes provide additional information. +They may be skipped for fast reading if background knowledge exists. +Also, they may be consulted later on for a quick look-up on basic concepts. +
+
+
+

After the Introduction, Getting Started leads you to using INCEpTION in three steps:

+
+
+
    +
  1. +

    We will see how to install it in Installing and starting INCEpTION.

    +
  2. +
  3. +

    In Project Settings and Structure of an Annotation Project, for a basic orientation and understanding the structure of a project will be explained.

    +
  4. +
  5. +

    You will be guided to make your first annotations in First Annotations with INCEpTION.

    +
  6. +
+
+
+
+
+

Introduction

+
+
+

What can INCEpTION be used for?

+
+

For a first impression on what INCEpTION is, you may want to watch our introduction video.

+
+
+

INCEpTION is a text-annotation environment useful for various kinds of annotation tasks on written text. +Annotations are usually used for linguistic and/or machine learning concerns. INCEpTION is a web application in which several users can work on the same annotation project and it can contain several annotation projects at a time. +It provides a recommender system to help you create annotations faster and easier. +Beyond annotating, you can also create a corpus by searching an external document repository and adding documents. +Moreover, you can use knowledge bases, e.g. for tasks like entity linking.

+
+
+

The following picture gives you a first impression on how annotated texts look like. +In this example, text spans have been annotated as whether they refer to a person (PER), location (LOC), organization (ORG) or any other (OTH).

+
+
+
+getting started example for annotations +
+
+
+

INCEpTION’s key features are: First, before you annotate, you need a corpus to be annotated (Corpus Creation). +You might have one already and import it or create it in INCEpTION. +Second, you might want to annotate the corpus (Annotation) and/or merge the annotations which different annotators made (Curation). +Third, you might want to integrate external knowledge used for annotating (Knowledge Bases). +You can do all three steps with +INCEpTION or only one or two.
+In addition, INCEpTION is extendable and adaptable to individual requirements. +Often, it provides predefined elements, like knowledge bases, layers and tagsets to give you a starting point but you can also modify them or create your own from scratch. +You may for example integrate a knowledge base of your choice; create and modify custom knowledge bases; create and modify custom layers and tagsets to annotate your individual task; build custom so-called recommenders which automatically suggest annotations to you so you will work quicker and easier; and much more.

+
+
+

Getting Started focuses on annotating. +For details on any other topic like Corpus Creation or the like, see the main documentation part of this User Guide: Core Functionalities.

+
+
+
+

Do you have questions or feedback?

+
+

INCEpTION is still in development, so you are welcome to give us feedback and tell us your wishes and requirements.

+
+
+ +
+
+
+

See our documentation for further reading

+
+

Our main documentation consists of three distinct documents:

+
+
+
    +
  • +

    User Guide: If you only use INCEpTION and do not develop it, the User Guide beginning right after Getting Started is the one of your choice. +If it does not answer your questions, don’t hesitate to contact us (see Do you have questions or feedback?).

    +
  • +
+
+
+ + + + + +
+ + +User Guide-Shortcuts: Whenever you find a blue question mark sign in the INCEpTION application, you may click on it to be linked to the respective section of the User Guide. +
+
+
+
    +
  • +

    Admin Guide: For information on how to set up INCEpTION for a group of users on a server and more installation details, see the Admin Guide.

    +
  • +
  • +

    Developer Guide: INCEpTION is open source. +So if you would like to develop for it, the Developer Guide might be interesting for you.

    +
  • +
+
+
+

All materials, including this guide, are available via the INCEpTION homepage.

+
+
+
+
+
+

Installing and starting INCEpTION

+
+
+

Installing Java

+
+

In order to run INCEpTION, you need to have Java installed in version 11 or higher. +If you do not have Java installed yet, please install the latest Java version e.g. from AdoptOpenJDK.

+
+
+
+

Download and start INCEpTION

+
+

In this section, we will download, open and log in to INCEpTION. +After, we will download and import an Example Project:

+
+
+

Step 1 - Download: Download the .jar-file from our website by clicking on INCEpTION x.xx.x (executable JAR) (instead of “x.xx.x”, there will be the number of the last release). +Wait a minute until it has been fully downloaded. +That is, until the name of the downloaded folder ends on “.jar“, not on “.jar.part“ anymore.

+
+
+ + + + + +
+ + +Working with the latest version: We recommend to always work with the latest version since we constantly add new features, improve usability and fix bugs. +After downloading the latest version, your previous work will not be lost: within a new version you will generally find all your projects, documents, users etc. like before without doing anything. +However, please consult the release notes on this beforehand. +To be notified when a new version has been released, please check the website, subscribe to Github notifications or the Google group (see Do you have questions or feedback?). +
+
+
+

Step 2 - Open: There are two ways to open the application: Either by double-clicking on it or via the terminal.

+
+
+

Step 2a - Open via double-click: Now, simply double-click on the downloaded .jar-file. +After a moment, a splash screen will display. +It shows that the application is loading.

+
+
+
+getting started starting the jar I +
+
+
+ + + + + +
+ + +In case INCEpTION does not start: If double-clicking the JAR file does not start INCEpTION, you might need to make the file executable first. +Right-click on the JAR file and navigate through the settings and permissions. +There, you can mark it as executable. +
+
+
+

Once the initialization is complete, a dialog appears. +Here, you can open the application in your default browser or shut it down again:

+
+
+
+getting started starting the jar II +
+
+
+

Step 2b - Open via terminal: If you prefer the command line, you may enter this command instead of double-clicking. +Make sure that instead of “x.xx.x”, you enter the version you downloaded:

+
+
+
+
$ java -jar inception-app-standalone-x.xx.x.jar
+
+
+
+

In this case, no splash screen will appear. +Just go to http://localhost:8080 in your browser.

+
+
+

Step 3 - Log in: The first time you start the application, a default user with the username admin and the password admin is created. +Use this username and password to log in to the application.

+
+
+
+getting started login +
+
+
+

You have finished the installation.

+
+
+ + + + + +
+ + +INCEpTION is designed for the browsers Chrome, Safari and Firefox. +It does work in other browsers as well but for these three, we can support you best. +For more installation details, see the Admin Guide. +
+
+
+
+

Download and import an Example Project

+
+

In order to understand what you read in this guide, it makes sense to have an annotation project to look at and click through. +We created several example projects for you to play with. +You find them in the section Example Projects on our website.

+
+
+
+getting started download example project +
+
+
+

Step 1 - Download: For this guide, we use the Interactive Concept Linking project. +Please download it from the Example Projects section on our website and save it without extracting it first. +It consists of two documents about pets. +The first one contains some annotations as an example, the second one is meant to be your playground. +It has originally been created for concept linking annotation but in every project, you can create any kind of annotations. +We will use it for Named Entity Recognition.

+
+
+ + + + + +
+ + +Named Entity Recognition: This is a certain kind of annotation. +In Getting Started, we use it to tell whether the annotated text part refers to a person (in INCEpTION, the built-in tag for person is PER), organization (ORG), location (LOC) or any other (OTH).
+The respective layer to annotate person/organization/location/other is the Named Entity layer. +If you are not sure what layers are, check the box on Layers and Features in the section Project Settings. +Also see Concept Linking in the User Guide. +
+
+
+
    +
  • +

    Step 2 - Import: After logging in to +INCEpTION, click on the Import project button on the top left (next to Create new project) and browse for the example project you have downloaded in Step 1. Finally, click Import. +The project has now been added and you can use it to follow the explanations of the next section.

    +
  • +
+
+
+
+getting started import project +
+
+
+
+

Project Settings

+
+

In this section we will see what elements each project has and where you can adjust these elements by examining the Project Settings. Note that you may have different projects in INCEpTION at the same time.

+
+
+

If you prefer to make some annotations first, you may go on with First Annotations with INCEpTION and return later.

+
+
+

Each project consists at least of the following elements. +There are more optional elements such as tagsets, document repositories etc. but to get started, we will focus on the most important ones:

+
+
+
    +
  • +

    one or (usually) more Documents to annotate

    +
  • +
  • +

    one or (usually) more Users to work on the project

    +
  • +
  • +

    one or (usually) more Layers to annotate with

    +
  • +
  • +

    Optional: one or more Knowledge Base/s

    +
  • +
  • +

    Optional: Recommenders to automatically suggest annotations

    +
  • +
  • +

    Optional: Guidelines for you and your team

    +
  • +
+
+
+

For a quick overview on the settings, you might want to watch our tutorial video Overview. +As for all topics of Getting Started, you will find more details on each of them in the main documentation on INCEpTION’s Core Functionalities.

+
+
+

The Settings provide a tab for each of these elements. +There are more tabs but we focus on the most important ones to get started. +You reach the settings after logging in when you click on the name of a project and then on Settings on the left. +If you have not imported the example project yet, we propose to follow the instruction in Download and import an Example Project first.

+
+
+
+getting started settings +
+
+
+

Documents

+
+

Here, you may upload your files to be annotated. +Make sure that the format selected in the dropdown on the right is the same as the one of the file to be uploaded.

+
+
+
+getting started documents +
+
+
+ + + + + +
+ + +Formats: For details on the different formats INCEpTION provides for importing and exporting single documents as well as whole projects, you may check the main documentation, Appendix A: Formats. +
+
+
+ + + + + +
+ + +INCEpTION Instance vs. +Project: In some cases, we have to distinguish between the INCEpTION instance we are working in and the project(s) it contains.
+For example, a user may be added to the INCEpTION instance but not to a certain project. +Or she may have different rights in several projects. +
+
+
+
+

Users

+
+

Here, you may add users to your project and change their rights within that project. +You can only add users to a project from the dropdown at the left if they exist already in the INCEpTION instance.

+
+
+
    +
  • +

    Add new users: In order to find users for a project in the dropdown, you need to add them to your INCEpTION instance first. +Click on the administration button in the very top right corner and select section Users on the left. +For user roles (for an instance of INCEpTION) see the User Management in the main documentation.

    +
    +
    +getting started create users +
    +
    +
  • +
  • +

    Giving rights to users: After selecting a user from the dropdown in the project settings section Users, you can check and uncheck the user’s rights on the right side. +User rights count for that project only and are different from user roles which count for the whole INCEpTION instance. +Any combination of rights is possible and the user will always have the sum of all rights given.

    +
    +
    +getting started users +
    +
    + +++++ + + + + + + + + + + + + + + + + + + + + + + + + +
    User RightDescriptionAccess to Dashboard Sections

    Annotator

    - annotate only

    - Annotation
    +- Knowledge Base

    Curator

    - curate only

    - Curation
    +- Workload
    +- Agreement
    +- Evaluation

    Manager

    - annotate
    +- curate
    +- create projects
    +- add new documents
    +- add guidelines
    +- manage users
    +- open annotated documents of other users (read only)

    - All pages

    +
  • +
+
+
+
+

Layers

+
+

In this section, you may create custom layers and modify them later. +Built-in layers should not be changed. +In case you do not want to work on built-in layers only but wish to create custom layers designed for your individual task, we recommend reading the documentation for details on Layers.

+
+
+
+getting started layers +
+
+
+ + + + + +
+ + +Layers and Features: There are different “aspects” or “categories” you might want to annotate. +For example, you might want to annotate all the places and persons in a text and link them to a knowledge base entry (see the box about Knowledge Bases) to tell which concrete place or person they are. +This type of annotation is called Named Entity. +In another case, you might want to annotate which words are verbs, nouns, adjectives, prepositions and so on (called Parts of Speech). +What we called “aspects”, “categories” or “ways to annotate” here, is referred to as layers in INCEpTION as in many other annotation tools, too.
+​
+INCEpTION supports span layers in order to annotate a span from one character (“letter”) in the text to another, relation layers in order to annotate the relation between two span annotations and chain layers which are normally used to annotate coreferences, that is, to show that different words or phrases refer to the same person or object (but not which one). +A span layer annotation always anchors on one span only. +A relation layer annotation always anchors on the two span annotations of the relation. +Chains anchor on all spans which are part of the chain. +For span layers, the default granularity is to annotate one or more tokens (“words”) but you can adjust to character level or sentence level in the layer details (see Layers in the main documentation; especially Properties).
+​
+Each layer provides appropriate fields, so-called features, to enter a label for the annotation of the selected text part. +For example, on the Named Entity layer in INCEpTION, you find two feature-fields: value and identifier. +In value, you can enter what kind of entity it is (“LOC” for a location, “PER” for a person, “ORG” for an organization and “OTH” for other). +In identifier you can enter which concrete entity (which must be in the knowledge base) it is. +For the example “Paris”, this may be the French capital; the person Paris Hilton; a company named “Paris” or something else. +​
+INCEpTION provides built-in layers with built-in features to give you a starting point. +Built-in layers cannot be deleted as custom layers can. +However, new features can be added. +See the main documentation for details on Layers, features, the different types of layers and features, how to create custom layers and how to adjust them for your individual task. +
+
+
+
+

Tagsets

+
+

Behind this tab, you can modify and create the tagsets for your layers. +Tagsets are always bound to a layer, or more precisely to a certain feature of a layer.

+
+
+ + + + + +
+ + +Tagsets: In order for all annotations to have consistent labels, it is preferable to use defined tags which can be given to the annotations. +If users do not enter free text for a label but stick to predefined tags, they avoid different names for the same thing and varying spelling. +A set of such defined tags is called a tagset i.e. a collection of labels which can be used for annotation. +INCEpTION comes with predefined tagsets out of the box and they serve as a suggestion and starting point only. +You can modify them or create your own ones. +
+
+
+ + + + + +
+ + +Feature Types: The tags of your tagset must always fit the type of the feature for which it will be used. +The feature type defines what type of information the feature can be, for example “Primitive: Integer” for whole numbers, “Primitive: Float” for decimals; “Primitive: Boolean” for a true/false label only; the most common one “Primitive: String” for text labels or “KB: Concept/Instance/Property” if the feature shall link to a knowledge base. +There are more types for features but these are the most important ones for you to know.
+Changing the type does only work for custom features, not for built-in features. +In order to do so, scroll in the Feature Details panel (in the Layers tab) until you see the field Type and select the type of your choice. +If a tagset shall be linked to a feature, they must have the same type. +For more details, see the Features in the main documentation. +
+
+
+
    +
  • +

    In order to create a new tagset, click on the blue create button on top. +Enter a name for it and - not technically necessary but highly recommended to avoid misunderstandings - a speaking description for the tagset. +As an example, let’s choose “Example_Tagset” for the name and “This tagset serves as a playground to get started.” for the description. +Check or uncheck Annotators may add new tags as you prefer. +Now, click on the blue save-button.

    +
  • +
  • +

    In order to fill your tagset with tags, first choose the set from the list on the left. +Then, click on the blue create-button in the Tags panel at the bottom. +A new panel called Tag Details opens right beside it. +Enter a name and description for a tag. +Let’s have “CAT” for the name and “This tag is to be used for every mention of a cat and only for mentions of cats.” for the description. +Click the save-button and the tag has now been added to your set. +As another example, create a new tag for the name “DOG” and description “This tag is to be used for every mention of a dog and only for mentions of dogs.”.

    +
    +
    +getting started tagset create +
    +
    +
  • +
  • +

    In order to use the tagset, it is necessary to link it to a layer and feature. +Herefore, click on the Layers tab and select the layer from the list at the left. +As an example, let’s select the layer Named entity. +Two new panels open now: Layer Details and Features. +We focus on the second one. +Choose the feature your tagset is made for. +In this example, we choose the feature value. +When you click on it, the panel Feature details opens. +In this panel, scroll down to Tagset and choose your tagset (to stick with our example: Example_Tagset) from the dropdown and click Save. +The tagset which was selected before is not linked to the layer any more but the new one is.

    +
    +
    +getting started tagset link +
    +
    +
  • +
  • +

    From now on, you can select your tags for annotating. +Navigate to the annotation page (click INCEpTION on the top left → Annotation and choose the document pets2.txt). +On the layer dropdown on the right, choose the layer Named entity. +When you double-click on any part in the text, for example “Socke” in line one, and click on the dropdown value on the right, you find the tags “DOG” and “CAT” to choose from. +(For details on how to annotate, see First Annotations with INCEpTION).

    +
    +
    +getting started tagset use +
    +
    +
  • +
  • +

    You might want to link Named Entity tags again to the Named entity Layer and value feature in order to use them like they were before our little experiment.

    +
  • +
  • +

    For more details on Tagsets, see the main documentation, Tagsets.

    +
  • +
  • +

    Note: Tagsets can be changed and deleted. +But the annotations they have been used for will remain with the same tag though. Other than the built-in layers, built-in tagsets can also be deleted.

    +
  • +
+
+
+ + + + + +
+ + +Saving: Some steps, like annotations, are saved automatically in INCEpTION. +Others need to be saved manually. +Whenever there is a blue Save button, it is necessary to click it to save the work. +
+
+
+
+

Knowledge Bases

+
+

In this section, you can change the settings for the knowledge bases used in your project, you can import local and remote knowledge bases into your project and you can create a custom knowledge base. +The latter will be empty at first. +It will not be filled here in the settings but at the knowledge base page ( → Dashboard, → Knowledge base; also see the part Knowledge Base in Structure of an Annotation Project). +In order to import or create a knowledge base, just click the Create button and INCEpTION will lead you.

+
+
+
+getting started kbs +
+
+
+ + + + + +
+ + +Knowledge Bases are data bases for knowledge. +Let’s assume, the mention “Paris” is to be annotated. +There are many different Parises - persons, the capital city of France and more - so the annotation is to tell clearly what entity with the name “Paris” is meant here. +Herefore, the knowledge base needs to have an entry of the correct entity. +In the annotation, we then want to make a reference to that very entry.
+There are knowledge bases on the web (“remote”) which can be used with INCEpTION like e.g. WikiData. +You can also create your own, new knowledge bases and use them in INCEpTION. +They will be saved on your device (“local”). +
+
+
+
    +
  • +

    Note that you can have several knowledge bases in your INCEpTION instance but you can choose for every project which one(s) to use. +Using many little knowledge bases in one project will slow down the performance more than few big ones.

    +
  • +
  • +

    Via the Dashboard (click the Dashboard-button at the top centre), you get to the knowledge base page. +This is a page different from the one in the project settings where you can modify and work on your knowledge bases.

    +
    +
    +getting started kb page +
    +
    +
  • +
  • +

    For details on knowledge bases, see our main documentation on Knowledge Bases, or our tutorial video “Overview“ mentioning knowledge bases.

    +
  • +
  • +

    If you like to explore a knowledge base check the example project we have downloaded and imported before. +It contains a small knowledge base, too.

    +
  • +
+
+
+
+

Recommenders

+
+

In this section, you can create and modify your recommenders. +They learn from what the user annotates and give suggestions. +For details on how to use recommenders, see our main documentation on Recommenders in the Annotation section. +For details on how to create and adjust them, see Recommenders in the Projects section. +Or check the tutorial video “Recommender Basics”.

+
+
+
+getting started recommenders +
+
+
+
Guidelines
+
+

In this section, you may import files with annotation guidelines. +There is no automatic correction or warning from INCEpTION if guidelines are violated but it is a short way for every user in the project to read and check the team guidelines while working. +On the annotation page (→ DashboardAnnotation → open any document), annotators can quickly look them up by clicking on the guidelines button on the top which looks like a book (this button only appears if at least one guideline was imported).

+
+
+
+getting started guidelines +
+
+
+
+
+

Export

+
+

In this section, you can export your project partially or wholly. +Projects which have been exported can be imported again in INCEpTION the way we did with our example project in section Download and import an Example Project: at the start page with the Import button. +We recommend exporting projects on a regular basis in order to have a backup. +For the different formats, their strengths and weaknesses, check the main documentation, Appendix A: Formats. +We recommend using WebAnno TSV x.x (where “x.x.” is the highest number available, e.g. 3.2) whenever possible. +Since it has been created specially for this application, it will provide all features required. +However, many other formats are provided.

+
+
+
+
+

Structure of an Annotation Project

+
+

Here, we will find out what you can do in each project having a look at the Structure of an Annotation Project. Therefore, we examine the dashboard.

+
+
+

If you are in a project already, click on the dashboard button on the top to get there. +If you just logged in, choose a project by clicking on its name. +As you are a Project Manager (see User Rights), you see all of the following sub pages. +For details on each section, check the section on Core Functionalities.

+
+
+

Annotation

+
+

If you went to First Annotations with INCEpTION before, you have been here already. +Here, the annotators can go to annotate the texts.

+
+
+
+

Curation

+
+

Everyone with curation rights (see User Rights) within a project can curate it. +All other users do not have access to nor see this page. +Only documents marked as finished by at least one annotator can be curated. +For details on how to curate, see the main documentation → Curation or just try it out:

+
+
+ + + + + +
+ + +Curation: If several annotators work on a project, their annotations usually do not match perfectly. +During the process called "Curation", you decide which annotations to keep in the final result. +
+
+
+
    +
  • +

    Create some annotations in any document

    +
  • +
  • +

    Mark the document as finished: Just click on the lock on top.

    +
  • +
  • +

    Add another user, just for testing this (see Users in the section Project Settings).

    +
  • +
  • +

    Log out and log in again as the test user.

    +
  • +
  • +

    In the very same document, make some annotations which are the same and some which are different than before. +Mark the document as finished.

    +
  • +
  • +

    Log in as any user with curation rights (e.g. as the “admin” user we used before), enter the curation page and explore how to curate: You see the automatic merge on top (what both users agreed on has been accepted already) and the annotations of each of the users below. +Differences are highlighted. +You can accept an annotation by clicking on it.

    +
  • +
+
+
+
+getting started curation +
+
+
+
    +
  • +

    As a curator, you can also create new annotations on this page. +It works exactly like on the Annotation page. +Note that users who have nothing but curation rights do not see nor have access to the annotation page (see User Rights).

    +
  • +
+
+
+
+

Knowledge Base

+
+

Also see the section on knowledge bases in the project settings. +On the Knowledge Base page, you can manage and create your knowledge base(s) for the project you are in. +You can create new knowledge bases from scratch, modify them and integrate existing knowledge bases into your project which are either local (that is, they are saved on your device) or remote (that is, they are online). +Note that this knowledge base page is distinct from the tab of the same name in the project settings (see Knowledge Base in section Project Settings).

+
+
+
+

Agreement

+
+

On this page, you can calculate the annotator agreement. +Note: Only documents marked as finished by annotators (clicking on the little lock on the annotation page) are taken into account.

+
+
+ + + + + +
+ + +Agreement: The annotations of different annotators usually do not match perfectly. +This aspect of difference / similarity is called agreement. +For agreement, some common measures are provided. +
+
+
+
+getting started agreement +
+
+
+
+

Workload

+
+

Here you can check the overall progress of your project; see which user is working on or has finished which document; and toggle for each user the status of each document between Done / In Progress or between New / Locked. +For details, see Workload Management in the main documentation.

+
+
+
+getting started monitoring +
+
+
+
+

Evaluation

+
+

The evaluation page shows a learning curve diagram of each recommender (see Recommender).

+
+
+
+

Settings

+
+

Here, you can organize, manage and adjust all the details of your project. +We had a look at those you need to get started for your own projects in the section Project Settings already.

+
+
+

This was the overview on what you can do in each project and what elements each project has. +Now you are ready to go for your own annotations.

+
+
+
+
+

First Annotations with INCEpTION

+
+

In this section, we will make our first annotations. +If you have not downloaded and imported an example project yet, we recommend to return to Download and import an Example Project and do so first. +In this section, no or little theory and background will be explained. +In case you want to have some theory and background knowledge first, we recommend reading the section Structure of an Annotation Project.

+
+
+

Create your first annotations

+
+
+

This will lead you step by step. +You also may want to watch our tutorial video „Overview“ on how to create annotations. +We will create a Named Entity annotation which tells whether a mention is a person (PER), location (LOC), organization (ORG) or other (OTH):

+
+
+ + + + + +
+ + +Creating your own Projects: In this guide, we will use our example project. +If you would like to create your own project later on, click on create, enter a project name and click on save. +Use the Projects link at the top of the screen to return to the project overview and select the project you just created to work with it. +See Project Settings in order to add documents, users, guidelines and more to your project. +
+
+
+

Step 1 - Opening a Project: After logging in, what you see first is the Project overview. +Here, you can see all the projects which you have access to. +Right now, this will be only the example project. +Choose the example project by clicking on its name and you will be on the Dashboard of this project.

+
+
+
+getting started open a project +
+
+
+ + + + + +
+ + +Instructions to Example Projects: In case of the example project, on the dashboard you also find instructions how to use it. +This goes for all our example projects. +You may use it instead of or in addition to the next steps of this guide.
+In case of your own projects, you will find the description you have given it instead. +
+
+
+

Step 2 - Open the Annotation Page: In order to annotate, click on Annotation on the top left. +You will be asked to open the document which you want to annotate. +For this guide, choose pets1.tsv.

+
+
+ + + + + +
+ + +Annotations in newly imported Projects: In the example project, you will see several annotations already. +If you import projects or single documents (see Documents) without any annotations, there will be none. +But in the example projects, we have added some annotations already as examples. +If you export a project (see Export) and import it again (as we just did with the example project in Download and import an Example Project), there will be the same annotations as before. +
+
+
+

Step 3 - Create an Annotation: After opening the document, select Named entity from the Layer dropdown menu on the right side of the screen to create your first annotation. +Then, use the mouse to select a word in the annotation area, e.g. in my home in line one. +When you release the mouse button, the annotation will immediately be created and you can edit its details in the right sidebar (see next paragraph). +These “details” are the features we mentioned before.

+
+
+
+getting started first annotation +
+
+
+

Note: All annotations will be saved automatically without clicking an extra save-button.

+
+
+

Congratulations, you have created your first annotation!

+
+
+

Now, let‘s examine the right panel to edit the details or to be precise: the features. +You find the panel named Layer on top and Annotation below.

+
+
+

In the Layer-dropdown, you can choose the layer you want to annotate with as we just did. +You always have to choose it before you make a new annotation. +After an annotation has been created, its layer cannot be changed any more. +In order to change it, you need to delete it, select the right layer and create a new annotation.

+
+
+

If you are not sure what layers are, check the box on Layers and Features in the section Project Settings. +In order to learn how to adjust and create them for your purpose, see section Layers in the main documentation.

+
+
+

In the Annotation panel, you see the details of a selected annotation. +They are called features.

+
+
+
+getting started annotation panel +
+
+
+

It shows the layer the annotation is made in (field Layer; here: Named entity) and what part of the text has been annotated (field Text; here in my home). +Below, you can see and modify what has been entered for each of the so-called Features. +If you are not sure what features are, check the box on Layers and Features in the section Project Settings (Here: The layer Named entity (see the note box on Named Entity) has the features identifier and value. +The identifier tells, to which entity in the knowledge base the annotated text refers to. +For example, in case the home referred to here is a location the knowledge base knows, you can choose it in the dropdown of this field. +The value tells if it is a Location (LOC) like here, a Person (PER), Organization (ORG) or any other (OTH).).
+You may enter free text here or work with tagsets to have a well defined set of labels to enter so all of the users within one project will use the same labels. +You can modify and create tagsets in the project settings. +See section Tagsets in Getting Started or check the main documentation for Tagsets.

+
+
+

You have almost finished the Getting Started. +One word can still be said about the Sidebars on the left. These offer access to various +additional functionalities such as an annotation overview, search, recommenders, etc. Which +functionalities are available to you is determined by the project settings. The sidebars can be +opened by clicking on one of the sidebar icons and they can be closed by clicking on the arrow icon at the top.

+
+
+
+getting started Sidebar closed +
+
+
+
+getting started Sidebar open +
+
+
+

There are several features you might want to check the main documentation for. +Especially the Recommender section of the sidebar (the black speech bubble) is worth a look in case you use recommenders (see Recommenders in the section Project Settings). +Amongst others, you will find their measures and learning behaviours here. +Also note the Search in the sidebar (the magnifier glass): You can create or delete annotations on all or some of the search results.

+
+
+

To get familiar with INCEpTION, you may want to follow the instructions for other example-projects, read more in-depth explanations on its Core Functionalities or explore INCEpTION yourself, learning by doing.

+
+
+

One way or the other: Have fun exploring!

+
+
+
+

Thank You

+
+

We hope the Getting Started helped you with your first steps in INCEpTION and gave you a general idea of how it works. +For further reading and more details, we recommend the main documentation, starting right after this paragraph.

+
+
+

Do not hesitate to contact us if you struggle, have any questions or special requirements. +We wish you success with your projects and you are welcome to let us know what you are working on.

+
+
+
+
+
+

Core functionalities

+
+

Workflow

+
+
+

The following image shows an exemplary workflow of an annotation project with INCEpTION.

+
+
+
+progress workflow +
+
+
+

First, the projects need to be set up. In more detail, this means that users are to be added, +guidelines need to be provided, documents have to be uploaded, tagsets need to be defined and uploaded, +etc. The process of setting up and managing a project are explicitly described in Projects.

+
+
+

After the setup of a project, the users who were assigned with the task of annotation annotate the +documents according to the guidelines. The task of annotation is further explained in Annotation. +The work of the annotators is managed and controlled by monitoring. Here, the person in charge has +to assign the workload. For example, in order to prevent redundant annotation, documents which are +already annotated by several other annotators and need not be annotated by another person, can be +blocked for others. The person in charge is also able to follow the progress of individual +annotators. All these tasks are demonstrated in Workload Management in more detail. The person in charge should not only control the quantity, but also the quality of annotation by looking closer into the +annotations of individual annotators. This can be done by logging in with the credentials of the +annotators.

+
+
+

After at least two annotators have finished the annotation of the same document by clicking on Done, the +curator can start his work. The curator compares the annotations and corrects them if needed. This +task is further explained in Curation.

+
+
+

The document merged by the curator can be exported as soon as the curator clicked on Done for the +document. The extraction of curated documents is also explained in Projects.

+
+
+
+
+

Logging in

+
+
+

Upon opening the application in the browser, the login screen opens. Please enter your +credentials to proceed.

+
+
+ + + + + +
+ + +When INCEpTION is started for the first time, a default user called admin with the password admin is automatically created. Be sure to change the password for this user after logging in (see User Management). +
+
+
+
+version3 login +
+
+
+
+
+
+

Dashboard

+
+
+

The dashboard allows you to navigate the functionalities of INCEpTION.

+
+
+

Menu bar

+
+

At the top of the screen, there is always a menu bar visible which allows a quick navigation within +the application. It offers the following items:

+
+
+
    +
  • +

    Projects - always takes you back to the Project overview.

    +
  • +
  • +

    Dashboard - is only visible if it is possible to take you to your last visited Project dashboard.

    +
  • +
  • +

    Help - opens the integrated help system in a new browser window.

    +
  • +
  • +

    Administration - takes you to the administrator dashboard which allows configuring projects +or managing users. This item is only available to administrators.

    +
  • +
  • +

    Username - shows the name of the user currently logged in. If the administrator has allowed +it, this is a link which allows accessing the current user’s profile, e.g. to change the +password.

    +
  • +
  • +

    Log out - logs out of the application.

    +
  • +
  • +

    Timer - shows the remaining time until the current session times out. When this happens, +the browser is automatically redirected to the login page.

    +
  • +
+
+
+
+

Project overview

+
+

After logging in to INCEpTION, the first thing you see is the project overview. Here, you can +see all the projects to which you have access. For every project, the roles you have are shown.

+
+
+

Using the filter toggle buttons, you can select which projects are listed depending on the +role that you have in them. By default, all projects are visible.

+
+
+

Users with the role project creator can conveniently create new projects or +import project archives on this page.

+
+
+

Users without a manager role can leave a project by clicking on the Leave Project button +below the project name.

+
+
+

When uploading projects via this page, user roles for the project are not fully imported! +If the importing user has the role project creator, then the manager role is added +for the importing user. Otherwise, only the roles of the importing user are retained.

+
+
+

If the current instance has users with the same name as those who originally worked on the +import project, the manager can add these users to the project and they can access their annotations. +Otherwise, only the imported source documents are accessible.

+
+
+

Users with the role administrator who wish to import projects with all permissions and optionally +create missing users have to do this through the Projects which can be access through +the Administration link in the menu bar.

+
+
+
+

Project dashboard

+
+

Once you have selected a project from the Project overview, you are taken to this project’s +dashboard. Depending on the roles that a user has in the project, different functionalities can +be accessed from here such as annotation, curation and project configuration. +On the right-hand side of the page, some of the last activities of the user in this project are shown. +The user can click on an activity to resume it e.g. if the user annotated a specific document, +the annotation page will be opened on this document.

+
+
+
+
+
+
+

Annotation

+
+
+ + + + + +
+ + +This functionality is only available to annotators and managers. Annotators and managers + only see projects in which they hold the respective roles. +
+
+
+

The annotation screen allows to view text documents and to annotate them.

+
+
+

In addition to the default annotation view, PDF documents can be viewed and annotated using the PDF-Editor. Please refer to PDF Annotation Editor for an explanation on navigating and annotating in the PDF-view.

+
+
+

Opening a Document for Annotation

+
+

When navigating to the Annotation page, a dialogue opens that allows you to select the document you want to annotate. If you want to access this dialog later, use the Open button in the action bar.

+
+
+
+open doc +
+
+
+

The keyboard focus is automatically placed into the search field when the dialog opens. You can use it to conveniently search for documents by name. The table below is automatically filtered according to your input. +If only one document is left, you can press ENTER to open it. Otherwise, you can click on a document in the table to open it. +The Filter buttons allow to filter the table by document state.

+
+
+

Users that are managers can additionally open other users' documents to view their annotations but cannot change them. This is down via the User dropdown menu. The user’s own name is listed at the top and marked (me).

+
+
+
+

Navigation

+
+

Sentence numbers on the left side of the annotation page show the exact sentence numbers in the document.

+
+
+
+annotation3 +
+
+
+

The arrow buttons first page, next page, previous page, last page, and go to page allow you to navigate accordingly.

+
+
+

The Prev. and Next buttons in the Document frame allow you to go to the previous or next document on your project list.

+
+
+

When an annotation is selected, there are additional arrow buttons in the right sidebar +which can be used to navigate between annotations on the selected layer within the current document.

+
+
+

You can also use the following keyboard assignments in order to navigate only using your keyboard.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 1. Navigation key bindings
KeyAction

Home

go to the start of the document

End

go to the end of the document

Page-Down

go to the next page, if not in the last page already

Page-Up

go to previous page, if not already in the first page

Shift+Page-Down

go to next document in project, if available

Shift+Page-Up

go to previous document in project, if available

Shuft+Cursor-Left

go to previous annotation on the current layer, if available

Shift+Cursor-Right

go to next annotation on the current layer, if available

Shift+Delete

delete the currently selected annotation

Ctrl+End

toggle document state (finished / in-progress)

+
+
+

Creating annotations

+
+

The Layer box in the right sidebar shows the presently active layer span layer. To create a span +annotation, select a span of text or double click on a word.

+
+
+

If a relation layer is defined on top of a span layer, clicking on a corresponding span annotation +and dragging the mouse creates a relation annotation.

+
+
+

Once an annotation has been created or if an annotation is selected, the Annotation box shows +the features of the annotation.

+
+
+

The definition of layers is covered in Section Layers.

+
+
+

Spans

+
+

To create an annotation over a span of text, click with the mouse on the text and drag the mouse to create a selection. When you release the mouse, the selected span is activated and highlighted in orange. The annotation detail editor is updated to display the text you have currently selected and to offer a choice on which layer the annotation is to be created. As soon as a layer has been selected, it is automatically assigned to the selected span. To delete an annotation, select a span and click on Delete. To deactivate a selected span, click on Clear.

+
+
+

Depending on the layer behavior configuration, span annotations can have any length, can overlap, +can stack, can nest, and can cross sentence boundaries.

+
+
+
Example
+

For example, for NE annotation, select the options as shown below (red check mark):

+
+
+
+annotation2 +
+
+
+

NE annotation can be chosen from a tagset and can span over several tokens within one sentence. Nested NE annotations are also possible (in the example below: "Frankfurter" in "Frankfurter FC").

+
+
+
+annotation ner +
+
+
+

Lemma annotation, as shown below, is freely selectable over a single token.

+
+
+
+annotation lemma +
+
+
+

POS can be chosen over one token out of a tagset.

+
+
+
+annotation pos +
+
+
+
Zero-width spans
+

To create a zero-length annotation, hold Shift and click on the position where you wish to create the annotation. To avoid accidental creations of zero-length annotations, a simple single-click triggers no action by default. The lock to token behavior cancels the ability to create zero-length annotations.

+
+
+ + + + + +
+ + +A zero-width span between two tokens that are directly adjacent, e.g. the full stop at the + end of a sentence and the token before it (end.) is always considered to be at the end of the + first token rather than at the beginning of the next token. So an annotation between d and . + in this example would be rendered at the right side of end rather than at the left side of .. +
+
+
+

Co-reference annotation can be made over several tokens within one sentence. A single token sequence can have several co-ref spans simultaneously.

+
+
+
+

Relations

+
+

In order to create relation annotation, a corresponding relation layer needs to be defined +and attached to the span layer you want to connect the relations to. An example of a relation +layer is the built-in Dependency relation layer which connects to the Part of speech +span layer, so you can create relations immediately on the Part of speech layer to try it out.

+
+
+

If you want to create relations on other span layers, you need to create a new layer of type +Relation in the layer settings. Attach the new relation layer +to a span layer. Note that only a single relation layer can connect to any given span layer.

+
+
+

Then you can start connecting the source and target annotations using relations.

+
+
+

There are two ways of creating a relation:

+
+
+
    +
  • +

    for short-distance relations, you can conveniently create relation by left-clicking on a span and +while keeping the mouse button pressed moving the cursor over to the target span. A rubber-band +arc is shown during this drag-and-drop operation to indicate the location of the relation. +To abort the creation of an annotation, hold the CTRL key when you release the mouse button.

    +
  • +
  • +

    for long-distance relations, first select the source span annotation. Then locate the target +annotation. You can scroll around or even switch to another page of the same document - just +make sure that your source span stays selected in the annotation detail editor panel on the right. +Once you have located the target span, right-click on it and select Link to…​. Mind that +long-ranging relations may not be visible as arcs unless both the source and target spans are +simultaneously visible (i.e. on the same "page" of the document). So you may have to increase the +number of visible rows in the settings dialog to make them visible.

    +
  • +
+
+
+
Navigating along relations
+

When a relation annotation is selected, the annotation detail panel includes two fields From and +To which indicate the origin and target annotations of the relation. These fields include a small +cross-hair icon which can be used to jump to the respective annotations.

+
+
+

When a span annotation is selected, and incoming or outgoing relations are also shown in the +annotation detail panel. Here, the cross-hair icon can be used to jump to the other endpoint of the +relation (i.e. to the other span annotation). There is also an icon indicating whether the relation +is incoming to the selected span annotation or whether it is outgoing from the current span. +Clicking on this icon will select the relation annotation itself.

+
+
+

Depending on the layer behavior configuration, relation annotations can stack, can cross each other, +and can cross sentence boundaries.

+
+
+
Self-looping relations
+

To create a relation from a span to itself, press the Shift key before starting to drag the mouse +and hold it until you release the mouse button. Or alternatively select the span and then +right-click on it and select Link to…​.

+
+
+ + + + + +
+ + +Currently, there can be at most one relation layer per span layer. Relations between spans + of different layers are not supported. +
+
+
+ + + + + +
+ + +Not all arcs displayed in the annotation view are belonging to chain or relation layers. Some + are induced by Link Features. +
+
+
+

When moving the mouse over an annotation with outgoing relations, the info pop-up includes the +yield of the relations. This is the text transitively covered by the outgoing relations. This +is useful e.g. in order to see all text governed the head of a particular dependency relation. +The text may be abbreviated.

+
+
+
+annotation relation yield +
+
Figure 1. Example of the yield of a dependency relation
+
+
+
+

Chains

+
+

A chain layer includes both, span and relation annotations, into a single structural layer. Creating +a span annotation in a chain layer basically creates a chain of length one. Creating a relation +between two chain elements has different effects depending on whether the linked list behavior +is enabled for the chain layer or not. To enable or disable the linked list behaviour, go to Layers +in the Projects Settings mode. After choosing Coreference, linked list behaviour +is displayed in the checkbox and can either be marked or unmarked.

+
+
+
+LinkedList 1 +
+
Figure 2. Configuration of a chain layer in the project settings
+
+
+
+annotation span many +
+
Figure 3. Example of chain annotations
+
+
+

To abort the creation of an annotation, hold CTRL when you release the mouse button.

+
+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 2. Chain behavior
Linked ListConditionResult

disabled

the two spans are already in the same chain

nothing happens

disabled

the two spans are in different chains

the two chains are merged

enabled

the two spans are already in the same chains

the chain will be re-linked such that a chain link points from the source to the target span, + potentially creating new chains in the process.

enabled

the two spans are in different chains

the chains will be re-linked such that a chain link points from the source to the target span, + merging the two chains and potentially creating new chains from the remaining prefix and suffix + of the original chains.

+
+
+

Document metadata

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding documentmetadata.enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+

Curation of document metadata annotations is not possible. Import and export of document metadata +annotations is only supported in the UIMA CAS formats, but not in WebAnno TSV.

+
+
+
+
+

Before being able to configure document-level annotations, you need to define an annotation layer of +type Document metadata on the project Settings, Layers tab. For this:

+
+
+
    +
  • +

    Go to Settings → Layers and click the Create button

    +
  • +
  • +

    Enter a name for the annotation layer (e.g. Author) and set its type to Document metadata

    +
  • +
  • +

    Click Save

    +
  • +
  • +

    On the right side of the page, you can now configure features for this annotation layer by clicking Create

    +
  • +
  • +

    Again, choose a name and type for the feature e.g. name of type Primitive: String

    +
  • +
  • +

    Click Save

    +
  • +
+
+
+

On the annotation page, you can now:

+
+
+
    +
  • +

    Open the Document Metadata sidebar (the tags icon) and

    +
  • +
  • +

    Choose the newly created annotation layer in the dropdown.

    +
  • +
  • +

    Clicking the plus sign will add a new annotation whose feature you can fill in.

    +
  • +
+
+
+
+metadata sidebar +
+
+
+
Singletons
+
+

If you want to define a document metadata layer for which each document should have exactly one +annotation, then you can mark the layer as a singleton. This means that in every document, an +annotation of this type is automatically created when the annotator opens the document. It is +immediately accessible via the document metadata sidebar - the annotator does not have to create +it first. Also, the singleton annotation cannot be deleted.

+
+
+
+
+

Primitive Features

+
+

Supported primitive features types are string, boolean, integer, and float.

+
+
+

String features without a tagset are displayed using a text field or a text area with multiple rows. If multiple rows are enabled it can either be dynamically sized or a size for collapsing and expanding can be configured. The multiple rows, non-dynamic text area can be expanded if focused and collapses again if focus is lost.

+
+
+

In case the string feature has a tagset, it instead appears as a radio group, a combobox, or an auto-complete field - depending on how many tags are in the tagset or whether a particular editor type has been chosen.

+
+
+

There is also the option to have multi-valued string features. These are displayed as a multi-value select field and can be used with or without an associated tagset. Keyboard shortcuts are not supported.

+
+
+

Boolean features are displayed as a checkbox that can either be marked or unmarked.

+
+
+

Integer and float features are displayed using a number field. +However if an integer feature is limited and the difference between the maximum and minimum is lower than 12 it can also be displayed with a radio button group instead.

+
+
+
+ +
+

Link features can be used to link one annotation to others. Before a link can be made, a slot must +be added. If role labels are enabled enter the role label in the text field and press the add +button to create the slot. Next, click on field in the newly created slot to arm it. The field’s +color will change to indicate that it is armed. Now you can fill the slot by double-clicking on a +span annotation. To remove a slot, arm it and then press the del button.

+
+
+
Navigating along links
+

Once a slot has been filled, there is a cross-hair icon in the slot field header which can be used +to navigate to the slot filler.

+
+
+

When a span annotation is selected which acts as a slot filler in any link feature, then the +annotation owning the slow is shown in the annotation detail panel. Here, the cross-hair icon can be used to jump to the slot owner.

+
+
+
Role labels
+

If role labels are enabled they can be changed by the user at any time. +To change a previously selected role label, no prior deletion is needed. +Just click on the slot you want to change, it will be highlighted in orange, and chose +another role label.

+
+
+

If there is a large number of tags in the tagset associated with the link feature, the the role +combobox is replaced with an auto-complete field. The difference is that in the auto-complete field, there is no button to open the dropdown to select a role. Instead, you can press space or use the cursor-down keys to cause the dropdown menu for the role to open. Also, the dropdown only shows up +to a configurable maximum of matching tags. You can type in something (e.g. action) to filter for +items containing action. The threshold for displaying an auto-complete field and the maximum number +of tags shown in the dropdown can be configured globally. The settings are documented in the +administrators guide.

+
+
+

If role labels are disabled for the link feature layer they cannot be manually set by the user. +Instead the UI label of the linked annotation is displayed.

+
+
+
+

Image Features

+
+

Image URL features can be used to link a piece of text to an image. The image must be accessible +via an URL. When the use edits an annotation, the URL is displayed it the feature editor. The +actual images can be viewed via the image sidebar.

+
+
+
+

Concept features

+
+

Concept features allow linking an annotation to a concept (class, instance, property) from a +knowledge base.

+
+
+

There are two types of concept features: single-value and multi-value. A single +value feature can only link an annotation to a single concept. The single-value feature is displayed +using an auto-complete field. When a concept has been linked, its description is shown below the +auto-complete field. A multi-value concept feature allows linking the annotation up to more than +one concept. It is shown as a multi-select auto-complete field. When hovering with the mouse over +one of the linked concepts, its description is displayed as a tooltip.

+
+
+
Searching for concepts
+

Typing into the field triggers a query against the knowledge base and displays candidates in a +dropdown list. The query takes into account not only what is typed into the input field, but also +the annotated text.

+
+
+ + + + + +
+ + +Just press SPACEBAR instead of writing anything into the field to search the knowledge + base for concepts matching the annotated text. +
+
+
+
Filtering
+

The query entered into the field only matches against the label of the knowledge base items, not +against their description. However, you can filter the candidates by their description. E.g. if you +wish to find all knowledge base items with Obama in the label and president in the description, +then you can write Obama :: president. A case-insensitive matching is being used.

+
+
+

If the knowledge base is configured for additional matching properties and the value entered into +the field matches such an additional property, then the label property will be shown separately +in the dropdown. In this case, filtering does not only apply to the description but also to the +canonical label.

+
+
+
Substring matching
+

Depending on the knowledge base and full-text mode being used, there may be fuzzy matching. To +filter the candidate list down to those candidates which contain a particular substring, put +double quotes around the query, e.g. "County Carlow". A case-insensitive matching is being used.

+
+
+
IRI matching
+

You can enter a full concept IRI to directly link to a particular concept. Note that searching by +IRIs by substrings or short forms is not possible. The entire IRI as used by the knowledge base must +be entered. This allows linking to concepts which have no label - however, it is quite inconvenient. +It is much more convenient if you can ensure that your knowledge base offers labels for all its +concepts.

+
+
+
Not finding the expected results?
+

The number of results displayed in the dropdown is limited. If you do not find +what you are looking for, try typing in a longer search string. If you know the IRI of the concept +you are looking for, try entering the IRI. Some knowledge bases (e.g. Wikidata) are not making a +proper distinction between classes and instances. Try configuring the Allowed values in +the feature settings to any to compensate.

+
+
+
Browsing the knowledge base
+

Instead of searching a concept using the auto-complete field, you can also browse the knowledge +base. However, this is only possible if:

+
+
+
    +
  • +

    the concept feature is bound to a specific knowledge base or the project contains only a single +knowledge base;

    +
  • +
  • +

    the concept feature allowed values setting is not set to properties.

    +
  • +
+
+
+

Note that only concept and instances can be linked, not properties - even if the allowed values setting is set to any.

+
+
+
+
+

Annotation Sidebar

+
+

The annotation sidebar provides an overview over all annotations in the current document. It is located in the left sidebar panel.

+
+
+

The sidebar supports two modes of displaying annotations:

+
+
+
    +
  • +

    Grouped by label (default): Annotations are grouped by label. Every annotation is represented +by its text. If the same text is annotated multiple times, there will be multiple items with the +same text. To help disambiguating between the same text occurring in different contexts, each item +also shows a bit of trailing context in a lighter font. Additionally, there is a small badge in +every annotation item which allows selecting the annotation or deleting it. Clicking on the text +itself will scroll to the annotation in the editor window, but it will not select the annotation. +If an item represents an annotation suggestion from a recommender, the badge instead has buttons +for accepting or rejecting the suggestion. Again, clicking on the text will scroll the editor +window to the suggestion without accepting or rejecting it. Within each group, annotations are +sorted alphabetically by their text. If the option sort by score is enabled, then +suggestions are sorted by score.

    +
  • +
  • +

    Grouped by position: In this mode, the items are ordered by their position in the text. +Relation annotations are grouped under their respective source span annotation. If there are +multiple annotations at the same position, then there are multiple badges in the respective item. +Each of these badges shows the label of an annotation present at this position and allows +selecting or deleting it. Clicking on the text will will scroll to the respective position in the +editor window.

    +
  • +
+
+
+
+

Undo/re-do

+
+

The undo/re-do buttons in the action bar allow to undo annotation actions or to re-do an an undone action.

+
+
+

This functionality is only available while working on a particular document. When switching to another document, the undo/redo history is reset.

+
+ + ++++ + + + + + + + + + + + + + + + + +
Table 3. Undo/re-do key bindings
KeyAction

Ctrl-Z

undo last action

Shift-Ctrl-Z

re-do last un-done action

+
+ + + + + +
+ + +Not all actions can be undone or redone. E.g. bulk actions are not supported. + While the undoing the creation of chain span and chain link annotations is supported, + re-doing these actions or undoing their deletions is not supported. +
+
+
+
+

Settings

+
+

Once the document is opened, a default of 5 sentences is loaded on the annotation page. The +Settings button will allow you to specify the settings of the annotation layer.

+
+
+
+annotation settings +
+
+
+

The Editor setting can be used to switch between different modes of presentation. It is currently +only available on the annotation page.

+
+
+

The Sidebar size controls the width of the sidebar containing the annotation detail editor and +actions box. In particular on small screens, increasing this can be useful. The sidebar can be +configured to take between 10% and 50% of the screen.

+
+
+

The Font zoom setting controls the font size in the annotation area. This setting may not apply to all editors.

+
+
+

The Page size controls how many sentences are visible in the annotation area. The more +sentences are visible, the slower the user interface will react. This setting may not apply to all editors.

+
+
+

The Auto-scroll setting controls if the annotation view is centered on the sentence in which the +last annotation was made. This can be useful to avoid manual navigation. This setting may not apply to all editors.

+
+
+

The Collapse arcs setting controls whether long ranging relations can be collapsed to save space +on screen. This setting may not apply to all editors.

+
+
+

The Read-only palette controls the coloring of annotations on read-only layers. This setting +overrides any per-layer preferences.

+
+
+

Layer preferences

+
+

In this section you can select which annotation layers are displayed during annotation and how +they are displayed.

+
+
+

Hiding layers is useful to reduce clutter if there are many annotation layers. Mind that hiding a layer which has relations attached to it will also hide the respective relations. E.g. if you disable POS, then +no dependency relations will be visible anymore.

+
+
+

The Palette setting for each layer controls how the layer is colored. There are the following +options:

+
+
+
    +
  • +

    static / static pastelle - all annotations receive the same color

    +
  • +
  • +

    dynamic / dynamic pastelle - all annotations with the same label receive the same color. Note +that this does not imply that annotations with different labels receive different colors.

    +
  • +
  • +

    static grey - all annotations are grey.

    +
  • +
+
+
+

Mind that there is a limited number of colors such that eventually colors will be reused. +Annotations on chain layers always receive one color per chain.

+
+
+
+
+

Export

+
+

Annotations are always immediately persistent in the backend database. Thus, it is not necessary to save the annotations explicitly. Also, losing the connection through network issues or timeouts does not cause data loss. To obtain a local copy of the current document, click on export button. The following frame will appear:

+
+
+
+annotation export +
+
+
+

Choose your preferred format. Please take note of the facts that the plain text format does not contain any annotations and that the files in the binary format need to be unpacked before further usage. For further information the supported formats, please consult the corresponding chapter Formats.

+
+
+

The document will be saved to your local disk, and can be re-imported via adding the document to a project by a project manager. Please export your data periodically, at least when finishing a document or not continuing annotations for an extended period of time.

+
+
+
+

Search

+
+

The search module allows to search for words, passages and annotations made in the +documents of a given project. Currently, the default search is provided by MTAS +(Multi Tier Annotation Search), a Lucene/Solr based search and indexing mechanism +(https://github.com/textexploration/mtas).

+
+
+

To perform a search, access the search sidebar located at the left of the screen, write a query and +press the Search button. The results are shown below the query in a KWIC (keyword in context) +style grouped by document. Clicking on a result will open the match in the main annotation editor.

+
+
+
+Search sidebar +
+
+
+

The search only considers documents in the current project and only matches annotations made by +the current user.

+
+
+ + + + + +
+ + +Very long annotations and tokens (longer than several thousand characters) are not indexed and + cannot be found by the search. +
+
+
+

Clicking on the search settings button (cog wheel) shows additional options:

+
+
+
    +
  • +

    Current document only limits the search to the document shown in the main annotation editor. +When switching to another document, the result list does not change automatically - the search +button needs to be pressed again in order to show results from the new document.

    +
  • +
  • +

    Rebuild index may help fixing search issues (e.g. no or only partial results), in particular +after upgrading to a new version of INCEpTION. Note that this process may take quite some +time depending on the number of documents in the project.

    +
  • +
  • +

    Grouping by allows to group the search results by feature values of the selected annotation +feature. By default the search results will be grouped by document title if no layer and no +feature is selected.

    +
  • +
  • +

    Low level paging will apply paging of search results directly at query +level. This means only the next n results are fetched every time a user switches to a new page +of results (where n is the page size). Thus the total number of results for a result group is +unknown. This option should be activated if a query is expected to yield a very large number of +results so that fetching all results at once would slow down the application too much. ++ +This option can only be activated if results are being grouped by document.

    +
  • +
+
+
+

Creating/Deleting Annotations for Search Results

+
+

The user can also use the search to create and/or delete annotations for a set of selected search +results.

+
+
+

This means that annotations will be created/deleted at the token offsets of the selected search +results. +Search results can be selected via the checkbox on the left. Per default all search +results are selected. If a result originates from a document which the user has already marked as +finished, there is no checkbox since such documents cannot be modified anyway.

+
+
+

The currently selected annotation in the annotation editor serves as template for the annotations +that are to be created/deleted. Note that selecting an annotation first is necessary for +creating/deleting annotations in this way.

+
+
+ + + + + +
+ + +The slots and slot fillers of slot features are not copied from the template to newly created + annotations. +
+
+
+

Clicking on the create settings button (cog wheel) shows additional options:

+
+
+
    +
  • +

    Override existing will override an existing annotation of the same layer at a target location. +If this option is disabled, annotations of the same layer will be stacked if stacking is enabled +for this layer. Otherwise no annotation will be created.

    +
  • +
+
+
+

Clicking on the delete settings button (cog wheel) shows additional options:

+
+
+
    +
  • +

    Delete only matching feature values will only delete annotations at search results that +exactly match the currently selected annotation including all feature values. If this option is +disabled all annotations with the same layer as the currently selected annotation will be +deleted regardless of their feature values. Note that slot features are not taken into account +when matching the selected annotation against candidates to be deleted.

    +
  • +
+
+
+
+

Mtas search syntax

+
+

The INCEpTION Mtas search provider allows queries to be executed using CQL (Corpus +Query Language), as shown in the following examples. +More examples and information about CQL syntax can be found +at https://meertensinstituut.github.io/mtas/search_cql.html.

+
+
+

When performing queries, the user must reference the annotation types using the layer names, +as defined in the project schema. In the same way, the features must be referenced using their names +as defined in the project schema. In both cases, empty spaces in the names must be replaced by +an underscore.

+
+
+

Thus, Lemma refers to the Lemma layer, Lemma.Lemma refers to the the Lemma feature in the +Lemma layer. In the same way, Named_entity refers to Named entity layer, and +Named_entity.value refers to the value feature in the Named entity layer.

+
+
+

Annotations made over single tokens can be queried using the […​] syntax, while annotations +made over multiple tokens must be queried using the <…​/> syntax.

+
+
+

In the first case, the user must always provide a feature and a value. The following syntax returns +all single token annotations of the LayerX layer whose FeatureX feature have the given value.

+
+
+
+
[LayerX.FeatureX="value"]
+
+
+
+

In the second case, the user may or not provide a feature and a value. Thus, the following syntax +will return all multi-token annotations of the LayerX layer, regardless of their features and +values.

+
+
+
+
<LayerX/>
+
+
+
+

On the other hand, the following syntax will return the multi-token annotations whose FeatureX +feature has the given value.

+
+
+
+
<LayerX.FeatureX="value"/>
+
+
+
+

Notice that the multi-token query syntax can also be used to retrieve single token annotations (e.g. +POS or lemma annotations).

+
+
+
Basic Annotation queries
+
+
Single token: all occurrences of the token Galicia
+
+
Galicia
+
+
+
+
Single token: all occurrences of the token Galicia (alternative)
+
+
"Galicia"
+
+
+
+
Multiple tokens: all occurrences of the token sequence The capital of Galicia
+
+
The capital of Galicia
+
+
+
+
Multiple tokens: all occurrences of the token sequence The capital of Galicia (alternative)
+
+
"The" "capital" "of" "Galicia"
+
+
+
+
Lemma: all occurrences of the lemma sign
+
+
[Lemma.Lemma="sign"]
+
+
+
+
Named entities: all named entity annotations
+
+
<Named_entity/>
+
+
+
+
Named entities: all occurrencies of a particular kind of named entity (in this case, location named entities)
+
+
<Named_entity.value="LOC"/>
+
+
+
+
Sequence: all occurrences of the lemma be immediately followed by the lemma signed
+
+
[Lemma.Lemma="be"] [Lemma.Lemma="sign"]
+
+
+
+
Sequence: all occurrences of the token house immediately followed by a verb
+
+
"house" [POS.PosValue="VERB"]
+
+
+
+
Sequence: all occurrences of a verb immediately followed by a named entity
+
+
[POS.PosValue="VERB"]<Named_entity/>
+
+
+
+
Sequence: All occurrences of two named entities in a row
+
+
<Named_entity/>{2}
+
+
+
+
Sequence: All occurrences of two named entities in a row (alternative syntax)
+
+
<Named_entity/> <Named_entity/>
+
+
+
+
Sequence: All occurrences of a named entity followed by a token (whatever it is) and another named entity:
+
+
<Named_entity/> [] <Named_entity/>
+
+
+
+
Sequence: All occurrences of a named entity followed by an optional token and another named entity:
+
+
<Named_entity/> []? <Named_entity/>
+
+
+
+
Sequence: All occurrences of two named entities separated by exactly two tokens
+
+
<Named_entity/> []{2} <Named_entity/>
+
+
+
+
Sequence: All occurrences of two named entities separated by among one and three tokens
+
+
<Named_entity/> []{1,3} <Named_entity/>
+
+
+
+
OR: All named entities of type LOC or OTH
+
+
(<Named_entity.value="OTH"/> | <Named_entity.value="LOC"/>)
+
+
+
+
Within: All occurrences of the lemma sign annotated as a verb
+
+
[POS.PosValue="VERB"] within [Lemma.Lemma="sign"]
+
+
+
+
Within: All occurrences of a determinant inside a named entity
+
+
[POS.PosValue="DET"] within <Named_entity/>
+
+
+
+
Not within: All occurrences of a determinant not inside a named entity
+
+
[POS.PosValue="DET"] !within <Named_entity/>
+
+
+
+
Containing: All occurrences of named entities containing a determinant
+
+
<Named_entity/> containing [POS.PosValue="DET"]
+
+
+
+
Not containing: All occurrences of named entities not containing a determinant
+
+
<Named_entity/> !containing [POS.PosValue="DET"]
+
+
+
+
Intersecting: All named entities of type LOC intersecting with a semantic argument
+
+
<Named_entity.value="LOC"/> intersecting <SemArg/>
+
+
+
+
OR combined with Within: All named entities of type LOC or OTH contained in a semantic argument
+
+
(<Named_entity.value="OTH"/> | <Named_entity.value="LOC"/>) within <SemArg/>
+
+
+
+
OR combined with Intersecting query: Named entities of type LOC or OTH intersecting with a semantic argument
+
+
(<Named_entity.value="OTH"/> | <Named_entity.value="LOC"/>) intersecting <SemArg/>
+
+
+
+
+
Relation layer queries
+
+

INCEpTION allows queries over relation annotations as well. When relations are indexed, they +are indexed by the position of their target span. That entails that match highlighted in the query +corresponds to text of the target of the relation.

+
+
+

For the following examples, we assume a span layer called component and a relation layer called rel attached to it. Both layers have a string feature called value.

+
+
+
Search for rel annotation by feature on the relation
+
+
<rel.value="foo"/>
+
+
+
+
Search for rel annotation by the text of the source annotation
+
+
<rel-source="foo"/>
+
+
+
+
Search for rel annotation by the text of the target annotation
+
+
<rel-target="foo"/>
+
+
+
+
Search for rel annotations by feature on the relation source
+
+
<rel-source.value="foo"/>
+
+
+
+
Search for rel annotations by feature on the relation target
+
+
<rel-target.value="foo"/>
+
+
+
+
Search for rel annotations by feature on the relation and on the relation target
+
+
<rel.value="bar"/> fullyalignedwith <rel-target.value="foo"/>
+
+
+
+
Search for rel annotations by feature on the relation and on the relation source and target
+
+
<rel.value="bar"/> fullyalignedwith (<rel-source.value="foo"/> fullyalignedwith <rel-target.value="foo"/>)
+
+
+
+
+
Boolean feature queries
+
+

The values of boolean features are indexed as true and false.

+
+
+
+
Concept feature queries
+
+
Generic Search over annotated KB entities : all occurrences for KB entity Bordeaux
+
+
<KB-Entity="Bordeaux"/>
+
+
+
+

The following query returns all mentions of ChateauMorgonBeaujolais or any of its subclasses in +the associated knowledge base.

+
+
+
Named Entity Identifier for KB instance: all mentions of ChateauMorgonBeaujolais
+
+
<Named_entity.identifier="ChateauMorgonBeaujolais"/>
+
+
+
+

Mind that the label of a knowledge base item may be ambiguous, so it may be necessary to search by +IRI.

+
+
+
Named Entity Identifier for KB instance: all mentions of ChateauMorgonBeaujolais by IRI
+
+
<Named_entity.identifier="http://www.w3.org/TR/2003/PR-owl-guide-20031209/wine#ChateauMorgonBeaujolais"/>
+
+
+
+
Named Entity Identifier : all exact mentions of ChateauMorgonBeaujolais .
+
+
<Named_entity.identifier-exact="ChateauMorgonBeaujolais"/>
+
+
+
+
OR All exact mentions of either ChateauMorgonBeaujolais or AmericanWine
+
+
(<Named_entity.identifier-exact="ChateauMorgonBeaujolais"/> | <Named_entity.identifier-exact="AmericanWine"/>)
+
+
+
+
+
+
+

Statistics

+
+

The statistics section provides useful statistics about the project. Currently, the statistics are provided by MTAS (Multi Tier Annotation Search), a Lucene/Solr based search and indexing mechanism (https://github.com/textexploration/mtas).

+
+
+

High-level statistics sidebar

+
+

To reach the statistics sidebar, go to Annotation, open a document and choose the statistics sidebar on the left, indicated by the clipboard icon. +Select a granularity and a statistic which shall be displayed. After clicking the calculate button, the results are shown in the table below.

+
+
+ + + + + +
+ + +Clicking the Calculate button will compute all statistics and all granularities at once. The dropdowns are just there to reduce the size of the table. Therefore, depending on the size of the project, clicking the calculate button may take a while . The exported file always contains all statistics, so it is significantly larger than the displayed table. +
+
+
+

For the calculation of the statistics, all documents which the current user has access to and all are considered. They are computed for all layer/feature combinations. Please make sure that the name of the layer/feature combinations are valid (e.g. they don’t contain incorrect bracketing).

+
+
+
    +
  • +

    Granularity: Currently, there are two options to choose from, per Document and per Sentence. Understanding what’s actually computed by them is illustrated best by an example. Assume you have 3 documents, the first with 1 sentence, the second with 2 sentences and the third with 3 sentences. Let Xi be the number of occurrences of feature X (e.g. the Feature "value" in the Layer "named entity") in document i (i = 1, 2, 3). Then per Document is just the vector Y = (X1, X2, X3), i.e. we look at the raw occurrences per Document. In contrast, per Sentence calculates the vector Z = (X1/1, X2/2, X3/3), i.e. it divides the number of occurrences by the number of sentences. This vector is then evaluated according to the chosen statistic (e.g. Mean(Y) = (X1 + X2 + X3)/3, Max(Z) = max(X1/1, X2/2, X3/3)).

    +
  • +
  • +

    Statistic: The kind of statistic which is displayed in the table. Let (Y1, …​, Yn) be a vector of real numbers. Its values are calculated as shown in the Granularity section above.

    +
    +
      +
    • +

      Maximum: the greatest entry, i.e. max(Y1, …​, Yn)

      +
    • +
    • +

      Mean: the arithmetic mean of the entries, i.e. (Y1 + …​ + Yn)/n

      +
    • +
    • +

      Median: the entry in the middle of the sorted vector, i.e. let Z = (Z1, …​, Zn) be a vector which contains the same entries as Y, but they are in ascending order (Z1 < = Z2 < = …​ < = Zn). Then the median is given by Z(n+1)/2 if n is odd +or (Zn/2 + Z(n/2)+1)/2 if n is even

      +
    • +
    • +

      Minimum: the smallest entry, i.e. min(Y1, …​, Yn)

      +
    • +
    • +

      Number of Documents: the number of documents considered, i.e. n

      +
    • +
    • +

      Standard Deviation: 1/n * ( (Y1 - Mean(Y))2 + …​ + (Yn - Mean(Y))2)

      +
    • +
    • +

      Sum: the total number of occurrences across all documents, i.e. Y1 + …​ + Yn

      +
    • +
    +
    +
  • +
+
+
+ + + + + +
+ + +The two artificial features token and sentence are contained in the artificial layer Segmentation and statistics for them are computed. Note that per Sentence statistics of Segmentation.sentence are trivial so they are omitted from the table and the downloadable file. +
+
+
+
    +
  • +

    Hide empty layers: Usually, a project does not use all layers. If a feature of a layer does never occur, all its statistics (except Number of Documents) will be zero. Tick this box and press the Calculate button again to omit them from the displayed table. If you then download the table, the generated file will not include these layers.

    +
  • +
+
+
+

After some data is displayed in the table, it is possible to download the results. For this, after clicking the Calculate button there will appear a Format Dropdown and an Export button below the table. Choose your format and click the button to start a download of the results. The download will always include all possible statistics and either all features or only the non-null features.

+
+
+
    +
  • +

    Formats: Currently, two formats are possible, .txt and .csv. In the first format, columns are separated by a tab "\t" whereas in the second format they are separated by a comma ",".

    +
  • +
+
+
+
+
+

Recommenders

+
+

After configuring one or more recommender in the Project Settings, +they can be used during annotation to generate predictions. In the annotation view, predictions are +shown as grey bubbles. Predictions can be accepted by clicking once on them. In order to reject, +use a double-click. For an example how recommendations look in action, please see the screenshot +below.

+
+
+
+annotation editor with suggestions +
+
+
+

Suggestions generated by a specific recommender can be deleted by removing the corresponding recommender in the Project Settings. +Clicking Reset in the Workflow area will remove all predictions, however it will also remove all hand-made annotations.

+
+
+

Accept/reject buttons

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding recommender.action-buttons-enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

It is possible to enable explicit Accept and Reject buttons in the annotation interface. These +appear left and right of the suggestion marker as the mouse hovers over the marker.

+
+
+
+

Recommender Sidebar

+
+

Clicking the chart icon in the left sidebar tray opens the recommendation sidebar which provides access to several functionalities:

+
+
+
+recommender sidebar +
+
+
+
+
View the state of the configured recommenders
+
+

The icon in the top-right corner of the info box indicates the state of the recommender, e.g. if it is active, inactive, or if information on the recommender state is not yet available due to no self-evaluation or train/predict run having been completed yet.

+
+
View the self-evaluation results of the recommenders
+
+

When evaluation results are available, the info box shows sizes of the training and evaluation data it uses for self-evaluation (for generating actual suggestions, the recommender is trained on all data), and the results of the self-evaluation in terms of F1 score, accuracy, precision and recall.

+
+
View the confusion matrix for a recommender
+
+

When evaluation results are available, there is also the option to view the confusion matrix of the results. This is a square matrix showing all of the possible labels on each axis and indicating for each pair of labels how often during the self-evaluation run, one was mistaken for the other by the recommender.

+
+
View the training log of the recommenders
+
+

The recommender log provides detailed information which recommenders did run or did not run on which layers. This can be useful if you believe that a recommender should be active but it is not. The log usually contains two sections. The first section contains the log messages for the currently visible suggestions. If a background training and prediction run has completed, there is also a second part contains the log messages for the suggestions that will become visible on the next user interaction.

+
+
Manually trigger a re-training of all recommenders
+
+

You can manually clear and re-train all recommenders. This causes all suggestions to disappear immediately and a self-evaluation run followed by a training and prediction run is triggered. Once they have completed, the logs become available via the log button and the suggestions become available once the main editor is refreshed either via a user action (e.g. making an annotation) or e.g. by reloading the browser page.

+
+
Bulk-accept the best recommendations of a given recommender
+
+

If you trust a recommender, you can bulk-accept its best annotations. In this case best means that if the recommender has generated multiple suggestions at the same location, the suggestion with the highest score is accepted.

+
+
Export the model of the recommender
+
+

If a recommender supports exporting its trained model, then there is a button to download the model. Currently, only the String Matching Span Recommender supports this option. A Model exported +from this recommender can be uploaded a gazetteer to a String Matching Span Recommender in the project settings.

+
+
+
+
+
Evaluation scores and recommender activation
+
+

The circles at the top of the sidebar indicate the progress towards the next recommender evaluation. Every change to the annotations triggers a new training and prediction run. If a run is already in progress, at most one additional run is queued. When a run starts, it always use the latest annotation data available at the time. Every 5th run, an additional evaluation step is triggered. This updates the recall, precision, accuracy and F1 scores in the sidebar. Also, if a recommender has been configured to activate only at a particular score threshold, then the recommender may get activated or deactivated depending on the evaluation results.

+
+
+
+
Additional settings
+
+

Additionally, there are several configuration options available from the settings dropdown accessible via the cogwheel icon:

+
+
+
+
Configure the minimum score threshold for a suggestion to be visible
+
+

Sets a minimum score for an individual suggestion to become visible. Any suggestions with a lower score are not shown.

+
+
Configure how many suggestions are shown for a given position
+
+

If there is more than one suggestion generated for a given position by all recommenders, then of all these suggestions only the n suggestions with the highest scores will be shown. Note though, that scores are not necessarily comparable between recommenders.

+
+
Configure whether to show hidden suggestions
+
+

In some cases, you may wonder why a suggestion you expect to see does not appear. Then you can choose to show all hidden suggestions. Hovering the mouse over a previously hidden suggestion will include information on why that suggestion was hidden.

+
+
+
+
+
+
+
+

Curation Sidebar

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding curation.sidebar.enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

Curation i.e. the process of combining finished annotated documents into a final curated document, +can be done via the Curation Page in INCEpTION (see Curation) but also via the +Curation Sidebar on the Annotation Page.

+
+
+
+Curation Sidebar +
+
+
+

To start a curation session, you need to choose a curation target and press the start curation +session buttion next to the curation target select box.

+
+
+
    +
  • +

    curation document: this is also used as the target when curating on the curation page. If +you choose this target, you will notice that the username in the info line above the annotation +document changes to CURATION_USER while the curation session is in progress.

    +
  • +
  • +

    my document: this option is available if the curator is also an annotator in the project. In +this case, the annotators own document may be chosen as the curation target.

    +
  • +
+
+
+

Once the session has started, annotations from annotators that have marked the document as +finished will be visible. You can see a list of these annotators in the sidebar. If you want to +see only annotations from specific annotators, you can enabled/disabled them as you like.

+
+
+

The user can copy annotations manually from other users into the curation document by clicking on +them. The automatic merge can be triggered by clicking the Re-Merge button (sync icon). It will +copy all annotations that all selected users agree on into the curation document.

+
+
+

Depending on the layer settings, once an annotation has been merged or an annotation has been +manually created in the curation target document, annotations from annotators might be hidden. This +happens for example when at a given position in the curation target document an annotation exists +and stacking is not enabled on the respective annotation layer. If you want to temporarily see all +annotations from the selected annotators, use the Show merged annotations checkbox.

+
+
+

The curation session remains active for a given project, even if you leave the annotation page and +come back at a later time.

+
+
+

To stop a curation session, use the stop curation session button next to the curation target +select box.

+
+
+

It is possible to start/stop a curation session via the URL. Adding the URL query parameter +curationSession=on to an annotation page URL will start a curation session (if none is running) +while curationSession=off will stop a running session. By default, the session is started using +the curation document as the curation target. By setting the parameter curationTargetOwn=true, the +curation target can be changed to the current users own document - if the user has the annotator +role in addition to the curator role. This parameter only takes effect when curationSession=on is +also set. Mind that curation sessions in a project run until terminated. If you want directly link +to a document on the annotation page and ensure that no curations session is running, be sure to +add the curationSession=off parameter. +Example: http://localhost:8080/p/PROJECT/annotate/DOC-ID?curationSession=on&curationTargetOwn=true.

+
+
+
+

Active Learning

+
+

Active learning is a family of methods which seeks to optimize the learning rate of classification algorithms by soliciting labels from a human user in a particular order. This means that recommenders should be able to make better suggestions with fewer user interactions, allowing the user to perform quicker and more accurate annotations. Note that Active Learning only works if there are recommenders and if these recommenders actually generate recommendations which are usually shown as grey bubbles over the text.

+
+
+

Open the Active Learning sidebar on the left of the screen. You can choose from a list of all layers for which recommenders have been configured and then start an active learning session on that layer.

+
+
+
+select +
+
+
+

The system will start showing recommendations, one by one, according to the +uncertainty sampling learning strategy. For every recommendation, it shows the related text, the +suggested annotation, the score and a delta that represents the difference between the +given score and the closest score calculated for another suggestion made by the same recommender to that text. Additionally, there is a field which shows the suggested label and which allows changing that label - i.e. to correct the suggestion provided by the system. The recommendation is also highlighted in the central annotation editor.

+
+
+

One can now Annotate, Reject or Skip this recommendation in the Active Learning sidebar:

+
+
+
+activeLearning3 +
+
+
+

When using the Annotate, Reject or Skip buttons, the system automatically jumps to the next suggestion for the user to inspect. However, at times it may be necessary to go back to a recently inspected suggestion in order to review it. The History panel shows the 50 most recent actions. Clicking on the text of an item loads it in the main annotation editor. It is also possible to delete items from the history, e.g. wrongly rejected items.

+
+
+

The history panel displays whether a given suggestion was accepted, corrected or rejected, but this information can only be indicative. It represents a snapshot of the moment where the user made the choice. As the recommender is continuously updated by the system, the suggestions constantly change. It may happen that a suggestion which is shown as rejected in the sidebar is at a later time not even generated anymore by the recommender. Thus, deleting an item from the history will not always cause the suggestion from which it was generated to reappear. Resetting a document also clears the Active Learning history.

+
+
+

INCEpTION allows the user to create annotations as usual in the main annotation editor panel, even when in an Active Learning session. However, there is only a limited interaction with actions performed in the main annotation editor. If a suggestion is accepted or rejected in the main annotation editor, this is recorded in the history. However, if a user manually creates an annotation which causes a suggestion to disappear by overlapping with it, the history does not record this as a correction. For example, if the system generates a suggestion for Paul. (including the final sentence punctuation) but the user manually creates an annotation only for Paul (without the punctuation), the system does not recognize it as a correction.

+
+
+

Accepting/correcting, rejecting and skipping a suggestion in the sidebar cause the main annotation editor to move to the next suggestion. However, when a suggestion is accepted or rejected via the main editor, the generated annotation is opened in the annotation detail editor panel on the right side and the editor does not move to the next suggestion. For actions made in the main editor, it is assumed that the user may want to perform additional actions (e.g. set features, create more annotations in the vicinity) - jumping to the next suggestion would interfere with such intentions. That said, the next suggestion is loaded in the active learning sidebar and the user can jump to it by clicking on the suggestion text in the sidebar.

+
+
+

When removing an accepted/corrected item from the history and the annotation which was generated from this item is still present (i.e. it has not been deleted by other means), the user is asked whether the associated annotation should also be deleted.

+
+
+

Suggestions that are skipped disappear at first. However, once all other suggestions have been processed, the system asks whether the skipped suggestions should now be reviewed. Accepting will remove all skipped items from the history (even those that might no longer be visible in the history because of its on-screen size limit).

+
+
+
+

Concept Linking

+
+

Concept Linking is the task of identifying concept mentions in the text and linking them to their +corresponding concepts in a knowledge base. +Use cases of Concept Linking are commonly found in the area of biomedical text mining, e.g. +to facilitate understanding of unexplained terminology or abbreviations in scientific literature by +linking biological entities.

+
+
+

Contextual Disambiguation

+
+

Concept names can be ambiguous. There can be potentially many different concepts +having the same name (consider the large number of famous people called John Smith). Thus, it is +helpful to rank the candidates before showing them to the user in the annotation interface. If the +ranking works well, the user can quickly choose on of the top-ranking candidates instead of having +to scroll through a long list.

+
+
+

To link a concept mention to the knowledge base, first select the mention annotation, then select +the concept feature in the right sidebar of the annotation editor and start typing the name of +a concept. A ranked list of candidates is then displayed in the form of a drop-down menu. +In order to make the disambiguation process easier, descriptions are shown for each candidate.

+
+
+
+concept linking2 +
+
+
+

The suggestions are updated every time it receives new input.

+
+
+
+

Automated Concept Suggestions

+
+

The Named Entity Linker (NEL) displays three highest-ranked candidates as suggestions boxes +over each mention annotated as Named Entity. +The user can accept, reject or ignore these suggestions. +If a suggestion is rejected, it is not showed again. +It is possible to combine the NEL with the existing Named Entity Recommenders for the NE type, +which makes the annotation process even faster. +The recommender needs to be set up in the Project Settings.

+
+
+
+concept linking4 +
+
+
+
+
+

Images

+
+

Linking text to images can be useful e.g. when dealing with OCRed data or with text describing +images. To support such cases, INCEpTION supports image features. Image features can +be to annotation layers just like and other type of features. When selecting an annotation +containing an image feature, the a text field is used as the feature editor. Enter an image URL into +this field in order to link the annotation to an image. It is presently not possible to upload +images to INCEpTION - the image must be accessible via an URL, e.g. from an IIIF server.

+
+
+

Open the images sidebar to get an overview over all images linked to any of the annotations +currently visible on screen.

+
+
+ + + + + +
+ + +The sidebar attempts to add a border of an appropriate color to each image. For light images, + a dark border is added and for dark images, a light border is added. However, this is only possible if + the image server supports cross-origin resource sharing (CORS). The website + enable-cors.org provides tips on how to configure your image + server to support CORS. If CORS is not supported by the image server, rendering performance will + degrade as there is an attempt to re-load the image without CORS and without trying to determine the + border color - but the application should still work and the images should still show. +
+
+
+ + + + + +
+ + +If the images are not hosted on the same server as INCEpTION, you may have to specify + the remote server in the security.csp.allowed-image-sources property to enable users to access these + images from their browsers within INCEpTION. This is a multi-valued property, so you have to + set its values as security.csp.allowed-image-sources[0]=https://my-first-image.host, + security.csp.allowed-image-sources[1]=https://my-second-image.host in the settings.properties + file. +
+
+
+
+
+
+
+

Curation

+
+
+ + + + + +
+ + +This functionality is only available to curators. +
+
+
+

Opening a Document for Curation

+
+

When navigating to the Curation Page, the procedure for opening projects and documents is the same as in Annotation. The navigation within the document is also equivalent to Annotation.

+
+
+

The table reflects the state of the document. A document can be in-progress, finished, curation-in-progress or curation-finished.

+
+
+
+

Curating a document

+
+

On the left, there is a sidebar titled Units, an overview of the chosen document is displayed. Units are represented by their number inside the document. Click on a unit in order to select it and to to edit it in the central part of the page.

+
+
+

The units are shown using different colors that indicate their state. Since the calculation of +the state can take significant time, it is not updated as changes are made in the main editor pane. +To update the coloring of the unit overview, use the Refresh button. When switching between +documents, the overview is automatically refreshed.

+
+
+ + + + + +
+ + +In order for the unit overview to consider a unit as Curated, the curation pane must +contain an annotation for all positions that any of the annotators have annotated. This implies +that the Curated state requires the curator to have made an annotation. It is not possible +at this time to mark a unit as curated in which an annotator has made an annotator, but the +curator has not (e.g. because the curator considers the annotator’s annotation to be entirely +wrong and misplaced). +
+
+
+
+curation 1 +
+
+
+

The center part of the annotation page is divided into the Annotation pane which is a full-scale +annotation editor and contains the final data from the curation step.

+
+
+

Below it are multiple read-only panes containing the annotations from individual annotators. +Clicking on an annotation in any of the annotator’s panes transfers the respective annotation to the Annotation pane. +There is also a small state icon for each annotator. If you click on that icon, you can change the state, e.g. from finished back to in progress. Note if you do that, the respective annotators document will no longer be available for curation. When the last finished annotation for a document is reopened, you will be forced to leave curation.

+
+
+

When a document is opened for the first time in the curation page, the application analyzes agreements +and disagreements between annotators. All annotations on which all annotators agree are automatically +copied to the Annotation pane. Any annotations on which the annotators disagree are skipped.

+
+
+

The annotator’s panes are color-coded according to their relation with the contents of the Annotation pane and according to the agreement status. The colors largely match the colors also used in the status over in the left sidebar.

+
+
+ + + + + +
+ + +The upper Annotation pane that the curator uses to edit annotations is not color-coded. It uses whatever coloring strategy is configured in the Settings dialog. +
+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + +
Table 4. Explanation of the annotation colors in the annotator’s panes (lower panes)

Green

Accepted by the curator: the annotation matches the corresponding annotation in the Annotation pane.

Cyan

Rejected by the curator: *the annotation does not match the corresponding annotation in the *Annotation pane.

Orange

Annotators agree: the annotators all agree but curator has not accepted the annotation yet (there is no corresponding annotation in the Annotation pane).

Red

Annotators disagree: the annotators disagree and the curator has not yet taken any action (there is also no corresponding annotation in the upper Annotation pane).

Purple

Annotation is incomplete: not all annotators have provided a annotation for this position and the curator has not yet taken any action (there is no corresponding annotation in the upper Annotation pane).

+
+

Left-click on an annotation in one of the lower panels to merge it. This action copies the annotation to the upper panel. The merged annotation will turn green in the lower panel from which it was selected. If other annotators had a conflicting opinion, these will turn red in the lower panels of the respective annotators.

+
+
+

Right-click on an annotation in the lower panels to bring up a menu with additional options.

+
+
+
    +
  • +

    Merge all XXX: merge all annotations of the given type from the selected annotator. Note that +this overrides any annotations of the type which may previously have been merged or manually +created in the upper panel.

    +
  • +
+
+
+
+

Merging strategies

+
+

INCEpTION supports several different strategies for pre-merging data from the annotators to the curated document. The default strategy is Merge completely agreeing non-stacked annotations, but this default can be changed by the project manager in the project settings. It is also possible to update the default settings from the Re-merge dialog on the curation page.

+
+
+

Merge completely agreeing non-stacked annotations

+
+

This merge strategy only considers annotations if all annotators made the same +annotation at the same location (i.e. complete and agreeing annotations) - i.e. it considers any +annotations not provided by all annotators as a disagreement between the annotators.

+
+
+
+

Merge incomplete agreeing non-stacked annotations

+
+

There are situations where it is desirable to merge annotations from all annotators, even +if some did not provide it. For example, if your project has two annotators, one working on POS +tagging and another working on lemmatization, then as a curator, you might simply want to merge the +annotators from the two.

+
+
+
+

Merge using thresholds

+
+

This is the most powerful and flexible strategy. It is also the only strategy so far that supports merging stacked annotations.

+
+
+

The strategy is controlled by three parameters:

+
+
+
    +
  • +

    User threshold: the minimum amount of annotators that must have voted for a given +label for the label to be considered at all. If less then this number of annotators as +assigned the label, then it is completely ignored.

    +
  • +
  • +

    Confidence threshold: the minimum confidence of a label. The confidence for a label is calculated by counting the total number annotators (all_votes) that annotated a given position and dividing the number of annotators that provided a given label by the total number (i.e. votes(label) / all_votes. Note that the user threshold is applied before counting votes to calculate confidence. Note how the confidence interacts with the number of valid labels you expect. E.g. if you expect that there could be four valid labels (and therefore set the top-voted parameter to 4), then the best confidence that a single label can have is 25% (= 100% / 4`).

    +
  • +
  • +

    Top-voted: when set to 1, only the single best label is pre-merged. If there is a tie on the best label, then nothing is merged. When set to 2 or higher, the respective n best labels are pre-merged. If there is any tie within the n best labels, then all labels that still meet the lowest score of the tie are merged as well. For example, if set to 2 and three annotators voted for label X and another two anotators voted for Y and Z respectively, then Y and Z have a tie at the second rank, so both of them are merged. Note that this setting only affects annotations on layers that allow stacking annotations. For other layers, an implicit setting of 1 is used here.

    +
  • +
+
+
+
+
+

Anonymized curation

+
+

By default, the curator can see the annotators names on the curation page. However, in some cases, +it may not be desirable for the curator to see the names. In this case, enable the option +Anonymous curation in the project detail settings. Users with the curator role will then only +see an anonymous label like Anonymized annotator 1 instead of the annotator names. Users who are +project managers can still see the annotator names.

+
+
+ + + + + +
+ + +The order of the annotators is not randomized - only the names are removed from the UI. Only + annotators who have marked their documents as finished are shown. Thus, which annotator receives + which number may changed depending on documents being marked as finished or put back into progress. +
+
+
+
+
+
+
+

Workload Management

+
+
+

The workload management determines which documents may be accessed and annotated by which users. It +also provides an overview which documents have already been annotated and who annotated them. +Curators and managers can access workload management.

+
+
+

Static assignment

+
+

Use static assignment if annotators should be able to freely choose which documents they want to annotate in which order and/or if you want to precisely control which annotator should be able to access which document.

+
+
+

To enable the static assignment workload manager, go to the Workload tab in the project settings.

+
+
+

In this mode, the workload management page allows you to monitor the progress of your annotation project. It also allows you to change the status of the annotation and curation documents. This allows you:

+
+
+
    +
  • +

    to control which users should annotator which documents,

    +
  • +
  • +

    to re-open document marked as finished so annotators can correct mistakes

    +
  • +
  • +

    to close documents to prevent annotators from further working on them

    +
  • +
  • +

    to reset documents so annotators can start over from scratch

    +
  • +
+
+
+

Annotation state management

+
+
+monitoring annotation states +
+
Figure 4. Annotation states
+
+
+

To change the annotation state of a document, click on the table cell in the row for the respective document and in the column for the respective user.

+
+
+

It is possible to discard all annotations by a user for a particular document by right-clicking on the table cell and choosing Reset. This is a permanent action that cannot be undone. The state is then set back to new and the user has to start over.

+
+
+

In order to lock a document for a user who has already started annotating, the document first needs to be reset and then it can be locked.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + +
Table 5. Annotation state transitions
Current stateNew state

Not started yet (new)

Locked

Locked

Not started yet (new)

In progress

Finished

Finished

In progress

+
+
+

Curation state management

+
+
+monitoring curation states +
+
Figure 5. Curation states
+
+
+

To change the curation state of a document, click on the table cell in the row for the respective document and in the column Curation.

+
+
+

It is possible to discard all the curation for particular document by right-clicking on the table cell and choosing Reset. This is a permanent action that cannot be undone. The state is then set back to new and the curation process has to start over.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + +
Table 6. Curation state transitions
Current stateNew state

Not started yet (new)

(no change possible until curation starts)

In progress

Finished

Finished

In progress

+
+
+

Bulk changes

+
+
+monitoring bulk actions +
+
Figure 6. Bulk actions
+
+
+

To facilitate management in projects with many users and documents, it is possible to enable the Bulk change mode by clicking the respective button in the table title.

+
+
+

In bulk-change mode, checkboxes appear for every row and every annotator column. These can be used to select the entire row and/or column. It is possible to select multiple rows/columns. The selected cells are highlighted in the table. Note that selecting a column means that all the rows for that column are selected, even though due to paging only a subset of them may visible at any time in the table. Also, if you select a row, that row remains selected even if you switch to another table page.

+
+
+

Once you have selected the document rows / annotator columns you want to change, use the dropdown menu next to the Bulk change button to select a bulk action.

+
+
+

When applying a bulk action, only those cells which permit the requested transition are affected. For example, image you select an annotator column containing documents that are new, in progress and some that are locked. Applying the Finish selected bulk action now will affect only the documents that are already in progress but not any of the new or locked documents.

+
+
+

To facilitate wrapping up annotations for a user or document, there is the combo action Close all which will lock any documents on which work has not started yet and mark and ongoing annotations as finished.

+
+
+
+

Filtering

+
+

It is possible to filter the table by document name and/or user name. If a filter has been set, then +bulk actions are applied only to those rows and column which match the filter and which are selected +for the bulk operation.

+
+
+

The document name and user name filters can be set in two ways: +* "contains" match or +* regular expression

+
+
+

The regular expression mode can be enabled by activating the checkbox (.) next to the +filter text field. For example, with the checkbox enabled, you could search for ^chapter01. to match +all documents whose name starts with chapter01 or for train|test to match all documents containing +train or test in their name.

+
+
+
+

Navigation between documents

+
+

By default, annotators and curators can navigate freely between accessible documents in the matrix +workload mode. However, there can be cases where users should be directed from an external system +only to specific documents and they should not be offered the ability to simply navigate to another +document. In this case, the option Allow annotators to freely navigate between documents can be +turned off in the matrix workload settings panel in the project settings.

+
+
+ + + + + +
+ + +This only disables the navigation elements. Direct access to accessible documents through the + URL is still possible. An external workload management system would need to explicitly lock documents + to prevent users from accessing them. +
+
+
+
+

Ability to re-open documents

+
+

When an annotator marks a document as Finished, the document becomes uneditable for them. +By default, the only way to re-open a document for further annotation is that a curator or project manager opens the workload management page and changes the state of the document there.

+
+
+

However, in some cases, it is more convenient if annotators themselves can re-open a document and continue editing it. +The option Reopenable by annotators in the Settings dialog on the workload management can be enabled to allow annotators put finished documents back into the in progress state directly from the annotation page by clicking on the Finish/lock button in the action bar. +If this option is enabled, the dialog that asks users to confirm that they wish to mark a document is finished is not shown.

+
+
+ + + + + +
+ + +This option only allows annotators to re-open documents that they have closed themselves. + If a document has been marked as finished by a project manager or curator, the annotators can not re-open it. + On the workload management page, documents that have been explicitly closed by a curator/manager bear a double icon in their state column (e.g. finished (in progress)). +
+
+
+
+
+

Dynamic assgiment

+
+

Use dynamic assignment if you want to get your documents each annotated by a certain number of annotators and do not care about which annotator annotates which documents.

+
+
+

To enable the dynamic assignment workload manager, go to the Workload tab in the project settings.

+
+
+

When dynamic assignment is enabled, annotators can no longer actively choose which documents they want to annotate. Any functionality for opening a particular document or switching between documents on the annotation page are disabled. When the annotator opens the annotation page, a document is automatically selected for annotation. The only way to progress to the next document is by marking the current document as finished.

+
+
+
+workload settings +
+
+
+

The dynamic workload management page gives the project manager a fast overview of all documents and users within the current project. Additionally, the automatic distribution of documents to annotators can be modified.

+
+
+
+workload +
+
+
+

Therefore, it mainly consists of a substantial, but easy to understand table containing the data a project manager +needs from their documents. This data is represented by a unique row for each individual document in the project. The following +columns with the respective data are displayed:

+
+
+
    +
  1. +

    State: state of the document within the project.

    +
  2. +
  3. +

    Document: document name.

    +
  4. +
  5. +

    Assigned: number of annotators, who are working currently on the document.

    +
  6. +
  7. +

    Finished: number of annotators, who have already finished their work on the document.

    +
  8. +
  9. +

    Annotators: names of all annotators, who are either working on the document or have already finished it.

    +
  10. +
  11. +

    Updated: time of the last change that has been made to the document. It either shows "today", "yesterday", "2 days ago" …​ , or when the last change is longer than 6 days ago, +the exact date is shown.

    +
  12. +
+
+
+

You can also configure display and workload settings using the three buttons on the top left corner of the table: Filter, Annotators and Settings.

+
+
+
    +
  1. +

    Filters: You can apply different filters to the document list e.g. show only documents that are annotated by one user or were working on in a specific time period. +The filters are accumulative, which means that you can filter based on several criteria simultaneously.

    +
  2. +
  3. +

    Annotators: Allows to directly assign annotators to specific documents.

    +
  4. +
  5. +

    Settings: See below.

    +
  6. +
+
+
+

Finally, also a small quick filter is integrated to the workload page on the top right corner. Upon selecting different states, the table will be filtered towards these in real time. These states are the same as the ones represented in the first column State. As default, all states will be shown in the table.

+
+
+

Overall, the workload feature shall support annotation projects in their organization. Thanks to the table, the filtering and the options for the annotation workflow and the annotators, the project manager now has more flexibility and insight in his projects' progress. Also,the redesigned annotation flow ensures better results from the annotations, as the data will be better distributed throughout the project.

+
+
+

Click on an annotator badge in the annotators column to cycle through the annotation states. Right-click on the badge for additional actions such as the option to reset the annotations.

+
+
+

Dynamic workload settings

+
+
+
Annotators per document
+
+

Controls how many annotators need to have marked a document as finished for the document to be considered as completely annotated. As soon as an annotator opens a document, the document becomes assigned to that user. A document will not automatically be assigned to more than the number of annotators configured here.

+
+
Workflow policy
+
+

Controls the order in which documents are presented to annotators. Default workflow means, that the documents are simply passed to the annotators in alphabetical order. Randomized workflow, as the name already explains, selects randomly from all documents each time a new document is requested by an annotator.

+
+
Handle abandoned documents
+
+

Whether to unassign a document from an annotator if the annotator has not marked the document as finished after a certain amount of time. If this option is not enabled, a manager or curator should regularly check the project status to ensure that no documents are stuck in an unfinished state because the assigned annotators do not work on them.

+
+
Abandonation timeout
+
+

The number of minutes after the last update performed by an annotator before a document is considered to have been abandoned. Documents are never considered abandoned as long as the annotator is still logged into system. Typical settings are to consider a document as abandoned after 24 hours or 7 days.

+
+
Abandonation state
+
+

The state into which to transition the document once it has been found to be abandoned. It is recommended to transition abandoned documents to the locked state. In this state, the document becomes available to other annotators, the annotations are not used e.g. in agreement calculations yet any annotations potentially already made by the annotator are kept. It is also possible to transition documents to the finished state. However, other annotators will then not get the option to complete the document and the (unfinished) annotations end up becoming available to e.g. the agreement calculations. Finally, it is possible to reset the document to the new state and to irrevocably discard any annotations the annotator may already have made. When an annotation has been found to be abandoned, it is marked with a yellow background and a person/clock symbol in the table. To take the annotations out of the abandoned state, you can right-click on the state badge to get a menu with possible actions. Select touch to update the annotation’s timestamp to the current time, taking the annotations out of the abandoned state with all annotations intact - this will give the annotator the opportunity to complete the annotations. After the abandoned state has been removed, you can also again click on the badge to change its state. You can also select reset to discard the annotations.

+
+
+
+
+
+
+
+
+
+

Agreement

+
+
+ + + + + +
+ + +This functionality is only available to curators and managers. +
+
+
+

This page allows you to calculate inter-annotator agreement between users. Agreement can be inspected on a per-feature basis and is calculated pair-wise between all +annotators across all documents.

+
+
+

The Feature dropdown allows the selection of layers and features for which an agreement shall be computed.

+
+
+
+agreement feature +
+
+
+

A measure for the inter-annotator-agreement can be selected by opening the Measure dropdown menu. A short description of available measures and their differences follows in the Measures section.

+
+
+

Selecting both Feature and Measure and clicking Calculate.. will start the agreement calculation and the results will be shown in a Pairwise agreement matrix:

+
+
+
+agreement table +
+
+
+

Below this matrix, the results of Coding measures can be exported. An export format can be chosen. Currently, only CSV format is possible.

+
+
+

Measures

+
+

Several agreement measures are supported.

+
+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 7. Supported agreement measures
MeasureTypeShort description

Cohen’s kappa

Coding

Chance-corrected inter-annotator agreement for two annotators. The measure assumes a different probability distribution for all raters. Incomplete annotations are always excluded.

Fleiss' kappa

Coding

Generalization of Scott’s pi-measure for calculating a chance-corrected inter-rater agreement for multiple raters, which is known as Fleiss' kappa and Carletta’s K. The measure assumes the same probability distribution for all raters. Incomplete annotations are always excluded.

Krippendorff’s alpha (nominal)

Coding

Chance-corrected inter-rater agreement for multiple raters for nominal categories (i.e. categories are either equal (distance 0) or unequal (distance 1). The basic idea is to divide the estimated variance of within the items by the estimated total variance.

Krippendorff’s alpha (unitizing)

Unitizing

Chance-corrected inter-rater agreement for unitizing studies with multiple raters. As a model for expected disagreement, all possible unitizations for the given continuum and raters are considered. Note that +units coded with the same categories by a single annotator may not overlap with each other.

+
+
+

Coding vs. Unitizing

+
+

Coding measures are based on positions. I.e. two annotations are either at the same position or not. +If they are, they can be compared - otherwise they cannot be compared. This makes coding measures +unsuitable in cases where partital overlap of annotations needs to be considered, e.g. in the case +of named entity annotations where it is common that annotators do not agree on the boundaries of the +entity. In order to calculate the positions, all documents are scanned for annotations and annotations located at the same positions are collected in configuration sets. To determine if two annotations are at the same position, different approaches are used depending on the layer type. For a span layer, the begin and end offsets are used. For a relation layer, the begin and end offsets of the source and target annotation are used. Chains are currently not supported.

+
+
+

Unitizing measures basically work by internally concatenating all documents into a single long virtual document and then consider partial overlaps of annotations from different annotations. I.e. there is no averaging over documents. The partial overlap agreement is calculated based on character positions, not on token positions. So if one annotator annotates the blackboard and another annotator just blackboard, then the partial overlap is comparatively high because blackboard is a longish word. Relation and chain layers are presently not supported by the unitizing measures.

+
+
+
+

Incomplete annotations

+
+

When working with coding measures, there is the concept of incomplete annotations. For a given +position, the annotation is incomplete if at least one annotator has not provided a label. In the +case of the pairwise comparisons that are used to generate the agreement table, this means that one +annotator has produced a label and the other annotator has not. Due to the way that positions are +generated, it also means that if one annotator annotates the blackboard and another annotator just +blackboard, we are actually dealing with two positions (the blackboard, offsets 0-15 and +blackboard, offsets 4-14), and both of them are incompletely annotated. Some measurs cannot deal +with incomplete annotations because they require that every annotator has produced an annotation. In these +cases, the incomplete annotations are excluded from the agreement calculation. The effect is that +in the (the) blackboard example, there is actually no data to be compared. If we augment that +example with some other word on which the annotators agree, then only this word is considered, +meaning that we have a perfect agreement despite the annotators not having agreed on (the) blackboard. +Thus, one should avoid measure that cannot deal with incomplete annotations such as Fleiss' kappa +and Cohen’s kappa except for tasks such as part-of-speech tagging where it is known that positions +are the same for all annotators and all annotators are required (not expected) to provide an annotation.

+
+
+

The agreement calculations considers an unset feature (with a null value) to be equivalent to a +feature with the value of an empty string. Empty strings are considered valid labels and are not +excluded from agreement calculation. Thus, an incomplete annotation is not one where the label is +missing, but rather one where the entire annotation is missing.

+
+
+

In general, it is a good idea to use at least a measure that supports incomplete data (i.e. missing +labels) or even a unitizing measure which is able to produce partial agreement scores.

+
+ + ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 8. Possible combinations for agreement
Feature value annotator 1Feature value annotator 2AgreementComplete

X

X

yes

yes

X

Y

no

yes

no annotation

Y

no

no

empty

Y

no

yes

empty

empty

yes

yes

null

empty

yes

yes

empty

no annotation

no

no

+
+
+

Stacked annotations

+
+

Multiple interpretations in the form of stacked annotations are not supported in the agreement +calculation! This also includes relations for which source or targets spans are stacked.

+
+
+
+

Pairwise agreement matrix

+
+

The lower part of the agreement matrix displays how many configuration sets were used to calculate +agreement and how many were found in total. The upper part of the agreement matrix displays the +pairwise agreement scores.

+
+
+

Annotations for a given position are considered complete when both annotators have made an +annotation. Unless the agreement measure supports null values (i.e. missing annotations), +incomplete annotations are implicitly excluded from the agreement calculation. If the agreement +measure does support incomplete annotations, then excluding them or not is the users' choice.

+
+
+
+
+
+
+

Evaluation Simulation

+
+
+

The evaluation simulation panel provides a visualization of the performance of the selected recommender with the help of a learning curve diagram. On the bottom right of the panel, the start button performs evaluation on the selected recommender using the annotated documents in the project and plots the evaluation scores against the training data size on the graph. The evaluation score can be one of the four metrics, Accuracy, Precision, Recall and F1. There is a drop down panel to change the metric. The evaluation might take a long time.

+
+
+

The training data use for the evaluation can be selected using the Annotator dropdown. Here, +you can select to train on the annotations of a specific user. Selecting INITIAL_CAS trains on +annotations present in the imported original documents. Selecting CURATION_USER trains on curated +documents. The data is split into 80% training data and 20% test data. The system tries to split the training data in 10 blocks of roughly the same size. For each training run, an additional block +is added to the training data for that run until in the last run, all training data is used.

+
+
+
+evaluation +
+
+
+
+
+
+

Knowledge Base

+
+
+

The knowledge base (KB) module of INCEpTION enables the user to create a KB from scratch or to import it from an RDF file. Alternatively, the user can connect to a remote KB using SPARQL. However, editing the content of remote KBs is currently not supported. This knowledge base can then be for instance used for entity linking.

+
+
+

This section briefly describes how to set up a KB in the KB management page on Projects Settings, explains the functionalities provided by the Knowledge Base page and covers the concept and property feature types.

+
+
+ + + + + +
+ + +In order for a knowledge base to be searchable (e.g. from the Knowledge Base page), + the configured knowledge base needs to have labels for all items + (e.g. concepts, instances, properties) that should be found. +
+
+
+

Knowledge Base Page

+
+

The knowledge base page provides a concept tree hierarchy with a list of instances and statements, together with the list of properties as shown in the figure below. For local knowledge bases, the user can edit the KB contents here, which includes adding, editing and deleting concepts, properties, statements and instances.

+
+
+

The knowledge base page provides the specific mentions of concepts and instances annotated in the text in the Mentions panel which integrates the knowledge base page with the annotated text.

+
+
+
+kb4 +
+
+
+

The concept tree in this page is designed using the subClass relationship for the configured mapping. Each concept associates itself with a list of instances (in case it has one) on the Instance panel which appear when we click on a specific concept along with the Mentions of the concept in the annotated text. The click on a specific instance shows the panel for the list of statements associated with the instance along with Mentions of the instance in the annotated text. In the left bottom side of the page, it lists the set of properties from the knowledge base. Clicking on the property showcases the statements associated with the property such as labels, domains, ranges, etc.

+
+
+

In case the user has the privilege to edit the knowledge base, the user may add statements for concepts, instances and properties.

+
+
+
+

Statement editors

+
+

INCEpTION allows the user to edit local knowledge bases. This includes adding statements or subclassing concepts and their instances.

+
+
+

In order to create a statement for a particular knowledge base entity, the Create Statement can be used.

+
+
+

When creating a new statement about an instance, a list of available properties is shown. After selecting the property of choice, the object of the statement has to be specified. The possible properties for a given subject are restricted by domain the domain of property, i.e. the property born_in would need an instance of human as the subject.

+
+
+

The same is true for the object of a statement: After choosing the property for a concept, the object has to be specified. The possible objects are limited by the range of the property if given. Right now, four different editors are available to specify features for:

+
+
+
    +
  1. +

    Boolean: Allows either true or false

    +
  2. +
  3. +

    Numeric: Accepts integers or decimals

    +
  4. +
  5. +

    String: String with a language tag or an URI identifying a resource that is not in the knowledge base

    +
  6. +
  7. +

    KB Resource: This is provided as an option when the property has a range as a particular concept from the knowledge base. In this option, the user is provided with an auto-complete field with a list of knowledge base entities. This includes the subclass and instances of the range specified for the property.

    +
  8. +
+
+
+
+

Concept features

+
+

Concept features are features that allow referencing concepts in the knowledge base during annotation.

+
+
+

To create a new concept feature, a new feature has to be created under Projects SettingsLayers. The type of the new feature should be KB: Concept/Instance/Property. Features of this type also can be configured to either take only concepts, only instances, only properties or either (select any).

+
+
+
+kb5 +
+
+
+

When creating a new annotation with this feature, then the user is offered a dropdown with possible entities from the knowledge base. This dropdown is then limited to only concepts or features or both when selecting the respective filter in the feature configuration.

+
+
+

The scope setting allows to limit linking candidates to a subtree of the knowledge base.

+
+
+ + + + + +
+ + +Selecting scope means that full-text search cannot be used. This means that queries may become + very slow if the scope covers a large number concepts or instances. Therefore, it is best not to choose + too broad scopes. +
+
+
+
+
+
+
+

Projects

+
+
+ + + + + +
+ + +This functionality is only available to managers of existing projects, + project creators (users with the ability to create new projects), and administrators. + Project managers only see projects in which they hold the respective roles. Project creators + only see projects in which they hold the project manager role. +
+
+
+

This is the place to specify/edit annotation projects. +You can either select one of the existing projects for editing, or click Create Project to add a project.

+
+
+

Click on Create Project to create a new project.

+
+
+
+project creation +
+
+
+

Here, you can specify the name of your project.

+
+
+

A suitable URL slug is automatically derived from the project name if you do not provide one yourself. The URL slug will be used in the browser URLs for the different pages belonging to the project. For example, if you project has the URL slug my-project, then it will be accessible under +an URL ending in /p/myproject. The URL slug must be unique for all projects. Only lower-case characters (a-z), numbers (0-9), dashes (-) and underscores (_) are allowed for the slug. Also, it must be at least 3 characters and can be at most 40 characters long. The slug must start with a letter.

+
+
+

Finally, you can provide a project description here which is displayed on the project dashboard.

+
+
+

When you have not save the project yet, you can cancel the creation of the project via the Close button. To delete a project after you have saved (i.e. created) it, use the Delete button.

+
+
+
+project details +
+
+
+

After saving the project, additional panes will appear where you can further configure the project.

+
+
+

Import

+
+

Here, you can import project archives such as the example projects provided on our website or +projects exported from the Export tab.

+
+
+

When a user with the role project creator imports a project, that user automatically becomes a +manager of the imported project. However, no permissions for the project are imported!

+
+
+ + + + + +
+ + +If the current instance has users with the same name as those who originally worked on the + import project, the manager can add these users to the project and they can access their annotations. + Otherwise, only the imported source documents are accessible. +
+
+
+

When a user with the role administrator imports a project, the user can choose whether to import +the permissions and whether to automatically create users who have permissions on the imported +project but so far do not exist. If this option to create missing users disabled, but the option to +import permissions is enabled, then projects still maintain their association to users by name. +If the respective user accounts are created manually after the import, the users will start showing +up in the projects.

+
+
+ + + + + +
+ + +Automatically added users are disabled and have no password. They must be explicitly enabled + and a password must be set before the users can log in. +
+
+
+
+

Users

+
+

After clicking on the Users tab, you are displayed with a new pane in which you can add new users by clicking on the Add users text field. You get a dropdown list of enabled users in the system which can be added to the project. Any users which are already part of the project are not offered. As you type the dropdown list with the users is filtered to match your input. By clicking on a username or by pressing enter you can select the corresponding user. You can keep typing to add more users to the project. When you press the Add button the selected users are added to your project.

+
+
+
+new userSelection +
+
+
+ + + + + +
+ + +For privacy reasons, the administrator may choose to restrict the users shown in the dropdown. + If this is the case, you have to enter the full name of a user before it appears in the dropdown and + can be added. +
+
+
+

By default, the users are added to the project as annotators. If you want to assign additional roles, +you can do so by clicking on the user and then on Permissions pane select the appropriate permissions.

+
+
+
+new userPermissions +
+
+
+

After ticking the wished permissions, click on Save. +To remove a user, remove all the permissions and then click on Save.

+
+
+
+

Documents

+
+

The documents in a project can be managed on the documents panel.

+
+
+

To upload one or more documents, use the folder icon in the Files to import field. A browser dialog will open which allows you to navigate to some folder on your computer, select files, and then upload them. Typically, you can select multiple files in this dialog either by holding the control key on your keyboard then then selecting them one-by-one with the mouse - or by clicking on the first file, then holding shift on the keyboard and then clicking on the last file - thereby selecting all files in between the two. Note that if you upload multiple files, they must all have the same format.

+
+
+

After selecting the files, use the Format dropdown to choose which format your files are in. A project can contain files in different formats.

+
+
+

Finally, use the Import button to upload the files and add them to the project.

+
+
+
+project documents +
+
+
+

To delete a document from the project, you have to click on it and then click on Delete in the right lower corner. Again, you can select multiple files for deletion using with the aid of the control or shift keys on the keyboard.

+
+
+
Uploading large numbers of documents
+

While it is possible to upload multiple documents at once, there are limits to how many documents can be uploaded in a single upload operation. For a start, it can take quite some time to upload thousands of documents. Also, the server configuration limits the individual file size and total batch size (the default limit is 100MB for both). Finally, browsers differ in their capability of dealing with large numbers of documents in an upload. In a test with 5000 documents of each ca. 2.5kb size including Chrome, Safari and Firebird, only Chrome (80.0.3987.122) completed the operation successfully. Safari (13.0.5) was only able to do upload about 3400 documents. Firebird (73.0.1) froze during the upload and was unable to deliver anything to the server. With a lower number of documents (e.g. 500), none of the browsers had any problems.

+
+
+
+

Layers

+
+

All annotations belong to an annotation layer. Each layer has a structural type that defines if it is a span, a relation, or a chain. It also defines how the annotations behave and what kind of features it carries.

+
+
+

Creating a custom layer

+
+

This section provides a short walk-through on the creation of a custom layer. The following sections act as reference documentation providing additional details on each step. In the following example, we will create a custom layer called Sentiment with a feature called Polarity that can be negative, neutral, or positive.

+
+
+
    +
  1. +

    Create the layer Sentiment

    +
    +
      +
    • +

      Go to the Layers tab in your project’s settings and press the Create layer button

      +
    • +
    • +

      Enter the name of the layer in Layer name: Sentiment

      +
    • +
    • +

      Choose the type of the layer: Span

      +
    • +
    • +

      Enable Allow multiple tokens because we want to mark sentiments on spans longer than a single token.

      +
    • +
    • +

      Press the Save layer button

      +
    • +
    +
    +
  2. +
  3. +

    Create the feature Polarity

    +
    +
      +
    • +

      Press the New feature button

      +
    • +
    • +

      Choose the type of the feature: Primitive: String

      +
    • +
    • +

      Enter the name of the feature: Polarity

      +
    • +
    • +

      Press Save feature

      +
    • +
    +
    +
  4. +
  5. +

    Create the tagset Polarity values

    +
    +
      +
    • +

      Go to the Tagsets tab and press Create tagset

      +
    • +
    • +

      Enter the name of the tagset: Polarity values

      +
    • +
    • +

      Press Save tagset

      +
    • +
    • +

      Press Create tag, enter the name of the tag: negative, press Save tag

      +
    • +
    • +

      Repeat for neutra and positive

      +
    • +
    +
    +
  6. +
  7. +

    Assign the tagset Polarity values to the feature Polarity

    +
    +
      +
    • +

      Back in the Layers tab, select the layer: Sentiment and select the feature: Polarity

      +
    • +
    • +

      Set the tagset to Polarity values

      +
    • +
    • +

      Press Save feature

      +
    • +
    +
    +
  8. +
+
+
+

Now you have created your first custom layer.

+
+
+
+

Built-in layers

+
+

INCEpTION comes with a set of built-in layers that allow you to start annotating immediately. Also, many import/export formats only work with these layers as their semantics are known. For this reason, the ability to customize the behaviors of built-in layers is limited and it is not possible to extend them with custom features.

+
+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 9. Built-in layers
LayerTypeEnforced behaviors

Chunk

Span

Lock to multiple tokens, +no overlap, +no sentence boundary crossing

Coreference

Chain

(no enforced behaviors)

Dependency

Relation over POS,

Any overlap, +no sentence boundary crossing

Lemma

Span

Locked to token offsets, +no overlap, +no sentence boundary crossing

Named Entity

Span

(no enforced behaviors)

Part of Speech (POS)

Span

Locked to token offsets, +no overlap, +no sentence boundary crossing

+
+

The coloring of the layers signal the following:

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + +
Table 10. Color legend
ColorDescription

green

built-in annotation layer, enabled

blue

custom annotation layer, enabled

red

disabled annotation layer

+
+

To create a custom layer, select Create Layer in the Layers frame. Then, the following frame will be displayed.

+
+
+
Exporting layers
+

At times, it is useful to export the configuration of a layer or of all layers, e.g. to copy them +to another project. There are two options:

+
+
+
    +
  • +

    JSON (selected layer): exports the currently selected layer as JSON. If the layer depends on +other layers, these are included as well in the JSON export.

    +
  • +
  • +

    UIMA (all layers): exports a UIMA type system description containing all layers of the project. +This includes built-in types (i.e. DKPro Core types) and it may include additional types required +to allow loading the type system description file again. However, this type system description +is usually not sufficient to interpret XMI files produced by INCEpTION. Be sure to load XMI +files together with the type system description file which was included in the XMI export.

    +
  • +
+
+
+

Both types of files can be imported back into INCEpTION. Note that any built-in types that +have have been included in the files are ignored on import.

+
+
+
+

Properties

+ + ++++ + + + + + + + + + + + + + + + + + + + + +
Table 11. Properites
PropertyDescription

Layer name

The name of the layer (obligatory)

Description

A description of the layer. This information will be shown in a tooltip when the mouse hovers over the layer name in the annotation detail editor panel.

Enabled

Whether the layer is enabled or not. Layers can currently not be deleted, but they can be disabled.

+
+ + + + + +
+ + +When a layer is first created, only ASCII characters are allowed for the layer name because the internal UIMA type name is derived from the initial layer name. After the layer has been created, the name can be changed arbitrarily. The internal UIMA type name will not be updated. The internal UIMA name is +e.g. used when exporting data or in constraint rules. +
+
+
+
+layer details +
+
+
+
+

Technical Properties

+
+

In the frame Technical Properties, the user may select the type of annation that will be made with this layer: span, relation, or chain.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + +
Table 12. Technical Properites
PropertyDescription

Internal name

Internal UIMA type name

Type

The type of the layer (obligatory, see below)

Attach to layer +(Relations)

Determines which span layer a relation attaches to. Relations can only be created between annotations of this span layer.

+
+

The layer type defines the structure of the layer. Three different types are supported: spans, relations, and chains.

+
+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + +
Table 13. Layer types
TypeDescriptionExample

Span

Continuous segment of text delimited by a start and end character offset. The example shows two spans.

project layer type span

Relation

Binary relation between two spans visualized as an arc between spans. The example shows a relation between two spans.

project layer type relation

Chain

Directed sequence of connected spans in which each span connects to the following one. The example shows a single chain consisting of three connected spans.

project layer type chain

+
+

For relation annotations the type of the spans which are to be connected can be chosen in the field Attach to layer. Here, only non-default layers are displayed. To create a relation, first the span annotation needs to be created.

+
+
+ + + + + +
+ + +Currently for each span layer there can be at most one relation layer attaching to it. +
+
+
+ + + + + +
+ + +It is currently not possible to create relations between spans in different layers. For example if you define span layers called Men and Women, it is impossible to define a relation layer Married to between the two. To work around this limitation, create a single span layer Person with a feature Gender instead. You can now set the feature Gender to Man or Woman and eventually define a relation layer Married to attaching to the Person layer. +
+
+
+
+

Behaviours

+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 14. Behaviors
BehaviorDescription

Read-only

The layer may be viewed but not edited.

Show text on hover

Whether the text covered by the annotation is shown in the popup panel that appears when hovering with the mouse over an annotation label. Note that this popup may not be supported by all annotation editors.

Validation

 When pre-annotated data is imported or when the behaviors settings are changed, it is possible that annotations exist which are not conforming to the current behavior settings. This setting controls when a validation of annotations is performed. Possible settings are Never (no validation when a user marks a document as finished) and Always (validation is performed when a user marks a document as finished). Mind that changing the document state via the Monitoring page does not trigger a validation. Also, problematic annotations are highlighted using an error marker in the annotation interface. NOTE: the default setting for new projects/layers is Always, but for any existing projects or for projects imported from versions of INCEpTION where this setting did not exist yet, the setting is initialized with Never.

Granularity +(span, chain)

The granularity controls at which level annotations can be created. When set to Character-level, annotations can be created anywhere. Zero-width annotations are permitted. When set to Token-level or Sentence-level annotation boundaries are forced to coincide with token/sentence boundaries. If the selection is smaller, the annotation is expanded to the next larger token/sentence covering the selection. Again, zero-width annotations are permitted. When set to Single tokens only may be applied only to a single token. If the selection covers multiple tokens, the annotation is reduced to the first covered token at a time. Zero-width annotations are not permitted in this mode. Note that +in order for the Sentence-level mode to allow annotating multiple sentences, the +Allow crossing sentence boundary setting must be enabled, otherwise only individual sentences +can be annotated.

Overlap

This setting controls if and how annotations may overlap. For span layers, overlap is defined in terms of the span offsets. If any character offset that is part of span A is also part of span B, then they are considered to be overlapping. If two spans have exactly the same offsets, then they are considered to be stacking. For relation layers, overlap is defined in terms of the end points of the relation. If two relations share any end point (source or target), they are considered to be overlapping. If two relations have exactly the same end points, they are considered to be stacking. Note that some export formats are unable to deal with stacked or overlapping annotations. E.g. the CoNLL formats cannot deal with overlapping or stacked named entities.

Allow crossing sentence boundary

Allow annotations to cross sentence boundaries.

Behave like a linked list +(chain)

Controls what happens when two chains are connected with each other. If this option is disabled, then the two entire chains will be merged into one large chain. Links between spans will be changed so that each span connects to the closest following span - no arc labels are displayed. If this option is enabled, then the chains will be split if necessary at the source and target points, reconnecting the spans such that exactly the newly created connection is made - arc labels are available.

+
+
+

Features

+
+
+layer feature details +
+
+
+

In this section, features and their properties can be configured.

+
+
+ + + + + +
+ + +When a feature is first created, only ASCII characters are allowed for the feature name because the internal UIMA name is derived from the initial layer name. After the feature has been created, the name can be changed arbitrarily. The internal UIMA feature name will not be updated. The internal UIMA name is +e.g. used when exporting data or in constraint rules. +
+
+
+ + + + + +
+ + +Features cannot be added to or deleted from built-in layers. +
+
+
+

The following feature types are supported.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 15. Feature types
TypeDescription

uima.cas.String

Textual feature that can optionally be controlled by a tagset. It is rendered as a text field or as a combobox if a tagset is defined.

uima.cas.Boolean

Boolean feature that can be true or false and is rendered as a checkbox.

uima.cas.Integer

Numeric feature for integer numbers.

uima.cas.Float

Numeric feature for decimal numbers.

uima.tcas.Annotation +(Span layers)

Link feature that can point to any arbitrary span annotation

other span layers +(Span layers)

Link feature that can point only to the selected span layer.

+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 16. General feature properties
PropertyDescription

Internal name

Internal UIMA feature name

Type

The type of the feature (obligatory, see below)

Name

The name of the feature (obligatory)

Description

A description that is shown when the mouse hovers over the feature name in the annotation detail editor panel.

Enabled

Features cannot be deleted, but they can be disabled

Show in label

Whether the feature value is shown in the annotation label. If this is disabled, the feature is only visible in the annotation detail editor panel.

Show on hover

Whether the feature value is shown in the popup panel that appears when hovering with the mouse over an annotation label. Note that this popup may not be supported by all annotation editors.

Remember

Whether the annotation detail editor should carry values of this feature +over when creating a new annotation of the same type. This can be useful when creating many annotations +of the same type in a row.

Curatable

Whether the feature is considered when comparing whether annotations are equal and can be +pre-merged during curation. This flag is enabled by default. When it is disabled, two annotations +will be treated as the same for the purpose of curation, even if the feature value is different. +The feature value will also not be copied to a pre-merged or manually merged annotation. Disabling +this flag on all features of a layer will cause annotations to be only compared by their positions.

+
+
String features
+
+

A string feature either holds a short tag (optionally from a restricted tag set) or a note (i.e. +a multi-line text).

+
+
+

When no tagset is associated with the string feature, it is displayed to the user simply as a +single line input field. You can enable the multiple rows option to turn it into a multi-line +text area. If you do so, additional options appear allowing to configure the size of the text area +which can be fixed or dynamic (i.e. automatically adjust to the text area content).

+
+
+

Optionally, a tagset can be associated with a string feature (unless you enabled multiple rows). If string feature is associated with a tagset, there are different options +as to which type of editor type (i.e. input field) is displayed to the user.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + +
Table 17. Editor types for string features with tagsets
Editor typeDescription

Auto

An editor is chosen automatically depending on the size of the tagset and whether annotators can add to it.

Radio group

 Each tag is shown as a button. Only one button can be active at a time. Best for quick access to small tagsets. Does not allow annotators to add new tags (yet).

Combo box

A text field with auto-completion and button that opens a drop-down list showing all possible tags and their descriptions. Best for mid-sized tagsets.

Autocomplete

A text field with auto-completion. A dropdown opens when the user starts typing into the field and it displays matching tags. There is no way to browse all available tags. Best for large tagsets.

+
+

The tagset size thresholds used by the Auto mode to determine which editor to choose can be +globally configured by an administrator via the settings.properties +file. Because the radio group editor does not support adding new tags (yet), it chosen automatically +only if the associated tagset does not allow annotators to add new tags.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 18. String feature properties
PropertyDescription

Tagset

The tagset controlling the possible values for a string feature.

Show only when constraints apply

Display the feature only if any constraint rules apply to it (cf. Conditional features)

Editor type

The type of input field shown to the annotators.

Multiple Rows

If enabled the textfield will be replaced by a textarea which expands on focus. This also enables options to set the size of the textarea and disables tagsets.

Dynamic Size

If enabled the textfield will dynamically resize itself based on the content. This disables collapsed and expanded row settings.

Collapsed Rows

Set the number of rows for the textarea when it is collapsed and not focused.

Expanded Rows

Set the number of rows for the textarea when it is expanded and not focused.

+
+
+
Number features
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + +
Table 19. Number feature properties
PropertyDescription

Limited

If enabled a minimum and maximum value can be set for the number feature.

Minimum

Only visible if Limited is enabled. Determines the minimum value of the limited number feature.

Maximum

Only visible if Limited is enabled. Determines the maximum value of the limited number feature.

Editor Type

Select which editor should be used for modifying this features value.

+
+
+
Boolean features
+ +
+
+ + + ++++ + + + + + + + + + + + + + + + + +
Table 20. Link feature properties
PropertyDescription

Tagset

The tagset controlling the possible values for the link roles.

Enable Role Labels

Allows users to add a role label to each slot when linking anntations. If disabled the UI labels of annotations will be displayed instead of role labels. This property is enabled by default.

+
+
+
Key bindings
+
+

Some types of features support key bindings. This means, you can assigning a combination of keys to a +particular feature value. Pressing these keys on the annotation page while a annotation is selected +will set the feature to the assigned value. E.g. you could assign the key combo CTRL P to the +value PER for the value feature on the Named Entity layer. So when you create a Named Entity +annotation and then press the CTRL P, the value would be set to PER.

+
+
+

If the focus is on an input field, the key bindings are suppressed. That means, you could even +assign single key shortcuts like p for PER while still be able to use p when entering text +manually into an input field. Normally, the focus would jump directly to the first feature editor +after selecting an annotation. But this is not the case if any features have key bindings defined, +because it would render the key bindings useless (i.e. you would have to click outside of the +feature editor input field so it looses the focus, thus activating the key bindings).

+
+
+

When defining a key binding, you have to enter a key combo consisting of one or more of the +following key names:

+
+
+
    +
  • +

    Modifier keys: Ctrl, Shift, Alt, Meta

    +
  • +
  • +

    Letter keys: a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z

    +
  • +
  • +

    Number keys: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9

    +
  • +
  • +

    Function keys: F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11, F12

    +
  • +
  • +

    Navigation keys: Home, End, Page_up, Page_down, Left, Up, Right, Down

    +
  • +
  • +

    Other keys: Escape, Tab, Space, Return, Enter, Backspace, Scroll_lock, Caps_lock, Num_lock, Pause, Insert, Delete

    +
  • +
+
+
+

Typically you would combine zero or more modifier keys with a regular key (letter, number, +function key, etc). A combination of multiple number or letter keys does not work.

+
+
+ + + + + +
+ + +Mind that you need to take care not to define the same key binding multiple times. Duplicate + definitions are only sensible if you can ensure that the features on which they are defined will never + be visible on screen simultaneously. +
+
+
+
+
Coloring rules
+
+

Coloring rules can be used to control the coloring of annotations. A rule consists of two parts: +1) a regular expression that matches the label of an annotation, 2) a hexadecimal color code.

+
+
+

A simple color rule could be use the pattern PER and the color code #0000ff (blue). This would +display all annotations with the label PER on the given layer in blue.

+
+
+

In order to assign a specific color to all annotations from the given layer, use the pattern .*.

+
+
+

It is also possible to assign a color to multiple label at once by exploiting the fact that the +pattern is a regular expression. E.g. PER|OTH would match annotations with the label PER as well +as with the label OTH. Mind not to add extra space such as PER | OTH - this would not work!

+
+
+

Be careful when creating coloring rules on layers with multiple features. If there are two features +with the values a and b, the label will be a | b. In order to match this label in a coloring +rule, the pipe symbol (|) must be escaped - otherwise it is interpreted as a regular expression +OR operator: a \| b.

+
+
+
+
Remote Lookup Feature
+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding annotation.feature-support.lookup.enabled=true to the settings.properties file. +
+
+
+
+
+

A remote lookup feature is basically a string feature, but it can query an external service for +possible values. The feature editor is a auto-complete field. When the user starts entering a +value into that field, it is sent to a configurable remote URL as a query. The expectation is that +the response from the remote service is a JSON structure that contains possible completions.

+
+
+

A remote lookup service must support a lookup and a query functionality:

+
+ ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Title

Query

Method

GET

Consumes

none

Produces

application/json;charset=UTF-8

URL params

+
    +
  • +

    q - query (max. 200 characters, mandatory)

    +
  • +
  • +

    qc - query context: the text of the selected annotation (max. 200 characters, optional)

    +
  • +
  • +

    l - limit - maximum number of results to return (mandatory)

    +
  • +
+

Data params

none

Success response

+
+
Code 200 - OK
+
+
+
Example
+
+
[
+  {
+    "id":"1",
+    "l":"Item 1",
+    "d":"Description 1"
+  },
+  {
+    "id":"2",
+    "l":"Item 2",
+    "d":"Description 2"
+  }
+]
+
+
+
+
+
+ ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Title

Lookup

Method

GET

Consumes

none

Produces

application/json;charset=UTF-8

URL params

+
    +
  • +

    id - item ID (mandatory)

    +
  • +
+

Data params

none

Success response

+
+
Code 200 - OK
+
+
+
Example
+
+
{
+  "id":"1",
+  "l":"Item 1",
+  "d":"Description 1"
+}
+
+
+
+
+

Error response

+
+
Code 404 - Item not found
+
+

no body

+
+
+
+
+
+
+
+

Annotation

+
+

Here the project manager can configure settings that affect the experience on the annotation page.

+
+
+

Default sidebar

+
+

Certain functionalities such as for example document-level annotations are accessible via a sidebar +on the annotation page. A project manager may choose a default sidebar here which will be expanded +by default when a new annotator opens a document for annotation. Note that this does not affect +any annotators that are already working in the current project. Thus, the manager should set the +default sidebar before adding annotators to the project. Not all pipelines are available to all +users. If the selected default sidebar is not available to a user, this setting has no effect. A +typical use for this setting is to set the document metadata sidebar as the default sidebar such +that annotators can open a document and immediately edit the document-level annotations without +first having to search for the sidebar.

+
+
+
+

Annotation sidebar

+
+
Pinned Groups
+

This setting allows configuring groups which are always visible in the annotation sidebar on the +annotation page when the sidebar is in group by label mode.

+
+
+

Consider a situation where annotators should always locate one or more mentions of a particular +concept in every document. Configuring the labels of these concepts as pinned groups will show +them in the sidebar, even if the annotator has not yet created an annotation for them. This can +help the annotator to see which concepts still need to be located and annotated in the text.

+
+
+

This functionality can also be used to enforce a particular order of groups if the automatic alphabetic sorting is not convenient.

+
+
+

Note that groups are formed by the label of an annotation which consists of the concatenated feature +values. Thus, for annotations that have multiple features included in their labels, you need to pay +close attention to exactly match the rendered labels in your pinned groups (wildcards are not +supported!). You might consider excluding non-essential features from the label by unchecking the +option Visible in the settings for the respective feature.

+
+
+
+
+

Knowledge Bases

+
+

In the Projects Settings, switch to the Knowledge Bases tab, then click New… on the bottom + and a dialogue box shows as in the figure below.

+
+
+
+kb1 +
+
+
+

To create a local or remote knowledge base, one needs to choose Local or Remote for the type. For the reification, +NONE is the default case, but to support qualifiers, one needs to choose WIKIDATA.

+
+
+

For the local KB, the user can optionally choose a RDF file from which to import the initial data. Alternatively, the user can skip the step to create an empty KB to create a knowledge base from scratch. It is also always possible to import data from an RDF file after the creation of a KB. It is also possible to multiple RDF files into the same KB, one after another.

+
+
+

For remote KBs, INCEpTION provides the user with some pre-configured knowledge base such as WikiData, British Museum, BabelNet, DBPediaa or Yago. The user can also set up a custom remote KB, in which case the user needs to provide the SPARQL endpoint URL for the knowledge base as in the figure below.

+
+
+
+kb2 +
+
+
+

Settings

+
+

There are various settings for knowledge bases.

+
+
+
+kb3 +
+
+
+
Local KBs
+
+
    +
  • +

    Read only: Whether the KB can be modified. This setting is disabled by default. Enabling it +prevents making changes to the KB and allows for more effective query caching.

    +
  • +
+
+
+
+
Remote KBs
+
+

The remote knowledge bases, there are the following settings:

+
+
+
    +
  • +

    SPARQL endpoint URL: The SPARQL URL used to access the knowledge base

    +
  • +
  • +

    Skip SSL certificate checks: Enable to skip the verification of SSL certificates. This can +help if the remote server is using a self-signed certificate. It should be avoided to use this +option in production. Instead, better install the remote certificate into your Java environment +so it can be validated.

    +
  • +
  • +

    Default dataset: A SPARQL endpoint may server multiple datasets. This setting can be used to +restrict queries to a specific one. Consult with the operator of the SPARQL server to see which +datasets are available.

    +
  • +
+
+
+ + + + + +
+ + +Changing the URL of a remote KB currently only takes affect after INCEpTION is restarted! + The updated URL will be shown in the settings, but queries will still be sent to the old URL until you restart INCEpTION. + This also means that if you add, remove or change HTTP "Basic" authentication that are part of the URL, they will not + take effect until you restart. It is usually easier to delete the remote KB configuration and create it from scratch + with the new URL. +
+
+
+
+
Query settings
+
+
    +
  • +

    Use fuzzy matching: enables fuzzy matching when searching the knowledge base. The effect is +slightly different depending on the backend being used and it can significantly slow down the +retrieval process. It is normally a good idea to leave this feature off. If you would like to +retrieve items from the knowledge base which only approximately match a query (e.g. you would +like that an entry John is matched if you enter Johan or vice versa), then you could try +this out.

    +
  • +
  • +

    Result limit for SPARQL queries: this is used to limit the amount of data retrieved from the +remote server, e.g when populating dropdown boxes for concept search.

    +
  • +
+
+
+
+
Schema mapping
+
+

Different types of knowledge base schemata are supported via a configurable mapping mechanism. The +user can choose one of the pre-configured mapping or provide a custom mapping.

+
+ +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Setting DescriptionExample

Class IRI

Identifies a concept as a class

+
+Details +
+
+
http://my-kb/foo is a class
+
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix owl: <http://www.w3.org/2002/07/owl#>.
+
+<http://my-kb/foo>
+  rdf:type owl:Class.
+
+
+
+

Subclass IRI (property)

Indicates the sub-class relation between two classes

+
+Details +
+
+ +
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
+
+<http://my-kb/foo>
+  rdfs:subClassOf <http://my-bb/bar>.
+
+
+
+

Type IRI (property)

Indicates the is-a relation between an instance and a class

+
+Details +
+
+ +
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+
+<http://my-kb/foo>
+  rdf:type <http://my-bb/bar>.
+
+
+
+

Label IRI (property)

Name of the class or instance

+
+Details +
+
+
http://my-kb/foo has a name
+
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
+
+<http://my-kb/foo>
+  rdfs:label "Foo".
+
+
+
+

Description IRI (property)

Description of a class or instance

+
+Details +
+
+
http://my-kb/foo has a description
+
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
+
+<http://my-kb/foo>
+  rdfs:comment "This entry describes a Foo".
+
+
+
+

Property IRI

Identifies a concept as a property

+
+Details +
+
+
http://my-kb/foo is marked as being a property
+
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
+
+<http://my-kb/foo>
+  rdf:type rdf:Property.
+
+
+
+

Sub-property IRI (property)

Indicates the sub-property relation between two properties

+
+Details +
+
+
http://my-kb/foo is a sub-property of http://my-bb/bar
+
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
+
+<http://my-kb/foo>
+  rdf:subPropertyOf <http://my-kb/bar> .
+
+
+
+

Property label IRI (property)

Name of the property

+
+Details +
+
+
http://my-kb/foo has a name
+
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
+
+<http://my-kb/foo>
+  rdfs:label "Foo".
+
+
+
+

Property description IRI (property)

Description of the property

+
+Details +
+
+
http://my-kb/foo has a description
+
+
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.
+@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.
+
+<http://my-kb/foo>
+  rdfs:comment "This entry describes a Foo".
+
+
+
+
+
+
+
Root Concepts
+
+

In the advanced settings, the user can leverage this feature of KB settings when one doesn’t want the entire knowledge base to be used and rather choose to identify some specific root concepts. This feature specially helps in case of large knowledge bases such as Wikidata.

+
+
+
+
Additional Matching Properties
+
+

When searching for a concept e.g. in the annotation editor, by default the search terms are matched only against the concept name (label). There should only be one label for each concept +(although there can be multiple label entries for a concept in the knowledge base, but theses +should refer to different languages). However, it is common that this one label is actually only +the preferred label and there could be any number of synonyms through which the concept can +also be found. Thus, here you can enter a list of properties which should also be considered +when searching for a concept.

+
+
+ + + + + +
+ + +Not all remote SPARQL knowledge bases may support additional matching properties. + If a full text index is used (recommended!), then the full text index may have to be configured to index + all properties listed here. +
+
+
+
+ +
+

Full text search in knowledge bases enables searching for entities by their textual context, e.g. their label. This is a prerequisite for some advanced features such as re-ranking linking candidates during entity linking. Two full text search modes are supported:

+
+
+ +
+
+
Apache Jena Fuseki
+
+

To enable the full text index on the Fuseki server side, set the options options text:storeValues and +text:multilingualSupport both to true (cf. Text Dataset Assembler documentation).

+
+
+

Fuseki databases are usually accessible via SPARQL at http://localhost:3030/DATABASE-NAME/sparql or +http://localhost:3030/DATABASE-NAME/query.

+
+
+
+
Stardog
+
+

To enable full text search in a Stardog database, create the database with the option +search.enabled=true.

+
+
+
Example creation of FTS-enabled Stardog database
+
+
stardog-admin db create -n DATABASE-NAME -o search.enabled=true -- knowledgebase.ttl
+
+
+
+

Stardog databases are usually accessible via SPARQL at http://localhost:5820/DATABASE-NAME/query. +You may have to specify credentials as part of the URL to gain access.

+
+
+
+
SPARQL Endpoint Authentication
+
+

INCEpTION supports endpoints require authentication. The following authentication mechanisms +are supported.

+
+
+
    +
  • +

    HTTP basic authentication

    +
  • +
  • +

    OAuth (client credentials)

    +
  • +
+
+
+

To enable authentication, select one of the options from the Authentication dropdown menu.

+
+
+ + + + + +
+ + +To protect you credentials while sending them to the remote side, it is strongly recommended + to use a HTTPS connection to the SPARQL endpoint and keep SSL certificate checking enabled. +
+
+
+
HTTP "basic" authentication
+

This is a simple mechanism that sends a username and password on every request.

+
+
+
OAuth (client credentials) authentication
+

This mechanism uses the client ID and client secret to obtain an authentication token which is then +used for subsequent requests. Once the token expires, a new token is requested.

+
+
+
+
+ + + + + +
+ + +Legacy feature. It is also possible to use HTTP basic authentication by prefixing the + SPARQL URL with the username and password (http://USERNAME:PASSWORD@localhost:5820/mock/query). + However, this is not recommended. For example, the password will be visible to anybody being able to + access the knowledge base settings. This option is only supported for backwards compatibility and will + be removed in future versions. +
+
+
+
+
+
+
+
Importing RDF
+
+ + + + + +
+ + +You can only import data into local KBs. Remote KBs are always read-only. +
+
+
+

KBs can be populated by importing RDF files. Several formats are supported. The type of the file is determined by the file extension. So make sure the files have the correct extension when you import them, otherwise nothing might be imported from them despite a potentially long waiting time. The application supports GZIP compressed files (ending in .gz, so e.g. .ttl.gz), so we recommend compressing the files before uploading them as this can significantly improve the import time due to a reduced transfer time across the network.

+
+ ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Format Extension

RDF

.rdf

RDF Schema

.rdfs

OWL

 .owl

N-Triples

 .nt

Turtle

.ttl

+
+
+
+
+

Recommenders

+
+

Recommenders provide annotation support by predicting potential labels. +These can be either accepted or rejected by the user. +A recommender learns from this interaction to further improve the quality of its predictions.

+
+
+

Recommenders are trained every time an annotation is created, updated or deleted. In order to determine +whether the annotations are good enough, recommenders are evaluated on the annotation data. +During recommender evaluation a score for each recommender is calculated and if this score does not +meet the configured threshold, the recommender will not be used.

+
+
+

Recommenders can be configured in the Project Settings under the Recommenders tab. To create a new +recommender, click Create. Then, the layer, feature and the classifier type has to be selected.

+
+
+

Overall recommender settings

+
+

The option wait for suggestions from non-trainable recommenders when opening document can be +enabled overall. It is accessible from the settings dropdown on the recommender list panel. +When this option is enabled, the system will wait for responses from all non-trainable recommenders +in the project when a user is opening a document before actually displaying the document to the +user. If this option is not checked, then recommendations may only appear after the user has +performed some action such as creating an annotation.

+
+
+ + + + + +
+ + +Enable this option only if all of your non-trainable recommenders have a fast response time, + as otherwise your users may complain about a long delay when opening documents. +
+
+
+
+

Per-recommender settings

+
+

By default, the name of new recommenders are auto-generated based on the choice of layer, feature and tool. However, you can deactivate this behavior by unchecking the auto-generate option next to the name field.

+
+
+

Recommenders can be enabled and disabled. This behaviour is configured by the Enabled checkbox. +Recommenders that are disabled are not used for training and prediction and are not evaluated.

+
+
+

The Activation strategy describes when a recommender should be used for prediction. Right now, +there are two options: either set a threshold on the evaluation score (if the evaluation score is +lower than the threshold, the recommender is not used for predicting until annotations have changed) +or always enable it. +If the option Always active is disabled and the score threshold is set to 0, +the recommender will also be always executed, but internally it is still evaluated.

+
+
+

Some recommenders are capable of generating multiple alternative suggestions per token or span. The maximum +number of suggestions can be configured by the Max. recommendations field.

+
+
+

Sometimes it is desirable to not train on all documents, but only on e.g. finished documents. In order +to control documents in which state should be used for training, the respective ones can be selected +from the States used for training.

+
+
+

To save a recommender, click Save. To abort, click Cancel. To edit an existing recommender, it +can be selected from the left pane, edited and then saved. Recommenders can be deleted by clicking on +Delete. This also removes all predictions by this recommender.

+
+
+
+recommender settings +
+
+
+ + + + + +
+ + +Stacked annotations: If you configured a recommender on a layer that allows stacking (i.e. multiple annotations of the same layer type at the same position in the text), accepting a suggestion will always create a new annotation with the suggested feature value. Even if annotation(s) of the same type already exist at this position, the suggested feature value will not be added to this annotation, but a new one will be created instead. +
+
+
+
+

String Matcher

+
+

The string matching recommender is able to provide a very high accuracy for tasks such as named +entity identification where a word or phrase always receives the same label. If an annotation is +made, then the string matching recommender projects the label to all other identical spans, +therefore making it easier to annotate repeated phenomena. So if we annotate Kermit once as a +PER, then it will suggest that any other mentions of Kermit should also be annotated as PER. +When the same word or phrase is observed with different labels, then the matcher will assign the +relative frequency of the observations as the score for each label. Thus, if Kermit is annotated +twice as PER and once as OTH, than the score for PER is 0.66 and the score for OTH is 0.33.

+
+
+

The recommender can be used for span layers that anchor to single or multiple tokens and where +cross-sentence annotations are not allowed. It can be used for string features or features which get +internally represented as strings (e.g. concept features).

+
+
+
Gazeteers
+
+

It is possible to pre-load gazeteers into string matching recommenders. A gazeteer is a simple text +file where each line consists of a text and a label separated by a tab character. The order of +items in the gazeteer does not matter. Suggestions are generated considering the longest match. Comment lines start with a #. Empty lines are ignored.

+
+
+
Gazeteer example
+
+
# This is a comment
+Obama	PER
+Barack Obama	PER
+Illinois	LOC
+Illinois State Senate	ORG
+Hawaii	LOC
+Indonesia	LOC
+
+
+
+
+
Character-level layers
+
+

For layers which are configured to have a character-level annotation granularity, the string +matching recommender will still try to match only at the beginning of tokens. However, it will not +require that the end of a match also ends at a token boundary. This helps e.g. in situations where +punctuation is not correctly detected as being a separate token.

+
+
+ + + + + +
+ + +For layers with character-level granularity or layers which allow cross-sentence annotations, + the evaluation scores of the recommender may not be exact. +
+
+
+
+
+

String Matcher for Relations

+
+

The string matching relation recommender can be used to predict relations, i.e. it predicts if there is a connection between +two annotations and what the relation’s feature value might be. You need a base layer with a feature on it in addition +to a relation layer on top configured for it to work.

+
+
+

As an example, we define a base layer called Locations. We add a +String feature named value on it. Then, we define a relation layer on top of it called Located, with a String feature +named relation.

+
+
+

During configuration, we first need to select the feature of the relation that should be predicted. +We create a String matcher for relations, choose the relation layer to be Located and the base layer +feature as value. This recommender now saves tuples of (source:value, target:value, relation). If it encounters a +sentence that contains locations with the same source and target value, it predicts a relation between them with the label +it saw before.

+
+
+

For instance, given the following text

+
+
+
+
Darmstadt is in Hesse.
+Hanover is in Lower Saxony.
+
+
+
+

we annotate Darmstadt and Hanover as a location with value=city and Hesse and Lower Saxony as a location with value=state. We draw a relation between Darmstadt and Hesse with a label of located in. The recommender then predicts that Hanover is also located in Lower Saxony, because it learned that a relation between city and state should have label located in.

+
+
+
+relation recommender city +
+
+
+

This recommender currently does not work for base layers that allow stacking.

+
+
+

This recommender is not enabled by default, please refer to the admin guide for how to enable it.

+
+
+
+

Sentence Classifier (OpenNLP Document Categorizer)

+
+

This recommender is available for sentence-level annotation layers where cross-sentence annotations +are disabled. It learns labels using a sentence-level bag-of-word model using the OpenNLP Document Categorizer.

+
+
+
+

Token Sequence Classifier (OpenNLP POS)

+
+

This recommender uses the OpenNLP Part-of-Speech Tagger to learn a token-level sequence tagging +model for layers that anchor to single tokens. The model will attempt to assign a label to every +single token. The model considers all sentences for training in which at least a one annotation +with a feature value exists.

+
+
+
+

Multi-Token Sequence Classifier (OpenNLP NER)

+
+

This recommender uses the OpenNLP Name Finder to learn a sequence tagging model for multi-token +annotations. The model generates a BIO-encoded representation of the annotations in the sentence.

+
+
+ + + + + +
+ + +If a layer contains overlapping annotations, it considers only the first overlapping + annotation and then skips all annotation until it reaches one that does not overlap with it. +
+
+
+
+

Named Entity Linker

+
+

This recommender can be used with concept features on span layers. It does not learn from training +data, but instead attempts to match the context of the entity mention in the text with the context +of candidate entities in the knowledge base and suggests the highest ranked candidate entities. +In order for this recommender to function, it is necessary that the knowledge base configured for +the respective concept feature supports full text search.

+
+
+
+

External Recommender

+
+

This recommender allows to use external web-services to generate predictions. For details on the +protocol used in the communication with the external services, please refer to the developer +documentation.

+
+
+
+

WebLicht

+
+

The WebLicht recommender allows you to use CLARIN WebLicht services to generate annotation +recommendations. In order to do so, first need to obtain an API key here.

+
+
+

After making the basic settings and entering the API key, Save the recommender. Doing so allows +you to attach a processing chain definition file. With out such a file, the recommender will not +work. We will provide some example settings here to go along with the example processing chain that +we will be building below:

+
+
+
    +
  • +

    Layer: Named entity

    +
  • +
  • +

    Feature: value

    +
  • +
  • +

    Tool: WebLicht recommender

    +
  • +
  • +

    URL: Do not change the default value unless you really know what you are doing (e.g. +developing custom WebLicht services).

    +
  • +
  • +

    Input format: Plain text

    +
  • +
+
+
+

Next, log in to WebLicht to build a processing chain.

+
+
+

The simplest way to build a chain is this:

+
+
+
    +
  • +

    Choose a sample input. Make sure the language of the input matches the language of the documents +in your INCEpTION project. WebLicht will only allow you to add NLP services to the chain +which are compatible with that language. For our example, we will choose [en] Example Food. Press OK.

    +
  • +
  • +

    Choose easy mode. This allows you to conveniently select a few common types of annotations to +generate.

    +
  • +
  • +

    Choose Named Entities. For our example, we choose to generate named entity annotations, so +we select this from the list on the left.

    +
  • +
  • +

    Download chain. Click this button to download the chain definition. Once downloaded, it is a +good idea to rename the file to something less cryptic than the default auto-generated ID, e.g. +we might rename the file to WebLicht_Named_Entities_English.xml.

    +
  • +
+
+
+
+weblicht chain builder +
+
+
+

Back in the recommender settings, click Browse in the Upload chain field and select the processing chain definition file you have just generated. Then click the Upload button that appears in the field.

+
+
+

For good measure, Save the whole settings once more. When you now open a document in the +annotation page, you should be able to see recommendations.

+
+
+
Supported annotations
+

The WebLicht recommender can currently be used with the following built-in annotation layers:

+
+
+
    +
  • +

    Part of speech

    +
  • +
  • +

    Lemma

    +
  • +
  • +

    Named entities (only the value feature)

    +
  • +
+
+
+
Using the TCF format
+

By default, the recommender sends data as plain text to WebLicht. This means that the processing +chain needs to run a tokenizer and sentence splitter. Since these might generate boundaries different +from the one you have in INCEpTION, some of the recommendations might look odd or may not be +displayed at all. This can be avoided by sending data in the WebLicht TCF format. If you select this +format, the tokens and sentence boundaries will be sent to WebLicht along with the text. You will then +also need to specify the language of the documents that you are going to be sending. Note that even +when selecting the TCF format, only text, language, tokens and sentences are sent along - no other +annotations. Also, only the target layer and feature will be extracted from the processing chain’s +results - no other annotations.

+
+
+

However, building a processing chain that takes TCF as input is a bit more difficult. When building +the chain, you need to upload some TCF file containing tokens, sentences, and the proper language +in the Input selection dialog of WebLicht. One way to get such a file is to open one of your +documents in the annotation page, export it in the TCF format, then opening the exported file in a +text editor an manually fixing the lang attribute on the tc:TextCorpus XML element. We know that +this is a bit inconvenient and try to come up with a better solution.

+
+
+
+

European Language Grid

+
+

This recommender allows to use some European Language Grid (ELG) web-services to generate predictions.

+
+
+

In order to use the recommender, you need to have an ELG account. When you add an ELG recommender to a project and the project has not yet signed in to an ELG account, you will see three steps offered in the ELG session panel:

+
+
+
    +
  1. +

    A link to through which you can obtain an ELG authentication token. +When you follow the link, you have to log in using your ELG account and then a token +is shown to you.

    +
  2. +
  3. +

    Copy that token into the Success code field.

    +
  4. +
  5. +

    Finally, press the sign in button.

    +
  6. +
+
+
+

Then you can find a service via the Service auto-complete field. E.g. if you enter entity into the field, you will get various services related to entity detection. Choose one to configure the recommender to use it.

+
+
+ + + + + +
+ + +ELG services have a quota. If the recommender suddenly stops working, it might + be that your account has exceeded its quota. +
+
+
+
+
+

Tagsets

+
+

To manager the tagsets, click on the tab Tagsets in the project pane.

+
+
+
+project7 +
+
+
+

To edit one of the existing tagsets, select it by a click. Then, the tagset characteristics are displayed.

+
+
+
+project8 +
+
+
+

In the Frame Tagset details, you can change them, export a tagset, save the changes you made on it or delete it by clicking on Delete tagset. +To change an individual tag, you select one in the list displayed in the frame Tags. You can then change its description or name or delete it by clicking Delete tag in Tag details. Please do not forget to save your changes by clicking on Save tag. +To add a new tag, you have to click on Create tag in Tag details. Then you add the name and the description, which is optional. Again, do not forget to click Save tag or the new tag will not be created.

+
+
+

To create an own tagset, click on Create tagset and fill in the fields that will be displayed in the new frame. Only the first field is obligatory. Adding new tags works the same way as described for already existing tagsets. If you want to have a free annotation, as it could be used for lemma or meta information annotation, do not add any tags.

+
+
+
+project tagset new +
+
+
+

To export a tagset, choose the format of the export at the bottom of the frame and click Export tagset.

+
+
+
+

Export

+
+
+project export +
+
+
+

Here you can export the project for different purposes. Once an export process has been started, its progress can be see in the right sidebar. If an export takes very long, you can keep it running and check back regularly to see its state. You can even log out and log in later. Once the export is complete, you have 30 minutes to download it before it gets cleaned up automatically. Any user with project manager permissions can visit this page and view the exports. When a user cancels an export or downloads an export, it is removed from the list. If there are any messages, warnings or errors, you should inspect them before cancelling or downloading the export. While an export is running, only the latest messages is displayed and it can happen that messages are skipped. Once the export is complete (either successfully or failed), the full list of messages is accessible.

+
+
+

Export backup archive

+
+

This export is for the purpose of creating a backup, of migrating it to a new INCEpTION version, of migrating to a different INCEpTION instance, or simply in order to re-import it as a duplicate copy.

+
+
+

The export is an archive which can be re-imported again since it includes +the annotations in the format internally used by the application.

+
+
+

In addition to the internal format, the annotations can optionally be included in a secondary format in the export. Files in this secondary format are ignored if the archive is re-imported into INCEpTION. This format is controlled by the Secondary Format drop-down field. When AUTO is selected, the file format corresponds to the format of the source document. If there is no write support for the source format, the file is exported in the WebAnno TSV3 format instead. If the original file format did not contain any annotations (e.g. plain text files) or only specific types of annotations (e.g. CoNLL files), the secondary annotation files will also have none or limited +annotations.

+
+
+ + + + + +
+ + +Some browsers automatically extract ZIP files into a folder after the download. Zipping this + folder and trying to re-import it into the application will generally not work because the process + introduces an additional folder level within the archive. The + best option is to disable the automatic extraction in your browser. E.g. in Safari, go to + PreferencesGeneral and disable the setting Open "safe" files after downloading. +
+
+
+

When exporting a whole project, the structure of the exported ZIP file is as follows:

+
+
+
+
+
    +
  • +

    <project ID>.json - project metadata file

    +
  • +
  • +

    annotation

    +
    +
      +
    • +

      <source document name>

      +
      +
        +
      • +

        <user ID>.XXX - file representing the annotations for this user in the selected format. +project + automatically generated suggestions

        +
      • +
      +
      +
    • +
    +
    +
  • +
  • +

    annotation_ser

    +
    +
      +
    • +

      <source document name>

      +
      +
        +
      • +

        <user ID>.ser - serialized CAS file representing the annotations for this user +project + automatically generated suggestions

        +
      • +
      +
      +
    • +
    +
    +
  • +
  • +

    curation

    +
    +
      +
    • +

      <source document name>

      +
      +
        +
      • +

        CURATION_USER.XXX - file representing the state of curation in the selected format.

        +
      • +
      +
      +
    • +
    +
    +
  • +
  • +

    curation_ser

    +
    +
      +
    • +

      <source document name>

      +
      +
        +
      • +

        CURATION_USER.ser - serialized UIMA CAS representing the state of curation

        +
      • +
      +
      +
    • +
    +
    +
  • +
  • +

    log

    +
    +
      +
    • +

      <project ID>.log - project log file

      +
    • +
    +
    +
  • +
  • +

    source - folder containing the original source files

    +
  • +
+
+
+
+
+
+

Export curated documents

+
+

This export only includes only the curated documents for the purpose of getting an easy access to the final annotation results. If you do not have any curated documents in your project, this export option is not offered. A re-import of these archives is not possible.

+
+
+
+
+

Invite Links

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding sharing.invites.enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

Project managers can generate invite links to their projects which allow users to easily join their project. For this, visit the Project Settings and click on Share Project. Clicking on Allow joining the project via a link will generate the invite link that can then be copied and given to users (e.g. via email).

+
+
+
+sharing settings +
+
+
+

The user can now follow the invite link by entering it into a browser. She might be prompted to log into INCEpTION and is then automatically added to the project with annotator rights and directed to the project dashboard page. She can now start annotating.

+
+
+

Invite life time

+
+

The life time of an invite link can be controlled in several ways:

+
+
+
    +
  • +

    By date: you can set an expiration date indicating a date until which the annotation will be valid.

    +
  • +
  • +

    By annotator count: you can set a limit of annotators for project. If the number of users in the +project reaches this number, the invite link can no longer be used to join.

    +
  • +
  • +

    By project state: the invite can be configured to stop working once all documents in the document +have been annotated. What exactly all documents have been annotated means depends on the workload +management strategy that has been configured. E.g. for a project using the dynamic workload +management, the annotations of the project are considered to complete once the required number +of annotators per document have marked all their documents as finished.

    +
  • +
+
+
+

If any of the configured conditions are triggered, an alert is shown next do the condition and the invite link cannot be used anymore.

+
+
+
+

Guest annotators

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding sharing.invites.guests-enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

By default, users need to already have a INCEpTION account to be able to use the link. However, +by activating the option Allow guest annotators, a person accessing the invite link can simply +enter any user ID they like and access the project using that ID. This ID is then valid only via the +invite link and only for the particular project. The ID is not protected by a password. When the +manager removes the project, the internal accounts backing the ID are automatically removed as well.

+
+
+

It is possible to replace the user ID input field placeholder with a different text. This is useful +if you e.g. want your users to user a specific information as their user ID. E.g. if you use this +feature in a classroom scenario, you might find it convenient if the students provide their +matriculation number.

+
+
+ + + + + +
+ + +Make sure to avoid multiple users signing in with the same user ID - INCEpTION does not +support being used from multiple browsers / windows / computers concurrently with the same user ID! +
+
+
+

Optionally the invite can be configured to require guest annotators to enter an email address in +addition to the user ID. If a user provides an email address along with the user ID, then for +subsequent logins, the user needs to provide the same email address. If a different email address +is provided, then the login is rejected.

+
+
+ + + + + +
+ + +When importing a project with guest annotators, the annotations of the guests can only be +imported if the respective guest accounts do not yet exist in the INCEpTION instance. This +means, it is possible to make a backup of a project and to import it into another INCEpTION +instance or also into the original instance after deleting the original project. However, when +importing a project as a clone of an existing project in the same instance, the imported project +will not have any guest annotators. +
+
+
+
+
+

Project Versioning

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding versioning.enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

Project managers can create snapshots of all documents in the project as well as its layer configuration via the versioning panel. +This is done via a git repository stored in the .inception folder. +This git repository can also be used to push to a remote repository, e.g. saving on Github or Gitlab. +We currently only support pushing via HTTPS.

+
+
+
+versioning settings +
+
+
+

If you want to roll back to an earlier version, then you need to manually check out the old version in the local or remote git repository, load the old layer configuration manually in the layer settings and replace source and annotation documents via the remote API (see the Admin Guide).

+
+
+
+
+
+
+

User Management

+
+
+ + + + + +
+ + +This functionality is only available to administrators. +
+
+
+

After selecting this functionality, a frame which shows all users is displayed. By selecting a user, a frame is displayed on the right.

+
+
+
+manage users +
+
+
+

Now you may change his role or password, specify an e-mail address and dis- or enable his account by placing the tick.

+
+
+ + + + + +
+ + +Disabling an account prevents the user from logging in. The user remains associated with any + projects and remains visible in the project user management and the project workload management. +
+
+
+

To create a new user, click on Create in the left frame. This will display a similar frame as the one described in the last paragraph. Here you have to give a login-name to the new user.

+
+
+

In both cases, do not forget to save your changes by pressing the Save button.

+
+
+
    +
  1. +

    User roles

    +
  2. +
+
+ ++++ + + + + + + + + + + + + + + + + + + + + + + +

Role

Description

ROLE_USER

User. Required to log in to the application. Removal of this role from an account will prevent + login even for users that additionally hold the ROLE_ADMIN!

ROLE_ADMIN

Administrator. Can manage users and has access to all other functionalities.

ROLE_PROJECT_CREATOR

Project creator. Can create new projects.

ROLE_REMOTE

Remote API access. Can access the remote API.

+
+
+
+

Advanced functionalities

+
+
+
+
+
+
+ +
+
+

In order to annotate text, it is first necessary to actually have text documents. Not every text +documented is worth annotating. For this reason, INCEpTION allows connecting to external +document repositories, to search these repositories for interesting documents, and to import +relevant documents.

+
+
+

Search page

+
+

If document repositories have been configured in a project, the Search +page becomes accessible through the project dashboard. +On the top left of the search page you can select in a dropdown menu which document repository you want to query. +All document repositories that were created in the project settings should be selectable here and +are identified by their Name. +The field next to it is the query text field in which the search queries are entered. +After entering a query, search by pressing the Enter key or by a clicking on the Search button. +The documents in the document repository which +match +the search query are returned as the search results and then shown as a table. +The table displays 10 results at a time and more can be accessed through the paging controls which +are located above the table. +Depending on the repository, you may see a document title or ID, text snippets with highlights +indicating matches of your query in the document, and a score which represents the relevance of the +document to the query. If a document has not yet been +imported into your project, there is an Import button which extracts the document from the +repository and adds it to the project, thereby making it available for annotation. If the document +has already been imported, there is an Open button instead. Clicking on the document title or ID +opens a preview page where the document text can be viewed before importing it.

+
+
+ + + + + +
+ + +Normally the ability to add new documents to a project is limited to project managers and it + is only possibly via the Documents tab in the project settings. However, any user can import a + document from an external repository. +
+
+
+
+

External search sidebar

+
+

The external search functionality can be used in the sidebar of the annotation page as well and +can be opened by clicking on the globe-logo on the sidebar at the left of the annotation page. +It essentially offers the same functionality as the external search page accessible via the project dashboard. +Being able to search directly from the annotation page may be more convenient though because the user does not +have to keep switching between the search page and the annotation page. Additionally, clicking on a search +result in the external search sidebar automatically imports the document into your project +and opens it in the annotation view.

+
+
+
+

Document repositories

+
+

Document repositories can be added via the Document repository tab in the project settings.

+
+
+

OpenSearch

+
+

Selecting the OpenSearch repository type allows connecting to remote OpenSearch instances.

+
+
+

In order to set up a connection to an OpenSearch repository, the following information needs to +be provided:

+
+
+
    +
  • +

    Remote URL: the URL where the OpenSearch instance is running (e.g. http://localhost:9200/)

    +
  • +
  • +

    Index Name: the name of the index within the instance (e.g. mycorpus)

    +
  • +
  • +

    Search path: the suffix used to access the searching endpoint (usually _search)

    +
  • +
  • +

    Object type: the endpoint used to download the full document text (usually texts)

    +
  • +
  • +

    Field: the field of the documents in the OpenSearch repository that is used for matching +the search query (default doc.text)

    +
  • +
+
+
+

From this information, two URLs are constructed:

+
+
+
    +
  • +

    the search URL: <URL>/<index name>/<search path>

    +
  • +
  • +

    the document retrieval URL as: <URL>/<index name>/<object type>/<document id>

    +
  • +
+
+
+ + + + + +
+ + +From the remote URL field, only the protocol, hostname and port information is used. Any + path information appearing after the port number is discarded and replaced by the index name and + search path as outlined above. +
+
+
+

The individual documents should contain following two fields as their source:

+
+
+
    +
  • +

    doc: should contain the subfield text which is the full text of the document

    +
  • +
  • +

    metadata: should contain subfields like language, source, timestamp and uri +to provide further information about the document

    +
  • +
+
+
+

The Random Ordering setting allows to switch the ranking of results from the default ranking used by +the OpenSearch server to a random order. The documents returned will still match the query, but +the order does not correspond to the matching quality anymore. When random ordering is enabled, no +score is associated with the search results. If desired, the random seed used for the ordering +can be customized.

+
+
+

The Result Size setting allows to specify the number of document results that should be retrieved +when querying the document repository. The possible result sizes lie between 1 and 10000 documents.

+
+
+

If the default Field setting doc.text is used, then the JSON structure for indexed documents +should look as follows:

+
+
+
+
{
+  "metadata": {
+    "language": "en",
+    "source": "My favourite document collection",
+    "timestamp": "2011/11/11 11:11",
+    "uri": "http://the.internet.com/my/document/collection/document1.txt",
+    "title": "Cool Document Title"
+  },
+  "doc": {
+    "text": "This is a test document"
+  }
+}
+
+
+
+
Setting up a simple OpenSearch document repository
+
+

In this example, we use Docker to get OpenSearch and ElasticVue up and running very quickly. Note, that the docker containers we start +here will not save any data permanently. It is just for you to get an idea of how the setup works. +In a productive environment, you need to use a proper installation of OpenSearch.

+
+
+
    +
  1. +

    Open a terminal and run OpenSearch as a Docker service

    +
    +
    +
    $ docker run -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e "http.cors.enabled=true" -e "http.cors.allow-origin=http://localhost:9090" -e "http.cors.allow-headers=*"  opensearchproject/opensearch:1
    +
    +
    +
  2. +
  3. +

    Open a second terminal and run ElasticVue as a Docker service

    +
    +
    +
    $ docker run -p 9090:8080 cars10/elasticvue
    +
    +
    +
  4. +
  5. +

    Open a browser and access ElasticVue at http://localhost:9090 - tell ElasticVue to connect to +https://localhost:9200 using the username admin and password admin

    +
  6. +
  7. +

    Switch to the Indices tab in ElasticVue

    +
  8. +
  9. +

    Create an index named test

    +
  10. +
  11. +

    Switch to the REST tab in ElasticVue

    +
  12. +
  13. +

    Set the HTTP Method to "POST" and enter test/_doc/1 as the Path (means "create a new document with ID 1 in collection test)

    +
  14. +
  15. +

    Put the following JSON into the request body field

    +
    +
    +
    {
    +  "metadata": {
    +    "language": "en",
    +    "source": "My favourite document collection",
    +    "timestamp": "2011/11/11 11:11",
    +    "uri": "http://the.internet.com/my/document/collection/document1.txt",
    +    "title": "Cool Document Title"
    +  },
    +  "doc": {
    +    "text": "This is a test document"
    +  }
    +}
    +
    +
    +
  16. +
  17. +

    Click Send request

    +
  18. +
  19. +

    Start up INCEpTION

    +
  20. +
  21. +

    Create a new project

    +
  22. +
  23. +

    Add a document repository with the following settings (and click save):

    +
    +
      +
    • +

      Name: My OpenSearch Document Repository

      +
    • +
    • +

      Type: OpenSearch

      +
    • +
    • +

      Remote URL: https://localhost:9200

      +
    • +
    • +

      SSL verification: disabled

      +
    • +
    • +

      Authentication type: basic

      +
    • +
    • +

      Username / password: admin / admin

      +
    • +
    • +

      Index name: test

      +
    • +
    • +

      Search path: _search

      +
    • +
    • +

      Object type: _doc

      +
    • +
    • +

      Field: doc.text

      +
    • +
    • +

      Result Size: 1000

      +
    • +
    • +

      Random ordering: false

      +
    • +
    +
    +
  24. +
  25. +

    Switch to the Dashboard and from there to the Search page

    +
  26. +
  27. +

    Select the repository My OpenSearch Document Repository

    +
  28. +
  29. +

    Enter document into the search field and press the Search button

    +
  30. +
  31. +

    You should get result for the document you posted to the OpenSearch index in step 8

    +
  32. +
  33. +

    Click on Import

    +
  34. +
  35. +

    The import button should change to Open now - click on it to open the document in the annotation editor

    +
  36. +
+
+
+
+
+

Solr

+
+

Selecting the Solr repository type allows connecting to remote Solr instances.

+
+
+

In order to set up a connection to an Solr repository, the following information needs to +be provided:

+
+
+
    +
  • +

    Remote URL: the URL where the Solr instance is running (e.g. http://localhost:9200/)

    +
  • +
  • +

    Index Name: the name of the collection (e.g. techproducts)

    +
  • +
  • +

    Search path: the suffix used to select the request handler. The '/select' request handler is the only supported for the moment.

    +
  • +
  • +

    Default Field: the field of the documents in the Solr repository that is used for searching (default id).

    +
  • +
  • +

    Text Field: the field of the document in the Solr repository that is used for retrieve all the text (default 'text')

    +
  • +
+
+
+

From this information, two URLs are constructed:

+
+
+
    +
  • +

    the search URL: <URL>/<index name>/<search path>

    +
  • +
  • +

    the document retrieval URL as: <URL>/<index name>/<search path>/<query with document id>

    +
  • +
+
+
+ + + + + +
+ + +From the remote URL field, only the protocol, hostname and port information is used. Any + path information appearing after the port number is discarded and replaced by the index name and + search path as outlined above. +
+
+
+

The individual documents must contain the following field as their source:

+
+
+
    +
  • +

    id: should contain a unique id for the document

    +
  • +
  • +

    text: collection should contain a field which contain the plain text of the document. By default +it take the value "text". You can change it by the "Text Field" parameter.

    +
  • +
+
+
+

The individual document should contain the following field as their source:

+
+
+
    +
  • +

    name or title : one of these two field should contain information about the title of the +document. +If no one of this field is set, the id is used

    +
  • +
  • +

    language, uri, timestamp : should contain this fields to provide further information +about the document

    +
  • +
+
+
+

The Random Ordering setting allows to switch the ranking of results from the default ranking used by +the Solr server to a random order. The documents returned will still match the query, but +the order does not correspond to the matching quality anymore. When random ordering is enabled, no +score is associated with the search results. If desired, the random seed used for the ordering +can be customized.

+
+
+

The Result Size setting allows to specify the number of document results that should be retrieved +when querying the document repository. The possible result sizes lie between 1 and 10000 documents.

+
+
+

The Highlight feature is available on the Default Field (or Search Field). Be aware that if Solr +does not include character by character +or word by word analysis in the schema the highlight feature would not work.

+
+
+

If the default Text Field setting text is used, then the JSON structure for indexed documents +should look as follows:

+
+
+
+
"docs" : {
+  "0" : {
+    "id" : "ID"
+    "text" : "Here goes the document text."
+    "other_field" : "Content of other field"
+  }
+}
+
+
+
+

The '0' represent the result number. By default the document with the best score +(matching score) is placed on the top.

+
+
+
+

PubAnnotation

+
+

PubAnnotation is a repository through which anyone can share +their texts and annotations with others. It can be added as an external document repository by +selecting the PubAnnotation repository type.

+
+
+
+

PubMed Central

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding external-search.pmc.enabled=true to the settings.properties file (see the Admin Guide). You should also add format.bioc.enabled=true to enable +support for the BioC format used by this repository connector. +
+
+
+
+
+

PubMed Central® (PMC) is a free full-text archive of biomedical and life sciences journal literature at the U.S. National Institutes of Health’s National Library of Medicine (NIH/NLM). It can be added as an external document repository by +selecting the PubMed Central repository type.

+
+
+ + + + + +
+ + +INCEpTION uses the BioC version of the PMC documents for import. The search tries to + consider only documents that have full text available, but the BioC version of these texts may be + available only with a delay. Thus, if you cannot import a recently uploaded document from PMC into + INCEpTION, you may try it again a day later and have more success. +
+
+
+
+
+
+
+
+

Constraints

+
+
+

Constraints reorder the choice of tags based on the context of an annotation. For instance, for a +given lemma, not all possible part-of-speech tags are sensible. Constraint rules can be set up to +reorder the choice of part-of-speech tags such that the relevant tags are listed first. This speeds +up the annotation process as the annotator can choose from the relevant tags more conveniently.

+
+
+

The choice of tags is not limited, only the order in which they are presented to the annotator. Thus, if +the project manager has forgotten to set up a constraint or did possible not consider an oddball case, +the annotator can still make a decision.

+
+
+

Importing constraints

+
+

To import a constraints file, go to Project and click on the particular project name. On the left side of the screen, a tab bar opens. Choose Constraints. You can now choose a constraint file by clicking on Choose Files. Then, click on Import. Upon import, the application checks if the constraints file is well formed. If they conform to the rules of writing constraints, the constraints are applied.

+
+
+
+

Implementing constraint sets

+
+

A constraint set consists of two components:

+
+
+
    +
  • +

    import statement

    +
  • +
  • +

    scopes

    +
  • +
  • +

    Import statements* are composed in the following way:

    +
  • +
+
+
+
+
import <fully_qualified_name_of_layer> as <shortName>;
+
+
+
+

It is necessary to declare short names for all fully qualified names because only short names can be used when writing a constraint rule. Short names cannot contain any dots or special characters, only letters, numbers, and the underscore.

+
+
+ + + + + +
+ + +All identifiers used in constraint statements are case sensitive. +
+
+
+ + + + + +
+ + +If you are not sure what the fully qualified name of a layer is, you can look it up going + to Layers in Project settings. Click on a particular layer and you can view the fully qualified + name under Technical Properties. +
+
+
+

Scopes consist of a scope name and one or more rules that refer to a particular annotation layer and define restrictions for particular conditions. For example, it is possible to reorder the applicable tags for a POS layer, based on what kind of word the annotator is focusing on.

+
+
+

While scope names can be freely chosen, scope rules have a fixed structure. They consist of conditions and restrictions, separated by an arrow symbol (). +Conditions consist of a path and a value, separated by an equal sign (=). Values always have to be embraced by double-quotes. Multiple conditions in the same rule are connected via the &-operator, multiple restrictions in the same rule are connected via the |-operator.

+
+
+

Typically a rule’s syntax is

+
+
+
Single constraint rule
+
+
<scopeName> {
+  <condition_set> -> <restriction_set>;
+}
+
+
+
+

This leads to the following structure:

+
+
+
Multiple constraint rules
+
+
<scopeName> {
+  <rule_1>;
+  ...
+  <rule_n>;
+}
+
+
+
+

Both conditions and restrictions are composed of a path and a value. The latter is always enclosed in double quotes.

+
+
+
Structure of conditions and restrictions
+
+
<path>="<value>"
+
+
+
+

A condition is a way of defining whether a particular situation in INCEpTION is based on annotation layers and features in it. Conditions can be defined on features with string, integer or boolean values, but in any case, the value needs to be put into quotes (e.g. someBooleanFeature="true", someIntegerFeature="2").

+
+
+

A condition set consists of one or more conditions. They are connected with logical AND as follows.

+
+
+
+
<condition> & <condition>
+
+
+
+

A restriction set defines a set of restrictions which can be applied if a particular condition set is evaluated to true. As multiple restrictions inside one rule are interpreted as conjunctions, they are separated by the |-operator. Restrictions can only be defined on String-valued features that are associated with a tagset.

+
+
+
+
<restriction> | <restriction>
+
+
+
+

A path is composed of one or more steps, separated by a dot. A step consists of a feature selector and a type selector. +Type selectors are only applicable while writing the condition part of a rule. They comprise a layer operator @ followed by the type (Lemma, POS, etc). +Feature selectors consist of a feature name, e.g.

+
+
+
+
pos.PosValue
+
+
+
+

Navigation across layers is possible via

+
+
+
+
@<shortLayerName>
+
+
+
+

Hereby all annotations of type <shortLayerName> at the same position as the current context are found.

+
+
+

Comments

+
+

The constraint language supports block comments which start with / and end with /. These +comments may span across multiple lines.

+
+
+
+
/* This is a single line comment */
+
+/*
+   This is a multi-
+   line comment
+*/
+
+
+
+
+

Example

+
+

The following simple example of a constraints file re-orders POS tags depending on Lemma values. +If the Lemma was annotated as can, the POS tags VERB and NOUN are highlighted. If the Lemma value is +the, the POS tag DET is suggested first.

+
+
+
+
import de.tudarmstadt.ukp.dkpro.core.api.segmentation.type.Lemma as Lemma;
+import de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS as Pos;
+
+Pos {
+  @Lemma.value = "can" ->
+    coarseValue = "VERB" |
+    coarseValue = "NOUN";
+
+  @Lemma.value = "the" ->
+    coarseValue = "DET";
+}
+
+
+
+

In the UI, the tags that were matched by the constraints are bold and come first in the list of tags:

+
+
+
+constraints +
+
+
+
+

Conditional features

+
+

Constraints can be used to set up conditional features, that is features that only become available +in the UI if another feature has a specific value. Let’s say that for example you want to annotate +events and only causing events should additionally offer a polarity feature, while for caused +events, there should be no way to select a polarity.

+
+
+

Sticking with the example of annotating events, conditional features can be set up as following:

+
+
+
    +
  • +

    Go to the Layer tab of the project settings

    +
  • +
  • +

    Create a new tagset called Event category and add the tags causing and caused

    +
  • +
  • +

    Create a new tagset called Event polarity and add the tags positive and negative

    +
  • +
  • +

    Create a new span layer called Event

    +
  • +
  • +

    Add a string feature called category and assign the tagset Event category

    +
  • +
  • +

    Save the changes to the category feature

    +
  • +
  • +

    Add a string feature called polarity and assign the tagset Event polarity

    +
  • +
  • +

    Enabled the checkbox Hide Un-constraint feature on the polarity feature

    +
  • +
  • +

    Save the changes to the polarity feature

    +
  • +
  • +

    Create a new text file called constraints.txt with the following contents +.

    +
  • +
+
+
+
+
import webanno.custom.Event as Event;
+
+Event {
+  category="causing" -> polarity="positive" | polarity="negative";
+}
+
+
+
+
    +
  • +

    Import constraints.txt in the tab Constraints in the project settings.

    +
  • +
+
+
+

When you now annotate an Event in this project, then the polarity feature is only visible and +editable if the category of the annotation is set to causing.

+
+
+ + + + + +
+ + +It is important that both of the features have tagsets assigned - otherwise the conditional + effect will not take place. +
+
+
+
+

Constraints for slot features

+
+

Constraints can be applied to the roles of slot features. This is useful, e.g. when annotating predicate/argument structures where specific predicates can only have certain arguments.

+
+
+

Consider having a span layer SemPred resembling a semantic predicate and bearing a slot feature arguments and a string feature senseId. We want to restrict the possible argument roles based on the lemma associated with the predicate. The first rule in the following example restricts the senseId depending on the value of a Lemma annotation at the same position as the SemPred annotation. The second rule then restricts the choice of roles for the arguments based on the senseId. Note that to apply a restriction to the role of a slot feature, it is +necessary to append .role to the feature name (that is because role is technically a nested feature). +Thus, while we can write e.g. senseId = "Request" for a simple string feature, it is necessary to write arguments.role = "Addressee".

+
+
+

Note that some role labels are marked with the flag (!). This is a special flag for slot features and indicates that slots with these role labels should be automatically displayed in the UI ready to be filled. This should be used for mandatory or common slots and saves time as the annotator does not have to manually create the slots before filling them.

+
+
+
+
SemPred {
+  /* Rule 1 */
+  @Lemma.value = "ask" -> senseId = "Questioning" | senseId = "Request" | senseId = "XXX";
+  /* .. other lemmata */
+  /* Rule 2 */
+  senseId = "Questioning" ->
+    /* core roles */
+    arguments.role = "Addressee" (!) | arguments.role = "Message" (!) | arguments.role = "Speaker" (!) |
+    /* non-core roles */
+    arguments.role = "Time" | arguments.role = "Iterations";
+  /* .. other senses */
+}
+
+
+
+
+
+

Constraints language grammar

+
+
Constraints language grammar
+
+
// Basic structure ---------------------------------------
+<file>            ::= <import>* | <scope>*
+<scope>           ::= <shortLayerName> "{" <ruleset> "}"
+<ruleset>         ::= <rule>*
+<import>          ::= "import" <qualifiedLayerName>
+                      "as" <shortLayerName>
+<rule>            ::= <conds> "->" <restrictions> ";"
+
+// Conditions --------------------------------------------
+<conds>           ::= <cond> | <cond> "&" <conds>
+<cond>            ::= <path> "=" <value>
+<path>            ::= <featureName> | <step> "." <path>
+<step>            ::= <featureName> | <layerSelector>
+<layerSelector>   ::= <layerOperator>? <shortLayerName>
+<layerOperator>   ::= "@" // select annotation in layer X
+
+// Restrictions ------------------------------------------
+<restrictions>    ::= <restriction> |
+                      <restriction> "|" <restrictions>
+<restriction>     ::= <restrictionPath> "=" <value>
+                      ( "(" <flags> ")" )
+<restrictionPath> ::= <featureName> |
+                      <restrictionPath> "." <featureName>
+<flags>           ::= "!" // core role
+
+
+
+
+
+
+
+

CAS Doctor

+
+
+

The CAS Doctor is an essential development tool. When enabled, it checks the CAS for +consistency when loading or saving a CAS. It can also automatically repair inconsistencies when +configured to do so. This section gives an overview of the available checks and repairs.

+
+
+

It is safe to enable any checks. However, active checks may considerably slow down +the application, in particular for large documents or for actions that work with many documents, e.g. +curation or the calculation of agreement. Thus, checks should not be enabled on a production system +unless the application behaves strangely and it is necessary to check the documents for consistency.

+
+
+

Enabling repairs should be done with great care as most repairs are performing +destructive actions. Repairs should never be enabled on a production system. The repairs are +executed in the order in which they are appear in the debug.casDoctor.repairs setting. This is +important in particular when applying destructive repairs.

+
+
+

When documents are loaded, CAS Doctor first tries to apply any enabled repairs +and afterwards applies enabled checks to ensure that the potentially repaired +document is consistent.

+
+
+

Additionally, CAS Doctor applies enabled checks before saving a document. This +ensures that a bug in the user interface introduces inconsistencies into the document on disk. I.e. +the consistency of the persisted document is protected! Of course, it requires that relevant checks +have been implemented and are actually enabled.

+
+
+

By default, CAS Doctor generates an exception when a check or repair fails. This ensures that +inconsistencies are contained and do not propagate further. In some cases, e.g. when it is known +that by its nature an inconsistency does not propagate and can be avoided by the user, it may be +convenient to allow the user to continue working with the application while a repair is being developed. +In such a case, CAS Doctor can be configured to be non-fatal. Mind that users can always continue +to work on documents that are consistent. CAS Doctor only prevents loading inconsistent documents +and saving inconsistent documents.

+
+
+

Configuration

+ ++++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
SettingDescriptionDefaultExample

debug.casDoctor.fatal

If the extra checks trigger an exception

true

false

debug.casDoctor.checks

Extra checks to perform when a CAS is saved (also on load if any repairs are enabled)

unset

list of checks

debug.casDoctor.repairs

Repairs to be performed when a CAS is loaded - order matters!

unset

list of repairs

debug.casDoctor.forceReleaseBehavior

Behave as like a release version even if it is a beta or snapshot version.

false

true

+
+

To specify a list of repairs or checks in the settings.properties file, use the following syntax:

+
+
+
+
debug.casDoctor.checks[0]=Check1
+debug.casDoctor.checks[1]=Check2
+debug.casDoctor.checks[...]=CheckN
+debug.casDoctor.repairs[0]=Repair1
+debug.casDoctor.repairs[1]=Repair2
+debug.casDoctor.repairs[...]=RepairN
+
+
+
+
+

Checks

+
+

All feature structures indexed

+
+ + + + + + + + + +
+ID + +

AllFeatureStructuresIndexedCheck

+
+Related repairs + +

Remove dangling chain links, Remove dangling relations, Re-index feature-attached spans, Remove dangling feature-attached span annotations

+
+
+
+

This check verifies if all reachable feature structures in the CAS are also indexed. We do not +currently use any un-indexed feature structures. If there are any un-indexed feature structures in the +CAS, it is likely due to a bug in the application and can cause undefined behavior.

+
+
+

For example, older versions of INCEpTION had a bug that caused deleted spans still to be +accessible through relations which had used the span as a source or target.

+
+
+

This check is very extensive and slow.

+
+
+
+

Feature-attached spans truly attached

+
+ + + + + + + + + +
+ID + +

FeatureAttachedSpanAnnotationsTrulyAttachedCheck

+
+Related repairs + +

Re-attach feature-attached spans, Re-attach feature-attached spans and delete extras

+
+
+
+

Certain span layers are attached to another span layer through a feature reference +from that second layer. For example, annotations in the POS layer must always be referenced from +a Token annotation via the Token feature pos. This check ensures that annotations on layers such +as the POS layer are properly referenced from the attaching layer (e.g. the Token layer).

+
+
+
+

Links reachable through chains

+
+ + + + + + + + + +
+ID + +

LinksReachableThroughChainsCheck

+
+Related repairs + +

Remove dangling chain links

+
+
+
+

Each chain in a chain layers consist of a chain and several links. The chain +points to the first link and each link points to the following link. If the CAS contains any links +that are not reachable through a chain, then this is likely due to a bug.

+
+
+
+

No multiple incoming relations

+
+ + + + + +
+ID + +

NoMultipleIncomingRelationsCheck

+
+
+
+

Check that nodes have only one in-going dependency relation inside the same annotation layer. +Since dependency relations form a tree, every node of this tree can only have at most one parent node. +This check outputs a message that includes the sentence number (useful to jump directly to the problem) and the actual offending dependency edges.

+
+
+
+

No 0-sized tokens and sentences

+
+ + + + + + + + + +
+ID + +

NoZeroSizeTokensAndSentencesCheck

+
+Related repairs + +

Remove 0-size tokens and sentences

+
+
+
+

Zero-sized tokens and sentences are not valid and can cause undefined behavior.

+
+
+
+

Relation offsets consistency

+
+ + + + + + + + + +
+ID + +

RelationOffsetsCheck

+
+Related repairs + +

Repair relation offsets

+
+
+
+

Checks that the offsets of relations match the target of the relation. This mirrors the DKPro +Core convention that the offsets of a dependency relation must match the offsets of the +dependent.

+
+
+
+

CASMetadata presence

+
+ + + + + + + + + +
+ID + +

CASMetadataTypeIsPresentCheck

+
+Related repairs + +

Upgrade CAS

+
+
+
+

Checks if the internal type CASMetadata is defined in the type system of this CAS. If this is +not the case, then the application may not be able to detect concurrent modifications.

+
+
+
+

Dangling relations

+
+ + + + + + + + + +
+ID + +

DanglingRelationsCheck

+
+Related repairs + +

Remove dangling relations

+
+
+
+

Checks if there are any relations that do not have a source or target. Either the source/end are +not set at all or they refer to an unset attach feature in another layer. Note that relations +referring to non-indexed end-points are handled by All feature structures indexed.

+
+
+
+

Negative-sized annotations check

+
+ + + + + + + + + +
+ID + +

NegativeSizeAnnotationsCheck

+
+Related repairs + +

Switch begin and end offsets on negative-sized annotations

+
+
+
+

Checks if there are any annotations with a begin offset that is larger than their end offset. Such +annotations are invalid and may cause errors in many functionalities of INCEpTION.

+
+
+
+

Negative-sized annotations check

+
+ + + + + + + + + +
+ID + +

AllAnnotationsStartAndEndWithinSentencesCheck

+
+Related repairs + +

Cover all text in sentences

+
+
+
+

Checks that the begins and ends of all annotations are within the boundaries of a sentence. +Annotations that are not within sentence boundaries may not be shown by certain annotation editors +such as the default sentence-oriented brat editor. Also, sentence-oriented formats such as WebAnno +TSV or CoNLL formats will not include any text and annotations of parts of the documents that is +not covered by sentences or may produce errors during export.

+
+
+
+

Unreachable annotations check

+
+ + + + + + + + + +
+ID + +

UnreachableAnnotationsCheck

+
+Related repairs + +

Upgrade CAS

+
+
+
+

Checks if there are any unreachable feature structures. Such feature structures take up memory, but +they are not regularly accessible. Such feature structures may be created as a result of bugs. +Removing them is harmless and reduces memory and disk space usage.

+
+
+
+
+

Repairs

+
+

Re-attach feature-attached spans

+
+ + + + + +
+ID + +

ReattachFeatureAttachedSpanAnnotationsRepair

+
+
+
+

This repair action attempts to attach spans that should be attached to another span, but are not. +E.g. it tries to set the pos feature of tokens to the POS annotation for that respective token. +The action is not performed if there are multiple stacked annotations to choose from. Stacked +attached annotations would be an indication of a bug because attached layers are not allowed to +stack.

+
+
+

This is a safe repair action as it does not delete anything.

+
+
+
+

Re-attach feature-attached spans and delete extras

+
+ + + + + +
+ID + +

ReattachFeatureAttachedSpanAnnotationsAndDeleteExtrasRepair

+
+
+
+

This is a destructive variant of Re-attach feature-attached spans. In +addition to re-attaching unattached annotations, it also removes all extra candidates that cannot +be attached. For example, if there are two unattached Lemma annotations at the position of a Token +annotation, then one will be attached and the other will be deleted. Which one is attached and +which one is deleted is undefined.

+
+
+
+

Re-index feature-attached spans

+
+ + + + + +
+ID + +

ReindexFeatureAttachedSpanAnnotationsRepair

+
+
+
+

This repair locates annotations that are reachable via a attach feature but which are not actually +indexed in the CAS. Such annotations are then added back to the CAS indexes.

+
+
+

This is a safe repair action as it does not delete anything.

+
+
+
+

Repair relation offsets

+
+ + + + + +
+ID + +

RelationOffsetsRepair

+
+
+
+

Fixes that the offsets of relations match the target of the relation. This mirrors the DKPro +Core convention that the offsets of a dependency relation must match the offsets of the +dependent.

+
+
+
+

Remove dangling chain links

+
+ + + + + +
+ID + +

RemoveDanglingChainLinksRepair

+
+
+
+

This repair action removes all chain links that are not reachable through a chain.

+
+
+

Although this is a destructive repair action, it is likely a safe action in most cases. Users are +not able see chain links that are not part of a chain in the user interface anyway.

+
+
+
+

Remove dangling feature-attached span annotations

+
+ + + + + +
+ID + +

RemoveDanglingFeatureAttachedSpanAnnotationsRepair

+
+
+
+

This repair action removes all annotations which are themselves no longer indexed (i.e. they have +been deleted), but they are still reachable through some layer to which they had attached. This +affects mainly the DKPro Core POS and Lemma layers.

+
+
+

Although this is a destructive repair action, it is sometimes a desired action because the user may +know that they do not care to resurrect the deleted annotation as per Re-index feature-attached spans.

+
+
+
+

Remove dangling relations

+
+ + + + + +
+ID + +

RemoveDanglingRelationsRepair

+
+
+
+

This repair action removes all relations that point to unindexed spans.

+
+
+

Although this is a destructive repair action, it is likely a safe action in most cases. When +deleting a span, normally any attached relations are also deleted (unless there is a bug). +Dangling relations are not visible in the user interface. A dangling relation is one that meets +any of the following conditions:

+
+
+
    +
  • +

    source or target are not set

    +
  • +
  • +

    the annotation pointed to by source or target is not indexed

    +
  • +
  • +

    the attach-feature in the annotation pointed to by source or target is not set

    +
  • +
  • +

    the annotation pointed to by attach-feature in the annotation pointed to by source or target is +not indexed

    +
  • +
+
+
+
+

Remove 0-size tokens and sentences

+
+ + + + + +
+ID + +

RemoveZeroSizeTokensAndSentencesRepair

+
+
+
+

This is a destructive repair action and should be used with care. When tokens are removed, also +any attached lemma, POS, or stem annotations are removed. However, no relations that attach to +lemma, POS, or stem are removed, thus this action could theoretically leave dangling relations +behind. Thus, the Remove dangling relations repair action should be configured +after this repair action in the settings file.

+
+
+
+

Upgrade CAS

+
+ + + + + +
+ID + +

UpgradeCasRepair

+
+
+
+

Ensures that the CAS is up-to-date with the project type system. It performs the same operation +which is regularly performed when a user opens a document for annotation/curation.

+
+
+

This repair also removes any unreachable feature structures. Such feature structures may be created as a result of bugs. +Removing them is harmless and reduces memory and disk space usage.

+
+
+

This is considered to be safe repair action as it only garbage-collects data from the CAS that is +no longer reachable anyway.

+
+
+
+

Switch begin and end offsets on negative-sized annotations

+
+ + + + + +
+ID + +

SwitchBeginAndEndOnNegativeSizedAnnotationsRepair

+
+
+
+

This repair switches the begin and end offsets on all annotations where the begin offset is larger +than the begin offset.

+
+
+
+

Cover all text in sentences

+
+ + + + + +
+ID + +

CoverAllTextInSentencesRepair

+
+
+
+

This repair checks if there is any text not covered by sentences. If there is, it creates a new +sentence annotation on this text starting at the end of the last sentence before it (or the start +of the document text) and the begin of the next sentence (or the end of the document text).

+
+
+
+
+
+
+
+

Annotation Guidelines

+
+
+

Providing your annotation team with guidelines helps assuring that every team member knows exactly +what is expected of them.

+
+
+

Annotators can access the guidelines via the Guidelines button on the annotation page.

+
+
+

Project managers can provide these guidelines via the Guidelines tab in the +project settings. Guidelines are provided as files (e.g. PDF files). To upload guidelines, +click on Choose files, select a file from your local disc and then click Import guidelines. +Remove a guideline document by selecting it and pressing the Delete button.

+
+
+
+
+
+

PDF Annotation Editor

+
+
+

The PDF annotation editor allows annotating text in PDF files. Usually, it opens automatically when +opening a PDF file.

+
+
+

To annotate a span, simply mark the span with the mouse. When you press the left mouse button and +drag the mouse, a highlight should appear. When you release the mouse button, the annotation +should be created.

+
+
+ + + + + +
+ + +If no highlight appears, then the PDF may not include text information at this location. You + may try verifying if the text can be selected in other PDF-enabled tools like macOS Preview or Acrobat + Reader. INCEpTION can only work with PDFs that include text information. If a PDF was OCRed, the + text may not always be at the same location as you see it on screen. Try marking a larger region to + see if you can "catch" it. +
+
+
+

A span annotation is rendered as a highlight with a small knob hovering above the start of the +highlight. To select the annotation click on that knob. If the knob overlaps with another +highlight, it might be hard to see. If you move the mouse over it, the knob reacts - that may help +you find it. If there are multiple annotations starting at the same position, their knobs are stacked.

+
+
+

To create a relation, press the left mouse button on the knob and drag the mouse over to the +knob of another span annotation.

+
+
+
+
+
+

PDF Annotation Editor (legacy)

+
+
+
+
+ + + + + +
+ + +Legacy feature. To use this functionality, you need to enable it first by adding ui.pdf-legacy.enabled=true to the settings.properties file. +
+
+
+

Support for this feature will be removed in a future version. The replacement is PDF Annotation Editor.

+
+
+
+
+

Opening the PDF Editor

+
+

To switch to the PDF editor for an opened document, click on Settings in the +Document panel located at the top. +In the section General Display Preferences select PDF for the Editor field. +Save your settings. +The PDF editor will open.

+
+
+
+

Navigation

+
+

Once the editor is loaded you can see the opened PDF document. +To navigate through the document you can hover your mouse over the PDF panel and +use the mouse wheel for scrolling. +After clicking in the PDF panel it is also possible to use the Up and Down +keys of the keyboard. +For a faster navigation the Page Up and Page Down keys can be used. +In the PDF panel on the top left there are buttons for switching to the previous +or next page in the document. +Next to the buttons you can enter a page number to jump to a specific page.

+
+
+
+pdf panel top left +
+
+
+

In the top center of the PDF panel the zoom level of the document can be adjusted.

+
+
+
+pdf panel top center +
+
+
+

The button on the top right in the PDF panel opens a small menu which provides +functionality to go to the first or last page. +You can also use the Home and End keys instead. +The menu also contains an option to enable the hand tool to navigate through the document via clicking +and dragging the pages.

+
+
+
+pdf panel top right +
+
+
+

When moving through the document annotations will not show immediately. +Once the movement stops for a short period of time the annotations for the +previous, current and next page will be loaded. +The loading process might take a few seconds.

+
+
+
+

Creating Span Annotations

+
+

To create a span annotation first select the desired layer for it. +This can be done in the Layer box on the right sidebar. +If another annotation is already selected press the Clear button on the right +sidebar.

+
+
+

Once you have chosen a layer, select the desired text to create a span annotation. +This can be done by clicking at the beginning of the text span, dragging until +the end and then releasing the mouse button. +In the upper right corner you can see a moving circle which indicates that the +creation of the annotation is in process.

+
+
+

The creation might take a few seconds. +Once finished the new span annotation will be rendered if it was created +successfully. +If it was not possible to create the annotation an error message is shown. +After the span annotation is created it will be automatically selected in the +Layer box.

+
+
+
+span annotation +
+
+
+
+

Creating Relation Annotations

+
+

To create a relation annotation click on the knob of a span annotation and drag +and drop on another span annotation knob. +In order to create a relation annotation between two spans an according layer +must exist.

+
+
+
+relation annotation drag +
+
+
+

After releasing the mouse button the creation process starts which is indicated +by a moving circle in the upper right corner. +This might take a few seconds. +Once finished the new relation annotation will be rendered if it was created +successfully. +If it was not possible to create the annotation an error message is shown. +After the relation annotation is created it will be automatically selected in +the Layer box.

+
+
+
+relation annotation +
+
+
+

Currently long distance relation annotations are not creatable as annotations are +rendered dynamically when moving through the pages.

+
+
+
+

Selecting Span and Relation Annotations

+
+

Span annotations can be selected by clicking on their span annotation knob.

+
+
+

To select relation annotations click on the relation arc.

+
+
+
+

Modifying Span and Relation Annotations

+
+

To modify an existing span or relation annotation you first need to select it.

+
+
+

Once an annotation is selected it will be shown in the Layer box.

+
+
+

You can now edit the selected annotation.

+
+
+
+

Deleting Span and Relation Annotations

+
+

First select the annotation that will be deleted.

+
+
+

The selected annotation will be shown in the Layer box.

+
+
+

To delete the annotation click on the Delete button on the right sidebar.

+
+
+
+

Accepting Recommendations

+
+

To accept and convert a recommendation to an actual span annotation +select it.

+
+
+

The recommendation is converted to an actual annotation and is selected +automatically.

+
+
+
+

Rejecting Recommendations

+
+

To reject a recommendation quickly double click the span annotation +knob.

+
+
+

The recommendation then will be removed from the editor.

+
+
+
+
+
+
+

Editable segmentation

+
+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding ui.sentence-layer-editable=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

Often, after importing a text into INCEpTION, one discovers that a segment boundary (e.g. a +sentence boundary) was not properly recognized or there was a segmentation mistake in the original +data. Normally, such mistakes cannot be corrected. Enabling the experimental +editable sentence layer feature can help in such cases.

+
+
+

Please note this feature is new and has not been tested a lot in practice yet. There may be +unexpected side effects when manually editing sentences. For example, normally it is expected that:

+
+
+
    +
  • +

    the entire text is covered by token and sentence annotations;

    +
  • +
  • +

    no tokens exist outside sentence boundaries;

    +
  • +
  • +

    sentences start at a token start boundary and end at a token end boundary.

    +
  • +
+
+
+

However, when you enable this feature, you will eventually be able to delete sentences (which leaves +tokens lying around outside sentence boundaries) or create other odd situations which exporters, +curation, recommenders, editors and other functionalities may not yet be able to deal with. So be +careful, ready to face unexpected situations and make regular backups of course.

+
+
+

Once the feature has been enabled, new projects get a Sentence layer. It is also possible to +add a sentence layer to existing project from the dropdown menu of the create layer button where +other built-in layers can also be added to a project that does not yet contain them. By default, the +layer is not enabled and read-only which means that you can neither see the sentence +annotations in the annotation editor nor create or delete sentence annotations. To make the sentences +visible and editable for the annotators, check the enabled checkbox and un-check the +read-only checkbox and save the layer settings.

+
+
+

While the sentence layer is editable (i.e. enabled and not read-only), the annotation page and the curation page default to a line-oriented editor instead of the usual sentence-oriented editor. In +the line-oriented editor, the sentences can be safely shown and edited because the editor does not +rely on sentence boundaries to control the rendering process. It is then possible to curate the +sentence boundaries.

+
+
+ + + + + +
+ + +If you start curating a document while the sentence layer is editable but then switch it back + not being editable, then it could happen that different annotators have different segmentations and/or that the curation + document does not contain all sentence boundaries. This means that some sentences may be invisible because the + the sentence-oriented visualization does not display them! +
+
+
+
+
+

Appendices

+
+

Appendix A: Frequently Asked Questions (FAQs)

+
+
+

What tokenization does INCEpTION use?

+
+

INCEpTION uses the Java BreakIterator internally. +Note that the linked file is part of a specific version of OpenJDK 11 and may change in other Java versions or for other Java vendors.

+
+
+

If you need to provide your own tokenization, then the best choice would be to use a format that supports it, e.g. XMI, WebAnno TSV or CoNLL formats.

+
+
+
+

How can I annotate discontinuous spans?

+
+

The is no immediate support for discontinuous spans in INCEpTION.

+
+
+

However, you can emulate them using either a relations or link features.

+
+
+

You can define a relation layer on top of your span layer. +When you have multiple spans that should be considered as one, you can use a relation to connect them.

+
+
+

Or you can add a Link: XXX feature to your span layer which either points to the same layer or which points to a new layer you might call e.g. Extension.

+
+
+

So when you have a discontinuous span, you could annotate the first span with your normal span layer and then add one or more links to the other spans.

+
+
+
+

What is the relation between WebAnno and INCEpTION?

+
+

INCEpTION is the successor of WebAnno and evolved from the WebAnno code base. Both INCEpTION and WebAnno are currently developed/maintained by the same team at the UKP Lab at the Technical University of Darmstadt.

+
+
+

INCEpTION has all the flexibility and many more exciting features including a completely new human-in-the-loop annotation assistance support, the ability to search texts and annotations, support for RDF/SPARQL knowledge bases for entity linking, and much more. +And best: it can import your WebAnno annotation projects (Projects of type automation or correction are not supported).

+
+
+
+
+
+
+

Appendix B: Editors

+
+
+

This section provides information about the different annotation editors that INCEpTION +provides.

+
+ + ++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 21. Editor overview
EditorFeature flag

brat (sentence-based)

ui.brat.enabled

brat (line-oriented)

ui.brat.enabled

brat (wrapping @ 120 chars)

ui.brat.enabled

brat (wrapping @ 120 chars)

ui.brat.enabled

HTML (AnnotatorJS)

ui.html-annotatorjs.enabled

HTML (RecogitoJS)

ui.ui.html-recogitojs.enabled

PDF

ui.pdf.enabled

PDF (legacy)

ui.pdf-legacy.enabled

+
+

Editor plugins

+
+
+
+ + + + + +
+ + +Experimental feature. The available plugins as well as their compatibility with a given +version of INCEpTION may change without further notice. +
+
+
+
+
+

In addition to these different editors, INCEpTION has the ability to load editor plugins. +Several of these can be found on your website. You can use these as inspirations to write your own.

+
+
+
+
+
+
+

Appendix C: Formats

+
+
+

This section provides information about the different formats that INCEpTION can import and +export. While many formats can be imported and exported, some formats can only be imported and others +can only be exported. Also, not all formats support custom annotation layers. Each format description +includes a small table explaining whether the format can be imported, exported and whether custom +layers are supported. The first column includes a format ID in addition to the format name. This +ID can be used e.g. in conjunction with the remote API when to select the format when importing or +exporting annotations and documents.

+
+
+

For your convenience, the following table provides an overview over all the available formats. +The remote API format ID column shows which format ID must be used when importing or exporting +data in a particular format. The feature flag column shows which flags you can put into the +settings.properties file to enable or disable a format. Most formats are enabled by default.

+
+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 22. Formats overview
FormatRemote API format IDFeature flag

BioC (experimental)

bioc

format.bioc.enabled

CoNLL 2000

conll2000

format.conll2000.enabled

CoNLL 2002

conll2000

format.conll2002.enabled

CoNLL 2003

conll2000

format.conll2003.enabled

CoNLL 2006

conll2006

format.conll2006.enabled

CoNLL 2009

conll2009

format.conll2009.enabled

CoNLL 2012

conll2012

format.conll2012.enabled

CoreNLP CoNLL-like format

conll2012

format.conllcorenlp.enabled

CoNLL-U

conllu

format.conllu.enabled

HTML

htmldoc

format.html.enabled

HTML (legacy)

html

format.html-legacy.enabled

IMS CWB (aka VRT)

imscwb

format.imscwb.enabled

NLP Interchange Format

nif

format.nif.enabled

PDF Format

pdf2

format.pdf.enabled

PDF Format (legacy)

pdf

format.pdf-legacy.enabled

Plain Text

text

format.text.enabled

Plain Text (one sentence per line)

textlines

format.text-line-oriented.enabled

Plain Text (pretokenized)

pretokenized-textlines

format.text-pretokenized.enabled

TEI P5 XML

dkpro-core-tei

format.dkpro-core-tei.enabled

UIMA Binary CAS

bin

format.uima-binary-cas.enabled

UIMA Inline XML

dkpro-core-uima-inline-xml

format.uima-inline-xml.enabled

UIMA CAS JSON (experimental)

jsoncas

format.json-cas.enabled

UIMA CAS JSON (legacy)

json

format.json-cas-legacy.enabled

UIMA XMI CAS (XML 1.0)

xmi

format.uima-xmi.enabled

UIMA XMI CAS (XML 1.1)

xmi-xml1.1

format.uima-xmi-xml1_1.enabled

WebAnno TSV 1 (legacy)

tsv

format.webanno1.enabled

WebAnno TSV 2 (legacy)

ctsv

format.webanno2.enabled

WebAnno TSV 3.x

ctsv3

format.webanno3.enabled

WebLicht TCF

tcf

format.tcf.enabled

XML (generic)

dkpro-core-xml-document

format.generic-xml.enabled

+
+

BioC (experimental)

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding format.bioc.enabled=true to the settings.properties file (see the Admin Guide). +
+
+
+
+
+

This is a new and still experimental BioC format.

+
+
+ + + + + +
+ + +This format dynamically maps information from the imported files to the layers and features configured in + the project. For this process to work, the layers and features need to be set up before importing BioC files. +
+
+
+
Supported features
+
    +
  • +

    Sentence information is supported

    +
  • +
  • +

    If sentences are present in a BioC document, they are imported. Otherwise, INCEpTION will +automatically try to determine sentence boundaries.

    +
  • +
  • +

    On export, the BioC files are always created with sentence information.

    +
  • +
  • +

    Passages are imported as a Div annotations and the passage type infon is set as the type +feature on these Div annotations

    +
  • +
  • +

    When reading span or relation annotations, the type infon is used to look up a suitable +annotation layer. If a layer exists where either the full technical name of the layer or the +simple technical name (the part after the last dot) match the type, then an attempt will be made +to match the annotation to that layer. If the annotation has other infons that match features on +that layer, they will also be matched. If no layer matches but the default SimpleSpan layer is +present, annotations will be matched to that. Similarly, if only a single infon is present in an +annotation and no other feature matches, then the infon value may be matched to a potentially +existing value feature.

    +
  • +
  • +

    When exporting annotations, the type infon will always be set to the full layer name and +features will be serialized to infons matching their names.

    +
  • +
  • +

    If a document has not been imported from a BioC file containing passages and does not contain +Div annotations from any other source either, then on export a single passage containing the +entire document is created.

    +
  • +
  • +

    Cross-passage relations are not supported.

    +
  • +
  • +

    Sentence-level infons are not supported.

    +
  • +
  • +

    Passage-level infons are not supported.

    +
  • +
  • +

    Document-level infons are not supported.

    +
  • +
  • +

    The writer writes one BioC file per CAS (i.e. writing multiple documents to a single collection file is not supported).

    +
  • +
+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

BioC (experimental) (bioc)

yes

yes

yes

BioC format

+
+
+

CoNLL 2000

+
+

The CoNLL 2000 format represents POS and Chunk tags. Fields in a line are separated by spaces. +Sentences are separated by a blank new line.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoNLL 2000 (conll2000)

yes

yes

no

POS, chunks

+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + +
Table 23. Columns
ColumnTypeDescription

FORM

Token

token

POSTAG

POS

part-of-speech tag

CHUNK

Chunk

chunk (IOB1 encoded)

+
+
Example
+
+
He PRP B-NP
+reckons VBZ B-VP
+the DT B-NP
+current JJ I-NP
+account NN I-NP
+deficit NN I-NP
+will MD B-VP
+narrow VB I-VP
+to TO B-PP
+only RB B-NP
+# # I-NP
+1.8 CD I-NP
+billion CD I-NP
+in IN B-PP
+September NNP B-NP
+. . O
+
+
+
+
+

CoNLL 2002

+
+

The CoNLL 2002 format encodes named entity spans. Fields are separated by a single space. +Sentences are separated by a blank new line.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoNLL 2002 (conll2002)

yes

yes

no

Named entities

+ + +++++ + + + + + + + + + + + + + + + + + + + +
Table 24. Columns
ColumnType/FeatureDescription

FORM

Token

Word form or punctuation symbol.

NER

NamedEntity

named entity (IOB2 encoded)

+
+
Example
+
+
Wolff B-PER
+, O
+currently O
+a O
+journalist O
+in O
+Argentina B-LOC
+, O
+played O
+with O
+Del B-PER
+Bosque I-PER
+in O
+the O
+final O
+years O
+of O
+the O
+seventies O
+in O
+Real B-ORG
+Madrid I-ORG
+. O
+
+
+
+
+

CoNLL 2003

+
+

The CoNLL 2003 format encodes named entity spans and chunk spans. Fields are separated by a single +space. Sentences are separated by a blank new line. Named entities and chunks are encoded in the +IOB1 format. I.e. a B prefix is only used if the category of the following span differs from the +category of the current span.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoNLL 2003 (conll2003)

yes

yes

no

+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + +
Table 25. Columns
ColumnType/FeatureDescription

FORM

Token

Word form or punctuation symbol.

CHUNK

Chunk

chunk (IOB1 encoded)

NER

Named entity

named entity (IOB1 encoded)

+
+
Example
+
+
U.N. NNP I-NP I-ORG
+official NN I-NP O
+Ekeus NNP I-NP I-PER
+heads VBZ I-VP O
+for IN I-PP O
+Baghdad NNP I-NP I-LOC
+. . O O
+
+
+
+
+

CoNLL 2006

+
+

The CoNLL 2006 (aka CoNLL-X) format targets dependency parsing. Columns are tab-separated. Sentences are separated by a blank new line.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoNLL 2006 (conll2006)

yes

yes

no

Lemma, POS, dependencies (basic)

+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 26. Columns
ColumnType/FeatureDescription

ID

ignored

Token counter, starting at 1 for each new sentence.

FORM

Token

Word form or punctuation symbol.

LEMMA

Lemma

Lemma of the word form.

CPOSTAG

POS coarseValue

POSTAG

POS PosValue

Fine-grained part-of-speech tag, where the tagset depends on the language, or identical to the coarse-grained part-of-speech tag if not available.

FEATS

MorphologicalFeatures

Unordered set of syntactic and/or morphological features (depending on the particular language), separated by a vertical bar (|), or an underscore if not available.

HEAD

Dependency

Head of the current token, which is either a value of ID or zero ('0'). Note that depending on the original treebank annotation, there may be multiple tokens with an ID of zero.

DEPREL

Dependency

Dependency relation to the HEAD. The set of dependency relations depends on the particular language. Note that depending on the original treebank annotation, the dependency relation may be meaningful or simply 'ROOT'.

PHEAD

ignored

Projective head of current token, which is either a value of ID or zero ('0'), or an underscore if not available. Note that depending on the original treebank annotation, there may be multiple tokens an with ID of zero. The dependency structure resulting from the PHEAD column is guaranteed to be projective (but is not available for all languages), whereas the structures resulting from the HEAD column will be non-projective for some sentences of some languages (but is always available).

PDEPREL

ignored

Dependency relation to the PHEAD, or an underscore if not available. The set of dependency relations depends on the particular language. Note that depending on the original treebank annotation, the dependency relation may be meaningful or simply 'ROOT'.

+
+
Example
+
+
Heutzutage	heutzutage	ADV	_	_	ADV	_	_
+
+
+
+
+

CoNLL 2009

+
+

The CoNLL 2009 format targets semantic role labeling. Columns are tab-separated. Sentences are separated by a blank new line.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoNLL 2009 (conll2009)

yes

yes

no

Lemma, POS, dependencies (basic)

+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 27. Columns
ColumnType/FeatureDescription

ID

ignored

Token counter, starting at 1 for each new sentence.

FORM

Token

Word form or punctuation symbol.

LEMMA

Lemma

Lemma of the word form.

PLEMMA

ignored

Automatically predicted lemma of FORM.

POS

POS PosValue

Fine-grained part-of-speech tag, where the tagset depends on the language.

PPOS

ignored

Automatically predicted major POS by a language-specific tagger.

FEATS

MorphologicalFeatures

Unordered set of syntactic and/or morphological features (depending on the particular language), separated by a vertical bar (|), or an underscore if not available.

PFEAT

ignored)

Automatically predicted morphological features (if applicable).

HEAD

Dependency

Head of the current token, which is either a value of ID or zero (`0). Note that depending on the original treebank annotation, there may be multiple tokens with an ID of zero.

PHEAD

ignored

Automatically predicted syntactic head.

DEPREL

Dependency

Dependency relation to the HEAD. The set of dependency relations depends on the particular language. Note that depending on the original treebank annotation, the dependency relation may be meaningful or simply ROOT.

PDEPREL

ignored

Automatically predicted dependency relation to PHEAD.

FILLPRED

ignored

Contains Y for argument-bearing tokens.

PRED

SemPred

(sense) identifier of a semantic 'predicate' coming from a current token.

APREDs

SemArg

Columns with argument labels for each semantic predicate (in the ID order).

+
+
Example
+
+
1	The	the	the	DT	DT	_	_	4	4	NMOD	NMOD	_	_	_	_
+2	most	most	most	RBS	RBS	_	_	3	3	AMOD	AMOD	_	_	_	_
+3	troublesome	troublesome	troublesome	JJ	JJ	_	_	4	4	NMOD	NMOD	_	_	_	_
+4	report	report	report	NN	NN	_	_	5	5	SBJ	SBJ	_	_	_	_
+5	may	may	may	MD	MD	_	_	0	0	ROOT	ROOT	_	_	_	_
+6	be	be	be	VB	VB	_	_	5	5	VC	VC	_	_	_	_
+7	the	the	the	DT	DT	_	_	11	11	NMOD	NMOD	_	_	_	_
+8	August	august	august	NNP	NNP	_	_	11	11	NMOD	NMOD	_	_	_	AM-TMP
+9	merchandise	merchandise	merchandise	NN	NN	_	_	10	10	NMOD	NMOD	_	_	A1	_
+10	trade	trade	trade	NN	NN	_	_	11	11	NMOD	NMOD	Y	trade.01	_	A1
+11	deficit	deficit	deficit	NN	NN	_	_	6	6	PRD	PRD	Y	deficit.01	_	A2
+12	due	due	due	JJ	JJ	_	_	13	11	AMOD	APPO	_	_	_	_
+13	out	out	out	IN	IN	_	_	11	12	APPO	AMOD	_	_	_	_
+14	tomorrow	tomorrow	tomorrow	NN	NN	_	_	13	12	TMP	TMP	_	_	_	_
+15	.	.	.	.	.	_	_	5	5	P	P	_	_	_	_
+
+
+
+
+

CoNLL 2012

+
+

The CoNLL 2012 format targets semantic role labeling and coreference. Columns are whitespace-separated (tabs or spaces). Sentences are separated by a blank new line.

+
+
+

Note that this format cannot deal with the following situations: +* An annotation has no label (e.g. a SemPred annotation has no category) - in such a case null is + written into the corresponding column. However, the reader will actually read this value as the + label. +* If a SemPred annotation is at the same position as a SemArg annotation linked to it, then only + the (V*) representing the SemPred annotation will be written. +* SemPred annotations spanning more than one token are not supported +* If there are multiple SemPred annotations on the same token, then only one of them is written. + This is because the category of the SemPred annotation goes to the Predicate Frameset ID + and that can only hold one value which.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoNLL 2012 (conll2012)

yes

yes

no

+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 28. Columns
ColumnType/FeatureDescription

Document ID

ignored

This is a variation on the document filename.</li>

Part number

ignored

Some files are divided into multiple parts numbered as 000, 001, 002, …​ etc.

Word number

ignored

Word itself

document text

This is the token as segmented/tokenized in the Treebank. Initially the *_skel file contain the placeholder [WORD] which gets replaced by the actual token from the Treebank which is part of the OntoNotes release.

Part-of-Speech

POS

Parse bit

Constituent

This is the bracketed structure broken before the first open parenthesis in the parse, and the word/part-of-speech leaf replaced with a *. The full parse can be created by substituting the asterisk with the ([pos] [word]) string (or leaf) and concatenating the items in the rows of that column.

Predicate lemma

Lemma

The predicate lemma is mentioned for the rows for which we have semantic role information. All other rows are marked with a -.

Predicate Frameset ID

SemPred

This is the PropBank frameset ID of the predicate in Column 7.

Word sense

ignored

This is the word sense of the word in Column 3.

Speaker/Author

ignored

This is the speaker or author name where available. Mostly in Broadcast Conversation and Web Log data.

Named Entities

NamedEntity

These columns identifies the spans representing various named entities.

Predicate Arguments

SemPred

There is one column each of predicate argument structure information for the predicate mentioned in Column 7.

Coreference

CoreferenceChain

Coreference chain information encoded in a parenthesis structure.

+
+
Example
+
+
en-orig.conll	0	0	John	NNP	(TOP(S(NP*)	john	-	-	-	(PERSON)	(A0)	(1)
+en-orig.conll	0	1	went	VBD	(VP*	go	go.02	-	-	*	(V*)	-
+en-orig.conll	0	2	to	TO	(PP*	to	-	-	-	*	*	-
+en-orig.conll	0	3	the	DT	(NP*	the	-	-	-	*	*	(2
+en-orig.conll	0	4	market	NN	*)))	market	-	-	-	*	(A1)	2)
+en-orig.conll	0	5	.	.	*))	.	-	-	-	*	*	-
+
+
+
+
+

CoreNLP CoNLL-like format

+
+

The CoreNLP CoNLL format is used by the Stanford CoreNLP package. Columns are tab-separated. +Sentences are separated by a blank new line.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoreNLP CoNLL-like format (conllcorenlp)

yes

yes

no

+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 29. Columns
ColumnType/FeatureDescription

ID

ignored

Token counter, starting at 1 for each new sentence.

FORM

Token

Word form or punctuation symbol.

LEMMA

Lemma

Lemma of the word form.

POSTAG

POS PosValue

Fine-grained part-of-speech tag, where the tagset depends on the language, or identical to the coarse-grained part-of-speech tag if not available.

NER

NamedEntity

Named Entity tag, or underscore if not available. If a named entity covers multiple tokens, all +of the tokens simply carry the same label without (no sequence encoding).

HEAD

Dependency

Head of the current token, which is either a value of ID or zero ('0'). Note that depending on the original treebank annotation, there may be multiple tokens with an ID of zero.

DEPREL

Dependency

Dependency relation to the HEAD. The set of dependency relations depends on the particular language. Note that depending on the original treebank annotation, the dependency relation may be meaningful or simply 'ROOT'.

+
+
Example
+
+
1	Selectum	Selectum	NNP	O	_	_
+2	,	,	,	O	_	_
+3	Société	Société	NNP	O	_	_
+4	d'Investissement	d'Investissement	NNP	O	_	_
+5	à	à	NNP	O	_	_
+6	Capital	Capital	NNP	O	_	_
+7	Variable	Variable	NNP	O	_	_
+8	.	.	.	O	_	_
+
+
+
+
+

CoNLL-U

+
+

The CoNLL-U format format targets dependency parsing. Columns are tab-separated. Sentences are +separated by a blank new line.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

CoNLL-U (conllu)

yes

yes

no

Lemma, POS, dependencies (basic & enhanced), surface form

+ + +++++ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Table 30. Columns
ColumnType/FeatureDescription

ID

ignored

Word index, integer starting at 1 for each new sentence; may be a range for tokens with multiple words.

FORM

Token

Word form or punctuation symbol.

LEMMA

Lemma

Lemma or stem of word form.

CPOSTAG

POS coarseValue

Part-of-speech tag from the universal POS tag set.

POSTAG

POS PosValue

Language-specific part-of-speech tag; underscore if not available.

FEATS

MorphologicalFeatures

List of morphological features from the universal feature inventory or from a defined language-specific extension; underscore if not available.

HEAD

Dependency

Head of the current token, which is either a value of ID or zero (0).

DEPREL

Dependency

Universal Stanford dependency relation to the HEAD (root iff HEAD = 0) or a defined language-specific subtype of one.

DEPS

Dependency

List of secondary dependencies (head-deprel pairs).

MISC

unused

Any other annotation.

+
+
Example
+
+
1	They	they	PRON	PRN	Case=Nom|Number=Plur	2	nsubj	4:nsubj	_
+2	buy	buy	VERB	VB	Number=Plur|Person=3|Tense=Pres	0	root	_	_
+3	and	and	CONJ	CC	_	2	cc	_	_
+4	sell	sell	VERB	VB	Number=Plur|Person=3|Tense=Pres	2	conj	0:root	_
+5	books	book	NOUN	NNS	Number=Plur	2	dobj	4:dobj	SpaceAfter=No
+6	.	.	PUNCT	.	_	2	punct	_	_
+
+
+
+
+

HTML (legacy)

+
+
+
+ + + + + +
+ + +Legacy feature. To use this functionality, you need to enable it first by adding format.html-legacy.enabled=true to the settings.properties file. +
+
+
+

Support for this feature will be removed in a future version. The replacement is HTML.

+
+
+
+
+

Legacy support for HTML documents which imports a small subset of HTML elements as annotations. +Supported elements are h1-h6 and p.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

HTML (html)

yes

no

no

+
+
+

HTML

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding format.html.enabled to the settings.properties file. +
+
+
+
+
+

Generic support for HTML documents. This format imports the entire HTML document structure and is +able to retain it until export. None of the HTML elements are converted to editable annotations +though. In combination with a HTML-based editor, this format allows annotating in HTML documents +while retaining most of the HTML layout. Note that some HTML elements and attributes are filtered +out during rendering. These include e.g. JavaScript-related elements and attributes as well as +links which could easily interfere with the functionality of the annotation editor.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

HTML (htmldoc)

yes

no

no

+
+
+

IMS CWB (aka VRT)

+
+

The "verticalized XML" format used by the IMS Open Corpus Workbench, +a linguistic search engine. It uses a tab-separated format with limited markup (e.g. for sentences, +documents, but not recursive structures like parse-trees). In principle, it is a generic format - +i.e. there can be arbitrary columns, pseudo-XML elements and attributes. However, support is limited +to a specific set of columns that must appear exactly in a specific order: token text, +part-of-speech tag, lemma. Also only specific pseudo-XML elements and attributes are supported: +text (including an id attribute), s.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

IMS CWB VRT (imscwb)

yes

no

no

+
+
Example
+
+
<text id="http://www.epguides.de/nikita.htm">
+<s>
+Nikita	NE	Nikita
+(	$(	(
+La	FM	La
+Femme	NN	Femme
+Nikita	NE	Nikita
+)	$(	)
+Dieser	PDS	dies
+Episodenführer	NN	Episodenführer
+wurde	VAFIN	werden
+von	APPR	von
+September	NN	September
+1998	CARD	1998
+bis	APPR	bis
+Mai	NN	Mai
+1999	CARD	1999
+von	APPR	von
+Konstantin	NE	Konstantin
+C.W.	NE	C.W.
+Volkmann	NE	Volkmann
+geschrieben	VVPP	schreiben
+und	KON	und
+im	APPRART	im
+Mai	NN	Mai
+2000	CARD	2000
+von	APPR	von
+Stefan	NE	Stefan
+Börzel	NN	Börzel
+übernommen	VVPP	übernehmen
+.	$.	.
+</s>
+</text>
+
+
+
+
+

NLP Interchange Format

+
+

The NLP Interchange Format (NIF) provides a way of representing NLP information using semantic web technology, specifically RDF and OWL. A few additions of the format were defined in the apparently in-official NIF 2.1 specification.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

NIF (nif)

yes

yes

no

+
+
Example
+
+
@prefix rdfs:  <http://www.w3.org/2000/01/rdf-schema#> .
+@prefix nif:   <http://persistence.uni-leipzig.org/nlp2rdf/ontologies/nif-core#> .
+@prefix itsrdf: <http://www.w3.org/2005/11/its/rdf#> .
+@prefix xsd:   <http://www.w3.org/2001/XMLSchema#> .
+@prefix rdf:   <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
+
+<http://example.org/document0#char=0,86>
+        a               nif:RFC5147String , nif:String , nif:Context ;
+        nif:beginIndex  "0"^^xsd:nonNegativeInteger ;
+        nif:endIndex    "86"^^xsd:nonNegativeInteger ;
+        nif:isString    "Japan (Japanese: 日本 Nippon or Nihon) is a stratovolcanic archipelago of 6,852 islands."^^xsd:string ;
+        nif:topic       <http://example.org/document0#annotation0> .
+
+<http://example.org/document0#char=0,5>
+        a                     nif:RFC5147String , nif:String ;
+        nif:anchorOf          "Japan"^^xsd:string ;
+        nif:beginIndex        "0"^^xsd:nonNegativeInteger ;
+        nif:endIndex          "5"^^xsd:nonNegativeInteger ;
+        nif:referenceContext  <http://example.org/document0#char=0,86> ;
+        itsrdf:taClassRef     <http://example.org/Country> , <http://example.org/StratovolcanicArchipelago> ;
+        itsrdf:taIdentRef     <http://example.org/Japan> .
+
+<http://example.org/document0#char=42,68>
+        a                     nif:RFC5147String , nif:String ;
+        nif:anchorOf          "stratovolcanic archipelago"^^xsd:string ;
+        nif:beginIndex        "42"^^xsd:nonNegativeInteger ;
+        nif:endIndex          "68"^^xsd:nonNegativeInteger ;
+        nif:referenceContext  <http://example.org/document0#char=0,86> ;
+        itsrdf:taClassRef     <http://example.org/Archipelago> , rdfs:Class ;
+        itsrdf:taIdentRef     <http://example.org/StratovolcanicArchipelago> .
+
+<http://example.org/document0#annotation0>
+        a                  nif:Annotation ;
+        itsrdf:taIdentRef  <http://example.org/Geography> .
+
+
+
+
+

PDF Format

+
+

This allows the import of PDF files. A PDF file can be viewed and annotated in its original form. +It is also possible to switch to another editor like the "brat" editor to annotate directly on the +text extracted from the PDF. The annotations made on PDF files can be exported again in other +formats (e.g. UIMA CAS XMI or UIMA CAS JSON), but not as PDF files.

+
+
+

When importing PDF files, {produce-name} will automatically detect token and sentence boundaries. +It is presently not possible override these boundaries externally.

+
+
+ + + + + +
+ + +When importing a PDF file, you may get a message that the file cannot be imported because it + is empty. You may be confused because you can see contents in the PDF if you open the file in your + PDF viewer of choice. It may be that your PDF contains only an image of the text, but not actual text + data. For INCEpTION to be able to work with a PDF, it must be searchable - i.e. the text must not + only be included as an image but as actual Unicode character information. You may try using an OCR tool + to process your PDF into a searchable PDF before importing it. +
+
+
+ + + + + +
+ + +There is a feature of PDF files called "annotations" which you may create in tools like + Acrobat Reader. These means annotations like notes, comments or highlights that are embedded in the + PDF file itself. You may be able to see those in the annotation editor, but do not confuse them + with INCEpTION annotations. There is currently no way for INCEpTION to interact with these + "PDF annotations". +
+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

PDF (pdf2)

yes

no

n/a

+
+
+

PDF Format (legacy)

+
+
+
+ + + + + +
+ + +Legacy feature. To use this functionality, you need to enable it first by adding ui.pdf-legacy.enabled=true to the settings.properties file. +
+
+
+

Support for this feature will be removed in a future version. The replacement is PDF Format.

+
+
+
+
+

This allows the import of PDF files. A PDF file can be viewed and annotated in its original form. +It is also possible to switch to another editor like the "brat" editor to annotate directly on the +text extracted from the PDF. The annotations made on PDF files can be exported again in other +formats (e.g. UIMA CAS XMI or UIMA CAS JSON), but not as PDF files.

+
+
+

This legacy PDF format support should no longer be used. It has known issues, in particular that +the creation of annotations in certain parts of a document may fail, that annotations disappear +from the PDF view after created (but still be visible in other editors), etc.

+
+
+

Unfortunately, there is no way to automatically migrate already annotated PDF files to the new PDF +editor which does not suffer from these problems. When importing new PDF documents, please ensure +to use the PDF and not the PDF (legacy) format.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

PDF (pdf)

yes

no

n/a

+
+
+

Perseus Ancient Greek and Latin Dependency Treebank 2.1 XML

+ + +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

Perseus Ancient Greek and Latin Dependency Treebank 2.1 XML (perseus_2.1)

yes

no

no

+
+
Example (excerpt from tlg0013.tlg002.perseus-grc1.tb.xml)
+
+
<treebank version="2.1" xml:lang="grc" cts="urn:cts:greekLit:tlg0013.tlg002.perseus-grc1.tb">
+  <body>
+    <sentence id="2" document_id="urn:cts:greekLit:tlg0013.tlg002.perseus-grc1" subdoc="1-495">
+      <word id="1" form="σέβας" lemma="σέβας" postag="n-s---nn-" relation="PNOM" sg="nmn dpd" gloss="object.of.wonder" head="13"/>
+      <word id="2" form="τό" lemma="ὁ" postag="p-s---nn-" relation="SBJ" sg="sbs nmn dpd" gloss="this" head="13"/>
+      <word id="3" form="γε" lemma="γε" postag="d--------" relation="AuxY" sg="prt" gloss="indeed" head="13"/>
+      <word id="4" form="πᾶσιν" lemma="πᾶς" postag="a-p---md-" relation="ATR" sg="prp" gloss="all" head="9"/>
+      <word id="5" form="ἰδέσθαι" lemma="εἶδον" postag="v--anm---" relation="ATR" sg="dpd vrb as_nmn not_ind" gloss="see" head="1"/>
+      <word id="6" form="ἀθανάτοις" lemma="ἀθάνατος" postag="a-p---md-" relation="ATR" sg="prp" gloss="immortal" head="8"/>
+      <word id="7" form="τε" lemma="τε" postag="c--------" relation="AuxY" sg="" gloss="and" head="9"/>
+      <word id="8" form="θεοῖς" lemma="θεός" postag="n-p---md-" relation="ADV_CO" sg="dtv dpd prp int adv" gloss="god" head="9"/>
+      <word id="9" form="ἠδὲ" lemma="ἠδέ" postag="c--------" relation="COORD" sg="" gloss="and" head="13"/>
+      <word id="10" form="θνητοῖς" lemma="θνητός" postag="a-p---md-" relation="ATR" sg="prp" gloss="mortal" head="11"/>
+      <word id="11" form="ἀνθρώποις" lemma="ἄνθρωπος" postag="n-p---md-" relation="ADV_CO" sg="dtv dpd prp int adv" gloss="man" head="9"/>
+      <word id="12" form="·" lemma="·" postag="u--------" relation="AuxK" sg="" head="0"/>
+      <word id="13" insertion_id="0003e" artificial="elliptic" relation="PRED" lemma="εἰμί" postag="v3spia---" form="ἐστι" sg="ind stt" gloss="be" head="0"/>
+    </sentence>
+</treebank>
+
+
+
+
+

WebLicht TCF

+
+

The TCF (Text Corpus Format) was created in the context of the CLARIN project. It is +mainly used to exchange data between the different web-services that are part of the +WebLicht platform.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

TCF (tcf)

yes

no

no

Lemma, POS, dependencies (basic), coreference, named entities

+
+
+

TEI P5 XML

+
+

The TEI P5 XML format is a widely used standard format. It is a very complex format and furthermore is often extended for specific corpora. INCEpTION supports various common element types, but by far not all.

+
+
+

For more details about the supported element types, see the DKPro Core TEI support documentation.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

TEI P5 (dkpro-core-tei)

yes

yes

no

Lemma, POS (xpos), named entities (value)

+
+
+

Plain Text

+
+

Basic UTF-8 plain text. Automatic sentence and token detection will be performed.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

Plain text (text)

yes

yes

no

No annotations

+
+
+

Plain Text (one sentence per line)

+
+

Basic UTF-8 plain text where each line is interpreted as one sentence.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

Plain text (textlines)

yes

no

no

No annotations

+
+
+

Plain Text (pretokenized)

+
+

Basic UTF-8 plain text. Tokens are taken to be separated by spaces. Each line is interpreted as a +sentence.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

Plain text (pretokenized-textlines)

yes

no

no

No annotations

+
+
+

UIMA Binary CAS

+
+
+
+ + + + + +
+ + +This format is currently disabled by default. It can be enabled using the property +format.uima-binary-cas.enabled in the settings.properties file. +
+
+
+
+
+

A binary format used by the Apache UIMA Java SDK.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

Binary (bin)

yes

yes

yes

UIMA Binary CAS

+
+
+

UIMA Inline XML

+
+

Tries its best to export the annotations into an inline XML representation. Overlapping annotations are not supported in this format and are silently discarded during export.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

UIMA Inline XML (dkpro-core-uima-inline-xml)

no

yes

yes

+
+
+

UIMA CAS JSON (experimental)

+
+

This is a new and still experimental UIMA CAS JSON format which is able to capture not only the +annotations but also the type system. As such, it is self-contained like the UIMA Binary CAS +format while at the same time being more readable than the UIMA CAS XMI format.

+
+
+

Support for this format is available in the following implementations:

+
+
+ +
+
+

The current draft specification of the format is available here.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

UIMA CAS JSON (experimental) (jsoncas)

yes

yes

yes

UIMA CAS JSON 0.4.0

+
+
+

UIMA CAS JSON (legacy)

+
+
+
+ + + + + +
+ + +Legacy feature. To use this functionality, you need to enable it first by adding format.json-cas-legacy.enabled=true to the settings.properties file. +
+
+
+

Support for this feature will be removed in a future version. The replacement is UIMA CAS JSON (experimental).

+
+
+
+
+

This is an old and deprecated UIMA CAS JSON format which can be exported but not imported. +It should no longer be used. Instead, one should turn to UIMA CAS JSON (experimental).

+
+
+

The format does support custom layers.

+
+
+

For more details on this format, please refer to the UIMA Reference Guide.

+
+
+

By default, the format writes all values to the JSON output, even if the values are the default values +in JSON (e.g. 0 for numbers or false for booleans). You can configure this behavior by setting +format.json-cas-legacy.omit-default-values to true or false (default) respectively.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

UIMA CAS JSON (legacy) (json)

no

yes

yes

UIMA CAS JSON (legacy)

+
+
+

UIMA CAS XMI

+
+

The probably most commonly used formats supported by the Apache UIMA framework is UIMA CAS XMI. +It is able to capture all the information contained in the CAS. This is the de-facto standard for exchanging data in the UIMA world. Most UIMA-related tools support it.

+
+
+

The XMI format does not include type system information. When exporting files in the XMI format, a ZIP file is created for each document which contains the XMI file itself as well as an XML file containing the type system. In order to import such files +again, the ZIPs would need to be extracted and only the XMI files contained within should be imported.

+
+
+

XML 1.0 and XML 1.1 do not allow all Unicode characters. In particular, certain control characters are not permitted. +INCEpTION by default will replace illegal characters with a space character on export. This behavior can be +disabled using the boolean properties format.uima-xmi.sanitize-illegal-characters and +format.uima-xmi-xml1_1.sanitize-illegal-characters. When disabled, an error is produced when trying to export texts +containing illegal characters.

+
+
+

There are two flavors of CAS XMI, namely XML 1.0 and XML 1.1. XML 1.0 is more widely supported in +the world of XML parsers, so you may expect better interoperability with other programming languages +(e.g. Python) with the XML 1.0 flavor. XML 1.1 has a support for a wider range of characters, despite +dating back to 2006, it is still not supported by all XML parsers.

+
+
+

The format can be processed in Java using the Apache UIMA Java SDK (both flavors) or in Python using DKPro Cassis (only the XML 1.0 flavor).

+
+ +++++++ + + + + + + + + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

UIMA CAS XMI (XML 1.0) (xmi)

yes

yes

yes

UIMA XMI CAS (XML 1.0)

UIMA CAS XMI (XML 1.1) (xmi-xml1.1)

yes

yes

yes

UIMA XMI CAS (XML 1.1)

+
+
+

WebAnno TSV 1 (legacy)

+
+

The file format used by WebAnno version 1 and earlier.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

WebAnno TSV 1 (tsv)

yes

no

no

+
+
+

WebAnno TSV 2 (legacy)

+
+

The file format used by WebAnno version 2.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

WebAnno TSV 2 (ctsv)

yes

no

yes

token, multiple token, and arc annotations supported. No chain annotation is supported. no sub-token annotation is supported

+
+
+

WebAnno TSV 3.x

+
+
+
+ + + + + +
+ + +Legacy feature. This format does not support all of the layer and feature configurations of INCEpTION. For example, multi-value features are not supported. Using this format when exporting documents or projects with layer configurations not supported by this file format may generate errors or may simply omit unsupported information from the export. Please consider switching your post-processing workflows to +the CAS XMI (XML 1.0) format. +
+
+
+
+
+

The file format used by WebAnno version 3.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

WebAnno TSV 3 (ctsv3)

yes

yes

yes

+
+
+

XML (generic)

+
+
+
+ + + + + +
+ + +Experimental feature. To use this functionality, you need to enable it first by adding format.generic-xml.enabled to the settings.properties file. +
+
+
+
+
+

Generic support for XML documents. This format imports the entire XML document structure and is +able to retain it until export. None of the XML elements are converted to editable annotations +though. In combination with a HTML-based editor, this format allows annotating in styled XML +documents. Note that some XML elements and attributes are filtered out during rendering. These +include e.g. elements which in a HTML file would be JavaScript-related elements and attributes as +well as links which could easily interfere with the functionality of the annotation editor.

+
+
+

Note that when exporting a document in this format, you only recover the originally imported XML +document - no annotations will be included. If you want to export the annotated data, you should +use e.g. UIMA CAS XMI.

+
+ +++++++ + + + + + + + + + + + + + + + + + + +
FormatReadWriteCustom LayersDescription

XML (generic) (dkpro-core-xml-document)

yes

yes

no

+
+
+
+
+
+

Appendix D: WebAnno TSV 3.3 File format

+
+
+

In this section, we will discuss the WebAnno TSV (Tab Separated Value) file format version 3.3. +The format is similar to the CoNNL file formats with specialized additions to the header and column +representations. The file format inhabits a header and a body section. The header section +present information about the different types of annotation layers and features used in the file. +While importing the WebAnno TSV file, the specified headers should be first created in to the +running WebAnno project. Otherwise, the importing of the file will not be possible.

+
+
+

The body section of the TSV file presents the document and all the associated annotations +including sentence and token annotations.

+
+
+

Encoding and Offsets

+
+

TSV files are always encoded in UTF-8. However, the offsets used in the TSV file are based on +UTF-16. This is important when using TSV files with texts containing e.g. Emojis or some modern +non-latin Asian, Middle-eastern and African scripts.

+
+
+

WebAnno is implemented in Java. The Java platform internally uses a UTF-16 representation for +text. For this reason, the offsets used in the TSV format currently represent offsets of the 16bit +units in UTF-16 strings. This is important if your text contains Unicode characters that cannot +be represented in 16bit and which thus require two 16bit units. For example a token represented +by the Unicode character 😊 (U+1F60A) requires two 16bit units. Hence, the offset count increased +by 2 for this character. So Unicode characters starting at U+10000 increase the offset count by 2.

+
+
+
Example: TSV sentence containing a Unicode character from the Supplementary Planes
+
+
#Text=I like it 😊 .
+1-1	0-1	I	_
+1-2	2-6	like	_
+1-3	7-9	it	_
+1-4	10-12	😊	*
+1-5	13-14	.	_
+
+
+
+ + + + + +
+ + +Since the character offsets are based on UTF-16 and the TSV file itself is encoded in UTF-8, + first the text contained in the file needs to be transcoded from UTF-8 into UTF-16 before the offsets + can be applied. The offsets cannot be used for random access to characters directly in the TSV file. +
+
+
+
+

File Header

+
+

WebAnno TSV 3.3 file header consists of two main parts:

+
+
+
    +
  • +

    the format indicator

    +
  • +
  • +

    the column declarations

    +
  • +
+
+
+

After the header, there must be two empty lines before the body part containing the annotations +may start.

+
+
+
Example: format in file header
+
+
#FORMAT=WebAnno TSV 3.3
+
+
+
+

Layers are marked by the # character followed by T_SP= for span types (including slot features), T_CH= for chain layers, and T_RL= for relation layers. Every layer is written in new line, followed by the features in the layer. +If all layer type exists, first, all the span layers will be written, then the chain layer, and finally the relation layers. +Features are separated by the | character and only the short name of the feature is provided.

+
+
+
Example: Span layer with simple features in file header
+
+
#T_SP=webanno.custom.Pred|bestSense|lemmaMapped|senseId|senseMapped
+
+
+
+

Here the layer name is webanno.custom.Pred and the features are named bestSense, lemmaMapped, senseId, senseMapped. +Slot features start with a prefix ROLE_ followed by the name of the role and the link. The role feature name and the link feature name are separated by the _ character.

+
+
+

The target of the slot feature always follows the role/link name

+
+
+
Example: Span layer with slot features in file header
+
+
#T_SP=webanno.custom.SemPred|ROLE_webanno.custom.SemPred:RoleSet_webanno.custom.SemPredRoleSetLink|uima.tcas.Annotation|aFrame
+
+
+
+

Here the name of the role is webanno.custom.SemPred:RoleSet and the name of the role link is webanno.custom.SemPredRoleSetLink and the target type is uima.tcas.Annotation.

+
+
+

Chain layers will have always two features, referenceType and referenceRelation.

+
+
+
Example: Chain layers in file header
+
+
#T_CH=de.tudarmstadt.ukp.dkpro.core.api.coref.type.CoreferenceLink|referenceType|referenceRelation
+
+
+
+

Relation layers will come at last in the list and the very last entry in the features will be the type of the base (governor or dependent) annotations with a prefix BT_.

+
+
+
Example: Relation layers in file header
+
+
#T_RL=de.tudarmstadt.ukp.dkpro.core.api.syntax.type.dependency.Dependency|DependencyType|BT_de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS
+
+
+
+

Here, the relation type de.tudarmstadt.ukp.dkpro.core.api.syntax.type.dependency.Dependency has a feature DependencyType and the relation is between a base type of de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS.

+
+
+
+

File Body / Annotations

+
+

In this section we discuss the different representations of texts and annotation in WebAnno TSV3format

+
+
+

Reserved Characters

+
+

Reserved characters have a special meaning in the TSV format and must be are escaped with the backslash (\) character if they appear in text or feature values. Reserved characters are the following:

+
+
+
Reserved Characters
+
+
\,[,],|,_,->,;,\t,\n,*
+
+
+
+ + + + + +
+ + +The way that TSV is presently defined/implemented, it kind of considers as a single + "character"…​ and it is also escaped as a single unit, i.e. becomes ->. It is something to + be addressed in a future iteration of the format. +
+
+
+
+

Sentence Representation

+
+

Sentence annotations are presented following the text marker #Text=, before the token +annotations. All text given here is inside the sentence boundaries.

+
+
+
Example: Original text sections
+
+
#Text=Bell , based in Los Angeles , makes and distributes electronic , computer and building products .
+
+
+
+

The text of an imported document is reconstructed from the sentence annotations. Additionally, +the offset information of the sentence tokens are taken into account to determine whether padding +needs to be added between sentences. The TSV format can presently not record text that occurs in +between two sentences.

+
+
+

If a sentence spans multiple lines, the text is split at the line feed characters (ASCII 12) and +multiple #Text= lines are generated. Note that carriage return characters (ASCII 13) are kept +as escaped characters (\r).

+
+
+
Example: Original multi-line text
+
+
#Text=Bell , based in Los Angeles , makes and distributes
+#Text=electronic , computer and building products .
+
+
+
+

Optionally, an alphanumeric sentence identifier can be added in the sentence header section.

+
+
+
Example: Sentence identifier
+
+
#Sentence.id=s1
+#Text=Bell , based in Los Angeles , makes and distributes electronic , computer and building products .
+
+
+
+
+

Token and Sub-token Annotations

+
+

Tokens represent a span of text within a sentence. Tokens cannot overlap, although then can be +directly adjacent (i.e. without any whitespace between them). The start offset of the first +character of the first token corresponds to the start of offset of the sentence.

+
+
+

Token annotation starts with a sentence-token number marker followed by the begin-end offsets +and the token itself, separated by a TAB characters.

+
+
+
Example: Token position
+
+
1-2	4-8	Haag
+
+
+
+

Here 1 indicates the sentence number, 2 indicates the token number (here, the second token +in the first sentence) and 4 is the begin offset of the token and 8 is the end offset of the +token while Haag is the token.

+
+
+

The begin offset of the first token in a sentence must coincide with the offset at which the first +#Text line starts in the original document text.

+
+
+
Example: Valid sentence text header / token offsets
+
+
#Text=Hello
+1-1	0-6	Hello
+
+
+
+
Example: Invalid sentence text header / token offsets
+
+
#Text= Hello
+1-1	1-7	Hello
+
+
+
+

Sub-token representations are affixed with a . and a number starts from 1 to N.

+
+
+
Example: Sub-token positions
+
+
1-3	9-14	plays
+1-3.1	9-13	play
+1-3.2	13-14	s
+
+
+
+

Here, the sub-token play is indicated by sentence-token number 1-3.1 and the sub-token s is +indicated by 1-3.2.

+
+
+

While tokens may not overlap, sub-tokens may overlap.

+
+
+
Example: Overlapping sub-tokens
+
+
1-3	9-14	plays
+1-3.1	9-12	pla
+1-3.2	11-14	ays
+
+
+
+
+

Span Annotations

+
+

For every features of a span Annotation, annotation value will be presented in the same row as the token/sub-token annotation, separated by a TAB character. If there is no annotation for the given span layer, a _ character is placed in the column. If the feature has no/null annotation or if the span layer do not have a feature at all, a * character represents the annotation.

+
+
+
Example: Span layer declaration in file header
+
+
#T_SP=de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS|PosValue
+#T_SP=webanno.custom.Sentiment|Category|Opinion
+
+
+
+
Example: Span annotations in file body
+
+
1-9	36-43	unhappy	JJ	abstract	negative
+
+
+
+

Here, the first annotation at column 4, JJ is avalue for a feature PosValue of the layer de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS. For the two features of the layer webanno.custom.Sentiment (Category and Opinion), the values abstract and negative are +presented at column 5 and 6 resp.

+
+
+ + + + + +
+ + +When serializing a span annotation starts or ends in a space between tokens, then the + annotation is truncated to start at the next token after the space or to end at the last token + before the space. For example, if you consider the text [one two] and there is an some span annotation + on [one ] (note the trailing space), the extent of this span annotation will be serialized as only + covering [one]. It is not possible in this format to have annotations starting or ending in + the space between tokens because the inter-token space is not rendered as a row and therefore is not + addressable in the format. +
+
+
+
+

Disambiguation IDs

+
+

Within a single line, an annotation can be uniquely identified by its type and stacking index. +However, across lines, annotation cannot be uniquely identified easily. Also, if the exact type +of the referenced annotation is not known, an annotation cannot be uniquely identified. For this +reason, disambiguation IDs are introduced in potentially problematic cases:

+
+
+
    +
  • +

    stacked annotations - if multiple annotations of the same type appear in the same line

    +
  • +
  • +

    multi-unit annotations - if an annotations spans multiple tokens or sub-tokens

    +
  • +
  • +

    un-typed slots - if a slot feature has the type uima.tcas.Annotation and may thus refer to +any kind of target annotation.

    +
  • +
+
+
+

The disambiguation ID is attached as a suffix [N] to the annotation value. Stacked annotations are separated by | character.

+
+
+
Example: Span layer declaration in file header
+
+
#T_SP=de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS|PosValue
+#T_SP=de.tudarmstadt.ukp.dkpro.core.api.ner.type.NamedEntity|value
+
+
+
+
Example: Multi-token span annotations and stacked span annotations
+
+
1-1	0-3	Ms.	NNP	PER[1]|PERpart[2]
+1-2	4-8	Haag	NNP	PER[1]
+
+
+
+

Here, PER[1] indicates that token 1-1 and 1-2 have the same annotation (multi-token annotations) while PERpart[2] is the second (stacked) annotation on token 1-1 separated by | character.

+
+
+ + + + + +
+ + +On chain layers, the number in brackets is not a disambiguation ID but rather a chain ID! +
+
+
+
+

Slot features

+
+

Slot features and the target annotations are separated by TAB character (first the feature column then the target column follows). In the target column, the sentence-token id is recorded where the feature is drawn.

+
+
+

Unlike other span layer features (which are separated by | character), multiple annotations for a slot feature are separated by the ; character.

+
+
+
Example: Span layer declaration in file header
+
+
#T_SP=webanno.custom.Frame|FE|ROLE_webanno.custom.Frame:Roles_webanno.custom.FrameRolesLink|webanno.custom.Lu
+#T_SP=webanno.custom.Lu|luvalue
+
+
+
+
Example: Span annotations and slot features
+
+
2-1	27-30	Bob	_	_	_	bob
+2-2	31-40	auctioned	transaction	seller;goods;buyer	2-1;2-3[4];2-6
+2-3	41-44	the	_	_	_	clock[4]
+2-4	45-50	clock	_	_	_	clock[4]
+2-5	52-54	to	_	_	_	_
+2-6	55-59	John	_	_	_	john
+2-7	59-60	.	_	_	_	_
+
+
+
+

Here, for example, at token 2-2, we have three slot annotations for feature Roles that are seller, goods, and buyer. The targets are on token 2-1, 2-3[4], and 2-6 respectively which are on annotations of the layer webanno.custom.Lu which are bob, clock and john.

+
+
+
+

Chain Annotations

+
+

In the Chain annotation, two columns (TAB separated) are used to represent the referenceType and the referenceRelation. A chain ID is attached to the referenceType to distinguish to which of the chains the annotation belongs. The referenceRelation of the chain is represented by the relation value followed by and followed by the CH-LINK number where CH is the chain number and LINK is the link number (the order the chain).

+
+
+
Example: Chain layer declaration in file header
+
+
#T_CH=de.tudarmstadt.ukp.dkpro.core.api.coref.type.CoreferenceLink|referenceType|referenceRelation
+
+
+
+
Example: Chain annotations
+
+
1-1	0-2	He	pr[1]	coref->1-1
+1-2	3-7	shot	_	_
+1-3	8-15	himself	pr[1]	coref->1-2
+1-4	16-20	with	_	_
+1-5	21-24	his	pr[1]	*->1-3
+1-6	25-33	revolver	_	_
+1-7	33-34	.	_	_
+
+
+
+

In this example, token 1-3 is marked as pr[1] which indicates that the referenceType is pr and it is part of the chain with the ID 1. The relation label is coref and with the CH-LINK number 1-2 which means that it belongs to chain 1 and this is the second link in the chain.

+
+
+
+

Relation Annotations

+
+

Relation annotations comes to the last columns of the TSV file format. Just like the span annotations, every feature of the relation layers are represented in a separate TAB. Besides, one extra column (after all feature values) is used to write the token id from which token/sub-token this arc of a relation annotation is drawn.

+
+
+
Example: Span and relation layer declaration in file header
+
+
#T_SP=de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS|PosValue
+#T_RL=de.tudarmstadt.ukp.dkpro.core.api.syntax.type.dependency.Dependency|DependencyType|BT_de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS
+
+
+
+
Example: Span and relation annotations
+
+
1-1	0-3	Ms.	NNP	SUBJ	1-3
+1-2	4-8	Haag	NNP	SBJ	1-3
+1-3	9-14	plays	VBD	P|ROOT	1-5|1-3
+1-4	15-22	Elianti	NNP	OBJ	1-3
+1-5	23-24	.	.	_	_
+
+
+
+

In this example (say token 1-1), column 4 (NNP) is a value for the feature PosValue of the de.tudarmstadt.ukp.dkpro.core.api.lexmorph.type.pos.POS layer. Column 5 (SUBJ) records the value for the feature DependencyType of the de.tudarmstadt.ukp.dkpro.core.api.syntax.type.dependency.Dependency relation layer, where as column 6 (1-3) shows from which governor (VBD) the dependency arc is drawn.

+
+
+

For relations, a single disambiguation ID is not sufficient. If a relation is ambiguous, then +the source ID of the relation is followed by the source and target disambiguation ID separated +by an underscore (_). If only one of the relation endpoints is ambiguous, then the other one +appears with the ID 0. E.g. in the example below, the annotation on token 1-5 is ambiguous, +but the annotation on token 1-1 is not.

+
+
+
Example: Disambiguation IDs in relations
+
+
#FORMAT=WebAnno TSV 3.3
+#T_SP=de.tudarmstadt.ukp.dkpro.core.api.ner.type.NamedEntity|value
+#T_RL=webanno.custom.Relation|value|BT_de.tudarmstadt.ukp.dkpro.core.api.ner.type.NamedEntity
+
+
+#Text=This is a test .
+1-1	0-4	This	*	_	_
+1-2	5-7	is	_	_	_
+1-3	8-9	a	_	_	_
+1-4	10-14	test	_	_	_
+1-5	15-16	.	*[1]|*[2]	*	1-1[0_1]
+
+
+
+
+
+

Changes

+
+
    +
  • +

    3.3

    +
  • +
  • +

    Adds support for the optional #Sentence.id stanza in the sentence header

    +
  • +
  • +

    3.2

    +
  • +
  • +

    First time the format is fully documented

    +
  • +
+
+
+
+
+
+
+

Appendix E: Troubleshooting

+
+
+

We are collecting error reports to improve the tool. For this, the error must be reproducible: +If you find a way how to produce the error, please open an issue and describe it.

+
+
+

Session timeout

+
+

If the tool is kept open in the browser, but not used for a long period of time, you will have to +log in again. For this, press the reload button of your browser.

+
+
+
+

Application is hanging

+
+

If the tool does not react for more than 1 minute, please also reload and re-login.

+
+
+

We are collecting error reports to improve the tool. For this, the error must be reproducible: +If you find a way how to produce the error, please open an issue and describe it.

+
+
+
+

Forgot admin password

+
+

If you locked yourself out of INCEpTION, you can reset/recreated the default admin account. In order to do so, first stop INCEpTION if it is still running. Then specify the system property restoreDefaultAdminAccount when you start INCEpTION (note that the value of the property does not matter and can be omitted!). For example, if you are using the standalone version of INCEpTION, you can start it as

+
+
+
+
$ java -DrestoreDefaultAdminAccount -jar inception-app-webapp-29.3-standalone.jar
+
+
+
+ + + + + +
+ + +Mind that if you are using a non-default inception.home, you also have to specify this system property. +
+
+
+

When INCEpTION has started, try opening it in your browser. The login page will show, but it will not allow you to log in. Instead a message will be shown stating that the default admin account has been reset or recreated. In order to resume normal operations, stop INCEpTION again and restart it without the restoreDefaultAdminAccount system property.

+
+
+
+
+
+ + + \ No newline at end of file diff --git a/releases/29.3/docs/user-guide/images/LinkedList_1.png b/releases/29.3/docs/user-guide/images/LinkedList_1.png new file mode 100644 index 0000000..9b84464 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/LinkedList_1.png differ diff --git a/releases/29.3/docs/user-guide/images/activeLearning2.png b/releases/29.3/docs/user-guide/images/activeLearning2.png new file mode 100644 index 0000000..d6ff24d Binary files /dev/null and b/releases/29.3/docs/user-guide/images/activeLearning2.png differ diff --git a/releases/29.3/docs/user-guide/images/activeLearning3.png b/releases/29.3/docs/user-guide/images/activeLearning3.png new file mode 100644 index 0000000..14bbf98 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/activeLearning3.png differ diff --git a/releases/29.3/docs/user-guide/images/agreement_feature.png b/releases/29.3/docs/user-guide/images/agreement_feature.png new file mode 100644 index 0000000..b13e8a8 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/agreement_feature.png differ diff --git a/releases/29.3/docs/user-guide/images/agreement_table.png b/releases/29.3/docs/user-guide/images/agreement_table.png new file mode 100644 index 0000000..3d5ef71 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/agreement_table.png differ diff --git a/releases/29.3/docs/user-guide/images/annotation1.jpg b/releases/29.3/docs/user-guide/images/annotation1.jpg new file mode 100644 index 0000000..57a0372 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation1.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation2.jpg b/releases/29.3/docs/user-guide/images/annotation2.jpg new file mode 100644 index 0000000..37f1bf0 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation2.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation3.jpg b/releases/29.3/docs/user-guide/images/annotation3.jpg new file mode 100644 index 0000000..d7f5bcc Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation3.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation4.png b/releases/29.3/docs/user-guide/images/annotation4.png new file mode 100644 index 0000000..7c2f15a Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation4.png differ diff --git a/releases/29.3/docs/user-guide/images/annotation_edit.jpg b/releases/29.3/docs/user-guide/images/annotation_edit.jpg new file mode 100644 index 0000000..317e015 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_edit.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation_edit_version3.png b/releases/29.3/docs/user-guide/images/annotation_edit_version3.png new file mode 100644 index 0000000..cb70f2f Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_edit_version3.png differ diff --git a/releases/29.3/docs/user-guide/images/annotation_editor_with_suggestions.png b/releases/29.3/docs/user-guide/images/annotation_editor_with_suggestions.png new file mode 100644 index 0000000..53d4deb Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_editor_with_suggestions.png differ diff --git a/releases/29.3/docs/user-guide/images/annotation_export.jpg b/releases/29.3/docs/user-guide/images/annotation_export.jpg new file mode 100644 index 0000000..78b8191 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_export.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation_lemma.jpg b/releases/29.3/docs/user-guide/images/annotation_lemma.jpg new file mode 100644 index 0000000..ce164d5 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_lemma.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation_ner.jpg b/releases/29.3/docs/user-guide/images/annotation_ner.jpg new file mode 100644 index 0000000..ef655ee Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_ner.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation_pos.jpg b/releases/29.3/docs/user-guide/images/annotation_pos.jpg new file mode 100644 index 0000000..fe9fae6 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_pos.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation_pos_span.jpg b/releases/29.3/docs/user-guide/images/annotation_pos_span.jpg new file mode 100644 index 0000000..be25c98 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_pos_span.jpg differ diff --git a/releases/29.3/docs/user-guide/images/annotation_relation_yield.png b/releases/29.3/docs/user-guide/images/annotation_relation_yield.png new file mode 100644 index 0000000..c8df221 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_relation_yield.png differ diff --git a/releases/29.3/docs/user-guide/images/annotation_settings.png b/releases/29.3/docs/user-guide/images/annotation_settings.png new file mode 100644 index 0000000..cea9b48 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_settings.png differ diff --git a/releases/29.3/docs/user-guide/images/annotation_span_many.jpg b/releases/29.3/docs/user-guide/images/annotation_span_many.jpg new file mode 100644 index 0000000..211cf36 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/annotation_span_many.jpg differ diff --git a/releases/29.3/docs/user-guide/images/concept-linking2.png b/releases/29.3/docs/user-guide/images/concept-linking2.png new file mode 100644 index 0000000..b26ac6d Binary files /dev/null and b/releases/29.3/docs/user-guide/images/concept-linking2.png differ diff --git a/releases/29.3/docs/user-guide/images/concept-linking4.png b/releases/29.3/docs/user-guide/images/concept-linking4.png new file mode 100644 index 0000000..53d4deb Binary files /dev/null and b/releases/29.3/docs/user-guide/images/concept-linking4.png differ diff --git a/releases/29.3/docs/user-guide/images/constraints.png b/releases/29.3/docs/user-guide/images/constraints.png new file mode 100644 index 0000000..ba458a5 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/constraints.png differ diff --git a/releases/29.3/docs/user-guide/images/curation-sidebar.png b/releases/29.3/docs/user-guide/images/curation-sidebar.png new file mode 100644 index 0000000..0e87e4c Binary files /dev/null and b/releases/29.3/docs/user-guide/images/curation-sidebar.png differ diff --git a/releases/29.3/docs/user-guide/images/curation_1.png b/releases/29.3/docs/user-guide/images/curation_1.png new file mode 100644 index 0000000..050a173 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/curation_1.png differ diff --git a/releases/29.3/docs/user-guide/images/evaluation.png b/releases/29.3/docs/user-guide/images/evaluation.png new file mode 100644 index 0000000..78ee101 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/evaluation.png differ diff --git a/releases/29.3/docs/user-guide/images/evaluation_simulation_panel.png b/releases/29.3/docs/user-guide/images/evaluation_simulation_panel.png new file mode 100644 index 0000000..684a7bf Binary files /dev/null and b/releases/29.3/docs/user-guide/images/evaluation_simulation_panel.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_Sidebar_closed.png b/releases/29.3/docs/user-guide/images/getting_started_Sidebar_closed.png new file mode 100644 index 0000000..99576d7 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_Sidebar_closed.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_Sidebar_open.png b/releases/29.3/docs/user-guide/images/getting_started_Sidebar_open.png new file mode 100644 index 0000000..c0b15bc Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_Sidebar_open.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_agreement.png b/releases/29.3/docs/user-guide/images/getting_started_agreement.png new file mode 100644 index 0000000..c4c1b53 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_agreement.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_annotation_panel.png b/releases/29.3/docs/user-guide/images/getting_started_annotation_panel.png new file mode 100644 index 0000000..b0c6205 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_annotation_panel.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_create_users.png b/releases/29.3/docs/user-guide/images/getting_started_create_users.png new file mode 100644 index 0000000..b5f820b Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_create_users.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_curation.png b/releases/29.3/docs/user-guide/images/getting_started_curation.png new file mode 100644 index 0000000..1e59641 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_curation.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_documents.png b/releases/29.3/docs/user-guide/images/getting_started_documents.png new file mode 100644 index 0000000..f76d943 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_documents.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_download_example_project.png b/releases/29.3/docs/user-guide/images/getting_started_download_example_project.png new file mode 100644 index 0000000..eee99e1 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_download_example_project.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_example_for_annotations.png b/releases/29.3/docs/user-guide/images/getting_started_example_for_annotations.png new file mode 100644 index 0000000..6833207 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_example_for_annotations.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_first_annotation.png b/releases/29.3/docs/user-guide/images/getting_started_first_annotation.png new file mode 100644 index 0000000..82783cf Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_first_annotation.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_guidelines.png b/releases/29.3/docs/user-guide/images/getting_started_guidelines.png new file mode 100644 index 0000000..cac7336 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_guidelines.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_import_project.png b/releases/29.3/docs/user-guide/images/getting_started_import_project.png new file mode 100644 index 0000000..01207ac Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_import_project.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_kb_page.png b/releases/29.3/docs/user-guide/images/getting_started_kb_page.png new file mode 100644 index 0000000..397d9a2 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_kb_page.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_kbs.png b/releases/29.3/docs/user-guide/images/getting_started_kbs.png new file mode 100644 index 0000000..6765369 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_kbs.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_layers.png b/releases/29.3/docs/user-guide/images/getting_started_layers.png new file mode 100644 index 0000000..58c48e9 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_layers.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_login.png b/releases/29.3/docs/user-guide/images/getting_started_login.png new file mode 100644 index 0000000..9a33ccc Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_login.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_monitoring.png b/releases/29.3/docs/user-guide/images/getting_started_monitoring.png new file mode 100644 index 0000000..1b350ca Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_monitoring.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_open_a_project.png b/releases/29.3/docs/user-guide/images/getting_started_open_a_project.png new file mode 100644 index 0000000..96327f8 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_open_a_project.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_recommenders.png b/releases/29.3/docs/user-guide/images/getting_started_recommenders.png new file mode 100644 index 0000000..b70da41 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_recommenders.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_settings.png b/releases/29.3/docs/user-guide/images/getting_started_settings.png new file mode 100644 index 0000000..7089786 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_settings.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_starting_the_jar_I.png b/releases/29.3/docs/user-guide/images/getting_started_starting_the_jar_I.png new file mode 100644 index 0000000..95ac8f4 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_starting_the_jar_I.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_starting_the_jar_II.png b/releases/29.3/docs/user-guide/images/getting_started_starting_the_jar_II.png new file mode 100644 index 0000000..c9bd80c Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_starting_the_jar_II.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_tagset_create.png b/releases/29.3/docs/user-guide/images/getting_started_tagset_create.png new file mode 100644 index 0000000..35083c6 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_tagset_create.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_tagset_link.png b/releases/29.3/docs/user-guide/images/getting_started_tagset_link.png new file mode 100644 index 0000000..90e3238 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_tagset_link.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_tagset_use.png b/releases/29.3/docs/user-guide/images/getting_started_tagset_use.png new file mode 100644 index 0000000..0e890f8 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_tagset_use.png differ diff --git a/releases/29.3/docs/user-guide/images/getting_started_users.png b/releases/29.3/docs/user-guide/images/getting_started_users.png new file mode 100644 index 0000000..8da19f3 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/getting_started_users.png differ diff --git a/releases/29.3/docs/user-guide/images/kb1.png b/releases/29.3/docs/user-guide/images/kb1.png new file mode 100644 index 0000000..9676a36 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/kb1.png differ diff --git a/releases/29.3/docs/user-guide/images/kb2.png b/releases/29.3/docs/user-guide/images/kb2.png new file mode 100644 index 0000000..2e2df49 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/kb2.png differ diff --git a/releases/29.3/docs/user-guide/images/kb3.png b/releases/29.3/docs/user-guide/images/kb3.png new file mode 100644 index 0000000..56160be Binary files /dev/null and b/releases/29.3/docs/user-guide/images/kb3.png differ diff --git a/releases/29.3/docs/user-guide/images/kb4.png b/releases/29.3/docs/user-guide/images/kb4.png new file mode 100644 index 0000000..0b7706b Binary files /dev/null and b/releases/29.3/docs/user-guide/images/kb4.png differ diff --git a/releases/29.3/docs/user-guide/images/kb5.png b/releases/29.3/docs/user-guide/images/kb5.png new file mode 100644 index 0000000..57bdbfe Binary files /dev/null and b/releases/29.3/docs/user-guide/images/kb5.png differ diff --git a/releases/29.3/docs/user-guide/images/layer_details.png b/releases/29.3/docs/user-guide/images/layer_details.png new file mode 100644 index 0000000..92cf8ed Binary files /dev/null and b/releases/29.3/docs/user-guide/images/layer_details.png differ diff --git a/releases/29.3/docs/user-guide/images/layer_feature_details.png b/releases/29.3/docs/user-guide/images/layer_feature_details.png new file mode 100644 index 0000000..3f14510 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/layer_feature_details.png differ diff --git a/releases/29.3/docs/user-guide/images/login.jpg b/releases/29.3/docs/user-guide/images/login.jpg new file mode 100644 index 0000000..4987c29 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/login.jpg differ diff --git a/releases/29.3/docs/user-guide/images/manage_users.png b/releases/29.3/docs/user-guide/images/manage_users.png new file mode 100644 index 0000000..9e2360b Binary files /dev/null and b/releases/29.3/docs/user-guide/images/manage_users.png differ diff --git a/releases/29.3/docs/user-guide/images/menu.jpg b/releases/29.3/docs/user-guide/images/menu.jpg new file mode 100644 index 0000000..95d3b1d Binary files /dev/null and b/releases/29.3/docs/user-guide/images/menu.jpg differ diff --git a/releases/29.3/docs/user-guide/images/metadata-sidebar.png b/releases/29.3/docs/user-guide/images/metadata-sidebar.png new file mode 100644 index 0000000..f6a27aa Binary files /dev/null and b/releases/29.3/docs/user-guide/images/metadata-sidebar.png differ diff --git a/releases/29.3/docs/user-guide/images/monitoring-annotation-states.png b/releases/29.3/docs/user-guide/images/monitoring-annotation-states.png new file mode 100644 index 0000000..4e7b0d8 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/monitoring-annotation-states.png differ diff --git a/releases/29.3/docs/user-guide/images/monitoring-bulk-actions.png b/releases/29.3/docs/user-guide/images/monitoring-bulk-actions.png new file mode 100644 index 0000000..b25c5bd Binary files /dev/null and b/releases/29.3/docs/user-guide/images/monitoring-bulk-actions.png differ diff --git a/releases/29.3/docs/user-guide/images/monitoring-curation-states.png b/releases/29.3/docs/user-guide/images/monitoring-curation-states.png new file mode 100644 index 0000000..327c2b3 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/monitoring-curation-states.png differ diff --git a/releases/29.3/docs/user-guide/images/monitoring-document-states.png b/releases/29.3/docs/user-guide/images/monitoring-document-states.png new file mode 100644 index 0000000..0a193d5 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/monitoring-document-states.png differ diff --git a/releases/29.3/docs/user-guide/images/monitoring-legend.png b/releases/29.3/docs/user-guide/images/monitoring-legend.png new file mode 100644 index 0000000..a34a31b Binary files /dev/null and b/releases/29.3/docs/user-guide/images/monitoring-legend.png differ diff --git a/releases/29.3/docs/user-guide/images/new_userPermissions.png b/releases/29.3/docs/user-guide/images/new_userPermissions.png new file mode 100644 index 0000000..dddf6dc Binary files /dev/null and b/releases/29.3/docs/user-guide/images/new_userPermissions.png differ diff --git a/releases/29.3/docs/user-guide/images/new_userSelection.png b/releases/29.3/docs/user-guide/images/new_userSelection.png new file mode 100644 index 0000000..42372b2 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/new_userSelection.png differ diff --git a/releases/29.3/docs/user-guide/images/open_doc.png b/releases/29.3/docs/user-guide/images/open_doc.png new file mode 100644 index 0000000..1e4d7a0 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/open_doc.png differ diff --git a/releases/29.3/docs/user-guide/images/package_structure.png b/releases/29.3/docs/user-guide/images/package_structure.png new file mode 100644 index 0000000..7531626 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/package_structure.png differ diff --git a/releases/29.3/docs/user-guide/images/pdf-panel-top-center.png b/releases/29.3/docs/user-guide/images/pdf-panel-top-center.png new file mode 100644 index 0000000..b742f2f Binary files /dev/null and b/releases/29.3/docs/user-guide/images/pdf-panel-top-center.png differ diff --git a/releases/29.3/docs/user-guide/images/pdf-panel-top-left.png b/releases/29.3/docs/user-guide/images/pdf-panel-top-left.png new file mode 100644 index 0000000..1d194e3 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/pdf-panel-top-left.png differ diff --git a/releases/29.3/docs/user-guide/images/pdf-panel-top-right.png b/releases/29.3/docs/user-guide/images/pdf-panel-top-right.png new file mode 100644 index 0000000..7cd7a93 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/pdf-panel-top-right.png differ diff --git a/releases/29.3/docs/user-guide/images/progress_workflow.jpg b/releases/29.3/docs/user-guide/images/progress_workflow.jpg new file mode 100644 index 0000000..ac1ded6 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/progress_workflow.jpg differ diff --git a/releases/29.3/docs/user-guide/images/project2.jpg b/releases/29.3/docs/user-guide/images/project2.jpg new file mode 100644 index 0000000..d7e0b73 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project2.jpg differ diff --git a/releases/29.3/docs/user-guide/images/project3.jpg b/releases/29.3/docs/user-guide/images/project3.jpg new file mode 100644 index 0000000..9ec1e61 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project3.jpg differ diff --git a/releases/29.3/docs/user-guide/images/project4.jpg b/releases/29.3/docs/user-guide/images/project4.jpg new file mode 100644 index 0000000..7a9a9c2 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project4.jpg differ diff --git a/releases/29.3/docs/user-guide/images/project5.jpg b/releases/29.3/docs/user-guide/images/project5.jpg new file mode 100644 index 0000000..e60d2a6 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project5.jpg differ diff --git a/releases/29.3/docs/user-guide/images/project7.jpg b/releases/29.3/docs/user-guide/images/project7.jpg new file mode 100644 index 0000000..7e3af3a Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project7.jpg differ diff --git a/releases/29.3/docs/user-guide/images/project8.jpg b/releases/29.3/docs/user-guide/images/project8.jpg new file mode 100644 index 0000000..793b11c Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project8.jpg differ diff --git a/releases/29.3/docs/user-guide/images/project_creation.png b/releases/29.3/docs/user-guide/images/project_creation.png new file mode 100644 index 0000000..d5f7eba Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_creation.png differ diff --git a/releases/29.3/docs/user-guide/images/project_details.png b/releases/29.3/docs/user-guide/images/project_details.png new file mode 100644 index 0000000..86fb7e9 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_details.png differ diff --git a/releases/29.3/docs/user-guide/images/project_documents.png b/releases/29.3/docs/user-guide/images/project_documents.png new file mode 100644 index 0000000..d87c918 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_documents.png differ diff --git a/releases/29.3/docs/user-guide/images/project_export.png b/releases/29.3/docs/user-guide/images/project_export.png new file mode 100644 index 0000000..ababa4f Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_export.png differ diff --git a/releases/29.3/docs/user-guide/images/project_layer_type_chain.png b/releases/29.3/docs/user-guide/images/project_layer_type_chain.png new file mode 100644 index 0000000..a897ce8 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_layer_type_chain.png differ diff --git a/releases/29.3/docs/user-guide/images/project_layer_type_relation.png b/releases/29.3/docs/user-guide/images/project_layer_type_relation.png new file mode 100644 index 0000000..dad5978 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_layer_type_relation.png differ diff --git a/releases/29.3/docs/user-guide/images/project_layer_type_span.png b/releases/29.3/docs/user-guide/images/project_layer_type_span.png new file mode 100644 index 0000000..b9e32a8 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_layer_type_span.png differ diff --git a/releases/29.3/docs/user-guide/images/project_tagset_new.jpg b/releases/29.3/docs/user-guide/images/project_tagset_new.jpg new file mode 100644 index 0000000..caa42f3 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/project_tagset_new.jpg differ diff --git a/releases/29.3/docs/user-guide/images/recommender_settings.png b/releases/29.3/docs/user-guide/images/recommender_settings.png new file mode 100644 index 0000000..9cf1427 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/recommender_settings.png differ diff --git a/releases/29.3/docs/user-guide/images/recommender_sidebar.png b/releases/29.3/docs/user-guide/images/recommender_sidebar.png new file mode 100644 index 0000000..61dcf64 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/recommender_sidebar.png differ diff --git a/releases/29.3/docs/user-guide/images/relation-annotation-drag.png b/releases/29.3/docs/user-guide/images/relation-annotation-drag.png new file mode 100644 index 0000000..f342b04 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/relation-annotation-drag.png differ diff --git a/releases/29.3/docs/user-guide/images/relation-annotation.png b/releases/29.3/docs/user-guide/images/relation-annotation.png new file mode 100644 index 0000000..9920802 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/relation-annotation.png differ diff --git a/releases/29.3/docs/user-guide/images/relation_recommender_city.png b/releases/29.3/docs/user-guide/images/relation_recommender_city.png new file mode 100644 index 0000000..9feaead Binary files /dev/null and b/releases/29.3/docs/user-guide/images/relation_recommender_city.png differ diff --git a/releases/29.3/docs/user-guide/images/search-core-search.png b/releases/29.3/docs/user-guide/images/search-core-search.png new file mode 100644 index 0000000..88e8808 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/search-core-search.png differ diff --git a/releases/29.3/docs/user-guide/images/sharing_settings.png b/releases/29.3/docs/user-guide/images/sharing_settings.png new file mode 100644 index 0000000..f251b47 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/sharing_settings.png differ diff --git a/releases/29.3/docs/user-guide/images/span-annotation.png b/releases/29.3/docs/user-guide/images/span-annotation.png new file mode 100644 index 0000000..9a4c415 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/span-annotation.png differ diff --git a/releases/29.3/docs/user-guide/images/streamlined_process.png b/releases/29.3/docs/user-guide/images/streamlined_process.png new file mode 100644 index 0000000..907137e Binary files /dev/null and b/releases/29.3/docs/user-guide/images/streamlined_process.png differ diff --git a/releases/29.3/docs/user-guide/images/version3_login.png b/releases/29.3/docs/user-guide/images/version3_login.png new file mode 100644 index 0000000..9a065b8 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/version3_login.png differ diff --git a/releases/29.3/docs/user-guide/images/versioning_settings.png b/releases/29.3/docs/user-guide/images/versioning_settings.png new file mode 100644 index 0000000..3292cc5 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/versioning_settings.png differ diff --git a/releases/29.3/docs/user-guide/images/weblicht_chain_builder.png b/releases/29.3/docs/user-guide/images/weblicht_chain_builder.png new file mode 100644 index 0000000..d0f8403 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/weblicht_chain_builder.png differ diff --git a/releases/29.3/docs/user-guide/images/word_alignment_editor.png b/releases/29.3/docs/user-guide/images/word_alignment_editor.png new file mode 100644 index 0000000..6630b52 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/word_alignment_editor.png differ diff --git a/releases/29.3/docs/user-guide/images/workload.png b/releases/29.3/docs/user-guide/images/workload.png new file mode 100644 index 0000000..9113466 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/workload.png differ diff --git a/releases/29.3/docs/user-guide/images/workload_settings.png b/releases/29.3/docs/user-guide/images/workload_settings.png new file mode 100644 index 0000000..88bbda4 Binary files /dev/null and b/releases/29.3/docs/user-guide/images/workload_settings.png differ