---
language:
- en
tags:
- sentence-transformers
- sentence-similarity
- feature-extraction
- generated_from_trainer
- dataset_size:557850
- loss:MultipleNegativesRankingLoss
base_model: answerdotai/ModernBERT-base
widget:
- source_sentence: A man dressed in yellow rescue gear walks in a field.
sentences:
- A person messes with some papers.
- The man is outdoors.
- The man is bowling.
- source_sentence: A young woman tennis player dressed in black carries many tennis
balls on her racket.
sentences:
- A young woman tennis player have many tennis balls.
- Two men are fishing.
- A young woman never wears white dress.
- source_sentence: An older gentleman enjoys a scenic stroll through the countryside.
sentences:
- A pirate boards the spaceship.
- A man walks the countryside.
- Girls standing at a whiteboard in front of class.
- source_sentence: A kid in a red and black coat is laying on his back in the snow
with his arm in the air and a red sled is next to him.
sentences:
- It is a cold day.
- A girl with her hands in a tub.
- The kid is on a sugar high.
- source_sentence: A young boy playing in the grass.
sentences:
- A woman in a restaurant.
- The boy is in the sand.
- There is a child in the grass.
datasets:
- sentence-transformers/all-nli
pipeline_tag: sentence-similarity
library_name: sentence-transformers
metrics:
- pearson_cosine
- spearman_cosine
model-index:
- name: SentenceTransformer based on answerdotai/ModernBERT-base
results:
- task:
type: semantic-similarity
name: Semantic Similarity
dataset:
name: sts dev
type: sts-dev
metrics:
- type: pearson_cosine
value: 0.7500819739694012
name: Pearson Cosine
- type: spearman_cosine
value: 0.7642960771418298
name: Spearman Cosine
- task:
type: semantic-similarity
name: Semantic Similarity
dataset:
name: sts test
type: sts-test
metrics:
- type: pearson_cosine
value: 0.6960229997567589
name: Pearson Cosine
- type: spearman_cosine
value: 0.689295049927495
name: Spearman Cosine
---
# SentenceTransformer based on answerdotai/ModernBERT-base
This is a [sentence-transformers](https://www.SBERT.net) model finetuned from [answerdotai/ModernBERT-base](https://huggingface.co/answerdotai/ModernBERT-base) on the [all-nli](https://huggingface.co/datasets/sentence-transformers/all-nli) 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:** [answerdotai/ModernBERT-base](https://huggingface.co/answerdotai/ModernBERT-base)
- **Maximum Sequence Length:** 8192 tokens
- **Output Dimensionality:** 768 dimensions
- **Similarity Function:** Cosine Similarity
- **Training Dataset:**
- [all-nli](https://huggingface.co/datasets/sentence-transformers/all-nli)
- **Language:** en
### Model Sources
- **Documentation:** [Sentence Transformers Documentation](https://sbert.net)
- **Repository:** [Sentence Transformers on GitHub](https://github.com/UKPLab/sentence-transformers)
- **Hugging Face:** [Sentence Transformers on Hugging Face](https://huggingface.co/models?library=sentence-transformers)
### Full Model Architecture
```
SentenceTransformer(
(0): Transformer({'max_seq_length': 8192, 'do_lower_case': False}) with Transformer model: ModernBertModel
(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})
)
```
## Test Evaluation
```python
# Run inference
sentences = [
"The cat sat on the windowsill, watching the birds outside.",
"Quantum computing has the potential to revolutionize cryptography.",
"A delicious homemade pizza requires fresh ingredients and patience.",
"The stock market fluctuates based on economic and political events.",
"Machine learning models improve with more diverse and high-quality data.",
"Quantum computing SOLVES many problems in stock market."
]
f_embeddings = finetuned_model.encode(sentences)
embeddings = model.encode(sentences)
similarities = model.similarity(embeddings, embeddings)
print(similarities)
# Get the similarity scores for the embeddings
f_similarities = finetuned_model.similarity(f_embeddings, f_embeddings)
print(f_similarities)
```
### Output
## Model Embedding Similarity Before and After Fine-Tuning
Below are the cosine similarity matrices before and after fine-tuning:
### **simlarity matrix Before and after Fine-Tuning:**
```python
tensor([[1.0000, 0.9052, 0.9002, 0.9080, 0.8959, 0.8925],
[0.9052, 1.0000, 0.8940, 0.9162, 0.9148, 0.9144],
[0.9002, 0.8940, 1.0000, 0.8995, 0.9033, 0.8940],
[0.9080, 0.9162, 0.8995, 1.0000, 0.9209, 0.9153],
[0.8959, 0.9148, 0.9033, 0.9209, 1.0000, 0.9142],
[0.8925, 0.9144, 0.8940, 0.9153, 0.9142, 1.0000]])
tensor([[1.0000, 0.3817, 0.3830, 0.3936, 0.3612, 0.4211],
[0.3817, 1.0000, 0.4469, 0.5501, 0.5800, 0.6188],
[0.3830, 0.4469, 1.0000, 0.4487, 0.4868, 0.5096],
[0.3936, 0.5501, 0.4487, 1.0000, 0.5981, 0.5528],
[0.3612, 0.5800, 0.4868, 0.5981, 1.0000, 0.5553],
[0.4211, 0.6188, 0.5096, 0.5528, 0.5553, 1.0000]])
```
## Model Embedding Visualization
Here is a heatmap of the embedding similarity matrix after fine-tuning:

## Usage
### Direct Usage (Sentence Transformers)
First install the Sentence Transformers library:
```bash
pip install -U sentence-transformers
```
Then you can load this model and run inference.
```python
from sentence_transformers import SentenceTransformer
# Download from the 🤗 Hub
model = SentenceTransformer("ravi259/ModernBERT-base-nli-v2")
# Run inference
sentences = [
'A young boy playing in the grass.',
'There is a child in the grass.',
'The boy is in the sand.',
]
embeddings = model.encode(sentences)
print(embeddings.shape)
# [3, 768]
# Get the similarity scores for the embeddings
similarities = model.similarity(embeddings, embeddings)
print(similarities.shape)
# [3, 3]
```
## Evaluation
### Metrics
#### Semantic Similarity
* Datasets: `sts-dev` and `sts-test`
* Evaluated with [EmbeddingSimilarityEvaluator
](https://sbert.net/docs/package_reference/sentence_transformer/evaluation.html#sentence_transformers.evaluation.EmbeddingSimilarityEvaluator)
| Metric | sts-dev | sts-test |
|:--------------------|:-----------|:-----------|
| pearson_cosine | 0.7501 | 0.696 |
| **spearman_cosine** | **0.7643** | **0.6893** |
## Training Details
### Training Dataset
#### all-nli
* Dataset: [all-nli](https://huggingface.co/datasets/sentence-transformers/all-nli) at [d482672](https://huggingface.co/datasets/sentence-transformers/all-nli/tree/d482672c8e74ce18da116f430137434ba2e52fab)
* Size: 557,850 training samples
* Columns: anchor
, positive
, and negative
* Approximate statistics based on the first 1000 samples:
| | anchor | positive | negative |
|:--------|:----------------------------------------------------------------------------------|:----------------------------------------------------------------------------------|:----------------------------------------------------------------------------------|
| type | string | string | string |
| details |
A person on a horse jumps over a broken down airplane.
| A person is outdoors, on a horse.
| A person is at a diner, ordering an omelette.
|
| Children smiling and waving at camera
| There are children present
| The kids are frowning
|
| A boy is jumping on skateboard in the middle of a red bridge.
| The boy does a skateboarding trick.
| The boy skates down the sidewalk.
|
* Loss: [MultipleNegativesRankingLoss
](https://sbert.net/docs/package_reference/sentence_transformer/losses.html#multiplenegativesrankingloss) with these parameters:
```json
{
"scale": 20.0,
"similarity_fct": "cos_sim"
}
```
### Evaluation Dataset
#### all-nli
* Dataset: [all-nli](https://huggingface.co/datasets/sentence-transformers/all-nli) at [d482672](https://huggingface.co/datasets/sentence-transformers/all-nli/tree/d482672c8e74ce18da116f430137434ba2e52fab)
* Size: 6,584 evaluation samples
* Columns: anchor
, positive
, and negative
* Approximate statistics based on the first 1000 samples:
| | anchor | positive | negative |
|:--------|:----------------------------------------------------------------------------------|:---------------------------------------------------------------------------------|:----------------------------------------------------------------------------------|
| type | string | string | string |
| details | Two women are embracing while holding to go packages.
| Two woman are holding packages.
| The men are fighting outside a deli.
|
| Two young children in blue jerseys, one with the number 9 and one with the number 2 are standing on wooden steps in a bathroom and washing their hands in a sink.
| Two kids in numbered jerseys wash their hands.
| Two kids in jackets walk to school.
|
| A man selling donuts to a customer during a world exhibition event held in the city of Angeles
| A man selling donuts to a customer.
| A woman drinks her coffee in a small cafe.
|
* Loss: [MultipleNegativesRankingLoss
](https://sbert.net/docs/package_reference/sentence_transformer/losses.html#multiplenegativesrankingloss) with these parameters:
```json
{
"scale": 20.0,
"similarity_fct": "cos_sim"
}
```
### Training Hyperparameters
#### Non-Default Hyperparameters
- `eval_strategy`: steps
- `per_device_train_batch_size`: 128
- `per_device_eval_batch_size`: 128
- `num_train_epochs`: 1
- `warmup_ratio`: 0.1
- `fp16`: True
- `batch_sampler`: no_duplicates
#### All Hyperparameters