The ever growing need to efficiently store, retrieve and analyze massive datasets, originated by very different sources, is currently made more complex by the different requirements posed by users and applications. Such a new level of complexity cannot be handled properly by current data structures for big data problems.

To successfully meet these challenges, we launched a project, funded by the Italian Ministry of Education (PRIN no. 2017WR7SHH), that will lay down the theoretical and algorithmic-engineering foundations of a new generation of Multicriteria Data Structures and Algorithms. The multicriteria feature refers to the fact that we wish to seamlessly integrate, via a principled optimization approach, modern compressed data structures with new, revolutionary, data structures learned from the input data by using proper machine-learning tools. The goal of the optimization is to select, among a family of properly designed data structures, the one that “best fits” the multiple constraints imposed by its context of use, thus eventually dominating the multitude of trade-offs currently offered by known solutions, especially in the realm of Big Data applications.

# What is a multicriteria data structure?

A multicriteria data structure, for a given problem $P$, is defined by a pair $\langle \mathcal F, \mathcal A \rangle_P$ where $\mathcal F$ is a family of data structures, each one solving $P$ with a proper trade-off in the use of some resources (e.g. time, space, energy), and $\mathcal A$ is an optimisation algorithm that selects in $\mathcal F$ the data structure that best fits an instance of $P$.

For more details on the project, have a look at its full description here.

# Publications

Quickly discover relevant content by filtering publications.
The Alternating BWT: An algorithmic perspective. Theor. Comput. Sci., 812, 2020.

Learned data structures. Oneto L., Navarin N., Sperduti A., Anguita D. (eds) Recent Trends in Learning From Data. Studies in Computational Intelligence, vol 896. Springer, 2020.

# Software

#### BigRePair

A grammar compressor for huge files with many repetitions.

#### CORENup

A Combination of Convolutional and Recurrent Deep Neural Networks for Nucleosome Positioning Identification.

An extensible framework to efficiently compute alignment-free functions on a set of large genomic sequences.

#### FASTdoopC

A general software framework for the efficient acquisition of FASTA/Q genomic files in a MapReduce environment.

#### FastKmer

A SPARK software system for the collection of $k$-mer statistics.

#### LA-vector

A compressed bitvector/container supporting efficient random access and rank queries.

#### Learned sorted table search

A software library to speed-up sorted table search procedures via learning from data.

#### PFP Data Structures

Data structures supporting Longest Common Extensions and Suffix Array queries, built on the prefix-free parsing of the text.

#### PGM-index

A data structure enabling fast searches in arrays of billions of items using orders of magnitude less space than traditional indexes.

#### PyGM

Python library of sorted containers with state-of-the-art query performance and compressed memory usage.

#### sHAM

Compression strategies and space-conscious representations for deep neural networks.

# Events

#### Project end

Aug 28, 2022 (postponed because of COVID-19 to Feb 28, 2023)

#### Report of the first year

Sep 1, 2020
• Relazione scientifica intermedia (breve) - Prima Annualità
• Detailed report

#### Kickoff meeting

Oct 14, 2019 Video conference

Minutes of the meeting

Sep 1, 2019