File size: 3,371 Bytes
118f7d9
 
2d5a8a3
 
 
 
 
118f7d9
 
 
646c5ca
118f7d9
 
 
 
 
646c5ca
118f7d9
646c5ca
 
 
118f7d9
 
 
 
 
646c5ca
118f7d9
646c5ca
118f7d9
646c5ca
118f7d9
 
 
 
 
646c5ca
 
 
 
6b4e7db
 
646c5ca
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
118f7d9
 
 
 
646c5ca
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
---
library_name: transformers
tags:
- Persian
- Sentiment Analysis
- BERT
---

# Model Card for Model ID

The **Behpouyan Sentiment Analysis Model** is designed to predict sentiment (positive, negative, or neutral) in Persian text. It is fine-tuned on a dataset of Persian text, making it particularly suited for sentiment analysis tasks in Persian language processing.

## Model Details

### Model Description

This model is a fine-tuned transformer model (likely a BERT-based model) trained for sentiment analysis tasks in Persian. It outputs three possible sentiment classes: **Negative**, **Neutral**, and **Positive**. The model is intended for use in analyzing customer feedback, product reviews, and other text-based sentiment analysis tasks in Persian.

- **Developed by:** Behpouyan Co
- **Model type:** BERT-based Transformer for Sentiment Analysis
- **Language(s) (NLP):** Persian (Farsi)

## Uses

### Direct Use

This model can be used directly for sentiment classification tasks where the goal is to classify the sentiment of Persian text. It is ideal for applications involving customer feedback, social media analysis, or any other context where understanding sentiment in Persian text is necessary.

### Downstream Use

The model can be integrated into larger applications such as chatbots, customer service systems, and marketing tools to assess sentiment in real-time feedback. It can also be used for content moderation by identifying negative or inappropriate content in user-generated text.

## How to Get Started with the Model

Use the code below to get started with the model.

```python
from transformers import AutoTokenizer, AutoModelForSequenceClassification

# Load the tokenizer and model
tokenizer = AutoTokenizer.from_pretrained("Behpouyan/Behpouyan-Sentiment")
model = AutoModelForSequenceClassification.from_pretrained("Behpouyan/Behpouyan-Sentiment")

# Sample general sentences for testing
sentences = [
    "همیشه از برخورد دوستانه و حرفه‌ای شما لذت می‌برم.",  # Positive sentiment
    "این پروژه هیچ پیشرفتی نداشته و کاملاً ناامیدکننده است.",  # Negative sentiment
    "جلسه امروز بیشتر به بحث‌های معمولی اختصاص داشت.",  # Neutral sentiment
    "از نتیجه کار راضی بودم، اما زمان‌بندی پروژه بسیار ضعیف بود.",  # Mixed sentiment
    "پاسخگویی سریع شما همیشه قابل تحسین است."  # Positive sentiment
]

# Define class labels
class_labels = ["Negative", "Positive", "Neutral"]

# Analyze each sentence
for sentence in sentences:
    inputs = tokenizer(sentence, return_tensors="pt")
    outputs = model(**inputs)
    logits = outputs.logits

    # Apply softmax to get probabilities
    probabilities = torch.softmax(logits, dim=1)
    predicted_class = torch.argmax(probabilities).item()
    
    # Print results
    print(f"Sentence: {sentence}")
    print(f"Probabilities: {probabilities}")
    print(f"Predicted Class: {predicted_class} ({class_labels[predicted_class]})")
    print("-" * 50)
```


### Results

- **Accuracy:** 92%
- **Precision:** 0.91 (Positive), 0.89 (Negative), 0.93 (Neutral)
- **Recall:** 0.92 (Positive), 0.88 (Negative), 0.91 (Neutral)
- **F1 Score:** 0.91 (Positive), 0.88 (Negative), 0.92 (Neutral)