SPLADE BERT-tiny trained on Natural-Questions tuples

This is a SPLADE Sparse Encoder model trained on the natural-questions dataset using the sentence-transformers library. It maps sentences & paragraphs to a 30522-dimensional sparse vector space and can be used for semantic search and sparse retrieval.

This model was trained using train_script.py.

Model Details

Model Description

  • Model Type: SPLADE Sparse Encoder
  • Maximum Sequence Length: 512 tokens
  • Output Dimensionality: 30522 dimensions
  • Similarity Function: Dot Product
  • Training Dataset:
  • Language: en
  • License: apache-2.0

Model Sources

Full Model Architecture

SparseEncoder(
  (0): MLMTransformer({'max_seq_length': 512, 'do_lower_case': False}) with MLMTransformer model: BertForMaskedLM 
  (1): SpladePooling({'pooling_strategy': 'max', 'activation_function': 'relu', 'word_embedding_dimension': 30522})
)

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 SparseEncoder

# Download from the 🤗 Hub
model = SparseEncoder("sparse-encoder-testing/splade-bert-tiny-nq")
# Run inference
sentences = [
    'is send in the clowns from a musical',
    'Send In the Clowns "Send In the Clowns" is a song written by Stephen Sondheim for the 1973 musical A Little Night Music, an adaptation of Ingmar Bergman\'s film Smiles of a Summer Night. It is a ballad from Act Two, in which the character Desirée reflects on the ironies and disappointments of her life. Among other things, she looks back on an affair years earlier with the lawyer Fredrik, who was deeply in love with her but whose marriage proposals she had rejected. Meeting him after so long, she realizes she is in love with him and finally ready to marry him, but now it is he who rejects her: he is in an unconsummated marriage with a much younger woman. Desirée proposes marriage to rescue him from this situation, but he declines, citing his dedication to his bride. Reacting to his rejection, Desirée sings this song. The song is later reprised as a coda after Fredrik\'s young wife runs away with his son, and Fredrik is finally free to accept Desirée\'s offer.[1]',
    'The Suite Life on Deck The Suite Life on Deck is an American sitcom that aired on Disney Channel from September 26, 2008 to May 6, 2011. It is a sequel/spin-off of the Disney Channel Original Series The Suite Life of Zack & Cody. The series follows twin brothers Zack and Cody Martin and hotel heiress London Tipton in a new setting, the SS Tipton, where they attend classes at "Seven Seas High School" and meet Bailey Pickett while Mr. Moseby manages the ship. The ship travels around the world to nations such as Italy, France, Greece, India, Sweden and the United Kingdom where the characters experience different cultures, adventures, and situations.[1]',
]
embeddings = model.encode(sentences)
print(embeddings.shape)
# (3, 30522)

# Get the similarity scores for the embeddings
similarities = model.similarity(embeddings, embeddings)
print(similarities.shape)
# [3, 3]

Evaluation

Metrics

Sparse Information Retrieval

Metric NanoMSMARCO NanoNFCorpus NanoNQ
dot_accuracy@1 0.22 0.24 0.1
dot_accuracy@3 0.36 0.38 0.24
dot_accuracy@5 0.4 0.48 0.34
dot_accuracy@10 0.54 0.58 0.44
dot_precision@1 0.22 0.24 0.1
dot_precision@3 0.12 0.2133 0.08
dot_precision@5 0.08 0.184 0.068
dot_precision@10 0.054 0.16 0.046
dot_recall@1 0.22 0.0191 0.09
dot_recall@3 0.36 0.0365 0.22
dot_recall@5 0.4 0.0433 0.32
dot_recall@10 0.54 0.0624 0.41
dot_ndcg@10 0.3571 0.1825 0.2484
dot_mrr@10 0.3011 0.3309 0.2051
dot_map@100 0.316 0.064 0.2087

Sparse Nano BEIR

  • Dataset: NanoBEIR_mean
  • Evaluated with SparseNanoBEIREvaluator with these parameters:
    {
        "dataset_names": [
            "msmarco",
            "nfcorpus",
            "nq"
        ]
    }
    
Metric Value
dot_accuracy@1 0.1867
dot_accuracy@3 0.3267
dot_accuracy@5 0.4067
dot_accuracy@10 0.52
dot_precision@1 0.1867
dot_precision@3 0.1378
dot_precision@5 0.1107
dot_precision@10 0.0867
dot_recall@1 0.1097
dot_recall@3 0.2055
dot_recall@5 0.2544
dot_recall@10 0.3375
dot_ndcg@10 0.2627
dot_mrr@10 0.2791
dot_map@100 0.1962

Training Details

Training Dataset

natural-questions

  • Dataset: natural-questions at f9e894e
  • Size: 99,000 training samples
  • Columns: query and answer
  • Approximate statistics based on the first 1000 samples:
    query answer
    type string string
    details
    • min: 29 characters
    • mean: 46.96 characters
    • max: 93 characters
    • min: 10 characters
    • mean: 582.13 characters
    • max: 2141 characters
  • Samples:
    query answer
    who played the father in papa don't preach Alex McArthur Alex McArthur (born March 6, 1957) is an American actor.
    where was the location of the battle of hastings Battle of Hastings The Battle of Hastings[a] was fought on 14 October 1066 between the Norman-French army of William, the Duke of Normandy, and an English army under the Anglo-Saxon King Harold Godwinson, beginning the Norman conquest of England. It took place approximately 7 miles (11 kilometres) northwest of Hastings, close to the present-day town of Battle, East Sussex, and was a decisive Norman victory.
    how many puppies can a dog give birth to Canine reproduction The largest litter size to date was set by a Neapolitan Mastiff in Manea, Cambridgeshire, UK on November 29, 2004; the litter was 24 puppies.[22]
  • Loss: SpladeLoss with these parameters:
    {'loss': SparseMultipleNegativesRankingLoss(
      (model): SparseEncoder(
        (0): MLMTransformer({'max_seq_length': 512, 'do_lower_case': False}) with MLMTransformer model: BertForMaskedLM 
        (1): SpladePooling({'pooling_strategy': 'max', 'activation_function': 'relu', 'word_embedding_dimension': 30522})
      )
      (cross_entropy_loss): CrossEntropyLoss()
    ), 'lambda_corpus': 3e-05, 'lambda_query': 5e-05, 'corpus_regularizer': FlopsLoss(
      (model): SparseEncoder(
        (0): MLMTransformer({'max_seq_length': 512, 'do_lower_case': False}) with MLMTransformer model: BertForMaskedLM 
        (1): SpladePooling({'pooling_strategy': 'max', 'activation_function': 'relu', 'word_embedding_dimension': 30522})
      )
    ), 'query_regularizer': FlopsLoss(
      (model): SparseEncoder(
        (0): MLMTransformer({'max_seq_length': 512, 'do_lower_case': False}) with MLMTransformer model: BertForMaskedLM 
        (1): SpladePooling({'pooling_strategy': 'max', 'activation_function': 'relu', 'word_embedding_dimension': 30522})
      )
    )}
    

Evaluation Dataset

natural-questions

  • Dataset: natural-questions at f9e894e
  • Size: 1,000 evaluation samples
  • Columns: query and answer
  • Approximate statistics based on the first 1000 samples:
    query answer
    type string string
    details
    • min: 30 characters
    • mean: 47.2 characters
    • max: 96 characters
    • min: 58 characters
    • mean: 598.96 characters
    • max: 2480 characters
  • Samples:
    query answer
    where is the tiber river located in italy Tiber The Tiber (/ˈtaɪbər/, Latin: Tiberis,[1] Italian: Tevere [ˈteːvere])[2] is the third-longest river in Italy, rising in the Apennine Mountains in Emilia-Romagna and flowing 406 kilometres (252 mi) through Tuscany, Umbria and Lazio, where it is joined by the river Aniene, to the Tyrrhenian Sea, between Ostia and Fiumicino.[3] It drains a basin estimated at 17,375 square kilometres (6,709 sq mi). The river has achieved lasting fame as the main watercourse of the city of Rome, founded on its eastern banks.
    what kind of car does jay gatsby drive Jay Gatsby At the Buchanan home, Jordan Baker, Nick, Jay, and the Buchanans decide to visit New York City. Tom borrows Gatsby's yellow Rolls Royce to drive up to the city. On the way to New York City, Tom makes a detour at a gas station in "the Valley of Ashes", a run-down part of Long Island. The owner, George Wilson, shares his concern that his wife, Myrtle, may be having an affair. This unnerves Tom, who has been having an affair with Myrtle, and he leaves in a hurry.
    who sings if i can dream about you I Can Dream About You "I Can Dream About You" is a song performed by American singer Dan Hartman on the soundtrack album of the film Streets of Fire. Released in 1984 as a single from the soundtrack, and included on Hartman's album I Can Dream About You, it reached number 6 on the Billboard Hot 100.[1]
  • Loss: SpladeLoss with these parameters:
    {'loss': SparseMultipleNegativesRankingLoss(
      (model): SparseEncoder(
        (0): MLMTransformer({'max_seq_length': 512, 'do_lower_case': False}) with MLMTransformer model: BertForMaskedLM 
        (1): SpladePooling({'pooling_strategy': 'max', 'activation_function': 'relu', 'word_embedding_dimension': 30522})
      )
      (cross_entropy_loss): CrossEntropyLoss()
    ), 'lambda_corpus': 3e-05, 'lambda_query': 5e-05, 'corpus_regularizer': FlopsLoss(
      (model): SparseEncoder(
        (0): MLMTransformer({'max_seq_length': 512, 'do_lower_case': False}) with MLMTransformer model: BertForMaskedLM 
        (1): SpladePooling({'pooling_strategy': 'max', 'activation_function': 'relu', 'word_embedding_dimension': 30522})
      )
    ), 'query_regularizer': FlopsLoss(
      (model): SparseEncoder(
        (0): MLMTransformer({'max_seq_length': 512, 'do_lower_case': False}) with MLMTransformer model: BertForMaskedLM 
        (1): SpladePooling({'pooling_strategy': 'max', 'activation_function': 'relu', 'word_embedding_dimension': 30522})
      )
    )}
    

Training Hyperparameters

Non-Default Hyperparameters

  • eval_strategy: steps
  • per_device_train_batch_size: 64
  • per_device_eval_batch_size: 64
  • learning_rate: 2e-05
  • num_train_epochs: 1
  • warmup_ratio: 0.1
  • fp16: True
  • batch_sampler: no_duplicates

All Hyperparameters

Click to expand
  • overwrite_output_dir: False
  • do_predict: False
  • eval_strategy: steps
  • prediction_loss_only: True
  • per_device_train_batch_size: 64
  • per_device_eval_batch_size: 64
  • per_gpu_train_batch_size: None
  • per_gpu_eval_batch_size: None
  • gradient_accumulation_steps: 1
  • eval_accumulation_steps: None
  • torch_empty_cache_steps: None
  • learning_rate: 2e-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: {}
  • warmup_ratio: 0.1
  • warmup_steps: 0
  • log_level: passive
  • log_level_replica: warning
  • log_on_each_node: True
  • logging_nan_inf_filter: True
  • save_safetensors: True
  • save_on_each_node: False
  • save_only_model: False
  • restore_callback_states_from_checkpoint: False
  • no_cuda: False
  • use_cpu: False
  • use_mps_device: False
  • seed: 42
  • data_seed: None
  • jit_mode_eval: False
  • use_ipex: False
  • bf16: False
  • fp16: True
  • fp16_opt_level: O1
  • half_precision_backend: auto
  • bf16_full_eval: False
  • fp16_full_eval: False
  • tf32: None
  • local_rank: 0
  • ddp_backend: None
  • tpu_num_cores: None
  • tpu_metrics_debug: False
  • debug: []
  • dataloader_drop_last: False
  • dataloader_num_workers: 0
  • dataloader_prefetch_factor: None
  • past_index: -1
  • disable_tqdm: False
  • remove_unused_columns: True
  • label_names: None
  • load_best_model_at_end: False
  • ignore_data_skip: False
  • fsdp: []
  • fsdp_min_num_params: 0
  • fsdp_config: {'min_num_params': 0, 'xla': False, 'xla_fsdp_v2': False, 'xla_fsdp_grad_ckpt': False}
  • fsdp_transformer_layer_cls_to_wrap: None
  • accelerator_config: {'split_batches': False, 'dispatch_batches': None, 'even_batches': True, 'use_seedable_sampler': True, 'non_blocking': False, 'gradient_accumulation_kwargs': None}
  • deepspeed: None
  • label_smoothing_factor: 0.0
  • optim: adamw_torch
  • optim_args: None
  • adafactor: False
  • group_by_length: False
  • length_column_name: length
  • 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
  • use_legacy_prediction_loop: False
  • push_to_hub: False
  • resume_from_checkpoint: None
  • hub_model_id: None
  • hub_strategy: every_save
  • hub_private_repo: None
  • hub_always_push: False
  • gradient_checkpointing: False
  • gradient_checkpointing_kwargs: None
  • include_inputs_for_metrics: False
  • include_for_metrics: []
  • eval_do_concat_batches: True
  • fp16_backend: auto
  • push_to_hub_model_id: None
  • push_to_hub_organization: None
  • mp_parameters:
  • auto_find_batch_size: False
  • full_determinism: False
  • torchdynamo: None
  • ray_scope: last
  • ddp_timeout: 1800
  • torch_compile: False
  • torch_compile_backend: None
  • torch_compile_mode: None
  • dispatch_batches: None
  • split_batches: None
  • include_tokens_per_second: False
  • include_num_input_tokens_seen: False
  • neftune_noise_alpha: None
  • optim_target_modules: None
  • batch_eval_metrics: False
  • eval_on_start: False
  • use_liger_kernel: False
  • eval_use_gather_object: False
  • average_tokens_across_devices: False
  • prompts: None
  • batch_sampler: no_duplicates
  • multi_dataset_batch_sampler: proportional

Training Logs

Epoch Step Training Loss Validation Loss NanoMSMARCO_dot_ndcg@10 NanoNFCorpus_dot_ndcg@10 NanoNQ_dot_ndcg@10 NanoBEIR_mean_dot_ndcg@10
0.0129 20 1688.0217 - - - - -
0.0259 40 1557.9103 - - - - -
0.0388 60 1205.4178 - - - - -
0.0517 80 692.3048 - - - - -
0.0646 100 297.4244 - - - - -
0.0776 120 144.2392 - - - - -
0.0905 140 75.7438 - - - - -
0.1034 160 35.3506 - - - - -
0.1164 180 20.7095 - - - - -
0.1293 200 12.5446 6.9048 0.1524 0.0784 0.0574 0.0961
0.1422 220 8.1351 - - - - -
0.1551 240 6.1495 - - - - -
0.1681 260 4.4986 - - - - -
0.1810 280 3.5353 - - - - -
0.1939 300 3.0714 - - - - -
0.2069 320 2.4237 - - - - -
0.2198 340 1.9325 - - - - -
0.2327 360 1.8585 - - - - -
0.2456 380 1.491 - - - - -
0.2586 400 1.4503 0.8541 0.2248 0.1322 0.1045 0.1538
0.2715 420 1.3789 - - - - -
0.2844 440 1.3195 - - - - -
0.2973 460 1.198 - - - - -
0.3103 480 1.1532 - - - - -
0.3232 500 1.1931 - - - - -
0.3361 520 1.1989 - - - - -
0.3491 540 1.008 - - - - -
0.3620 560 0.9798 - - - - -
0.3749 580 0.9551 - - - - -
0.3878 600 0.9687 0.4356 0.2709 0.1438 0.1519 0.1888
0.4008 620 0.8331 - - - - -
0.4137 640 0.6947 - - - - -
0.4266 660 0.7768 - - - - -
0.4396 680 0.7101 - - - - -
0.4525 700 0.6902 - - - - -
0.4654 720 0.6766 - - - - -
0.4783 740 0.6001 - - - - -
0.4913 760 0.6231 - - - - -
0.5042 780 0.5953 - - - - -
0.5171 800 0.6846 0.3068 0.2958 0.1543 0.2071 0.2190
0.5301 820 0.5851 - - - - -
0.5430 840 0.579 - - - - -
0.5559 860 0.5659 - - - - -
0.5688 880 0.553 - - - - -
0.5818 900 0.4812 - - - - -
0.5947 920 0.5389 - - - - -
0.6076 940 0.4658 - - - - -
0.6206 960 0.5309 - - - - -
0.6335 980 0.484 - - - - -
0.6464 1000 0.4655 0.2527 0.3131 0.1660 0.2294 0.2362
0.6593 1020 0.5617 - - - - -
0.6723 1040 0.4786 - - - - -
0.6852 1060 0.5561 - - - - -
0.6981 1080 0.4869 - - - - -
0.7111 1100 0.5134 - - - - -
0.7240 1120 0.4702 - - - - -
0.7369 1140 0.4481 - - - - -
0.7498 1160 0.4758 - - - - -
0.7628 1180 0.4625 - - - - -
0.7757 1200 0.4733 0.2330 0.3498 0.1748 0.2357 0.2534
0.7886 1220 0.4527 - - - - -
0.8016 1240 0.4735 - - - - -
0.8145 1260 0.3818 - - - - -
0.8274 1280 0.4546 - - - - -
0.8403 1300 0.4724 - - - - -
0.8533 1320 0.4194 - - - - -
0.8662 1340 0.4352 - - - - -
0.8791 1360 0.3926 - - - - -
0.8920 1380 0.397 - - - - -
0.9050 1400 0.4157 0.2206 0.3558 0.1785 0.2495 0.2613
0.9179 1420 0.4426 - - - - -
0.9308 1440 0.4077 - - - - -
0.9438 1460 0.4227 - - - - -
0.9567 1480 0.4184 - - - - -
0.9696 1500 0.4838 - - - - -
0.9825 1520 0.4991 - - - - -
0.9955 1540 0.3889 - - - - -
-1 -1 - - 0.3571 0.1825 0.2484 0.2627

Environmental Impact

Carbon emissions were measured using CodeCarbon.

  • Energy Consumed: 0.027 kWh
  • Carbon Emitted: 0.011 kg of CO2
  • Hours Used: 0.082 hours

Training Hardware

  • On Cloud: No
  • GPU Model: 1 x NVIDIA GeForce RTX 3090
  • CPU Model: 13th Gen Intel(R) Core(TM) i7-13700K
  • RAM Size: 31.78 GB

Framework Versions

  • Python: 3.11.6
  • Sentence Transformers: 4.2.0.dev0
  • Transformers: 4.49.0
  • PyTorch: 2.6.0+cu124
  • Accelerate: 1.5.1
  • Datasets: 2.21.0
  • Tokenizers: 0.21.1

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",
}

SpladeLoss

@misc{formal2022distillationhardnegativesampling,
      title={From Distillation to Hard Negative Sampling: Making Sparse Neural IR Models More Effective},
      author={Thibault Formal and Carlos Lassance and Benjamin Piwowarski and Stéphane Clinchant},
      year={2022},
      eprint={2205.04733},
      archivePrefix={arXiv},
      primaryClass={cs.IR},
      url={https://arxiv.org/abs/2205.04733},
}
Downloads last month
132
Safetensors
Model size
4.42M params
Tensor type
F32
·
Inference Providers NEW
This model isn't deployed by any Inference Provider. 🙋 Ask for provider support

Dataset used to train sparse-encoder-testing/splade-bert-tiny-nq

Evaluation results