File size: 9,378 Bytes
43e1acc
 
df4edc7
 
 
 
 
 
 
 
 
 
 
 
c8511fc
 
 
 
 
 
 
6c8370a
c8511fc
 
c071971
 
 
 
 
 
c8511fc
 
 
 
6c8370a
c071971
c8511fc
c071971
 
 
c8511fc
 
 
 
6c8370a
c071971
c8511fc
c071971
 
 
c8511fc
 
 
6c8370a
c071971
6c8370a
c8511fc
c071971
 
 
43e1acc
 
 
 
 
df4edc7
43e1acc
 
 
 
 
 
 
 
df4edc7
 
 
 
 
43e1acc
df4edc7
43e1acc
df4edc7
43e1acc
 
 
 
 
 
 
 
df4edc7
43e1acc
df4edc7
 
 
43e1acc
df4edc7
43e1acc
 
df4edc7
43e1acc
df4edc7
 
 
 
43e1acc
df4edc7
43e1acc
df4edc7
43e1acc
 
 
 
df4edc7
43e1acc
 
 
 
df4edc7
43e1acc
df4edc7
43e1acc
 
 
 
 
df4edc7
 
 
 
 
 
 
 
 
 
 
 
 
43e1acc
 
 
 
 
df4edc7
43e1acc
df4edc7
 
43e1acc
 
 
 
 
df4edc7
 
 
 
43e1acc
 
 
 
 
 
df4edc7
 
 
 
 
43e1acc
 
 
 
 
 
 
df4edc7
 
43e1acc
 
 
 
 
 
 
 
df4edc7
43e1acc
 
 
 
 
c8511fc
43e1acc
 
 
df4edc7
43e1acc
df4edc7
43e1acc
df4edc7
43e1acc
 
 
df4edc7
 
 
43e1acc
 
 
 
 
 
 
 
 
 
 
 
 
df4edc7
 
 
43e1acc
 
 
df4edc7
43e1acc
 
 
df4edc7
 
43e1acc
df4edc7
43e1acc
97ddf9d
df4edc7
97ddf9d
 
 
 
 
 
 
 
df4edc7
 
43e1acc
df4edc7
43e1acc
 
 
df4edc7
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
---
library_name: transformers
tags:
- nepali
- roberta
- nlp
- language-model
datasets:
- IRIISNEPAL/Nepali-Text-Corpus
language:
- ne
metrics:
- f1
- accuracy
model-index:
- name: IRIISNEPAL/RoBERTa_Nepali_110M
  results:
  - task:
      type: token-classification
      name: Named Entity Recognition (NER)
    dataset:
      name: Nep-gLUE - Named Entity Recognition (NER)
      type: nep_glue
    metrics:
    - type: f1
      value: 93.74
      name: Macro F1 Score
    - type: f1
      value: 97.52
      name: Macro F1 Score
  - task:
      type: text-classification
      name: Categorical Classification (CC)
    dataset:
      name: Nep-gLUE - Categorical Classification (CC)
      type: nep_glue
    metrics:
    - type: f1
      value: 94.68
      name: Macro F1 Score
  - task:
      type: similarity
      name: Categorical Pair Similarity (CPS)
    dataset:
      name: Nep-gLUE - Categorical Pair Similarity (CPS)
      type: nep_glue
    metrics:
    - type: f1
      value: 96.49
      name: Macro F1 Score
  - task:
      type: overall-benchmark
      name: Nep-gLUE
    dataset:
      name: Nep-gLUE
      type: nep_glue
    metrics:
    - type: score
      value: 95.6
      name: Overall Score
---

# Model Card for Model ID

<!-- Provide a quick summary of what the model is/does. -->
IRIISNEPAL/RoBERTa_Nepali_110M is a RoBERTa-based transformer model developed specifically for the Nepali language. This 110-million-parameter model is intended for tasks in natural language understanding (NLU), such as sentiment analysis, text classification, and named entity recognition in Nepali.


## Model Details

### Model Description

<!-- Provide a longer summary of what this model is. -->

- **Developed by:** Institute of Research and Innovation in Intelligent Systems (IRIIS) 
- **Model type:** RoBERTa-based transformer model specifically trained on Nepali language data
- **Model Size:** 110 million parameters
- **Language (NLP):** Nepali
- **Training Objective:** Masked Language Modeling (MLM) and Next Sentence Prediction (NSP)

The IRIISNEPAL/RoBERTa_Nepali_110M model aims to provide a robust tool for NLP tasks specific to the Nepali language, supporting NLP research and applications within low-resource languages.

---

## Uses

<!-- Address questions around how the model is intended to be used, including the foreseeable users of the model and those affected by the model. -->

### Direct Use

<!-- This section is for the model use without fine-tuning or plugging into a larger ecosystem/app. -->
The model provides contextual embeddings for each token in an input sequence (`last_hidden_state`) and a pooled representation of the entire input (`pooler_output`). These outputs can be used for:

- **Text Classification**: Using `pooler_output` to classify the overall sentiment, intent, or category of a sentence.
- **Token-Level Tasks**: Leveraging `last_hidden_state` to perform tasks like named entity recognition (NER) or part-of-speech tagging by predicting labels for individual tokens.
- **Sentence Embeddings**: Using `pooler_output` as an embedding for the entire input text for similarity search or clustering tasks. 

### Downstream Use

<!-- This section is for the model use when fine-tuned for a task, or when plugged into a larger ecosystem/app -->
The model was evaluated on the [Nepali Language Understanding Evaluation (Nep-gLUE)](https://nepberta.github.io/nepglue/) benchmark, demonstrating strong performance across various natural language understanding (NLU) tasks:

- **Named Entity Recognition (NER)**: 93.74
- **Part-of-Speech (POS) Tagging**: 97.52
- **Categorical Classification (CC)**: 94.68
- **Categorical Pair Similarity (CPS)**: 96.49

These results indicate the model’s effectiveness in capturing language nuances for multiple NLU tasks in Nepali.

---

## Bias, Risks, and Limitations

<!-- This section is meant to convey both technical and sociotechnical limitations. -->
The model may exhibit biases present in its training data, especially regarding social, cultural, and regional aspects of the Nepali language. Users should exercise caution when deploying it in applications that might perpetuate stereotypes or cultural biases.

### Recommendations

<!-- This section is meant to convey recommendations with respect to the bias, risk, and technical limitations. -->
It’s advisable for users to monitor model outputs for fairness and avoid high-stakes applications without thorough testing. Fine-tuning or retraining may be necessary for sensitive applications.

---

## How to Get Started with the Model

Use the code below to get started with the model.

```python
# Load model directly
from transformers import AutoTokenizer, AutoModel

tokenizer = AutoTokenizer.from_pretrained("IRIISNEPAL/RoBERTa_Nepali_110M")
model = AutoModel.from_pretrained("IRIISNEPAL/RoBERTa_Nepali_110M")

text = "नेपालमा पर्यटनको विकास गर्नुपर्ने आवश्यकता छ।"
inputs = tokenizer(text, return_tensors="pt")
outputs = model(**inputs)
```

---

## Training Details

### Training Data

The model was trained on a 27.5 GB Nepali language corpus compiled from 99 Nepali news websites. This dataset represents the largest Nepali language corpus to date, providing a significant expansion in training resources for the language. The preprocessing involved deduplication, translation/removal of non-Nepali content, and noise reduction.

<!-- This should link to a Dataset Card, perhaps with a short stub of information on what the training data is all about as well as documentation related to data pre-processing or additional filtering. -->
You can find detailed information about the dataset in the [dataset card on Hugging Face](https://huggingface.co/datasets/IRIISNEPAL/Nepali-Text-Corpus).

### Training Procedure

<!-- This relates heavily to the Technical Specifications. Content here should link to that section when it is relevant to the training procedure. -->

- **Training Regime:** Mixed precision (fp16) on TPU v4-8 hardware
- **Batch Size:** 256
- **Learning Rate:** 1e-4 with a warmup over the first 10,000 steps followed by linear decay

#### Preprocessing [optional]

[More Information Needed]

#### Training Hyperparameters

- **Max Sequence Length:** 512 tokens
- **Learning Rate Scheduler:** Linear with warmup
- **Optimizer:** AdamW with β1 = 0.9, β2 = 0.999, and L2 weight decay of 0.01
- **Dropout Probability:** 0.1 across all layers
- **Activation Function:** GELU

#### Speeds, Sizes, Times [optional]

<!-- This section provides information about throughput, start/end time, checkpoint size if relevant, etc. -->

[More Information Needed]

---

## Evaluation

<!-- This section describes the evaluation protocols and provides the results. -->

### Testing Data, Factors & Metrics

#### Testing Data

The model was evaluated on the [Nepali Language Evaluation Benchmark (Nep-gLUE)](https://nepberta.github.io/nepglue/), which includes tasks like Named Entity Recognition (NER), Part-of-Speech (POS) Tagging, text classification, and categorical pair similarity.

#### Metrics

<!-- These are the evaluation metrics being used, ideally with a description of why. -->

- **Macro-F1** for the [Nepali Language Understanding Evaluation (Nep-gLUE)](https://nepberta.github.io/nepglue/) benchmark.

### Results

On Nep-gLUE, the model outperformed existing state-of-the-art models with an overall score of 95.60, reflecting its strong language understanding capabilities.

---

## Model Examination

<!-- Relevant interpretability work for the model goes here -->

Performance analysis indicates robustness in capturing grammatical and syntactical features of Nepali. However, the model may have limited effectiveness in handling dialect-specific content or informal language.

---

## Environmental Impact

<!-- Total emissions (in grams of CO2eq) and additional considerations, such as electricity usage, go here. Edit the suggested text below accordingly -->

Carbon emissions can be estimated using the [Machine Learning Impact calculator](https://mlco2.github.io/impact#compute) presented in [Lacoste et al. (2019)](https://arxiv.org/abs/1910.09700).

- **Hardware Type:** [More Information Needed]
- **Hours used:** [More Information Needed]
- **Cloud Provider:** [More Information Needed]
- **Compute Region:** [More Information Needed]
- **Carbon Emitted:** [More Information Needed]

---

## Technical Specifications

### Model Architecture and Objective

RoBERTa architecture with 12 transformer layers, hidden size of 768, 12 attention heads, and 110 million parameters. This architecture facilitates strong bidirectional attention for accurate language understanding.

### Compute Infrastructure

- **Hardware:** TPU v4-8 and Nvidia GeForce RTX 3090 GPUs
- **Software:** Python, PyTorch, Hugging Face Transformers

---

## Citation
```
@misc{thapa2024developmentpretrainedtransformerbasedmodels,
      title={Development of Pre-Trained Transformer-based Models for the Nepali Language}, 
      author={Prajwal Thapa and Jinu Nyachhyon and Mridul Sharma and Bal Krishna Bal},
      year={2024},
      eprint={2411.15734},
      archivePrefix={arXiv},
      primaryClass={cs.CL},
      url={https://arxiv.org/abs/2411.15734}, 
}
```

---

## Model Card Contact

For questions and support, contact IRIIS Nepal.