shqqq commited on
Commit
303cc2f
1 Parent(s): 5c0b115

Update README.md

Browse files
Files changed (1) hide show
  1. README.md +314 -0
README.md CHANGED
@@ -1,3 +1,317 @@
1
  ---
2
  license: cc-by-4.0
 
 
3
  ---
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
  ---
2
  license: cc-by-4.0
3
+ language:
4
+ - 'no'
5
  ---
6
+ # NorMistral 7B scratch AWQ
7
+ - Model creator: [NorwAI](https://huggingface.co/norallm/)
8
+ - Original model: [NorMistral-7b-scratch](https://huggingface.co/norallm/normistral-7b-scratch)
9
+
10
+ <!-- description start -->
11
+ ## Description
12
+
13
+ This repo contains AWQ model files for [Norallm's NorMistral-7B-scratch](https://huggingface.co/norallm/normistral-7b-scratch).
14
+
15
+
16
+ ### About AWQ
17
+
18
+ AWQ is an efficient, accurate and blazing-fast low-bit weight quantization method, currently supporting 4-bit quantization. Compared to GPTQ, it offers faster Transformers-based inference with equivalent or better quality compared to the most commonly used GPTQ settings.
19
+
20
+ AWQ models are currently supported on Linux and Windows, with NVidia GPUs only. macOS users: please use GGUF models instead.
21
+
22
+ It is supported by:
23
+
24
+ - [Text Generation Webui](https://github.com/oobabooga/text-generation-webui) - using Loader: AutoAWQ
25
+ - [vLLM](https://github.com/vllm-project/vllm) - version 0.2.2 or later for support for all model types.
26
+ - [Hugging Face Text Generation Inference (TGI)](https://github.com/huggingface/text-generation-inference)
27
+ - [Transformers](https://huggingface.co/docs/transformers) version 4.35.0 and later, from any code or client that supports Transformers
28
+ - [AutoAWQ](https://github.com/casper-hansen/AutoAWQ) - for use from Python code
29
+
30
+
31
+ ### From original model card:
32
+
33
+ <img align="center" src="https://huggingface.co/ltg/norbert3-base/resolve/main/norbert.png" width=12.5%>
34
+
35
+ NorMistral-7b-scratch is a large Norwegian language model pretrained from scratch on a total of 260 billion subword tokens (using six repetitions of open Norwegian texts).
36
+
37
+ This model is a part of the NORA.LLM family developed in collaboration between [the Language Technology Group at the University of Oslo](https://huggingface.co/ltg), [the High Performance Language Technologies (HPLT) project](https://hplt-project.org/), [the National Library of Norway](https://huggingface.co/NbAiLab), and [the University of Turku](https://huggingface.co/TurkuNLP).
38
+ All the models are pre-trained on the same dataset and with the same tokenizer.
39
+ NorMistral-7b-scratch has over 7 billion parameters and is based on [the Mistral architecture](https://huggingface.co/mistralai/Mistral-7B-v0.1).
40
+
41
+ The NORA.LLM language model family includes (as of now):
42
+ - [**NorMistral-7b-warm**](https://huggingface.co/norallm/normistral-7b-warm) -- an LLM initialized from [Mistral-7b-v0.1](https://huggingface.co/mistralai/Mistral-7B-v0.1) and continuously pretrained on Norwegian data;
43
+ - [**NorMistral-7b-scratch**](https://huggingface.co/norallm/normistral-7b-scratch) -- a Mistral-based LLM pretrained from scratch on Norwegian data;
44
+ - [**NorBLOOM-7b-scratch**](https://huggingface.co/norallm/NorBLOOM-7b-scratch) -- a BLOOM-based LLM pretrained from scratch on Norwegian data.
45
+
46
+
47
+ *Disclaimer: This model is pretrained on raw (mostly web-based) textual data.
48
+ It is not finetuned to follow instructions, and it can generate harmful completions after inappropriate user prompts.
49
+ It is primarily intended for research purposes.*
50
+
51
+ _____
52
+ ## Pretraining corpus
53
+
54
+ The model is pretrained exclusively on publicly available data. We combine the resources from [the public part of the NCC corpus](https://huggingface.co/datasets/NbAiLab/NCC), from [the cleaned HPLT corpus](https://hplt-project.org/datasets/v1.2), and from [CulturaX](https://huggingface.co/datasets/uonlp/CulturaX).
55
+ This resulted in over 34B subword tokens of Norwegian (Bokmål or Nynorsk) in total, which amounts to about 26.7B whitespace-separated tokens.
56
+ We also augment the corpus with [Starcoder](https://huggingface.co/datasets/vikp/starcoder_filtered); 20% of the 260B tokens are sampled from this code corpus.
57
+ The natural language data is repeated six times to get the pretraining budget of 260B tokens, in accordance with findings from [Muennighoff et al. (2023)](https://neurips.cc/virtual/2023/poster/70706).
58
+
59
+
60
+ _____
61
+ ## Model details
62
+
63
+ **Model Developers:** Language Technology Group at the University of Oslo.
64
+
65
+ **Variations:** NorMistral is currently published as two 7B variants: one trained entirely from *scratch* and one *warm*-started from the Mistral model.
66
+
67
+ **Input:** Textual input.
68
+
69
+ **Output:** Generated text.
70
+
71
+ **Model Architecture:** NorMistral is an auto-regressive language model that uses an optimized transformer architecture based on the Mistral/Llama language models.
72
+
73
+ ||Training Data|Params|Context Length|Tokens|LR|
74
+ |---|---|---|---|---|---|
75
+ |NorMistral-7b-warm|NCC+HPLT+CulturaX+Starcoder|7B|2k|260B|1.0 x 10<sup>-4</sup>|
76
+ |NorMistral-7b-scratch|NCC+HPLT+CulturaX+Starcoder|7B|2k|260B|3.0 x 10<sup>-4</sup>|
77
+ |NorBLOOM-7b-scratch|NCC+HPLT+CulturaX+Starcoder|7B|2k|260B|1.2 x 10<sup>-4</sup>|
78
+
79
+ **Tokenizer:** Byte-based BPE tokenizer trained on the same Norwegian corpus as this model. The vocabulary size is 32,768 tokens.
80
+
81
+ **Training FLOPs** The approximate amount is 1.22e+22 FLOPs; calculated as in [Chowdhery et al. (2022)](https://arxiv.org/abs/2204.02311).
82
+
83
+ **Model Dates:** The models were pretrained between December 2023 and January 2024.
84
+
85
+ **Status:** These are only pretrained language models; instruction-finetuned models will follow soon.
86
+
87
+ **License:** Creative Commons Attribution 4.0
88
+
89
+ **Research Paper:** Forthcoming
90
+
91
+ _____
92
+ ## Initial evaluation
93
+
94
+ *Disclaimer: our model evaluation is an ongoing phase and is not claimed to be exhaustive. We provide our initial evaluation results on standard natural language understanding and generation tasks, and our evaluation design will be extended.
95
+ The user should perform evaluation for their particular model application scenario, including safety and bias evaluations.*
96
+
97
+ The perplexity on the heldout [validation set from the Norwegian Colossal Corpus (NCC)](https://huggingface.co/datasets/NbAiLab/NCC) is 7.43 and the final training perplexity is 4.76.
98
+
99
+ Our initial downstream evaluation is conducted on reading comprehension, sentiment analysis and machine translation tasks using open-source peer-reviewed datasets and benchmarks in native Norwegian.
100
+ We release [our codebase here](https://github.com/ltgoslo/norallm). We compare against other pretrained generative language models that officially support Norwegian: [NB-GPT-J](https://huggingface.co/NbAiLab/nb-gpt-j-6B), [GPT-Sw3 6.7B](https://huggingface.co/AI-Sweden-Models/gpt-sw3-6.7b), [GPT-Sw3 6.7B v2](https://huggingface.co/AI-Sweden-Models/gpt-sw3-6.7b-v2), and [Falcon-7B](https://huggingface.co/tiiuae/falcon-7b); we also include evaluation of [Mistral-7b-v0.1](https://huggingface.co/mistralai/Mistral-7B-v0.1).
101
+
102
+
103
+ ### Sentiment analysis
104
+
105
+ [NoReC](https://huggingface.co/datasets/ltg/norec_sentence) ([Øvrelid et al., 2020](https://aclanthology.org/2020.lrec-1.618/)) is a dataset for sentence-level sentiment analysis derived from the Norwegian Review Corpus [(Velldal et al., 2018)](https://aclanthology.org/L18-1661/).
106
+ We use the binary formulation of this task (positive vs. negative).
107
+
108
+ <details>
109
+ <summary>Method</summary>
110
+
111
+ * Evaluation setting: zero-shot and few-shot perplexity-based evaluation.
112
+ * Prompt: ```"Tekst: {text}\nSentiment:{label}"```, where the ```label``` is either "positiv" or "negativ".
113
+ * Few-shot results show the average scores across 5 repetitions
114
+ * Evaluation script: https://github.com/ltgoslo/norallm/blob/main/initial_evaluation/sentiment_analysis.py
115
+ * Performance metric: macro-averaged F1-score.
116
+
117
+ </details>
118
+
119
+ <details open>
120
+ <summary>Macro-averaged F1-scores on the sentence-level sentiment analysis task (NoReC)</summary>
121
+
122
+ |Model|0-shot (macro F1)|1-shot (macro F1)|16-shot (macro F1)|
123
+ |---|---|---|---|
124
+ |NorMistral-7b-warm|60.6|**77.8**|**87.3**|
125
+ |NorMistral-7b-scratch|47.3|62.2|80.1|
126
+ |NorBLOOM-7b|**75.7**|73.8|65.5|
127
+ |NB-GPT-J|48.4|56.5|65.2|
128
+ |GPT-Sw3-6.7B|61.5|72.2|76.5|
129
+ |GPT-Sw3-6.7B-v2|42.4|69.1|83.4|
130
+ |Falcon-7B|53.3|61.6|74.9|
131
+ |Mistral-7B-v0.1|70.2|72.9|84.8|
132
+
133
+ </details>
134
+
135
+
136
+
137
+ ### Reading comprehension
138
+
139
+ [NorQuAD](https://huggingface.co/datasets/ltg/norquad) ([Ivanova et al., 2023](https://aclanthology.org/2023.nodalida-1.17/)) is a dataset for extractive question answering in Norwegian designed similarly to [SQuAD (Rajpurkar et al., 2016)](https://aclanthology.org/D16-1264/).
140
+
141
+ <details>
142
+ <summary>Method</summary>
143
+
144
+ * Evaluation setting: zero-shot and few-shot settings via natural language generation using the greedy decoding strategy.
145
+ * Prompt: ```"Tittel: {title}\n\nTekst: {text}\n\nSpørsmål: {question}\n\nSvar:{answer}"``` Based on [Brown et al. (2020)](https://arxiv.org/abs/2005.14165).
146
+ * Few-shot results show the average scores across 5 repetitions
147
+ * Evaluation script: https://github.com/ltgoslo/norallm/blob/main/initial_evaluation/norquad.py
148
+ * Performance metrics: macro-averaged F1-score and exact match (EM).
149
+
150
+ </details>
151
+ <details open>
152
+ <summary>Performance results on the extractive question answering task (NorQuAD)</summary>
153
+ |Model|0-shot (F1/EM)|1-shot (F1/EM)|2-shot (F1/EM)|
154
+ |---|---|---|---|
155
+ |NorMistral-7b-warm|**48.6**/**24.8**|63.6/40.0|66.5/43.8|
156
+ |NorMistral-7b-scratch|34.0/15.7|46.5/25.8|48.5/27.8|
157
+ |NorBLOOM-7b|35.0/13.3|47.7/28.0|49.3/30.1|
158
+ |NB-GPT-J|24.4/6.8|32.8/11.6|35.0/12.3|
159
+ |GPT-Sw3-6.7B|46.5/22.0|55.9/32.0|58.1/34.3|
160
+ |GPT-Sw3-6.7B-v2|46.9/22.5|61.1/38.9|66.0/44.5|
161
+ |Falcon-7B|15.8/7.0|27.3/13.9|27.4/13.1|
162
+ |Mistral-7B-v0.1|46.4/22.4|**64.9**/**41.1**|**71.7**/**49.4**|
163
+ </details>
164
+ ### Machine translation
165
+ [Tatoeba](https://huggingface.co/datasets/Helsinki-NLP/tatoeba_mt) [(Tiedemann, 2020)](https://aclanthology.org/2020.wmt-1.139/) is a benchmark for machine translation, which includes hundreds of language pairs. We consider six language pairs (English <-> Bokmål, English <-> Nynorsk, and Bokmål <-> Nynorsk).
166
+ <details>
167
+ <summary>Method</summary>
168
+
169
+ * Evaluation setting: zero-shot and few-shot settings via natural language generation using the greedy decoding strategy.
170
+ * Prompt: ```"{source_language}: {source_text}\n{target_language}:{target_text}"```, where the ```source_language``` and ```target_language``` are ```Engelsk```, ```Bokmål```, or ```Nynorsk```. Based on [Garcia et al. (2023)](https://arxiv.org/abs/2302.01398).
171
+ * Few-shot results show the average scores across 5 repetitions
172
+ * Evaluation script: https://github.com/ltgoslo/norallm/blob/main/initial_evaluation/machine_translation.py
173
+ * Performance metrics: BLEU ([Papineni et al., 2002](https://aclanthology.org/P02-1040/)) and chrF++ ([Popović, 2015](https://aclanthology.org/W15-3049/)).
174
+ </details>
175
+ <details open>
176
+ <summary>English → Norwegian Bokmål</summary>
177
+ |Model|0-shot (BLEU/chrF++)|1-shot (BLEU/chrF++)|5-shot (BLEU/chrF++)|
178
+ |---|---|---|---|
179
+ |NorMistral-7b-warm|**55.8**/**70.7**|**56.7**/**71.5**|57.7/72.4|
180
+ |NorMistral-7b-scratch|46.4/62.9|50.4/66.3|52.1/67.6|
181
+ |NorBLOOM-7b|37.1/53.6|50.1/65.8|52.0/67.6|
182
+ |NB-GPT-J|8.6/39.1|35.9/64.5|47.2/68.7|
183
+ |GPT-Sw3-6.7B|21.8/55.2|54.5/69.6|**58.6**/**73.2**|
184
+ |GPT-Sw3-6.7B-v2|20.6/53.2|51.2/66.6|58.4/73.0|
185
+ |Falcon-7B|19.1/40.1|20.6/41.8|22.1/43.6|
186
+ |Mistral-7B-v0.1|32.5/51.9|35.4/55.1|36.3/56.0|
187
+ </details>
188
+ <details open>
189
+ <summary>English → Norwegian Nynorsk</summary>
190
+ |Model|0-shot (BLEU/chrF++)|1-shot (BLEU/chrF++)|5-shot (BLEU/chrF++)|
191
+ |---|---|---|---|
192
+ |NorMistral-7b-warm|**43.6**/**62.0**|**44.2**/**63.2**|44.3/**63.7**|
193
+ |NorMistral-7b-scratch|38.0/56.9|39.2/57.9|40.7/59.3|
194
+ |NorBLOOM-7b|35.6/54.7|36.6/56.3|38.1/57.4|
195
+ |NB-GPT-J|1.7/14.7|6.3/34.1|35.2/60.4|
196
+ |GPT-Sw3-6.7B|13.4/44.3|43.6/62.5|**44.5**/63.5|
197
+ |GPT-Sw3-6.7B-v2|14.8/45.5|43.7/62.3|44.0/63.6|
198
+ |Falcon-7B|6.4/28.6|8.3/30.5|9.3/32.1|
199
+ |Mistral-7B-v0.1|11.6/35.7|13.5/38.7|15.0/40.0|
200
+ </details>
201
+ <details open>
202
+ <summary>Norwegian Bokmål → English</summary>
203
+ |Model|0-shot (BLEU/chrF++)|1-shot (BLEU/chrF++)|5-shot (BLEU/chrF++)|
204
+ |---|---|---|---|
205
+ |NorMistral-7b-warm|**55.1**/**68.4**|**55.5**/**69.5**|56.0/69.8|
206
+ |NorMistral-7b-scratch|47.1/61.9|49.4/64.2|52.3/66.2|
207
+ |NorBLOOM-7b|45.0/59.3|48.3/64.0|49.0/64.7|
208
+ |NB-GPT-J|9.8/41.4|24.8/58.3|47.6/67.7|
209
+ |GPT-Sw3-6.7B|47.8/66.2|49.1/68.1|49.6/69.4|
210
+ |GPT-Sw3-6.7B-v2|46.3/67.5|48.9/69.3|**58.2**/**72.8**|
211
+ |Falcon-7B|21.6/40.6|31.7/47.4|36.6/51.7|
212
+ |Mistral-7B-v0.1|53.8/68.2|54.6/69.0|56.9/70.7|
213
+ </details>
214
+ <details open>
215
+ <summary>Norwegian Nynorsk → English</summary>
216
+ |Model|0-shot (BLEU/chrF++)|1-shot (BLEU/chrF++)|5-shot (BLEU/chrF++)|
217
+ |---|---|---|---|
218
+ |NorMistral-7b-warm|**55.1**/**68.4**|**55.5**/**69.5**|56.0/69.8|
219
+ |NorMistral-7b-scratch|47.1/61.9|49.4/64.2|52.3/66.2|
220
+ |NorBLOOM-7b|45.0/59.3|48.3/64.0|49.0/64.7|
221
+ |NB-GPT-J|2.9/19.5|10.1/41.0|44.4/66.9|
222
+ |GPT-Sw3-6.7B|47.8/66.2|49.1/68.1|49.6/69.4|
223
+ |GPT-Sw3-6.7B-v2|46.3/67.5|48.9/69.3|**58.2**/**72.8**|
224
+ |Falcon-7B|21.6/40.6|31.7/47.4|36.6/57.1|
225
+ |Mistral-7B-v0.1|40.7/57.1|46.2/60.7|49.9/63.8|
226
+ </details>
227
+ <details open>
228
+ <summary>Norwegian Bokmål → Norwegian Nynorsk</summary>
229
+ |Model|0-shot (BLEU/chrF++)|1-shot (BLEU/chrF++)|5-shot (BLEU/chrF++)|
230
+ |---|---|---|---|
231
+ |NorMistral-7b-warm|**75.8**/**87.5**|74.0/**86.9**|75.3/87.5|
232
+ |NorMistral-7b-scratch|38.0/56.9|39.2/57.9|40.7/59.3|
233
+ |NorBLOOM-7b|71.5/84.4|70.1/84.1|71.9/85.1|
234
+ |NB-GPT-J|6.6/35.5|9.6/41.0|26.0/64.7|
235
+ |GPT-Sw3-6.7B|63.6/82.8|74.7/86.0|75.8/86.9|
236
+ |GPT-Sw3-6.7B-v2|57.5/81.1|**75.3**/86.7|**76.7**/**87.6**|
237
+ |Falcon-7B|28.7/59.2|29.8/60.8|32.1/62.3|
238
+ |Mistral-7B-v0.1|32.0/62.2|32.9/62.6|35.2/63.9|
239
+ </details>
240
+ <details open>
241
+ <summary>Norwegian Nynorsk → Norwegian Bokmål</summary>
242
+ |Model|0-shot (BLEU/chrF++)|1-shot (BLEU/chrF++)|5-shot (BLEU/chrF++)|
243
+ |---|---|---|---|
244
+ |NorMistral-7b-warm|**88.1**/**93.6**|**89.2**/**94.3**|**89.3**/**94.6**|
245
+ |NorMistral-7b-scratch|85.1/91.4|86.6/92.4|87.4/93.0|
246
+ |NorBLOOM-7b|78.7/88.5|84.2/90.7|87.4/93.0|
247
+ |NB-GPT-J|2.7/18.5|6.9/35.6|52.9/84.3|
248
+ |GPT-Sw3-6.7B|652.3/82.4|86.1/92.5|87.8/93.6|
249
+ |GPT-Sw3-6.7B-v2|72.0/88.6|86.1/92.5|88.2/93.9|
250
+ |Falcon-7B|36.7/61.6|38.3/63.5|45.8/68.1|
251
+ |Mistral-7B-v0.1|57.0/74.8|59.9/77.5|62.6/79.1|
252
+ </details>
253
+ _____
254
+ ## Hardware and Software
255
+
256
+ **Training Factors:** The models were pretrained using the Megatron-DeepSpeed library on [the LUMI cluster in Finland](https://lumi-supercomputer.eu/).
257
+
258
+ **Carbon Footprint:** Pretraining one model took approximately 70k GPU hours of computation on AMD MI250X GPUs (assuming 2 GPUs per one AMD MI250X device), each of which draws 500W.
259
+ LUMI is [one of the most eco-efficient data centers in the world](https://www.lumi-supercomputer.eu/sustainable-future/), and its energy consumption is covered 100% with renewable electricity.
260
+
261
+
262
+
263
+ _____
264
+ ## Example usage
265
+
266
+ Let's try to use this model for English-to-Norwegian machine translation using simple zero-shot prompting:
267
+
268
+ ```python
269
+ from transformers import AutoTokenizer, AutoModelForCausalLM
270
+ # First, we will have to import the tokenizer and the language model
271
+ tokenizer = AutoTokenizer.from_pretrained("norallm/normistral-7b-scratch")
272
+ model = AutoModelForCausalLM.from_pretrained("norallm/normistral-7b-scratch").cuda().eval()
273
+ # Now we will define the zero-shot prompt template
274
+ prompt = """Engelsk: {0}
275
+ Bokmål:"""
276
+ # A function that will take care of generating the output
277
+ @torch.no_grad()
278
+ def generate(text):
279
+ text = prompt.format(text)
280
+ input_ids = tokenizer(text, return_tensors='pt').input_ids.cuda()
281
+ prediction = model.generate(
282
+ input_ids,
283
+ max_new_tokens=64,
284
+ do_sample=False,
285
+ eos_token_id=tokenizer('\n').input_ids
286
+ )
287
+ return tokenizer.decode(prediction[0, input_ids.size(1):]).strip()
288
+ # Now you can simply call the generate function with an English text you want to translate:
289
+ generate("I'm super excited about this Norwegian NORA model! Can it translate these sentences?")
290
+ # > this should output: 'Jeg er super spent på denne norske NORA modellen! Kan den oversette disse setningene?'
291
+ ```
292
+
293
+ ## Example usage on a GPU with ~16GB VRAM (try for yourself [in Google Colab](https://colab.research.google.com/drive/1AQgJ8lN-SNOqkUKj4xpQI5rr0R7V2Xzy?usp=sharing))
294
+ Install bitsandbytes if you want to load in 8bit
295
+
296
+ ```bash
297
+ pip install bitsandbytes
298
+ pip install accelerate
299
+ ```
300
+
301
+
302
+ ```python
303
+ import torch
304
+ from transformers import AutoTokenizer, AutoModelForCausalLM
305
+ tokenizer = AutoTokenizer.from_pretrained(
306
+ "norallm/normistral-7b-scratch"
307
+ )
308
+ # This setup needs about 8gb VRAM
309
+ # Setting `load_in_8bit=False` -> 15gb VRAM
310
+ # Using `torch.float32` and `load_in_8bit=False` -> 21gb VRAM
311
+ model = AutoModelForCausalLM.from_pretrained(
312
+ "norallm/normistral-7b-scratch",
313
+ device_map='auto',
314
+ load_in_8bit=True,
315
+ torch_dtype=torch.bfloat16
316
+ )
317
+ ```