Instructions to use xtr-replicability/modernbert_xtr_contrastive_multik128-256-512 with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- sentence-transformers
How to use xtr-replicability/modernbert_xtr_contrastive_multik128-256-512 with sentence-transformers:
from pylate import models queries = [ "Which planet is known as the Red Planet?", "What is the largest planet in our solar system?", ] documents = [ ["Mars is the Red Planet.", "Venus is Earth's twin."], ["Jupiter is the largest planet.", "Saturn has rings."], ] model = models.ColBERT(model_name_or_path="xtr-replicability/modernbert_xtr_contrastive_multik128-256-512") queries_emb = model.encode(queries, is_query=True) docs_emb = model.encode(documents, is_query=False) - Notebooks
- Google Colab
- Kaggle
tags:
- ColBERT
- PyLate
- sentence-transformers
- sentence-similarity
- feature-extraction
- generated_from_trainer
- dataset_size:10000000
- loss:Contrastive
base_model: answerdotai/ModernBERT-base
datasets:
- bclavie/msmarco-10m-triplets
pipeline_tag: sentence-similarity
library_name: PyLate
metrics:
- MaxSim_accuracy@1
- MaxSim_accuracy@3
- MaxSim_accuracy@5
- MaxSim_accuracy@10
- MaxSim_precision@1
- MaxSim_precision@3
- MaxSim_precision@5
- MaxSim_precision@10
- MaxSim_recall@1
- MaxSim_recall@3
- MaxSim_recall@5
- MaxSim_recall@10
- MaxSim_ndcg@10
- MaxSim_mrr@10
- MaxSim_map@100
model-index:
- name: PyLate model based on answerdotai/ModernBERT-base
results:
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoClimateFEVER
type: NanoClimateFEVER
metrics:
- type: MaxSim_accuracy@1
value: 0.24
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.5
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.56
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.72
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.24
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.18
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.136
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.09
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.12
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.23166666666666663
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.26733333333333337
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.3456666666666666
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.28659074634439036
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.38899206349206344
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.22237332831909778
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoDBPedia
type: NanoDBPedia
metrics:
- type: MaxSim_accuracy@1
value: 0.72
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.88
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.92
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.92
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.72
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.6333333333333333
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.608
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.514
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.08698943062762281
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.15785394286086044
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.25560775585402196
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.35140662490283503
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.6310474103595507
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.8023333333333333
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.4766459270446468
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoFEVER
type: NanoFEVER
metrics:
- type: MaxSim_accuracy@1
value: 0.84
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.98
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 1
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 1
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.84
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.33333333333333326
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.20799999999999996
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.10599999999999998
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.7866666666666667
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.9266666666666667
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.9566666666666667
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.9633333333333333
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.8973997659405684
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.905
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.8618368368368369
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoFiQA2018
type: NanoFiQA2018
metrics:
- type: MaxSim_accuracy@1
value: 0.46
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.66
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.74
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.78
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.46
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.32666666666666666
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.244
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.14
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.2685793650793651
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.47251587301587306
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.5722857142857143
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.6081190476190477
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.5290995192750131
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.579
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.4613817582717077
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoHotpotQA
type: NanoHotpotQA
metrics:
- type: MaxSim_accuracy@1
value: 0.88
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.96
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.96
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.98
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.88
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.49999999999999983
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.32799999999999996
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.17199999999999996
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.44
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.75
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.82
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.86
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.8190215640428958
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.9195238095238095
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.7542864635927516
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoMSMARCO
type: NanoMSMARCO
metrics:
- type: MaxSim_accuracy@1
value: 0.46
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.74
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.76
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.86
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.46
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.24666666666666665
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.15200000000000002
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.08599999999999998
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.46
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.74
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.76
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.86
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.6683749348060735
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.6068333333333333
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.6153476502857308
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoNFCorpus
type: NanoNFCorpus
metrics:
- type: MaxSim_accuracy@1
value: 0.46
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.52
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.54
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.56
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.46
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.3533333333333333
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.29600000000000004
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.23600000000000002
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.043124364328590487
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.07617110540472594
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.0888523411805491
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.10700228981811344
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.30567453687850876
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.494
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.13042780558280634
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoNQ
type: NanoNQ
metrics:
- type: MaxSim_accuracy@1
value: 0.38
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.66
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.78
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.9
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.38
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.22
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.15600000000000003
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.092
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.37
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.62
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.73
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.84
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.6117132890493197
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.5528888888888889
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.5368699134199134
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoQuoraRetrieval
type: NanoQuoraRetrieval
metrics:
- type: MaxSim_accuracy@1
value: 0.9
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.98
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 1
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 1
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.9
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.3933333333333333
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.24799999999999997
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.13599999999999998
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.7973333333333333
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.9386666666666668
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.9593333333333334
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.9933333333333334
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.9500644303763519
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.945
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.9287460317460318
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoSCIDOCS
type: NanoSCIDOCS
metrics:
- type: MaxSim_accuracy@1
value: 0.42
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.62
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.7
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.82
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.42
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.30666666666666664
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.24
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.172
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.08866666666666667
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.19066666666666662
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.24666666666666665
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.3526666666666666
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.34178587115776565
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.5458571428571429
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.254228684034207
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoArguAna
type: NanoArguAna
metrics:
- type: MaxSim_accuracy@1
value: 0.14
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.48
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.66
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.82
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.14
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.15999999999999998
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.132
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.08199999999999999
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.14
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.48
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.66
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.82
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.46517990763149614
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.3529603174603174
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.3567092878593359
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoSciFact
type: NanoSciFact
metrics:
- type: MaxSim_accuracy@1
value: 0.66
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.76
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.8
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.84
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.66
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.2733333333333333
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.176
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.09399999999999999
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.625
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.745
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.79
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.83
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.7435557624884191
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.720888888888889
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.7171289121218996
name: Maxsim Map@100
- task:
type: py-late-information-retrieval
name: Py Late Information Retrieval
dataset:
name: NanoTouche2020
type: NanoTouche2020
metrics:
- type: MaxSim_accuracy@1
value: 0.7346938775510204
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.9591836734693877
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.9591836734693877
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.9591836734693877
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.7346938775510204
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.7006802721088434
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.6285714285714286
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.5122448979591837
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.05035830341896132
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.14458823716252048
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.20896761189253432
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.3315966017926261
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.5870329612095947
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.8401360544217688
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.4348641866623347
name: Maxsim Map@100
- task:
type: nano-beir
name: Nano BEIR
dataset:
name: NanoBEIR mean
type: NanoBEIR_mean
metrics:
- type: MaxSim_accuracy@1
value: 0.5611302982731554
name: Maxsim Accuracy@1
- type: MaxSim_accuracy@3
value: 0.7460910518053375
name: Maxsim Accuracy@3
- type: MaxSim_accuracy@5
value: 0.7983987441130298
name: Maxsim Accuracy@5
- type: MaxSim_accuracy@10
value: 0.8583987441130299
name: Maxsim Accuracy@10
- type: MaxSim_precision@1
value: 0.5611302982731554
name: Maxsim Precision@1
- type: MaxSim_precision@3
value: 0.3559497645211931
name: Maxsim Precision@3
- type: MaxSim_precision@5
value: 0.2732747252747253
name: Maxsim Precision@5
- type: MaxSim_precision@10
value: 0.18709576138147568
name: Maxsim Precision@10
- type: MaxSim_recall@1
value: 0.3289783177016312
name: Maxsim Recall@1
- type: MaxSim_recall@3
value: 0.4979842942392806
name: Maxsim Recall@3
- type: MaxSim_recall@5
value: 0.5627471864009862
name: Maxsim Recall@5
- type: MaxSim_recall@10
value: 0.6356249664717402
name: Maxsim Recall@10
- type: MaxSim_ndcg@10
value: 0.6028108230430728
name: Maxsim Ndcg@10
- type: MaxSim_mrr@10
value: 0.6656472178615036
name: Maxsim Mrr@10
- type: MaxSim_map@100
value: 0.519295906598254
name: Maxsim Map@100
PyLate model based on answerdotai/ModernBERT-base
This is a PyLate model finetuned from answerdotai/ModernBERT-base on the msmarco-10m-triplets dataset. It maps sentences & paragraphs to sequences of 128-dimensional dense vectors and can be used for semantic textual similarity using the MaxSim operator.
Model Details
Model Description
- Model Type: PyLate model
- Base model: answerdotai/ModernBERT-base
- Document Length: 512 tokens
- Query Length: 32 tokens
- Output Dimensionality: 128 tokens
- Similarity Function: MaxSim
- Training Dataset:
Model Sources
- Documentation: PyLate Documentation
- Repository: PyLate on GitHub
- Hugging Face: PyLate models on Hugging Face
Full Model Architecture
ColBERT(
(0): Transformer({'max_seq_length': 512, 'do_lower_case': False, 'architecture': 'ModernBertModel'})
(1): Dense({'in_features': 768, 'out_features': 128, 'bias': False, 'activation_function': 'torch.nn.modules.linear.Identity', 'use_residual': False})
)
Usage
First install the PyLate library:
pip install -U pylate
Retrieval
Use this model with PyLate to index and retrieve documents. The index uses FastPLAID for efficient similarity search.
Indexing documents
Load the ColBERT model and initialize the PLAID index, then encode and index your documents:
from pylate import indexes, models, retrieve
# Step 1: Load the ColBERT model
model = models.ColBERT(
model_name_or_path="pylate_model_id",
)
# Step 2: Initialize the PLAID index
index = indexes.PLAID(
index_folder="pylate-index",
index_name="index",
override=True, # This overwrites the existing index if any
)
# Step 3: Encode the documents
documents_ids = ["1", "2", "3"]
documents = ["document 1 text", "document 2 text", "document 3 text"]
documents_embeddings = model.encode(
documents,
batch_size=32,
is_query=False, # Ensure that it is set to False to indicate that these are documents, not queries
show_progress_bar=True,
)
# Step 4: Add document embeddings to the index by providing embeddings and corresponding ids
index.add_documents(
documents_ids=documents_ids,
documents_embeddings=documents_embeddings,
)
Note that you do not have to recreate the index and encode the documents every time. Once you have created an index and added the documents, you can re-use the index later by loading it:
# To load an index, simply instantiate it with the correct folder/name and without overriding it
index = indexes.PLAID(
index_folder="pylate-index",
index_name="index",
)
Retrieving top-k documents for queries
Once the documents are indexed, you can retrieve the top-k most relevant documents for a given set of queries. To do so, initialize the ColBERT retriever with the index you want to search in, encode the queries and then retrieve the top-k documents to get the top matches ids and relevance scores:
# Step 1: Initialize the ColBERT retriever
retriever = retrieve.ColBERT(index=index)
# Step 2: Encode the queries
queries_embeddings = model.encode(
["query for document 3", "query for document 1"],
batch_size=32,
is_query=True, # # Ensure that it is set to False to indicate that these are queries
show_progress_bar=True,
)
# Step 3: Retrieve top-k documents
scores = retriever.retrieve(
queries_embeddings=queries_embeddings,
k=10, # Retrieve the top 10 matches for each query
)
Reranking
If you only want to use the ColBERT model to perform reranking on top of your first-stage retrieval pipeline without building an index, you can simply use rank function and pass the queries and documents to rerank:
from pylate import rank, models
queries = [
"query A",
"query B",
]
documents = [
["document A", "document B"],
["document 1", "document C", "document B"],
]
documents_ids = [
[1, 2],
[1, 3, 2],
]
model = models.ColBERT(
model_name_or_path="pylate_model_id",
)
queries_embeddings = model.encode(
queries,
is_query=True,
)
documents_embeddings = model.encode(
documents,
is_query=False,
)
reranked_documents = rank.rerank(
documents_ids=documents_ids,
queries_embeddings=queries_embeddings,
documents_embeddings=documents_embeddings,
)
Evaluation
Metrics
Py Late Information Retrieval
- Dataset:
['NanoClimateFEVER', 'NanoDBPedia', 'NanoFEVER', 'NanoFiQA2018', 'NanoHotpotQA', 'NanoMSMARCO', 'NanoNFCorpus', 'NanoNQ', 'NanoQuoraRetrieval', 'NanoSCIDOCS', 'NanoArguAna', 'NanoSciFact', 'NanoTouche2020'] - Evaluated with
pylate.evaluation.pylate_information_retrieval_evaluator.PyLateInformationRetrievalEvaluator
| Metric | NanoClimateFEVER | NanoDBPedia | NanoFEVER | NanoFiQA2018 | NanoHotpotQA | NanoMSMARCO | NanoNFCorpus | NanoNQ | NanoQuoraRetrieval | NanoSCIDOCS | NanoArguAna | NanoSciFact | NanoTouche2020 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| MaxSim_accuracy@1 | 0.24 | 0.72 | 0.84 | 0.46 | 0.88 | 0.46 | 0.46 | 0.38 | 0.9 | 0.42 | 0.14 | 0.66 | 0.7347 |
| MaxSim_accuracy@3 | 0.5 | 0.88 | 0.98 | 0.66 | 0.96 | 0.74 | 0.52 | 0.66 | 0.98 | 0.62 | 0.48 | 0.76 | 0.9592 |
| MaxSim_accuracy@5 | 0.56 | 0.92 | 1.0 | 0.74 | 0.96 | 0.76 | 0.54 | 0.78 | 1.0 | 0.7 | 0.66 | 0.8 | 0.9592 |
| MaxSim_accuracy@10 | 0.72 | 0.92 | 1.0 | 0.78 | 0.98 | 0.86 | 0.56 | 0.9 | 1.0 | 0.82 | 0.82 | 0.84 | 0.9592 |
| MaxSim_precision@1 | 0.24 | 0.72 | 0.84 | 0.46 | 0.88 | 0.46 | 0.46 | 0.38 | 0.9 | 0.42 | 0.14 | 0.66 | 0.7347 |
| MaxSim_precision@3 | 0.18 | 0.6333 | 0.3333 | 0.3267 | 0.5 | 0.2467 | 0.3533 | 0.22 | 0.3933 | 0.3067 | 0.16 | 0.2733 | 0.7007 |
| MaxSim_precision@5 | 0.136 | 0.608 | 0.208 | 0.244 | 0.328 | 0.152 | 0.296 | 0.156 | 0.248 | 0.24 | 0.132 | 0.176 | 0.6286 |
| MaxSim_precision@10 | 0.09 | 0.514 | 0.106 | 0.14 | 0.172 | 0.086 | 0.236 | 0.092 | 0.136 | 0.172 | 0.082 | 0.094 | 0.5122 |
| MaxSim_recall@1 | 0.12 | 0.087 | 0.7867 | 0.2686 | 0.44 | 0.46 | 0.0431 | 0.37 | 0.7973 | 0.0887 | 0.14 | 0.625 | 0.0504 |
| MaxSim_recall@3 | 0.2317 | 0.1579 | 0.9267 | 0.4725 | 0.75 | 0.74 | 0.0762 | 0.62 | 0.9387 | 0.1907 | 0.48 | 0.745 | 0.1446 |
| MaxSim_recall@5 | 0.2673 | 0.2556 | 0.9567 | 0.5723 | 0.82 | 0.76 | 0.0889 | 0.73 | 0.9593 | 0.2467 | 0.66 | 0.79 | 0.209 |
| MaxSim_recall@10 | 0.3457 | 0.3514 | 0.9633 | 0.6081 | 0.86 | 0.86 | 0.107 | 0.84 | 0.9933 | 0.3527 | 0.82 | 0.83 | 0.3316 |
| MaxSim_ndcg@10 | 0.2866 | 0.631 | 0.8974 | 0.5291 | 0.819 | 0.6684 | 0.3057 | 0.6117 | 0.9501 | 0.3418 | 0.4652 | 0.7436 | 0.587 |
| MaxSim_mrr@10 | 0.389 | 0.8023 | 0.905 | 0.579 | 0.9195 | 0.6068 | 0.494 | 0.5529 | 0.945 | 0.5459 | 0.353 | 0.7209 | 0.8401 |
| MaxSim_map@100 | 0.2224 | 0.4766 | 0.8618 | 0.4614 | 0.7543 | 0.6153 | 0.1304 | 0.5369 | 0.9287 | 0.2542 | 0.3567 | 0.7171 | 0.4349 |
Nano BEIR
- Dataset:
NanoBEIR_mean - Evaluated with
pylate.evaluation.nano_beir_evaluator.NanoBEIREvaluator
| Metric | Value |
|---|---|
| MaxSim_accuracy@1 | 0.5611 |
| MaxSim_accuracy@3 | 0.7461 |
| MaxSim_accuracy@5 | 0.7984 |
| MaxSim_accuracy@10 | 0.8584 |
| MaxSim_precision@1 | 0.5611 |
| MaxSim_precision@3 | 0.3559 |
| MaxSim_precision@5 | 0.2733 |
| MaxSim_precision@10 | 0.1871 |
| MaxSim_recall@1 | 0.329 |
| MaxSim_recall@3 | 0.498 |
| MaxSim_recall@5 | 0.5627 |
| MaxSim_recall@10 | 0.6356 |
| MaxSim_ndcg@10 | 0.6028 |
| MaxSim_mrr@10 | 0.6656 |
| MaxSim_map@100 | 0.5193 |
Training Details
Training Dataset
msmarco-10m-triplets
- Dataset: msmarco-10m-triplets at 8c5139a
- Size: 10,000,000 training samples
- Columns:
query,positive, andnegative - Approximate statistics based on the first 1000 samples:
query positive negative type string string string details - min: 4 tokens
- mean: 9.31 tokens
- max: 31 tokens
- min: 20 tokens
- mean: 31.95 tokens
- max: 32 tokens
- min: 18 tokens
- mean: 31.91 tokens
- max: 32 tokens
- Samples:
query positive negative the most important factor that influences k+ secretion is __________.The regulation of K+ distribution between the intracellular and extracellular space is referred to as internal K+ balance. The most important factors regulating this movement under normal conditions are insulin and catecholamines (1).They are both also important for secretion and flow of bile: 1 Cholecystokinin: The name of this hormone describes its effect on the biliary system-cholecysto = gallbladder and kinin = movement. 2 Secretin: This hormone is secreted in response to acid in the duodenum.how much did the mackinac bridge cost to buildThe cost to design the project was $3,500,000 (Steinman Company). The cost to construct the bridge was $70, 268,500. Two primary contractors were hired to build the bridge: American Bridge for superstructure - $44,532,900; and Merritt-Chapman and Scott of New York for the foundations - $25,735,600.When your child needs a dental tooth bridge, you need to know the average cost so you can factor the price into your budget. Several factors affect the price of a bridge, which can run between $700 to $1,500 per tooth. If you have insurance or your child is covered by Medicaid, part of the cost may be covered.when do concussion symptoms appearThen you can get advice on what to do next. For milder symptoms, the doctor may recommend rest and ask you to watch your child closely for changes, such as a headache that gets worse. Symptoms of a concussion don't always show up right away, and can develop within 24 to 72 hours after an injury.Concussion: A traumatic injury to soft tissue, usually the brain, as a result of a violent blow, shaking, or spinning. A brain concussion can cause immediate but temporary impairment of brain functions, such as thinking, vision, equilibrium, and consciousness. After a person has had a concussion, he or she is at increased risk for recurrence. Moreover, after a person has several concussions, less of a blow can cause injury, and the person can require more time to recover. - Loss:
pylate.losses.contrastive.Contrastive
Training Hyperparameters
Non-Default Hyperparameters
eval_strategy: stepsper_device_train_batch_size: 64learning_rate: 3e-05max_steps: 50000fp16: Truedataloader_drop_last: Truedataloader_num_workers: 8ddp_find_unused_parameters: Falsetorch_compile: Truetorch_compile_backend: inductoreval_on_start: True
All Hyperparameters
Click to expand
overwrite_output_dir: Falsedo_predict: Falseeval_strategy: stepsprediction_loss_only: Trueper_device_train_batch_size: 64per_device_eval_batch_size: 8per_gpu_train_batch_size: Noneper_gpu_eval_batch_size: Nonegradient_accumulation_steps: 1eval_accumulation_steps: Nonetorch_empty_cache_steps: Nonelearning_rate: 3e-05weight_decay: 0.0adam_beta1: 0.9adam_beta2: 0.999adam_epsilon: 1e-08max_grad_norm: 1.0num_train_epochs: 3.0max_steps: 50000lr_scheduler_type: linearlr_scheduler_kwargs: {}warmup_ratio: 0.0warmup_steps: 0log_level: passivelog_level_replica: warninglog_on_each_node: Truelogging_nan_inf_filter: Truesave_safetensors: Truesave_on_each_node: Falsesave_only_model: Falserestore_callback_states_from_checkpoint: Falseno_cuda: Falseuse_cpu: Falseuse_mps_device: Falseseed: 42data_seed: Nonejit_mode_eval: Falseuse_ipex: Falsebf16: Falsefp16: Truefp16_opt_level: O1half_precision_backend: autobf16_full_eval: Falsefp16_full_eval: Falsetf32: Nonelocal_rank: 0ddp_backend: Nonetpu_num_cores: Nonetpu_metrics_debug: Falsedebug: []dataloader_drop_last: Truedataloader_num_workers: 8dataloader_prefetch_factor: Nonepast_index: -1disable_tqdm: Falseremove_unused_columns: Truelabel_names: Noneload_best_model_at_end: Falseignore_data_skip: Falsefsdp: []fsdp_min_num_params: 0fsdp_config: {'min_num_params': 0, 'xla': False, 'xla_fsdp_v2': False, 'xla_fsdp_grad_ckpt': False}fsdp_transformer_layer_cls_to_wrap: Noneaccelerator_config: {'split_batches': False, 'dispatch_batches': None, 'even_batches': True, 'use_seedable_sampler': True, 'non_blocking': False, 'gradient_accumulation_kwargs': None}parallelism_config: Nonedeepspeed: Nonelabel_smoothing_factor: 0.0optim: adamw_torchoptim_args: Noneadafactor: Falsegroup_by_length: Falselength_column_name: lengthddp_find_unused_parameters: Falseddp_bucket_cap_mb: Noneddp_broadcast_buffers: Falsedataloader_pin_memory: Truedataloader_persistent_workers: Falseskip_memory_metrics: Trueuse_legacy_prediction_loop: Falsepush_to_hub: Falseresume_from_checkpoint: Nonehub_model_id: Nonehub_strategy: every_savehub_private_repo: Nonehub_always_push: Falsehub_revision: Nonegradient_checkpointing: Falsegradient_checkpointing_kwargs: Noneinclude_inputs_for_metrics: Falseinclude_for_metrics: []eval_do_concat_batches: Truefp16_backend: autopush_to_hub_model_id: Nonepush_to_hub_organization: Nonemp_parameters:auto_find_batch_size: Falsefull_determinism: Falsetorchdynamo: Noneray_scope: lastddp_timeout: 1800torch_compile: Truetorch_compile_backend: inductortorch_compile_mode: Noneinclude_tokens_per_second: Falseinclude_num_input_tokens_seen: Falseneftune_noise_alpha: Noneoptim_target_modules: Nonebatch_eval_metrics: Falseeval_on_start: Trueuse_liger_kernel: Falseliger_kernel_config: Noneeval_use_gather_object: Falseaverage_tokens_across_devices: Falseprompts: Nonebatch_sampler: batch_samplermulti_dataset_batch_sampler: proportionalrouter_mapping: {}learning_rate_mapping: {}