Scaling Deep Contrastive Learning Batch Size under Memory Limited Setup
Paper • 2101.06983 • Published • 2
How to use ktcapraz/embeddinggemma-german_qna-checkpoint-500 with sentence-transformers:
from sentence_transformers import SentenceTransformer
model = SentenceTransformer("ktcapraz/embeddinggemma-german_qna-checkpoint-500")
sentences = [
"Was ist aus der früheren Division \"Passive Sicherheitstechnik\" geworden?",
"Adania Shiblis Roman \"Eine Nebensache\" erschien im Original vor sieben Jahren und auf Deutsch vor zwei Jahren.",
"Der Bundesvorsitzende des Fahrgastverbandes Pro Bahn, Detlef Neuß, rät Reisenden, ausreichend Getränke, Obst und Verpflegung mitzuführen, da Bordrestaurants nicht immer garantiert geöffnet sein werden. Es wird auch empfohlen, Bücher oder Unterhaltungselektronik sowie Spiele für Kinder mitzunehmen, um die Reisezeit angenehmer zu gestalten. Die Bahn empfiehlt zudem dringend, Sitzplätze zu reservieren, da die Züge stark gebucht sind, und rät, auf weniger ausgelastete Fahrten auszuweichen, falls möglich.",
"Die frühere Division \"Passive Sicherheitstechnik\", die Airbags und Sicherheitsgurte herstellt, wurde aus den Konzernstrukturen herausgelöst und firmiert eigenständig als Tochter unter dem Namen ZF Lifetec. Für diesen Bereich sucht ZF einen Partner, erwägt aber auch einen Börsengang."
]
embeddings = model.encode(sentences)
similarities = model.similarity(embeddings, embeddings)
print(similarities.shape)
# [4, 4]This is a sentence-transformers model finetuned from google/embeddinggemma-300m on the german-qna-full 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.
SentenceTransformer(
(0): Transformer({'max_seq_length': 2048, 'do_lower_case': False, 'architecture': 'Gemma3TextModel'})
(1): Pooling({'word_embedding_dimension': 768, 'pooling_mode_cls_token': False, 'pooling_mode_mean_tokens': True, 'pooling_mode_max_tokens': False, 'pooling_mode_mean_sqrt_len_tokens': False, 'pooling_mode_weightedmean_tokens': False, 'pooling_mode_lasttoken': False, 'include_prompt': True})
(2): Dense({'in_features': 768, 'out_features': 3072, 'bias': False, 'activation_function': 'torch.nn.modules.linear.Identity'})
(3): Dense({'in_features': 3072, 'out_features': 768, 'bias': False, 'activation_function': 'torch.nn.modules.linear.Identity'})
(4): Normalize()
)
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
# Download from the 🤗 Hub
model = SentenceTransformer("ktcapraz/embeddinggemma-german_qna-checkpoint-500")
# Run inference
queries = [
"Was ist das R\u00fcckhaltebecken Siefenwang und wann wurde es geplant?",
]
documents = [
'Das Rückhaltebecken Siefenwang ist ein Projekt zum Hochwasserschutz, benannt nach einem Ortsteil von Dinkelscherben. Die Pläne dafür stammen aus den Jahren 2000 und 2005. Es soll bis zu 1,25 Millionen Kubikmeter Wasser fassen und eine Überflutungsfläche von bis zu 136 Hektar haben. Die Gesamtkosten belaufen sich auf 9,5 Millionen Euro.',
'Der parteilose Ex-Minister Volker Wissing warnt vor einem Scheitern der schwarz-roten Koalition aufgrund innerer Spannungen, die sich auch in der Gesellschaft widerspiegeln. Er verweist auf die gescheiterte Wahl von Frauke Brosius-Gersdorf zur Verfassungsrichterin und die verfehlte Mehrheit für Friedrich Merz als Zeichen mangelnder Disziplin.',
'Der Kakaopreis hat sich innerhalb eines Jahres mehr als verdoppelt, von rund 4000 auf über 9200 Euro pro Tonne. Hauptursachen sind Missernten in Westafrika, insbesondere an der Elfenbeinküste, die für über ein Drittel der weltweiten Kakaoproduktion verantwortlich ist. Schlechte Wetterbedingungen und kranke Bäume haben dort im zweiten Jahr in Folge zu erheblichen Ernteausfällen geführt, was die weltweiten Kakaobestände auf ein 20-Jahres-Tief sinken ließ.',
]
query_embeddings = model.encode_query(queries)
document_embeddings = model.encode_document(documents)
print(query_embeddings.shape, document_embeddings.shape)
# [1, 768] [3, 768]
# Get the similarity scores for the embeddings
similarities = model.similarity(query_embeddings, document_embeddings)
print(similarities)
# tensor([[ 0.6243, 0.0075, -0.1137]])
germanqna-evalInformationRetrievalEvaluator| Metric | Value |
|---|---|
| cosine_accuracy@1 | 0.7827 |
| cosine_accuracy@3 | 0.902 |
| cosine_accuracy@5 | 0.9312 |
| cosine_accuracy@10 | 0.9563 |
| cosine_precision@1 | 0.7827 |
| cosine_precision@3 | 0.3007 |
| cosine_precision@5 | 0.1862 |
| cosine_precision@10 | 0.0956 |
| cosine_recall@1 | 0.7827 |
| cosine_recall@3 | 0.902 |
| cosine_recall@5 | 0.9312 |
| cosine_recall@10 | 0.9563 |
| cosine_ndcg@10 | 0.8741 |
| cosine_mrr@10 | 0.8472 |
| cosine_map@100 | 0.849 |
frage and antwort| frage | antwort | |
|---|---|---|
| type | string | string |
| details |
|
|
| frage | antwort |
|---|---|
Welche konkreten Maßnahmen für E-Autos sind im Koalitionsvertrag von Union und SPD geplant? |
Geplant sind eine steuerliche Begünstigung für Dienstwagen als E-Autos, eine Sonderabschreibung für E-Fahrzeuge und eine Verlängerung der Kfz-Steuerbefreiung für Elektroautos bis 2035. Zudem soll der Ausbau des Ladenetzes beschleunigt werden. |
Welche Kritik übte Bundeskanzler Olaf Scholz an der CDU und Friedrich Merz? |
Bundeskanzler Olaf Scholz warf der CDU unter ihrem Kanzlerkandidaten Friedrich Merz vor, sich sehr weit von der Linie der ehemaligen Bundeskanzlerin Angela Merkel entfernt zu haben. Er sagte, die CDU habe sich von ihren sozialen Werten abgewandt und warnte vor ihrer konservativen Politik, insbesondere in der Rentenpolitik. |
Welche Koalitionspräferenz äußerte Aiwanger? |
Aiwanger äußerte die Hoffnung auf eine "bürgerliche Koalition der Mitte" im Bundestag, idealerweise mit seiner Partei. Er zeigte sich besorgt über eine mögliche Koalition aus Schwarz-Rot-Grün, da diese die Probleme des Landes seiner Meinung nach nicht lösen würde. Sollte seine Partei nicht in Berlin vertreten sein, plane er, in Bayern zu bleiben. |
CachedMultipleNegativesRankingLoss with these parameters:{
"scale": 20.0,
"similarity_fct": "cos_sim",
"mini_batch_size": 8,
"gather_across_devices": false
}
frage and antwort| frage | antwort | |
|---|---|---|
| type | string | string |
| details |
|
|
| frage | antwort |
|---|---|
Warum haben Griechenland und Italien viele Lobbyisten für fossile Brennstoffe zur COP29 entsandt? |
Griechenland und Italien sind die größten Abnehmer von aserbaidschanischem Gas. Beide Länder sind auf die südeuropäische Erdgaspipeline angewiesen, die Aserbaidschan über die Türkei mit Europa verbindet und eine Kapazität von mindestens 10 Milliarden Kubikmetern Gas pro Jahr hat. Dies erklärt die hohe Präsenz von Lobbyisten für fossile Brennstoffe aus diesen Ländern. |
Welche Strafe erhielt der Angeklagte und warum? |
Der 29-jährige Angeklagte wurde zu fünfeinhalb Jahren Haft verurteilt. Die Strafkammer berücksichtigte sein Geständnis, kritisierte jedoch, dass er seinen Tatbeitrag herunterspielen wollte. Strafverschärfend wirkte, dass die Seniorin gefesselt zurückgelassen wurde und unter Todesangst litt. |
Wann werden die neuen Direktverbindungen zwischen Deutschland und Italien voraussichtlich starten? |
Die Direktverbindungen im Hochgeschwindigkeitszug von München nach Mailand und Rom sollen voraussichtlich ab Dezember 2026 starten. Zunächst wird es je eine Verbindung pro Tag geben, mit italienischen Frecciarossa-Zügen, die auch in Deutschland verkehren. |
CachedMultipleNegativesRankingLoss with these parameters:{
"scale": 20.0,
"similarity_fct": "cos_sim",
"mini_batch_size": 8,
"gather_across_devices": false
}
eval_strategy: stepsper_device_train_batch_size: 128per_device_eval_batch_size: 128learning_rate: 2e-05num_train_epochs: 1warmup_ratio: 0.1fp16: Trueprompts: {'frage': 'task: search result | query: ', 'antwort': 'title: none | text: '}batch_sampler: no_duplicatesoverwrite_output_dir: Falsedo_predict: Falseeval_strategy: stepsprediction_loss_only: Trueper_device_train_batch_size: 128per_device_eval_batch_size: 128per_gpu_train_batch_size: Noneper_gpu_eval_batch_size: Nonegradient_accumulation_steps: 1eval_accumulation_steps: Nonetorch_empty_cache_steps: Nonelearning_rate: 2e-05weight_decay: 0.0adam_beta1: 0.9adam_beta2: 0.999adam_epsilon: 1e-08max_grad_norm: 1.0num_train_epochs: 1max_steps: -1lr_scheduler_type: linearlr_scheduler_kwargs: {}warmup_ratio: 0.1warmup_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: Falsedataloader_num_workers: 0dataloader_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_torch_fusedoptim_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: {'frage': 'task: search result | query: ', 'antwort': 'title: none | text: '}batch_sampler: no_duplicatesmulti_dataset_batch_sampler: proportionalrouter_mapping: {}learning_rate_mapping: {}| Epoch | Step | Training Loss | Validation Loss | germanqna-eval_cosine_ndcg@10 |
|---|---|---|---|---|
| -1 | -1 | - | - | 0.6554 |
| 0.0342 | 20 | 0.4638 | - | - |
| 0.0684 | 40 | 0.125 | - | - |
| 0.1026 | 60 | 0.1045 | - | - |
| 0.1368 | 80 | 0.1135 | - | - |
| 0.1709 | 100 | 0.1174 | 0.1014 | 0.8230 |
| 0.2051 | 120 | 0.1047 | - | - |
| 0.2393 | 140 | 0.1092 | - | - |
| 0.2735 | 160 | 0.1067 | - | - |
| 0.3077 | 180 | 0.0822 | - | - |
| 0.3419 | 200 | 0.0809 | 0.0840 | 0.8315 |
| 0.3761 | 220 | 0.0767 | - | - |
| 0.4103 | 240 | 0.0841 | - | - |
| 0.4444 | 260 | 0.0654 | - | - |
| 0.4786 | 280 | 0.0771 | - | - |
| 0.5128 | 300 | 0.0843 | 0.0699 | 0.8462 |
| 0.5470 | 320 | 0.076 | - | - |
| 0.5812 | 340 | 0.0543 | - | - |
| 0.6154 | 360 | 0.0563 | - | - |
| 0.6496 | 380 | 0.0584 | - | - |
| 0.6838 | 400 | 0.053 | 0.0593 | 0.8596 |
| 0.7179 | 420 | 0.0525 | - | - |
| 0.7521 | 440 | 0.0625 | - | - |
| 0.7863 | 460 | 0.0544 | - | - |
| 0.8205 | 480 | 0.0537 | - | - |
| 0.8547 | 500 | 0.0651 | 0.0505 | 0.8741 |
@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",
}
@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}
}
Base model
google/embeddinggemma-300m