HappyBERT: DistilBERT Emotion Classifier

Model Description

HappyBERT is a DistilBERT-based text classifier fine-tuned to detect emotions in English text. It predicts numeric labels corresponding to different emotions. The model is lightweight, fast, and optimized for social media text, reviews, and conversational data.

Label Mapping

Label ID Emotion
0 sadness
1 joy
2 love
3 anger
4 fear
5 surprise

Note: The numeric output from the model corresponds to the label IDs above.

Intended Use

  • Sentiment and emotion analysis of short text
  • Chatbots and conversational agents
  • Social media monitoring
  • Research in NLP and emotion analysis

Limitations and Risks

  • Trained on English text; may not generalize to other languages.
  • Emotions can be subjective; misclassifications may occur.
  • May misinterpret sarcasm, idioms, or mixed emotions.
  • Not suitable for critical decision-making (clinical, legal, or safety applications).

Model Training

  • Base Model: distilbert-base-uncased
  • Fine-tuning: Emotion-labeled dataset (e.g., GoEmotions or custom dataset)
  • Framework: Hugging Face Transformers + PyTorch
  • Training Procedure:
    • Tokenization using DistilBERT tokenizer
    • Optimizer: AdamW
    • Learning rate: 2e-5
    • Epochs: 3
    • Batch size: 32
  • Checkpoints: Only the final model is uploaded; intermediate checkpoints are not included.

How to Use

from transformers import pipeline

classifier = pipeline("text-classification", model="Dnyanesh29/happybert")

text = "I am so happy today!"
result = classifier(text)
print(result)  # e.g., [{'label': '3', 'score': 0.98}]
Downloads last month
36
Safetensors
Model size
67M params
Tensor type
F32
ยท
Inference Providers NEW
This model isn't deployed by any Inference Provider. ๐Ÿ™‹ Ask for provider support

Model tree for Dnyanesh29/happybert

Finetuned
(10008)
this model

Space using Dnyanesh29/happybert 1