Sentence-BERT: Sentence Embeddings using Siamese BERT-Networks
Paper
โข 1908.10084 โข Published
โข 12
This is a Cross Encoder model finetuned from MatMulMan/araelectra-base-discriminator-tydi-tafseer-pairs using the sentence-transformers library. It computes scores for pairs of texts, which can be used for text reranking and semantic search.
First install the Sentence Transformers library:
pip install -U sentence-transformers
Then you can load this model and run inference.
from sentence_transformers import CrossEncoder
# Download from the ๐ค Hub
model = CrossEncoder("cross_encoder_model_id")
# Get scores for pairs of texts
pairs = [
['ูุนูู ูุง ุชุฑูุ ุงูู
ูุธููู ุงููู ุจูุดุชุบููุง ูู ูุณู
ุงูุงู
ุชุญุงูุงุช ุจุงูุฌุงู
ุนุฉุ ูููู
ูุงู
ููู
ุฅุฌุงุฒุฉ ููู
ุฐุงูุฑุฉ ูุจู ุงูุงู
ุชุญุงูุงุชุ (ุชุฑููุฒ ุนูู ูุณู
ุงูุงู
ุชุญุงูุงุช ูุชุญุฏูุฏ ุงููุชุฑุฉ ุงูุฒู
ููุฉ)ุ', 'ุงููุงููู ุญุฏุฏ 7 ุฃูุงู
ููุท ู
ู ุชูุฏูู
ุงูุงุณุชูุงูุฉ ุนูุดุงู ุงูุนุงู
ู ููุฏุฑ ูุชุฑุงุฌุน ุนููุง. ูู ุนุฏุช ุงูู
ุฏุฉ ุฏู ุจุฏูู ู
ุง ูุทูุจ ุงูุชุฑุงุฌุนุ ุจุชุนุชุจุฑ ุงุณุชูุงูุชู ููุงุฆูุฉ.'],
['ู
ู
ูู ุฃุนุฑู ุงููุงููู ุงูุฌุฏูุฏ ุจููููุ ุณูู ุงูู
ุนุงุด ูู ุดุฑูุงุช ุงููุทุงุน ุงูุฎุงุต ุจูู ูุงู
ุฏูููุชูุ', 'ุงูู
ูุงูุฃุฉ ูู ู
ุจูุบ ุซุงุจุช ุจูุงุฎุฏู ุงูุนุงู
ู ุนู ุงูุณููู ุงููู ุงุดุชุบููุง. ุฃู
ุง ุงูุชุนููุถุ ููู ู
ุจูุบ ุฅุถุงูู ุจูุชุฏูุน ูู ุญุตูุช ูู ู
ุดููุฉ ุฒู ูุตู ุชุนุณูู ุฃู ุฅุตุงุจุฉ. ุงูุงุชููู ู
ุฎุชูููู ูู ุงูุณุจุจ ูุทุฑููุฉ ุงูุญุณุงุจ.'],
['ุฃูุตู ู
ุจูุบ ู
ู
ูู ูุชุฎุตู
ู
ู ุงูู
ุฑุชุจ ุฃุฏ ุฅููุ (ุฃุฏ ุฅูู = ูู
)', 'ุฃูุตู ุญุฏ ููุฎุตู
ู
ู ุงูู
ุฑุชุจ ูู 25% ู
ู ุตุงูู ุงูู
ุฑุชุจุ ุฒู ู
ุง ุงููุงููู ุญุฏุฏุ ุฅูุง ุฅุฐุง ูู ุญูู
ูุถุงุฆู ุฒู ุงููููุฉ.'],
['ู
ู
ูู ุฃุนุฑู ู
ุงุฐุง ุงููุฑู ุงูุฌููุฑู ุจูู ุนูุฏ ุงูุฏูุงู
ุงููู ููู ุชุงุฑูุฎ ููุงูุฉ ูุนูุฏ ุงูุนู
ู ุงูู
ูุชูุญ ุงููู ู
ููุด ุชุงุฑูุฎ ููุงูุฉุ', 'ุฃูููุ ุงูุฃู
ุงูู
ุฑุถุนุฉ ู
ู ุญููุง ููู
ููุง "ูุชุฑุชูู ุฑุถุงุนุฉ" ูู ูุงุญุฏุฉ ูุต ุณุงุนุฉุ ุฃู ุชูุฏุฑ ุชุฏู
ุฌูู
ูุณุงุนุฉ ูุงู
ูุฉ. ูุฏู ุจูุณุชู
ุฑ ูู
ุฏุฉ 24 ุดูุฑ ู
ู ููู
ุงูููุงุฏุฉ.'],
['ุจุงููุณุจุฉ ููุงุดุชุฑุงูุงุชุ ุงูุนุงู
ู ุจูุชุญู
ู ุฌุฒุก ุฃุฏ ุฅูู ู
ููุง ูุตุงุญุจ ุงูุนู
ู ุจูุชุญู
ู ุงูุฌุฒุก ุงูุจุงููุ ุนุงูุฒูู ูุนุฑู ุชูุฒูุน ุงูู
ุณุงูู
ุงุช ุจุงูุถุจุท.', 'ุฃูููุ ุงููุงููู ุจูุทูุจ ุชุดููู ูุฌูุฉ ููุณูุงู
ุฉ ูุงูุตุญุฉ ุงูู
ูููุฉ ูู ุงูู
ูุดุขุช ุงููุจูุฑุฉุ ุฎุตูุตูุง ุงููู ูููุง ุฃูุชุฑ ู
ู ุนุฏุฏ ู
ุนูู ู
ู ุงูุนู
ุงู. ุงููุฌูุฉ ุฏู ุจุชุชุงุจุน ุชุทุจูู ุฅุฌุฑุงุกุงุช ุงูุณูุงู
ุฉ.'],
]
scores = model.predict(pairs)
print(scores.shape)
# (5,)
# Or rank different texts based on similarity to a single text
ranks = model.rank(
'ูุนูู ูุง ุชุฑูุ ุงูู
ูุธููู ุงููู ุจูุดุชุบููุง ูู ูุณู
ุงูุงู
ุชุญุงูุงุช ุจุงูุฌุงู
ุนุฉุ ูููู
ูุงู
ููู
ุฅุฌุงุฒุฉ ููู
ุฐุงูุฑุฉ ูุจู ุงูุงู
ุชุญุงูุงุชุ (ุชุฑููุฒ ุนูู ูุณู
ุงูุงู
ุชุญุงูุงุช ูุชุญุฏูุฏ ุงููุชุฑุฉ ุงูุฒู
ููุฉ)ุ',
[
'ุงููุงููู ุญุฏุฏ 7 ุฃูุงู
ููุท ู
ู ุชูุฏูู
ุงูุงุณุชูุงูุฉ ุนูุดุงู ุงูุนุงู
ู ููุฏุฑ ูุชุฑุงุฌุน ุนููุง. ูู ุนุฏุช ุงูู
ุฏุฉ ุฏู ุจุฏูู ู
ุง ูุทูุจ ุงูุชุฑุงุฌุนุ ุจุชุนุชุจุฑ ุงุณุชูุงูุชู ููุงุฆูุฉ.',
'ุงูู
ูุงูุฃุฉ ูู ู
ุจูุบ ุซุงุจุช ุจูุงุฎุฏู ุงูุนุงู
ู ุนู ุงูุณููู ุงููู ุงุดุชุบููุง. ุฃู
ุง ุงูุชุนููุถุ ููู ู
ุจูุบ ุฅุถุงูู ุจูุชุฏูุน ูู ุญุตูุช ูู ู
ุดููุฉ ุฒู ูุตู ุชุนุณูู ุฃู ุฅุตุงุจุฉ. ุงูุงุชููู ู
ุฎุชูููู ูู ุงูุณุจุจ ูุทุฑููุฉ ุงูุญุณุงุจ.',
'ุฃูุตู ุญุฏ ููุฎุตู
ู
ู ุงูู
ุฑุชุจ ูู 25% ู
ู ุตุงูู ุงูู
ุฑุชุจุ ุฒู ู
ุง ุงููุงููู ุญุฏุฏุ ุฅูุง ุฅุฐุง ูู ุญูู
ูุถุงุฆู ุฒู ุงููููุฉ.',
'ุฃูููุ ุงูุฃู
ุงูู
ุฑุถุนุฉ ู
ู ุญููุง ููู
ููุง "ูุชุฑุชูู ุฑุถุงุนุฉ" ูู ูุงุญุฏุฉ ูุต ุณุงุนุฉุ ุฃู ุชูุฏุฑ ุชุฏู
ุฌูู
ูุณุงุนุฉ ูุงู
ูุฉ. ูุฏู ุจูุณุชู
ุฑ ูู
ุฏุฉ 24 ุดูุฑ ู
ู ููู
ุงูููุงุฏุฉ.',
'ุฃูููุ ุงููุงููู ุจูุทูุจ ุชุดููู ูุฌูุฉ ููุณูุงู
ุฉ ูุงูุตุญุฉ ุงูู
ูููุฉ ูู ุงูู
ูุดุขุช ุงููุจูุฑุฉุ ุฎุตูุตูุง ุงููู ูููุง ุฃูุชุฑ ู
ู ุนุฏุฏ ู
ุนูู ู
ู ุงูุนู
ุงู. ุงููุฌูุฉ ุฏู ุจุชุชุงุจุน ุชุทุจูู ุฅุฌุฑุงุกุงุช ุงูุณูุงู
ุฉ.',
]
)
# [{'corpus_id': ..., 'score': ...}, {'corpus_id': ..., 'score': ...}, ...]
sentence_0, sentence_1, and label| sentence_0 | sentence_1 | label | |
|---|---|---|---|
| type | string | string | float |
| details |
|
|
|
| sentence_0 | sentence_1 | label |
|---|---|---|
ูุนูู ูุง ุชุฑูุ ุงูู
ูุธููู ุงููู ุจูุดุชุบููุง ูู ูุณู
ุงูุงู
ุชุญุงูุงุช ุจุงูุฌุงู
ุนุฉุ ูููู
ูุงู
ููู
ุฅุฌุงุฒุฉ ููู
ุฐุงูุฑุฉ ูุจู ุงูุงู
ุชุญุงูุงุชุ (ุชุฑููุฒ ุนูู ูุณู
ุงูุงู
ุชุญุงูุงุช ูุชุญุฏูุฏ ุงููุชุฑุฉ ุงูุฒู
ููุฉ)ุ |
ุงููุงููู ุญุฏุฏ 7 ุฃูุงู
ููุท ู
ู ุชูุฏูู
ุงูุงุณุชูุงูุฉ ุนูุดุงู ุงูุนุงู
ู ููุฏุฑ ูุชุฑุงุฌุน ุนููุง. ูู ุนุฏุช ุงูู
ุฏุฉ ุฏู ุจุฏูู ู
ุง ูุทูุจ ุงูุชุฑุงุฌุนุ ุจุชุนุชุจุฑ ุงุณุชูุงูุชู ููุงุฆูุฉ. |
0.0 |
ู
ู
ูู ุฃุนุฑู ุงููุงููู ุงูุฌุฏูุฏ ุจููููุ ุณูู ุงูู
ุนุงุด ูู ุดุฑูุงุช ุงููุทุงุน ุงูุฎุงุต ุจูู ูุงู
ุฏูููุชูุ |
ุงูู
ูุงูุฃุฉ ูู ู
ุจูุบ ุซุงุจุช ุจูุงุฎุฏู ุงูุนุงู
ู ุนู ุงูุณููู ุงููู ุงุดุชุบููุง. ุฃู
ุง ุงูุชุนููุถุ ููู ู
ุจูุบ ุฅุถุงูู ุจูุชุฏูุน ูู ุญุตูุช ูู ู
ุดููุฉ ุฒู ูุตู ุชุนุณูู ุฃู ุฅุตุงุจุฉ. ุงูุงุชููู ู
ุฎุชูููู ูู ุงูุณุจุจ ูุทุฑููุฉ ุงูุญุณุงุจ. |
0.0 |
ุฃูุตู ู
ุจูุบ ู
ู
ูู ูุชุฎุตู
ู
ู ุงูู
ุฑุชุจ ุฃุฏ ุฅููุ (ุฃุฏ ุฅูู = ูู
) |
ุฃูุตู ุญุฏ ููุฎุตู
ู
ู ุงูู
ุฑุชุจ ูู 25% ู
ู ุตุงูู ุงูู
ุฑุชุจุ ุฒู ู
ุง ุงููุงููู ุญุฏุฏุ ุฅูุง ุฅุฐุง ูู ุญูู
ูุถุงุฆู ุฒู ุงููููุฉ. |
1.0 |
BinaryCrossEntropyLoss with these parameters:{
"activation_fn": "torch.nn.modules.linear.Identity",
"pos_weight": null
}
per_device_train_batch_size: 16per_device_eval_batch_size: 16num_train_epochs: 4disable_tqdm: Trueoverwrite_output_dir: Falsedo_predict: Falseeval_strategy: noprediction_loss_only: Trueper_device_train_batch_size: 16per_device_eval_batch_size: 16per_gpu_train_batch_size: Noneper_gpu_eval_batch_size: Nonegradient_accumulation_steps: 1eval_accumulation_steps: Nonetorch_empty_cache_steps: Nonelearning_rate: 5e-05weight_decay: 0.0adam_beta1: 0.9adam_beta2: 0.999adam_epsilon: 1e-08max_grad_norm: 1num_train_epochs: 4max_steps: -1lr_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: Falsefp16_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: Falsedataloader_num_workers: 0dataloader_prefetch_factor: Nonepast_index: -1disable_tqdm: Trueremove_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}deepspeed: Nonelabel_smoothing_factor: 0.0optim: adamw_torchoptim_args: Noneadafactor: Falsegroup_by_length: Falselength_column_name: lengthddp_find_unused_parameters: Noneddp_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: Falsetorch_compile_backend: Nonetorch_compile_mode: Noneinclude_tokens_per_second: Falseinclude_num_input_tokens_seen: Falseneftune_noise_alpha: Noneoptim_target_modules: Nonebatch_eval_metrics: Falseeval_on_start: Falseuse_liger_kernel: Falseliger_kernel_config: Noneeval_use_gather_object: Falseaverage_tokens_across_devices: Falseprompts: Nonebatch_sampler: batch_samplermulti_dataset_batch_sampler: proportional| Epoch | Step | Training Loss |
|---|---|---|
| 0.0460 | 500 | 0.5364 |
| 0.0920 | 1000 | 0.2314 |
| 0.1380 | 1500 | 0.151 |
| 0.1840 | 2000 | 0.1318 |
| 0.2300 | 2500 | 0.1201 |
| 0.2760 | 3000 | 0.1132 |
| 0.3220 | 3500 | 0.0935 |
| 0.3680 | 4000 | 0.082 |
| 0.4140 | 4500 | 0.0817 |
| 0.4600 | 5000 | 0.0804 |
| 0.5060 | 5500 | 0.0726 |
| 0.5520 | 6000 | 0.0662 |
| 0.5980 | 6500 | 0.0632 |
| 0.6440 | 7000 | 0.0579 |
| 0.6900 | 7500 | 0.0558 |
| 0.7360 | 8000 | 0.0448 |
| 0.7820 | 8500 | 0.0626 |
| 0.8280 | 9000 | 0.0419 |
| 0.8740 | 9500 | 0.0495 |
| 0.9200 | 10000 | 0.047 |
| 0.9660 | 10500 | 0.0447 |
| 1.0120 | 11000 | 0.0376 |
| 1.0580 | 11500 | 0.0342 |
| 1.1040 | 12000 | 0.0404 |
| 1.1500 | 12500 | 0.0364 |
| 1.1960 | 13000 | 0.0329 |
| 1.2420 | 13500 | 0.0373 |
| 1.2879 | 14000 | 0.0407 |
| 1.3339 | 14500 | 0.0298 |
| 1.3799 | 15000 | 0.0319 |
| 1.4259 | 15500 | 0.0361 |
| 1.4719 | 16000 | 0.0423 |
| 1.5179 | 16500 | 0.0349 |
| 1.5639 | 17000 | 0.0304 |
| 1.6099 | 17500 | 0.0291 |
| 1.6559 | 18000 | 0.0277 |
| 1.7019 | 18500 | 0.0288 |
| 1.7479 | 19000 | 0.0285 |
| 1.7939 | 19500 | 0.0288 |
| 1.8399 | 20000 | 0.0268 |
| 1.8859 | 20500 | 0.027 |
| 1.9319 | 21000 | 0.0215 |
| 1.9779 | 21500 | 0.0214 |
| 2.0239 | 22000 | 0.0263 |
| 2.0699 | 22500 | 0.0192 |
| 2.1159 | 23000 | 0.0242 |
| 2.1619 | 23500 | 0.0286 |
| 2.2079 | 24000 | 0.0144 |
| 2.2539 | 24500 | 0.0283 |
| 2.2999 | 25000 | 0.0209 |
| 2.3459 | 25500 | 0.0188 |
| 2.3919 | 26000 | 0.0211 |
| 2.4379 | 26500 | 0.0264 |
| 2.4839 | 27000 | 0.0245 |
| 2.5299 | 27500 | 0.023 |
| 2.5759 | 28000 | 0.0211 |
| 2.6219 | 28500 | 0.0248 |
| 2.6679 | 29000 | 0.0201 |
| 2.7139 | 29500 | 0.0194 |
| 2.7599 | 30000 | 0.0176 |
| 2.8059 | 30500 | 0.0194 |
| 2.8519 | 31000 | 0.0165 |
| 2.8979 | 31500 | 0.0209 |
| 2.9439 | 32000 | 0.0178 |
| 2.9899 | 32500 | 0.0166 |
| 3.0359 | 33000 | 0.0207 |
| 3.0819 | 33500 | 0.0143 |
| 3.1279 | 34000 | 0.0114 |
| 3.1739 | 34500 | 0.0208 |
| 3.2199 | 35000 | 0.0143 |
| 3.2659 | 35500 | 0.0221 |
| 3.3119 | 36000 | 0.0218 |
| 3.3579 | 36500 | 0.0144 |
| 3.4039 | 37000 | 0.0201 |
| 3.4499 | 37500 | 0.0172 |
| 3.4959 | 38000 | 0.0177 |
| 3.5419 | 38500 | 0.0129 |
| 3.5879 | 39000 | 0.013 |
| 3.6339 | 39500 | 0.016 |
| 3.6799 | 40000 | 0.0137 |
| 3.7259 | 40500 | 0.0171 |
| 3.7718 | 41000 | 0.0201 |
| 3.8178 | 41500 | 0.0166 |
| 3.8638 | 42000 | 0.0097 |
| 3.9098 | 42500 | 0.0146 |
| 3.9558 | 43000 | 0.0182 |
@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",
}