BeardedMonster
commited on
Update
Browse files
README.md
CHANGED
@@ -3,197 +3,105 @@ library_name: transformers
|
|
3 |
tags: []
|
4 |
---
|
5 |
|
6 |
-
#
|
7 |
-
|
8 |
-
<!-- Provide a quick summary of what the model is/does. -->
|
9 |
|
|
|
10 |
|
|
|
11 |
|
12 |
## Model Details
|
13 |
|
14 |
### Model Description
|
15 |
|
16 |
-
|
17 |
-
|
18 |
-
This is the model card of a 🤗 transformers model that has been pushed on the Hub. This model card has been automatically generated.
|
19 |
-
|
20 |
-
- **Developed by:** [More Information Needed]
|
21 |
-
- **Funded by [optional]:** [More Information Needed]
|
22 |
-
- **Shared by [optional]:** [More Information Needed]
|
23 |
-
- **Model type:** [More Information Needed]
|
24 |
-
- **Language(s) (NLP):** [More Information Needed]
|
25 |
-
- **License:** [More Information Needed]
|
26 |
-
- **Finetuned from model [optional]:** [More Information Needed]
|
27 |
-
|
28 |
-
### Model Sources [optional]
|
29 |
-
|
30 |
-
<!-- Provide the basic links for the model. -->
|
31 |
-
|
32 |
-
- **Repository:** [More Information Needed]
|
33 |
-
- **Paper [optional]:** [More Information Needed]
|
34 |
-
- **Demo [optional]:** [More Information Needed]
|
35 |
|
36 |
-
|
|
|
|
|
37 |
|
38 |
-
|
|
|
39 |
|
40 |
-
|
41 |
|
42 |
-
|
|
|
|
|
|
|
|
|
43 |
|
44 |
-
[More Information Needed]
|
45 |
|
46 |
-
###
|
47 |
|
48 |
-
|
49 |
|
50 |
-
|
51 |
|
52 |
-
|
53 |
|
54 |
-
|
55 |
|
56 |
-
|
57 |
|
58 |
-
|
59 |
|
60 |
-
|
61 |
|
62 |
-
[More Information Needed]
|
63 |
|
64 |
### Recommendations
|
65 |
|
66 |
-
<!-- This section is meant to convey recommendations with respect to the bias, risk, and technical limitations. -->
|
67 |
-
|
68 |
Users (both direct and downstream) should be made aware of the risks, biases and limitations of the model. More information needed for further recommendations.
|
69 |
|
|
|
70 |
## How to Get Started with the Model
|
71 |
|
72 |
Use the code below to get started with the model.
|
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 |
-
<!-- These are the things the evaluation is disaggregating by, e.g., subpopulations or domains. -->
|
118 |
-
|
119 |
-
[More Information Needed]
|
120 |
-
|
121 |
-
#### Metrics
|
122 |
-
|
123 |
-
<!-- These are the evaluation metrics being used, ideally with a description of why. -->
|
124 |
-
|
125 |
-
[More Information Needed]
|
126 |
-
|
127 |
-
### Results
|
128 |
-
|
129 |
-
[More Information Needed]
|
130 |
-
|
131 |
-
#### Summary
|
132 |
-
|
133 |
-
|
134 |
-
|
135 |
-
## Model Examination [optional]
|
136 |
-
|
137 |
-
<!-- Relevant interpretability work for the model goes here -->
|
138 |
-
|
139 |
-
[More Information Needed]
|
140 |
-
|
141 |
-
## Environmental Impact
|
142 |
-
|
143 |
-
<!-- Total emissions (in grams of CO2eq) and additional considerations, such as electricity usage, go here. Edit the suggested text below accordingly -->
|
144 |
-
|
145 |
-
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).
|
146 |
-
|
147 |
-
- **Hardware Type:** [More Information Needed]
|
148 |
-
- **Hours used:** [More Information Needed]
|
149 |
-
- **Cloud Provider:** [More Information Needed]
|
150 |
-
- **Compute Region:** [More Information Needed]
|
151 |
-
- **Carbon Emitted:** [More Information Needed]
|
152 |
-
|
153 |
-
## Technical Specifications [optional]
|
154 |
|
155 |
### Model Architecture and Objective
|
|
|
156 |
|
157 |
-
[More Information Needed]
|
158 |
-
|
159 |
-
### Compute Infrastructure
|
160 |
-
|
161 |
-
[More Information Needed]
|
162 |
-
|
163 |
-
#### Hardware
|
164 |
-
|
165 |
-
[More Information Needed]
|
166 |
-
|
167 |
-
#### Software
|
168 |
-
|
169 |
-
[More Information Needed]
|
170 |
-
|
171 |
-
## Citation [optional]
|
172 |
-
|
173 |
-
<!-- If there is a paper or blog post introducing the model, the APA and Bibtex information for that should go in this section. -->
|
174 |
-
|
175 |
-
**BibTeX:**
|
176 |
-
|
177 |
-
[More Information Needed]
|
178 |
-
|
179 |
-
**APA:**
|
180 |
-
|
181 |
-
[More Information Needed]
|
182 |
-
|
183 |
-
## Glossary [optional]
|
184 |
-
|
185 |
-
<!-- If relevant, include terms and calculations in this section that can help readers understand the model or model card. -->
|
186 |
-
|
187 |
-
[More Information Needed]
|
188 |
-
|
189 |
-
## More Information [optional]
|
190 |
-
|
191 |
-
[More Information Needed]
|
192 |
-
|
193 |
-
## Model Card Authors [optional]
|
194 |
-
|
195 |
-
[More Information Needed]
|
196 |
-
|
197 |
-
## Model Card Contact
|
198 |
|
199 |
-
[More Information Needed]
|
|
|
3 |
tags: []
|
4 |
---
|
5 |
|
6 |
+
# SabiYarn
|
|
|
|
|
7 |
|
8 |
+
Test the whole generation capabilities here: https://huggingface.co/spaces/BeardedMonster/SabiYarn_125M
|
9 |
|
10 |
+
Pretrained model on Nigerian languages including English using a causal language modeling (CLM) Multi-task objective.
|
11 |
|
12 |
## Model Details
|
13 |
|
14 |
### Model Description
|
15 |
|
16 |
+
SabiYarn-125M is the first of a series of transformer models (adopted from nanogpt and inspired by GPT-J's architecture) pretrained on a large corpus of Nigerian language data in a self-supervised fashion. This means it was pretrained on the raw texts only,
|
17 |
+
with no humans labelling them in any way (which is why it can use lots of publicly available data) with an automatic process to generate inputs and labels from those texts. More precisely, it was trained to guess the next word in sentences.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
18 |
|
19 |
+
More precisely, inputs are sequences of continuous text of a certain length and the targets are the same sequence, shifted one token (word or piece of word) to the right.
|
20 |
+
The model uses internally a mask-mechanism to make sure the predictions for the token i only uses the inputs from 1 to i but not the future tokens. It also makes sure attention
|
21 |
+
is not calculated across documents.
|
22 |
|
23 |
+
This way, the model learns an inner representation of the languages that can then be used to extract features useful for downstream tasks. The model is best at what
|
24 |
+
it was pretrained for however, which is generating coherent texts.
|
25 |
|
26 |
+
This is the smallest version, with 125M parameters.
|
27 |
|
28 |
+
- **Developed by:** Aletheia.ai Research Lab
|
29 |
+
- **Funded by [optional]:** Personal
|
30 |
+
- **Shared by [optional]:** Jeffreypaul
|
31 |
+
- **Model type:** GPTJX (Adopted from NanoGPT)
|
32 |
+
- **Language(s) (NLP):** Majorly English, Yoruba, Hausa, Igbo, Pidgin and some others: Fulah/Fulfulde, Efik, Urhobo.
|
33 |
|
|
|
34 |
|
35 |
+
### Model Sources [optional]
|
36 |
|
37 |
+
- **Demo:** https://huggingface.co/spaces/BeardedMonster/SabiYarn_125M
|
38 |
|
39 |
+
## Uses
|
40 |
|
41 |
+
You can use the raw model for text generation or fine-tune it to a downstream task.
|
42 |
|
43 |
+
## Bias, Risks, and Limitations
|
44 |
|
45 |
+
The training data used for this model is mostly an aggregation of data available on huggingface for nigerian languages. We know it contains a lot of unfiltered content from the internet, which is far from neutral.
|
46 |
|
47 |
+
Because large-scale language models of this size do not distinguish fact from fiction, we don’t support use-cases that require the generated text to be true.
|
48 |
|
49 |
+
Additionally, language models often reflect the biases inherent to the systems they were trained on, so we do not recommend that they be deployed into systems that interact with humans > unless the deployers first carry out a study of biases relevant to the intended use-case.
|
50 |
|
|
|
51 |
|
52 |
### Recommendations
|
53 |
|
|
|
|
|
54 |
Users (both direct and downstream) should be made aware of the risks, biases and limitations of the model. More information needed for further recommendations.
|
55 |
|
56 |
+
|
57 |
## How to Get Started with the Model
|
58 |
|
59 |
Use the code below to get started with the model.
|
60 |
|
61 |
+
```python
|
62 |
+
from transformers import AutoModelForCausalLM, AutoTokenizer
|
63 |
+
from transformers import GenerationConfig
|
64 |
+
|
65 |
+
generation_config = GenerationConfig(
|
66 |
+
max_length=100, # Adjust this based on your translation requirements
|
67 |
+
max_new_tokens=50, # Ensure sufficient tokens for your translations
|
68 |
+
num_beams=5, # Moderate number of beams for a balance between speed and quality
|
69 |
+
do_sample=False, # Disable sampling to make output deterministic
|
70 |
+
temperature=1.0, # Neutral temperature since sampling is off
|
71 |
+
top_k=0, # Disable top-k sampling (since sampling is off)
|
72 |
+
top_p=0, # Disable top-p (nucleus) sampling (since sampling is off)
|
73 |
+
repetition_penalty=4.0, # Neutral repetition penalty for translation
|
74 |
+
length_penalty=3.0, # No penalty for sequence length; modify if your translations tend to be too short/long
|
75 |
+
early_stopping=True # Stop early when all beams finish to speed up generation
|
76 |
+
)
|
77 |
+
|
78 |
+
repo_name = "BeardedMonster/SabiYarn-125M-finetune"
|
79 |
+
model = AutoModelForCausalLM.from_pretrained(repo_name, trust_remote_code=True)
|
80 |
+
tokenizer= AutoTokenizer.from_pretrained(repo_name, trust_remote_code=True)
|
81 |
+
|
82 |
+
Use the following tags for the following downstream tasks:
|
83 |
+
- Translation
|
84 |
+
```python
|
85 |
+
<translate> <yor>, <translate> .... <ibo>, <translate> ... <hau>
|
86 |
+
```
|
87 |
+
- Topic classification
|
88 |
+
```python
|
89 |
+
<classify> ...... <topic>
|
90 |
+
```
|
91 |
+
|
92 |
+
- Sentiment Analysis
|
93 |
+
```python
|
94 |
+
<classify> .... <sentiment>
|
95 |
+
```
|
96 |
+
|
97 |
+
- Named Entity Recognition
|
98 |
+
```python
|
99 |
+
<NER>.... <tag>
|
100 |
+
```
|
101 |
+
|
102 |
+
You should typically put user's input between these 2 tags. Currently, model also doesnt perform very well on NER due to the scarce data on this.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
103 |
|
104 |
### Model Architecture and Objective
|
105 |
+
Architecture is very similar to GPT-J
|
106 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
107 |
|
|