MPNet base with Landmark Pooling trained on GooAQ triplets using CachedMultipleNegativesRankingLoss with GradCache
This is a sentence-transformers model finetuned from microsoft/mpnet-base on the gooaq dataset. It maps sentences & paragraphs to a 768-dimensional dense vector space and can be used for semantic textual similarity, semantic search, paraphrase mining, text classification, clustering, and more.
Model Details
Model Description
- Model Type: Sentence Transformer
- Base model: microsoft/mpnet-base
- Maximum Sequence Length: 512 tokens
- Output Dimensionality: 768 dimensions
- Similarity Function: Cosine Similarity
- Training Dataset:
- Language: en
- License: apache-2.0
Model Sources
Full Model Architecture
SentenceTransformer(
(0): Transformer({'max_seq_length': 512, 'do_lower_case': False, 'splitter_type': 'variable', 'splitter_granularity': [32, 64, 128, 256], 'lmk_token_id': 2, 'architecture': 'MPNetModel'})
(1): Pooling({'word_embedding_dimension': 768, 'pooling_mode_cls_token': False, 'pooling_mode_mean_tokens': False, 'pooling_mode_max_tokens': False, 'pooling_mode_mean_sqrt_len_tokens': False, 'pooling_mode_weightedmean_tokens': False, 'pooling_mode_lasttoken': False, 'pooling_mode_lmk': True, 'lmk_token_id': -1, 'include_prompt': True})
(2): Normalize()
)
Usage
Direct Usage (Sentence Transformers)
First install the Sentence Transformers library:
pip install -U sentence-transformers
Then you can load this model and run inference.
from sentence_transformers import SentenceTransformer
model = SentenceTransformer("tomaarsen/mpnet-base-gooaq-cmnrl-1024bs-lmk")
queries = [
"how to change timezone on facebook?",
]
documents = [
"You can change the timezone used in the Custom Facebook Feed plugin by just going to the plugin's Typography page, scrolling down to the Post Date section and setting the Timezone option so that it is the same as your timezone of your Facebook events.",
'When there are no double bonds between carbon atoms, it is called a saturated fatty acid (the carbon chain is "saturated" with hydrogen atoms). If there is one double bond between carbon atoms, it is called a monounsaturated fatty acid, and if there are 2 or more double bonds it is called polyunsaturated fatty acid.',
'clonazePAM zaleplon Using clonazePAM together with zaleplon may increase side effects such as dizziness, drowsiness, confusion, and difficulty concentrating. Some people, especially the elderly, may also experience impairment in thinking, judgment, and motor coordination.',
]
query_embeddings = model.encode_query(queries)
document_embeddings = model.encode_document(documents)
print(query_embeddings.shape, document_embeddings.shape)
similarities = model.similarity(query_embeddings, document_embeddings)
print(similarities)
Evaluation
Metrics
Information Retrieval
| Metric |
Value |
| cosine_accuracy@1 |
0.7551 |
| cosine_accuracy@3 |
0.8917 |
| cosine_accuracy@5 |
0.9311 |
| cosine_accuracy@10 |
0.9631 |
| cosine_precision@1 |
0.7551 |
| cosine_precision@3 |
0.2972 |
| cosine_precision@5 |
0.1862 |
| cosine_precision@10 |
0.0963 |
| cosine_recall@1 |
0.7551 |
| cosine_recall@3 |
0.8917 |
| cosine_recall@5 |
0.9311 |
| cosine_recall@10 |
0.9631 |
| cosine_ndcg@10 |
0.8631 |
| cosine_mrr@10 |
0.8306 |
| cosine_map@100 |
0.8323 |
Training Details
Training Dataset
gooaq
- Dataset: gooaq at b089f72
- Size: 90,000 training samples
- Columns:
question and answer
- Approximate statistics based on the first 1000 samples:
|
question |
answer |
| type |
string |
string |
| details |
- min: 8 tokens
- mean: 11.83 tokens
- max: 20 tokens
|
- min: 15 tokens
- mean: 60.84 tokens
- max: 181 tokens
|
- Samples:
| question |
answer |
how long does halifax take to transfer mortgage funds? |
Bear in mind that the speed of application will vary depending on your own personal circumstances and the lender's present day-to-day performance. In some cases, applications can be approved by the lender within 24 hours, while some can take weeks or even months. |
can you get a false pregnancy test? |
In very rare cases, you can have a false-positive result. This means you're not pregnant but the test says you are. You could have a false-positive result if you have blood or protein in your pee. Certain drugs, such as tranquilizers, anticonvulsants, hypnotics, and fertility drugs, could cause false-positive results. |
are ahead of its time? |
Definition of ahead of one's/its time : too advanced or modern to be understood or appreciated during the time when one lives or works As a director, he was ahead of his time. |
- Loss:
CachedMultipleNegativesRankingLoss with these parameters:{
"scale": 20.0,
"similarity_fct": "cos_sim",
"mini_batch_size": 64,
"gather_across_devices": false
}
Evaluation Dataset
gooaq
- Dataset: gooaq at b089f72
- Size: 10,000 evaluation samples
- Columns:
question and answer
- Approximate statistics based on the first 1000 samples:
|
question |
answer |
| type |
string |
string |
| details |
- min: 8 tokens
- mean: 11.93 tokens
- max: 25 tokens
|
- min: 14 tokens
- mean: 61.27 tokens
- max: 130 tokens
|
- Samples:
| question |
answer |
should you take ibuprofen with high blood pressure? |
In general, people with high blood pressure should use acetaminophen or possibly aspirin for over-the-counter pain relief. Unless your health care provider has said it's OK, you should not use ibuprofen, ketoprofen, or naproxen sodium. If aspirin or acetaminophen doesn't help with your pain, call your doctor. |
how old do you have to be to work in sc? |
The general minimum age of employment for South Carolina youth is 14, although the state allows younger children who are performers to work in show business. If their families are agricultural workers, children younger than age 14 may also participate in farm labor. |
how to write a topic proposal for a research paper? |
['Write down the main topic of your paper. ... ', 'Write two or three short sentences under the main topic that explain why you chose that topic. ... ', 'Write a thesis sentence that states the angle and purpose of your research paper. ... ', 'List the items you will cover in the body of the paper that support your thesis statement.'] |
- Loss:
CachedMultipleNegativesRankingLoss with these parameters:{
"scale": 20.0,
"similarity_fct": "cos_sim",
"mini_batch_size": 64,
"gather_across_devices": false
}
Training Hyperparameters
Non-Default Hyperparameters
eval_strategy: steps
per_device_train_batch_size: 1024
per_device_eval_batch_size: 1024
learning_rate: 8e-05
num_train_epochs: 1
warmup_ratio: 0.1
warmup_steps: 0.1
bf16: True
batch_sampler: no_duplicates
All Hyperparameters
Click to expand
do_predict: False
eval_strategy: steps
prediction_loss_only: True
per_device_train_batch_size: 1024
per_device_eval_batch_size: 1024
gradient_accumulation_steps: 1
eval_accumulation_steps: None
torch_empty_cache_steps: None
learning_rate: 8e-05
weight_decay: 0.0
adam_beta1: 0.9
adam_beta2: 0.999
adam_epsilon: 1e-08
max_grad_norm: 1.0
num_train_epochs: 1
max_steps: -1
lr_scheduler_type: linear
lr_scheduler_kwargs: None
warmup_ratio: 0.1
warmup_steps: 0.1
log_level: passive
log_level_replica: warning
log_on_each_node: True
logging_nan_inf_filter: True
enable_jit_checkpoint: False
save_on_each_node: False
save_only_model: False
restore_callback_states_from_checkpoint: False
use_cpu: False
seed: 42
data_seed: None
bf16: True
fp16: False
bf16_full_eval: False
fp16_full_eval: False
tf32: None
local_rank: -1
ddp_backend: None
debug: []
dataloader_drop_last: False
dataloader_num_workers: 0
dataloader_prefetch_factor: None
disable_tqdm: False
remove_unused_columns: True
label_names: None
load_best_model_at_end: False
ignore_data_skip: False
fsdp: []
fsdp_config: {'min_num_params': 0, 'xla': False, 'xla_fsdp_v2': False, 'xla_fsdp_grad_ckpt': False}
accelerator_config: {'split_batches': False, 'dispatch_batches': None, 'even_batches': True, 'use_seedable_sampler': True, 'non_blocking': False, 'gradient_accumulation_kwargs': None}
parallelism_config: None
deepspeed: None
label_smoothing_factor: 0.0
optim: adamw_torch_fused
optim_args: None
group_by_length: False
length_column_name: length
project: huggingface
trackio_space_id: trackio
ddp_find_unused_parameters: None
ddp_bucket_cap_mb: None
ddp_broadcast_buffers: False
dataloader_pin_memory: True
dataloader_persistent_workers: False
skip_memory_metrics: True
push_to_hub: False
resume_from_checkpoint: None
hub_model_id: None
hub_strategy: every_save
hub_private_repo: None
hub_always_push: False
hub_revision: None
gradient_checkpointing: False
gradient_checkpointing_kwargs: None
include_for_metrics: []
eval_do_concat_batches: True
auto_find_batch_size: False
full_determinism: False
ddp_timeout: 1800
torch_compile: False
torch_compile_backend: None
torch_compile_mode: None
include_num_input_tokens_seen: no
neftune_noise_alpha: None
optim_target_modules: None
batch_eval_metrics: False
eval_on_start: False
use_liger_kernel: False
liger_kernel_config: None
eval_use_gather_object: False
average_tokens_across_devices: True
use_cache: False
prompts: None
batch_sampler: no_duplicates
multi_dataset_batch_sampler: proportional
router_mapping: {}
learning_rate_mapping: {}
Training Logs
| Epoch |
Step |
Training Loss |
Validation Loss |
gooaq-dev_cosine_ndcg@10 |
| -1 |
-1 |
- |
- |
0.2172 |
| 0.0114 |
1 |
6.4055 |
- |
- |
| 0.0568 |
5 |
5.8504 |
- |
- |
| 0.1023 |
9 |
- |
1.2436 |
0.6087 |
| 0.1136 |
10 |
2.5387 |
- |
- |
| 0.1705 |
15 |
1.2297 |
- |
- |
| 0.2045 |
18 |
- |
0.5426 |
0.7804 |
| 0.2273 |
20 |
0.8311 |
- |
- |
| 0.2841 |
25 |
0.6543 |
- |
- |
| 0.3068 |
27 |
- |
0.3952 |
0.8216 |
| 0.3409 |
30 |
0.5505 |
- |
- |
| 0.3977 |
35 |
0.5029 |
- |
- |
| 0.4091 |
36 |
- |
0.3372 |
0.8357 |
| 0.4545 |
40 |
0.4531 |
- |
- |
| 0.5114 |
45 |
0.4427 |
0.3017 |
0.8459 |
| 0.5682 |
50 |
0.4324 |
- |
- |
| 0.6136 |
54 |
- |
0.2836 |
0.8523 |
| 0.625 |
55 |
0.4050 |
- |
- |
| 0.6818 |
60 |
0.3767 |
- |
- |
| 0.7159 |
63 |
- |
0.2707 |
0.8570 |
| 0.7386 |
65 |
0.3537 |
- |
- |
| 0.7955 |
70 |
0.3847 |
- |
- |
| 0.8182 |
72 |
- |
0.2588 |
0.8624 |
| 0.8523 |
75 |
0.3622 |
- |
- |
| 0.9091 |
80 |
0.3540 |
- |
- |
| 0.9205 |
81 |
- |
0.2538 |
0.8634 |
| 0.9659 |
85 |
0.3505 |
- |
- |
| -1 |
-1 |
- |
- |
0.8631 |
Framework Versions
- Python: 3.11.6
- Sentence Transformers: 5.3.0.dev0
- Transformers: 5.0.1.dev0
- PyTorch: 2.10.0+cu126
- Accelerate: 1.12.0
- Datasets: 4.3.0
- Tokenizers: 0.22.2
Citation
BibTeX
Sentence Transformers
@inproceedings{reimers-2019-sentence-bert,
title = "Sentence-BERT: Sentence Embeddings using Siamese BERT-Networks",
author = "Reimers, Nils and Gurevych, Iryna",
booktitle = "Proceedings of the 2019 Conference on Empirical Methods in Natural Language Processing",
month = "11",
year = "2019",
publisher = "Association for Computational Linguistics",
url = "https://arxiv.org/abs/1908.10084",
}
CachedMultipleNegativesRankingLoss
@misc{gao2021scaling,
title={Scaling Deep Contrastive Learning Batch Size under Memory Limited Setup},
author={Luyu Gao and Yunyi Zhang and Jiawei Han and Jamie Callan},
year={2021},
eprint={2101.06983},
archivePrefix={arXiv},
primaryClass={cs.LG}
}