The task is concentrated on using full text search engine (ElasticSearch) to perform basic search operations in a text corpus.
Task objective (8 points):
- Install ElasticSearch (ES).
- Install an ES plugin for Polish https://github.com/allegro/elasticsearch-analysis-morfologik
- Define an ES analyzer for Polish texts containing:
- standard tokenizer
- synonym filter with alternative forms for months, e.g.
kwiecień
,kwi
,IV
. - lowercase filter
- Morfologik-based lemmatizer
- lowercase filter (looks strange, but Morfologi produces capitalized base forms for proper names, so we have to lowercase them once more).
- Define another analyzer for Polish, without the synonym filter.
- Define an ES index for storing the contents of the corpus FiQA-PL using both analyzers. Use different names for the fields analyzed with a different pipeline.
- Load the data to the ES index.
- Determine the number of documents and the number of matches containing the word
kwiecień
(in any form) including and excluding the synonyms. - Download the QA pairs for the FiQA-PL dataset.
- Compute NDCG@5 for the QA dataset (the test subset) for the following setusp:
- synonyms enabled and disabled,
- lemmatization in the query enabled and disabled.
- (optional) Find three questions from the test subset with the following features:
- the relevant document is returned by ES at position 1,
- the relevant document is returned by ES at position 4 or 5.
- the relevant document is returned by ES is not found.
- (optional) Analyze the possible reasons for these outcomes.
Answer the following questions (2 points):
- What are the strengths and weaknesses of regular expressions versus full text search regarding processing of text?
- Can an LLM be applied in the context of searching for documents? Justify your answer, excluding the obvious observation that an LLM can be used to formulate the answer.
- Full text search engines were developed for storing and searching textual data.
- The most popular FTSes are SOLR and ElasticSearch (ES).
- Some relational databases support full text search, but usually it is limited and not easy to adapt.
- Both for SOLR and ES there are plugins supporting Polish.
- FTSes use inverted-index to store the data. At loading time the text is split by tokenizer into tokens and individual tokens go through filters. The resulting tokens are placed as keys in a hash-like structure. The values are so called posting lists, containing pointers to the documents where the tokens come from.
- The minimal FTS configuration requires two elements: a tokenizer and a set of filters (the set might be empty in the extreme case). Changing the configuration of an index does not result in the new definitions being applied to the already stored documents. In such cases the index has to be rebuilt, meaning that the documents have to be loaded once again.
- FTSes contain a large number of tokenizers, e.g. they may know semantics of HTML documents and treat HTML tags as
tokens. Some popular tokenizers include:
- standard tokenizer - based on the Unicode tokenization rules,
- whitespace tokenizer - which splits the tokens by white spaces,
- url tokenizer - which keeps the URLs as indivisible tokens.
- Some tokens such as commas and full stops might be removed at the stage of filtering. Filtering of common tokens reduces the index size.
- Some popular filters include:
- lowercase filter - which downcases the letters,
- ASCII folding filter - which removes Polish diacritics,
- stop token filter - which removes the specified tokens (described above),
- lematizers - which find the base form of a word,
- etc. (present implementation of ES has more than 50 filters)
- Lemmatization is a process when the inflected form of a word is replaced with its base form, e.g the form psu is replaced with pies. You should notice that there are many ambiguous forms, e.g. goli can have the following base forms: golić, gol and goły. To overcome the ambiguity, FTSes take very pragmatic approach - for a given inflected form all possible base forms are put in the index. Even though it's not valid from the linguistics' point of view, it works well in practice.
- Term vector API allows to retrieve useful statistics of a given term in a particular document or in the whole document collection.
- Polish retrieval models comparison is available at :https://huggingface.co/spaces/sdadas/pirb
- In the
elastic
directory there's a basic configuration for runnig ElasticSearch withdocker compose
:- You can use the
docker-compose.yml
configuration - it will start ES with the morfologik plugin installed. - You can also modify the
Dockerfile
configuration and run it locally. - In the
query.sh
file there's a check for ES showing if it is possible to connect to the instance usingcurl
. - The correct output from curl is
[]
meaning there aren't any indices defined.
- You can use the