2022-09-01 13:35:24 +02:00
---
sidebar_position: 1
---
2024-01-17 13:39:34 +01:00
# Research products
2022-09-01 13:35:24 +02:00
2024-02-09 12:45:53 +01:00
Duplicates among research products are identified among results of the same
type (publications, datasets, software, other research products). If two
duplicate research products are aggregated one as a dataset and one as a
software, for example, they will never be compared and they will never be
identified as duplicates.
OpenAIRE supports different deduplication strategies based on the type of
results.
2022-09-01 13:35:24 +02:00
2024-02-09 12:45:53 +01:00
The next sections describe how each stage of the deduplication workflow is faced
for research products.
2022-09-01 13:35:24 +02:00
2022-11-03 13:16:44 +01:00
### Candidate identification (clustering)
2022-09-01 13:35:24 +02:00
2024-02-09 12:45:53 +01:00
To match the requirements of limiting the number of comparisons, OpenAIRE
clustering for research products works with two different strategies based on
entity types:
2022-09-01 13:35:24 +02:00
2024-02-09 12:45:53 +01:00
#### Software
* *Title extraction functions*:
two clustering functions are applied to the title (normalized, stemming, etc.)
* *stats and suffix prefix of words*: the function generates a key that
depends on (i) number of significant words in the title, (ii) module 10 of
the number of characters of such words, and (iii) a
string
obtained as an alternation of the function prefix(3) and suffix(3) (and
vice-versa) on the first 3 words (2 words if the title only has 2). For
example, the title ``Search for the Standard Model Higgs Boson``
becomes the two keys ``5-3-seaardmod`` and ``5-3-rchstadel``
* *n-grams*: the function generates ngrams from the
title. For example, the
title ``Search for the Standard Model Higgs Boson``
becomes the keys ``tan``, ``sta``, ``ode``, ``mod``, ``ear``, ``hig``,
``igg``, ``sea``
* *DOI extraction function*: the function generates the DOI when this is
provided as part of the record properties
* *URL extraction function*: the function generates the hostname part provided
by the URL of the software, if any
#### Publication, Dataset and Other Research Product
* *PID extraction function*: the function generates the PIDs when at least one
is provided as part of the ``pid`` record properties
* *Author and Title extraction function*: the function generates a key that
depends on (i) the number of authors of the product, with a cap of 21
authors (ii) number of significant words in the title (normalized, stemming,
etc.), divided by 10, and (iii) a string obtained as an alternation of the
function prefix(3) and suffix(3) (and vice versa) on the first 3 words (2
words if the title only has 2).
2024-02-14 09:43:36 +01:00
< br / >
For example, a product composed by 197 authors and
2024-02-09 12:45:53 +01:00
titled ``Search for the Standard Model Higgs Boson``
becomes the two keys ``21-0-seaardmod`` and ``21-0-rchstadel``
2022-09-01 13:35:24 +02:00
2022-11-03 13:16:44 +01:00
### Duplicates identification (pair-wise comparisons)
2022-09-01 13:35:24 +02:00
2024-02-09 12:45:53 +01:00
Comparisons in a block are performed using a *sliding window* set to 50 records.
The records are sorted lexicographically on the normalized version of their
titles. The 1st record is compared against all the 50 following ones using the
decision tree, then the second, etc.
Local information about matching records is kept and possibly used to prune
unneeded comparisons, for example once it is known that A equals to both B and
C, B will not be compared against C because the A,B,C group will be anyway
discovered by the global transitive closure step later.
2024-02-14 09:43:36 +01:00
< br / >
2024-02-09 12:45:53 +01:00
A different decision tree is adopted depending on the type of the entity being
processed.
Similarity relations drawn in this stage will be consequently used to perform
the duplicates grouping.
2022-09-01 13:35:24 +02:00
2022-11-03 13:16:44 +01:00
#### Publications
2022-09-01 13:35:24 +02:00
2024-02-09 12:45:53 +01:00
For each pair of publications in a cluster the following strategy (depicted in
the figure below) is applied.
2022-11-03 13:16:44 +01:00
The comparison goes through different stages:
2024-02-09 12:45:53 +01:00
1. *trusted pids check* : comparison of the trusted pid lists (in the `pid` field
of the record). If at least 1 pid is equivalent, records match and the
similarity relation is drawn.
2. *instance type check* : comparison of the instance types (indicating the
subtype of the record, i.e. presentation, conference object, etc.). If the
instance types are not compatible then the records does not match. Otherwise,
the comparison proceeds to the next stage
3. *untrusted pids check* : comparison of all the available pids (in the `pid`
and the `alternateid` fields of the record). In every case, no similarity
relation is drawn in this stage. If at least one pid is equivalent, the next
stage will be a *soft check* , otherwise the next stage is a *strong check* .
4. *soft check* : comparison of the record titles with the Levenshtein distance.
If the distance measure is above 0.9 then the similarity relation is drawn.
5. *strong check* : comparison composed by three substages involving the (i)
comparison of the author list sizes and the version of the record to
determine if they are coherent, (ii) comparison of the record titles with the
Levenshtein distance to determine if it is higher than 0.95, (iii) "smart"
comparison of the author lists to check if common authors are more than 60%
in case of titles whose length is greater than 30 chars or more than 90%
otherwise.
2022-09-01 13:35:24 +02:00
2022-09-23 18:00:46 +02:00
< p align = "center" >
2022-12-21 18:13:15 +01:00
< img loading = "lazy" alt = "Publications Decision Tree" src = {require('../../assets/img/decisiontree-publication.png').default} width = "100%" className = "img_node_modules-@docusaurus-theme-classic-lib-theme-MDXComponents-Img-styles-module" / >
2022-09-23 18:00:46 +02:00
< / p >
2022-09-01 13:35:24 +02:00
2022-11-14 11:13:29 +01:00
[//]: # (Link to the image: https://docs.google.com/drawings/d/19SIilTp1vukw6STMZuPMdc0pv0ODYCiOxP7OU3iPWK8/edit?usp=sharing)
2024-02-09 12:45:53 +01:00
#### Datasets and Other types of research products
For each pair of datasets or other types of research products in a cluster the
strategy depicted in the figure below is applied.
The decision tree is almost identical to the publication decision tree, with the
only exception of the *instance type check* stage. Since such type of record
does not have a relatable instance type, the check is not performed and the
decision tree node is skipped.
< p align = "center" >
< img loading = "lazy" alt = "Dataset and Other types of research products Decision Tree" src = {require('../../assets/img/decisiontree-dataset-orp.png').default} width = "90%" className = "img_node_modules-@docusaurus-theme-classic-lib-theme-MDXComponents-Img-styles-module" / >
< / p >
[//]: # (Link to the image: https://docs.google.com/drawings/d/1uBa7Bw2KwBRDUYIfyRr_Keol7UOeyvMNN7MPXYLg4qw/edit?usp=sharing)
2022-11-03 13:16:44 +01:00
#### Software
2024-02-09 12:45:53 +01:00
For each pair of software in a cluster the following strategy (depicted in the
figure below) is applied.
2022-11-03 13:16:44 +01:00
The comparison goes through different stages:
2024-02-09 12:45:53 +01:00
1. *DOI pids and URLs check* : comparison of the pids of type DOI and URLs in the
records. If at least 1 DOI is equivalent or 1 URL is equivalent, then records
match and the similarity relation is drawn
2. *title check* : comparison of the record titles with Levenshtein distance,
excluding versioning information.
If the distance is below 0.95 then the records does not match. Otherwise, the
comparison proceeds to the next stage
3. *untrusted DOI check* : comparison of all the available DOIs (in the `pid` and
the `alternateid` fields of the record). If at least 1 DOI is equivalent,
records match and the similarity relation is drawn
4. *authors check* : "smart" comparison of the author lists to check if the two
products share all authors
2022-11-03 13:16:44 +01:00
< p align = "center" >
2022-12-21 18:13:15 +01:00
< img loading = "lazy" alt = "Software Decision Tree" src = {require('../../assets/img/decisiontree-software.png').default} width = "85%" className = "img_node_modules-@docusaurus-theme-classic-lib-theme-MDXComponents-Img-styles-module" / >
2022-11-03 13:16:44 +01:00
< / p >
2022-09-01 13:35:24 +02:00
2022-11-14 11:13:29 +01:00
[//]: # (Link to the image: https://docs.google.com/drawings/d/19gd1-GTOEEo6awMObGRkYFhpAlO_38mfbDFFX0HAkuo/edit?usp=sharing)
2024-02-09 12:45:53 +01:00
### Duplicates grouping
2022-11-03 13:16:44 +01:00
2024-04-22 14:22:29 +02:00
The aim of the final stage is the creation of records that group all the
equivalent entities discovered pairwise by the previous step. This is done in
multiple phases.
2022-09-01 13:35:24 +02:00
2024-02-09 12:45:53 +01:00
#### Transitive closure
2022-11-14 11:13:29 +01:00
2024-04-22 14:22:29 +02:00
As the concluding step of duplicate identification, a transitive closure is
performed against similarity relations to identify complete groups of duplicated
records (cliques). If a group exceeds 200 elements, only the first 200 elements
are included in the group, while the remaining elements are kept ungrouped.
#### Selection of the pivot record
Each group of duplicate records needs to be identified in the final graph with
an OpenAIRE identifier, derived from a record of the group known as the _pivot
record_. It is determined after sorting the group of duplicate records by the
following criteria:
2024-05-29 23:18:42 +02:00
1. Records with identifiers from a [PID authority ](/data-model/pids-and-identifiers#pid-authorities ).
2. Records chosen as pivots in the graph's previous generations.
2024-04-22 14:22:29 +02:00
3. Publications from CrossRef or datasets from DataCite.
4. Records with an earlier date of acceptance.
5. Records with smaller IDs in lexicographical order.
The first sorting criterion is possible because a state table, called "pivot
history", is maintained across graph generations. It keeps track of which
records were used as pivot records in what graph, guaranteed to retain data for
the last 12 months.
#### Creation of representative records
The representative record, also known as the "dedup record", replaces the group
of deduplicated records in the graph.
##### OpenAIRE identifier of the representative record
The OpenAIRE identifier of the representative record is generated based on the
identifier of the record chosen as the pivot of the group:
- if the pivot record comes from a "PID authority", the identifier of the
representative record is the same, but the "PID Type Prefix" part of the
identifier is modified to append ``_dedup``.< br / >
For example ```doi_________::d5021b53204e4fdeab6ff5d5bc468032``` will
become ```doi_dedup___::d5021b53204e4fdeab6ff5d5bc468032```
- otherwise the "PID Type Prefix" part will be set to the fixed value
``dedup_wf_002``, and the following hash will be calculated as the MD5 hash of
the entire raw id of the pivot record.< br / >
For example ``DansKnawCris::0829b5191605bdbea36d6502b8c1ce1g`` will
become ``dedup_wf_002::345e5d1b80537b0d0e0a49241ae9e516``
##### Content of the representative record
The representative records inherits properties from the records it merges
and tracks their provenance. Whenever possible, it preserves all data from the
merged records, such as the ``instance`` field. In cases where a specific value
must be chosen, the most representative one is selected. For example, for the
"dateofacceptance" field, the earliest value is chosen.
##### Merged and singleton representative record
Changes in metadata content or graph construction may lead to cases where
representative records disappear from the graph:
1. When two or more representative records are merged into one representative
record. Put it other terms this happens when a group of duplicated records
contains multiple records formerly used as pivot record.
2. When a record chosen as a pivot record leaves its group and remains alone.
3. When a record chosen as a pivot record is no longer published by its data
source (deletion of the metadata record).
To address these cases, the pivot history table ensures the visibility of
disappearing representative records for the first two cases. Specifically:
1. In the case of merged representative records, the new representative record
and the ones that would be lost are generated and linked as part of the new
representative record.
2. In the case of a record no longer serving as a pivot, a representative record
is generated and linked only with that record.
This approach ensures that users can access representative records that would
otherwise be lost.