=================================================================== Ajavt (Ajaväljendite tuvastaja): Temporal Expression Tagger for Estonian =================================================================== Temporal Expression Tagger is a program that detects time referring expressions (timexes) from natural language text and normalises semantics of these expressions in a standard format. This repository contains Ajavt, a rule-based language-specific temporal expression tagger for Estonian. The tool uses an annotation format that is based on the TimeML's TIMEX3 tag (http://www.timeml.org), and it is currently tuned for temporal tagging in news domain. Previous versions of this tool have been introduced in two publications. Technical details about the implementation were covered in (Orasmaa 2010), and a more general overview, accompanied with evaluation of the tagger on different text genres, was provided in (Orasmaa 2012). =========================================== Temporal expression tagging: an example =========================================== The sentence: Potsataja ütles eile, et vaatavad nüüd Genaga viie aasta plaanid uuesti üle. 'Potsataja said yesterday that he and Gena will now check over the plans for the five years.' is tagged for temporal expressions in a following way (assuming that the creation time of the text is 2014-10-06): Potsataja ütles <TIMEX tid="t1" type="DATE" value="2014-10-05"> eile </TIMEX>, et vaatavad <TIMEX tid="t2" type="DATE" value="PRESENT_REF" anchorTimeID="t0"> nüüd </TIMEX> Genaga <TIMEX tid="t3" type="DURATION" value="P5Y"> viie aasta </TIMEX> plaanid uuesti üle. ========================= Requirements ========================= For building the program (JAR file): ** Java JDK (at least version 1.8.x is expected); ** Apache Ant (at least version 1.8.2); For using the program: ** A sentence segmentator; ** A word tokenizer; ** Estonian morphological analyzer and disambiguator, possible options: -- Filosoft's Vabamorf: https://github.com/Filosoft/vabamorf -- PyVabamorf: https://github.com/estnltk/pyvabamorf -- T3MESTA (a commercial morphological analyzer) (NB! The program also works on morphologically ambiguous input, but the quality of the analysis is expected to be lower than on the morphologically disambiguated text.) ========================= Building the program ========================= The most straightforward way for compiling the program is by using Apache Ant and the build script ("build.xml" in root dir); Before building, correct path to JDK must be set in the file "build.properties" (variable "java.home.location"). Then, building and deploying can be evoked with the command: ant deploy (in the same directory where "build.xml" is located); This compiles the Java source code, makes the JAR file (Ajavt.jar), and copies the JAR file along with required files into the folder "test"; ========================= Using the program ========================= Before Ajavt can be applied on a text, a number of text preprocessing steps must be made: text must be split into sentences and tokens (words), and words must be morphologically analysed (and disambiguated). These functionalities are provided by EstNLTK toolkit, so the easiest way to use the program is within this toolkit ( see https://github.com/estnltk/estnltk for more details ). Processing JSON format texts ------------------------------ In the JSON processing mode (flag '-format json'), it is expected that the input of the program is in the same format as the output of Vabamorf's command 'etana analyze' - a JSON structured text in UTF8 encoding. Note that the minimum JSON structure that the input should have is: {"words": [ {"analysis": [ ... ], "text": "word1"}, {"analysis": [ ... ], "text": "word2"}, ... {"analysis": [ ... ], "text": "wordN"} ]} That is, an object with key "words" must be present, indicating an analysable sentence. Also note that Ajavt expects that word root analyses are 'clean', i.e. without any phonetic markup symbols (which can be optionally added in 'etana' with flag '-phonetic'). An example of JSON input can be found in file "test/example_input.json"; In the "test" folder, following command evokes Ajavt on the input file "example_input.json" and outputs the results to standard input: java -jar Ajavt.jar -format json -in file example_input.json -pretty_print (flag "-pretty_print" switches on the pretty printing mode, otherwise, all of the output JSON is on a single line); Alternatively, output can also be directed to a file by specifying: java -jar Ajavt.jar -format json -in file example_input.json -pretty_print -out file my_output.json Document creation time (DCT) ------------------------------ By default, temporal expressions with relative semantics (such as 'eile' / yesterday, 'reedel' / on Friday) are normalised with respect to execution time of the program. This setting can be overridden by providing a separate document creation time as an input of the program: java -jar Ajavt.jar 1999-01-01TXX:XX -format json -in file example_input.json -pretty_print The document creation time must be in the format "YYYY-MM-DDThh:mm". Date/time fields marked with X-es are considered as unspecified/unknown. For example, it can be specified that the creation time is only known at month level (e.g. 1999-01-XXTXX:XX) or at year level (e.g. 1999-XX-XXTXX:XX). This also affects the normalisation, e.g. if DCT is only specified at the year level, date-granularity relative expressions (for example: 'reedel' / on Friday) will be normalised as unspecified temporal references (XXXX-XX-XXTXX:XX); Other remarks ------------------------------ The Ajavt.jar should be executed in a directory that contains other files required by the program: javax.json-1.0.4.jar joda-time-1.6.jar reeglid.xml The program can be executed with a custom configuration of rules, using the flag "-r" followed by the full path to the XML rules file (e.g. "reeglid.xml"): java -jar Ajavt.jar -format json -in file example_input.json -pretty_print -r FULL/PATH/TO/reeglid.xml Flag "-pyvabamorf" evokes the program in a special standard input/output processing mode, where the program reads a JSON formatted line from the standard input, analyzes the line, and outputs the results (in a single JSON formatted line) to the standard output: java -jar Ajavt.jar -pyvabamorf ============================ Interpreting the output ============================ The annotation format used by the program is described in the file "doc/margendusformaat_et.pdf" (currently only in Estonian). Here, we give a brief overview how this format is expressed in JSON. JSON format output ---------------------- In JSON input/output format, the presence of identified temporal expression(s) is indicated by adding object "timexes" to the token (at the same level as objects "text" and "analysis"). The "timexes" is a list of objects and each object has (at minimum) a following structure: { "tid": string, } where "tid" is an unique identifier of the temporal expression (in form that can be described by a regular expression "t[0-9]+" ). (Note that in "-pyvabamorf" processing mode, this uniqueness only holds within a single input line, which is expected to be a single document); If the token begins a temporal expression phrase (either a single-word phrase or a multiword phrase), additional attribute/value pairs will be specified in the timex object: "text" : string // full extent phrase of the temporal expression "type" : string // one of the following: "DATE", "TIME", "DURATION", "SET" "value": string // calendrical value (largely follows TimeML TIMEX3 value format), // but see "doc/margendusformaat_et.pdf" for details; "temporalFunction": string ("true" or "false") // indicates whether the semantics of the expression are relative // to the context: // *) For DATE and TIME expressions: // "true" indicates that the expression is relative and // semantics have been computed by heuristics; // "false" indicates that the expression is absolute and // semantics haven't been computed by heuristics; // *) For DURATION expressions, the value is mostly "false", // except for vague durations; // *) For SET expressions, the value is always "true"; Depending on the (semantics of the) temporal expression, there can also be other attribute/value pairs: "mod" : string // largely follows TimeML TIMEX3 mod format, with two additional // values used to mark first/second half of the date/time (e.g. "in // the first half of the month"): FIRST_HALF, SECOND_HALF; "anchorTimeID" // points to the temporal expression (by identifier) that this // expression has been anchored to while calculating or determining // the value; // "t0" -- means that the expression is anchored to document // creation time; "beginPoint" // in case of DURATION: points to the temporal expression (by // identifier) that serves as a beginning point of this duration; // "?" -- indicates problems on finding the beginning point; "endPoint" // in case of DURATION: points to the temporal expression (by // identifier) that serves as an ending point of this duration; // "?" -- indicates problems on finding the ending point; "quant" // Quantifier; Used only in some SET expressions, e.g. quant="EVERY" "freq" // Used in some SET expressions, marks frequency of repetition, // e.g. "three days in each month" will be have freq="3D" An example -------------- The sentence "Potsataja ütles eile, et vaatavad nüüd Genaga viie aasta plaanid uuesti üle." (created at 2014-10-06) will obtain following temporal expression annotations: { "words":[ { "analysis":[ ... ], "text":"Potsataja" }, { "analysis":[ ... ], "text":"ütles" }, { "analysis":[ ... ], "text":"eile,", "timexes":[ { "tid":"t1", "text":"eile,", "type":"DATE", "temporalFunction":"true", "value":"2014-10-05" } ] }, { "analysis":[ ... ], "text":"et" }, { "analysis":[ ... ], "text":"vaatavad" }, { "analysis":[ ... ], "text":"nüüd", "timexes":[ { "tid":"t2", "text":"nüüd", "type":"DATE", "temporalFunction":"true", "value":"PRESENT_REF", "anchorTimeID":"t0" } ] }, { "analysis":[ ... ], "text":"Genaga" }, { "analysis":[ ... ], "text":"viie", "timexes":[ { "tid":"t3", "text":"viie aasta", "type":"DURATION", "temporalFunction":"false", "value":"P5Y" } ] }, { "analysis":[ ... ], "text":"aasta", "timexes":[ { "tid":"t3", "text":"viie aasta" } ] }, { "analysis":[ ... ], "text":"plaanid" }, { "analysis":[ ... ], "text":"uuesti" }, { "analysis":[ ... ], "text":"üle" } ] } which should be interpreted as: "eile," -- is a single-word temporal expression, which is from type "DATE", and which refers to the date "2014-10-05"; "nüüd" -- is a single-word temporal expression, which is from type "DATE", and which has an uncertain calendaric value, but it refers to the present time (PRESENT_REF), contemporary to the document creation time (t0, which is 2014-10-06); "viie", "aasta" -- forms a multiword temporal expression phrase ("viie aasta"), referring to a period ("DURATION") of length 5 years; Specifics -------------- I. Note that there can also be timexes with no "text" value, i.e. timexes that form an implicit duration (A), or mark implicit beginning or ending points (B): (A) e.g. "2001-2005" -- the period covering explicit timepoints "2001-" and "2005" is annotated as a timex (DURATION) with no textual content; (B) e.g. "following three years" -- beginning and ending timepoints of the explicit duration expression ("three years") are marked as timexes with no textual content; II. The program does not always resolve the ambiguities of possible multiple readings of temporal expressions, e.g. "aastas 2000 tundi" can be interpreted as "aastas 2000" (in year 2000) or as "2000 tundi" (2000 hours). In case of ambiguities, "timexes" also lists multiple timex objects. =============================== Development and evaluation =============================== The structure ------------------ The Ajavt project has following directory structure: [doc] <--- documentation about the annotation format and about format of the rules file; [lib] <--- Java dependencies of the program; [res] <--- resources used by the program: [res\reeglid.xml] <--- the rules file [src] <--- source of the program: [src\ee\ut\soras\ajavtV2] <--- main source of the tagger; [src\ee\ut\soras\wrappers] <--- wrappers for handling different input formats, and a common model for encapsulating morphological analyses; [test-src] <--- methods for automated testing & evaluation; [test-src\ee\ut\soras\test_ajavt] --- tools for evaluating the tagger on an annotated corpus; [test] <--- the testing folder; tagger's JAR file along with required dependencies will be deployed here; readme.txt <--- you are here :) build.properties <--- configuration for the Ant build script; build.xml <--- the Ant build script for compiling, deploying and testing the tagger; Automated testing and evaluation ---------------------------------- This distribution also contains tools for automated testing/evaluating the tagger against manually annotated TIMEX corpora. In order to set up and use the automatic evaluation, proceed in following steps: I. Download Estonian TIMEX annotated corpora from following repository: https://github.com/soras/EstTimexCorpora II. Modify "build.properties" of this program and set the root directory of evaluation corpora: test.root=FULL/PATH/TO/EstTimexCorpora III. Modify "build.xml" of this program to enable automated testing: remove the comments around properties "use.tml.corpus.04" and "use.t3o.corpus.03". The property "use.tml.corpus.04" enables the evaluation task "test-tml-04", and the property "use.t3o.corpus.03" enables the task "test-t3-olp-03"; IV. Execute the automatic evaluation on all corpora with the command: ant test-all Alternatively, evaluation can be executed only on the TML format corpus: ant test-tml and only on the T3-OLP-AJAV format corpus: ant test-t3-olp V. The evaluation program will output a detailed analysis on matching (and mismatching) TIMEX annotations for each document. Additionally, precisions and recalls on TIMEX extents and attributes will be reported for each document, and microaverages of these measures will be reported at the end of the evaluation; The results of the evaluation will also be written into text files, marked with the timestamp of evaluation. Each evaluation corpus has a subdirectory "testlog" that stores these text files. ============================ Acknowledgements and license ============================ Copyright (C) 2009-2016 University of Tartu Author: Siim Orasmaa ( siim . orasmaa {at} ut . ee ) Ajavt is released under the GNU General Public License version 2. Dependency libraries have their own respective license terms, see "lib/LIB_LICENSES.txt" for details. Development of this tool has been supported by the National Programme for Estonian Language Technology under projects EKKTT09-66, EKT7 and EKT57. ============================ References ============================ Orasmaa, S. (2010). Ajaväljendite tuvastamine eestikeelses tekstis (Recognition and Resolution of Estonian Temporal Expressions). Master’s thesis, University of Tartu. (in Estonian). ( url: http://comserv.cs.ut.ee/forms/ati_report/downloader.php?file=F0E53012D5F88F71DD6E2E84830460F334E14EA2 ) Orasmaa, S. (2012) "Automaatne ajaväljendite tuvastamine eestikeelsetes tekstides" (Automatic Recognition and Normalization of Temporal Expressions in Estonian Language Texts). Eesti Rakenduslingvistika Ühingu aastaraamat 8: 153-169.