renillhuang commited on
Commit
054e6fd
·
1 Parent(s): 4871737

readme: Add model intro and testset rename

Browse files

Signed-off-by: eric <renillhuang@163.com>

README.md CHANGED
@@ -48,9 +48,35 @@ tags:
48
 
49
  - Orion-MOE8x7B-Base Large Language Model(LLM) is a pretrained generative Sparse Mixture of Experts, trained from scratch by OrionStarAI. The base model is trained on multilingual corpus, including Chinese, English, Japanese, Korean, etc, and it exhibits superior performance in these languages.
50
 
51
- - The Orion-MOE8x7B series models exhibit the following features:
52
  - The model demonstrates excellent performance in comprehensive evaluations compared to other base models of the same parameter scale.
53
  - It has strong multilingual capabilities, significantly leading in Japanese and Korean test sets, and also performing comprehensively better in Arabic, German, French, and Spanish test sets.
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
54
 
55
 
56
  <a name="model-download"></a><br>
@@ -68,69 +94,71 @@ Model release and download links are provided in the table below:
68
 
69
  ## 3.1. Base Model Orion-MOE8x7B-Base Benchmarks
70
  ### 3.1.1. LLM evaluation results on examination and professional knowledge
71
- |TestSet | Mixtral 8*7B | Qwen1.5-32b | Qwen2.5-32b | Orion 14B | Orion 8*7B|
72
- | -- | -- | -- | -- | -- | -- |
73
- |ceval | 54.0861 | 83.5 | 87.7414 | 72.8 | 89.74|
74
- |cmmlu | 53.21 | 82.3 | 89.0088 | 70.57 | 89.1555|
75
- |mmlu | 70.4 | 73.4 | 82.9 | 69.94 | 85.9|
76
- |mmlu_pro | 38.5 | 45.25 | 58.01 | 33.95 | 58.31|
77
- |ARC_c | 85.0847 | 90.1695 | 94.2373 | 79.66 | 91.8644|
78
- |hellaswag | 81.9458 | 81.9757 | 82.5134 | 78.53 | 89.19|
79
- |lambada | 76.7902 | 73.7434 | 75.3736 | 78.83 | 79.7399|
80
- |bbh | 50.87 | 57.28 | 67.69 | 50.35 | 55.82|
81
- |musr | 43.21 | 42.65 | 49.78 | 43.61 | 49.93|
82
- |piqa | 83.41 | 82.15 | 80.05 | 79.54 | 87.32|
83
- |commonsense_qa | 69.62 | 74.69 | 72.97 | 66.91 | 73.05|
84
- |IFEval | 24.15 | 32.97 | 41.59 | 29.08 | 30.06|
85
- |GQPA | 30.9 | 33.49 | 49.5 | 28.53 | 52.17|
86
- |human-eval | 33.5366 | 35.9756 | 46.9512 | 20.12 | 44.5122|
87
- |MBPP | 60.7 | 49.4 | 71 | 30 | 43.4|
88
- |math lv5 | 9 | 25 | 31.72 | 2.54 | 5.07|
89
- |gsm8k | 47.5 | 77.4 | 80.363 | 52.01 | 59.82|
90
- |math | 28.4 | 36.1 | 48.88 | 7.84 | 23.68|
91
 
92
  ### 3.1.2. Comparison of LLM performances on Japanese testsets
93
- | Model | jsquad | jcommonsenseqa | jnli | marc_ja | jaqket_v2 | paws_ja | avg |
94
- |-------|---------|--------|-------|----------|-------|-----------|-----|
95
- |Mixtral-8x7B | 0.8900 | 0.7873 | 0.3213 | 0.9544 | 0.7886 | 44.5000 | 8.0403 |
96
- |Qwen1.5-32B | 0.8986 | 0.8454 | 0.5099 | 0.9708 | 0.8214 | 0.4380 | 0.7474 |
97
- |Qwen2.5-32B | 0.8909 | 0.9383 | 0.7214 | 0.9786 | 0.8927 | 0.4215 | 0.8073 |
98
- |Orion-14B-Base | 0.7422 | 0.8820 | 0.7285 | 0.9406 | 0.6620 | 0.4990 | 0.7424 |
99
- |Orion 8x7B |0.9177 |0.9043 |0.9046 |0.9640 |0.8119 |0.4735 |0.8293 |
100
 
101
  ### 3.1.3. Comparison of LLM performances on Korean testsets
102
- |Model | haerae | kobest boolq | kobest copa | kobest hellaswag | kobest sentineg | kobest wic | paws_ko | avg |
103
- |--------|----|----|----|----|----|----|----|----|
104
- |Mixtral-8x7B | 53.16 | 78.56 | 66.2 | 56.6 | 77.08 | 49.37 | 44.05 | 60.71714286 |
105
- |Qwen1.5-32B | 46.38 | 76.28 | 60.4 | 53 | 78.34 | 52.14 | 43.4 | 58.56285714 |
106
- |Qwen2.5-32B | 70.67 | 80.27 | 76.7 | 61.2 | 96.47 | 77.22 | 37.05 | 71.36857143 |
107
- |Orion-14B-Base | 69.66 | 80.63 | 77.1 | 58.2 | 92.44 | 51.19 | 44.55 | 67.68142857 |
108
- |Orion 8x7B |65.17 |85.4 |80.4 |56 |96.98 |73.57 |46.35 |71.98142857 |
109
 
110
  ### 3.1.4. Comparison of LLM performances on Arabic, German, French, and Spanish testsets
111
  | Lang | ar | | de | | fr | | es | |
112
  |----|----|----|----|----|----|----|----|----|
113
- |**model**|**hellaswag**|**arc**|**hellaswag**|**arc**|**hellaswag**|**arc**|**hellaswag**|**arc**|
114
- |Mixtral-8x7B | 47.93 | 36.27 | 69.17 | 52.35 | 73.9 | 55.86 | 74.25 | 54.79 |
115
- |Qwen1.5-32B | 50.07 | 39.95 | 63.77 | 50.81 | 68.86 | 55.95 | 70.5 | 55.13 |
116
- |Qwen2.5-32B | 59.76 | 52.87 | 69.82 | 61.76 | 74.15 | 62.7 | 75.04 | 65.3 |
117
- |Orion-14B-Base | 42.26 | 33.88 | 54.65 | 38.92 | 60.21 | 42.34 | 62 | 44.62 |
118
- |Orion 8x7B |69.39 |54.32 |80.6 |63.47 |85.56 |68.78 |87.41 |70.09 |
119
 
120
  ### 3.1.5. Leakage Detection Benchmark
121
- The proportion of leakage data(from various evaluation benchmarks) in the pre-trained corpus; the higher the proportion, the more leakage it indicates.
122
- - Code: https://github.com/nishiwen1214/Benchmark-leakage-detection
123
- - Paper: https://web3.arxiv.org/pdf/2409.01790
124
- - English Test: mmlu
125
- - Chinese Test: ceval, cmmlu
126
 
127
- |Threshold 0.2 | qwen2.5 32b | qwen1.5 32b | orion 8x7b | orion 14b | mixtral 8x7b |
 
 
 
 
128
  |------|------|------|------|------|------|
129
- |mmlu | 0.3 | 0.27 | 0.22 | 0.28 | 0.25 |
130
- |ceval | 0.39 | 0.38 | 0.27 | 0.26 | 0.26 |
131
- |cmmlu | 0.38 | 0.39 | 0.23 | 0.27 | 0.22 |
132
 
133
- ### 3.1.6. Inference speed
134
  Based on 8x Nvidia RTX3090, in unit of tokens per second.
135
  |OrionLLM_V2.4.6.1 | 1para_out62 | 1para_out85 | 1para_out125 | 1para_out210 |
136
  |----|----|----|----|----|
@@ -197,6 +225,8 @@ device, you can use something like `export CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7`
197
  CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 python demo/text_generation_base.py --model OrionStarAI/Orion-MOE8x7B-Base --tokenizer OrionStarAI/Orion-MOE8x7B-Base --prompt hello
198
 
199
  ```
 
 
200
 
201
  <a name="declarations-license"></a><br>
202
  # 5. Declarations, License
 
48
 
49
  - Orion-MOE8x7B-Base Large Language Model(LLM) is a pretrained generative Sparse Mixture of Experts, trained from scratch by OrionStarAI. The base model is trained on multilingual corpus, including Chinese, English, Japanese, Korean, etc, and it exhibits superior performance in these languages.
50
 
51
+ - The Orion-MOE8x7B series models exhibit the following features
52
  - The model demonstrates excellent performance in comprehensive evaluations compared to other base models of the same parameter scale.
53
  - It has strong multilingual capabilities, significantly leading in Japanese and Korean test sets, and also performing comprehensively better in Arabic, German, French, and Spanish test sets.
54
+ - Model Hyper-Parameters
55
+ - The architecture of the OrionMOE 8*7B models closely resembles that of Mixtral 8*7B, with specific details shown in the table below.
56
+
57
+ |Configuration |OrionMOE 8*7B|
58
+ |-------------------|-------------|
59
+ |Hidden Size | 4096 |
60
+ |# Layers | 32 |
61
+ |# Query Heads | 32 |
62
+ |# KV Heads | 8 |
63
+ |Intermediate Size | 14592 |
64
+ |# Experts | 8 |
65
+ |# Activated Experts| 2 |
66
+ |Embedding Tying | False |
67
+ |Position embedding | RoPE |
68
+ |seq_len | 8192 |
69
+ |Vocabulary Size | 1136664 |
70
+
71
+ - Model pretrain hyper-parameters
72
+ - We use the AdamW optimizer with hyperparameters set to 𝛽1 = 0.9, 𝛽2 = 0.95, and a weight decay of 0.1.
73
+ - Training begins with a learning rate warm-up phase over 2000 iterations, where the learning rate is linearly increased to a peak of 3e-4. Afterward, a cosine schedule is applied to gradually reduce the learning rate to 3e-5 over the course of training.
74
+ - The model is trained using BF16/FP32 mixed precision, with a batch size of 2600, processing approximately 22 million tokens per step.
75
+ - Model pretrain data distribution
76
+ - The training dataset is primarily composed of English, Chinese, and other languages, accounting for 50%, 25%, and 12% of the data, respectively. Additionally, code makes up 9%, while mathematical text accounts for 4%. The distribution by topics is detailed in the table below.
77
+ <div align="center">
78
+ <img src="./assets/imgs/data_src_dist.png" alt="logo" width="80%" />
79
+ </div>
80
 
81
 
82
  <a name="model-download"></a><br>
 
94
 
95
  ## 3.1. Base Model Orion-MOE8x7B-Base Benchmarks
96
  ### 3.1.1. LLM evaluation results on examination and professional knowledge
97
+ |TestSet|Mixtral 8*7B|Qwen1.5-32b|Qwen2.5-32b|Orion 14B|Orion 8*7B|
98
+ | ----------- | ----- | ----- | ----- | ----- | ----- |
99
+ |CEval | 54.09 | 83.50 | 87.74 | 72.80 | 89.74 |
100
+ |CMMLU | 53.21 | 82.30 | 89.01 | 70.57 | 89.16 |
101
+ |MMLU | 70.40 | 73.40 | 82.90 | 69.94 | 85.90 |
102
+ |MMLU Pro | 38.50 | 45.25 | 58.01 | 33.95 | 58.31 |
103
+ |ARC_c | 85.08 | 90.17 | 94.24 | 79.66 | 91.86 |
104
+ |HellaSwag | 81.95 | 81.98 | 82.51 | 78.53 | 89.19 |
105
+ |LAMBADA | 76.79 | 73.74 | 75.37 | 78.83 | 79.74 |
106
+ |BBH | 50.87 | 57.28 | 67.69 | 50.35 | 55.82 |
107
+ |MuSR | 43.21 | 42.65 | 49.78 | 43.61 | 49.93 |
108
+ |PIQA | 83.41 | 82.15 | 80.05 | 79.54 | 87.32 |
109
+ |CommonSenseQA| 69.62 | 74.69 | 72.97 | 66.91 | 73.05 |
110
+ |IFEval | 24.15 | 32.97 | 41.59 | 29.08 | 30.06 |
111
+ |GPQA | 30.90 | 33.49 | 49.50 | 28.53 | 52.17 |
112
+ |HumanEval | 33.54 | 35.98 | 46.95 | 20.12 | 44.51 |
113
+ |MBPP | 60.70 | 49.40 | 71.00 | 30.00 | 43.40 |
114
+ |MATH Lv5 | 9.00 | 25.00 | 31.72 | 2.54 | 5.07 |
115
+ |GSM8K | 47.50 | 77.40 | 80.36 | 52.01 | 59.82 |
116
+ |MATH | 28.40 | 36.10 | 48.88 | 7.84 | 23.68 |
117
 
118
  ### 3.1.2. Comparison of LLM performances on Japanese testsets
119
+ | Model | JSQuAD | JCommonSenseQA | JNLI | MARC-ja | JAQKET v2 | PAWS-ja | avg |
120
+ |--------------|-------|-------|-------|-------|-------|-------|-------|
121
+ |Mixtral-8x7B | 89.00 | 78.73 | 32.13 | 95.44 | 78.86 | 44.50 | 69.78 |
122
+ |Qwen1.5-32B | 89.86 | 84.54 | 50.99 | 97.08 | 82.14 | 43.80 | 74.74 |
123
+ |Qwen2.5-32B | 89.09 | 93.83 | 72.14 | 97.86 | 89.27 | 42.15 | 80.73 |
124
+ |Orion-14B-Base| 74.22 | 88.20 | 72.85 | 94.06 | 66.20 | 49.90 | 74.24 |
125
+ |Orion 8x7B | 91.77 | 90.43 | 90.46 | 96.40 | 81.19 | 47.35 | 82.93 |
126
 
127
  ### 3.1.3. Comparison of LLM performances on Korean testsets
128
+ |Model | HAE-RAE | KoBEST BoolQ | KoBEST COPA | KoBEST HellaSwag | KoBEST SentiNeg | KoBEST WiC | PAWS-ko | avg |
129
+ |--------------|-------|-------|-------|-------|-------|-------|-------|-------|
130
+ |Mixtral-8x7B | 53.16 | 78.56 | 66.20 | 56.60 | 77.08 | 49.37 | 44.05 | 60.72 |
131
+ |Qwen1.5-32B | 46.38 | 76.28 | 60.40 | 53.00 | 78.34 | 52.14 | 43.40 | 58.56 |
132
+ |Qwen2.5-32B | 70.67 | 80.27 | 76.70 | 61.20 | 96.47 | 77.22 | 37.05 | 71.37 |
133
+ |Orion-14B-Base| 69.66 | 80.63 | 77.10 | 58.20 | 92.44 | 51.19 | 44.55 | 67.68 |
134
+ |Orion 8x7B | 65.17 | 85.40 | 80.40 | 56.00 | 96.98 | 73.57 | 46.35 | 71.98 |
135
 
136
  ### 3.1.4. Comparison of LLM performances on Arabic, German, French, and Spanish testsets
137
  | Lang | ar | | de | | fr | | es | |
138
  |----|----|----|----|----|----|----|----|----|
139
+ |**Model**|**HellaSwag**|**ARC**|**HellaSwag**|**ARC**|**HellaSwag**|**ARC**|**HellaSwag**|**ARC**|
140
+ |Mixtral-8x7B | 53.16 | 78.56 | 66.20 | 56.60 | 77.08 | 49.37 | 44.05 | 60.72 |
141
+ |Qwen1.5-32B | 46.38 | 76.28 | 60.40 | 53.00 | 78.34 | 52.14 | 43.40 | 58.56 |
142
+ |Qwen2.5-32B | 70.67 | 80.27 | 76.70 | 61.20 | 96.47 | 77.22 | 37.05 | 71.37 |
143
+ |Orion-14B-Base| 69.66 | 80.63 | 77.10 | 58.20 | 92.44 | 51.19 | 44.55 | 67.68 |
144
+ |Orion 8x7B | 65.17 | 85.40 | 80.40 | 56.00 | 96.98 | 73.57 | 46.35 | 71.98 |
145
 
146
  ### 3.1.5. Leakage Detection Benchmark
147
+ When the pre-training data of a large language model contains content from a specific dataset, the model’s performance on that dataset may be artificially enhanced, leading to inaccurate performance evaluations. To address this issue, researchers from the Shenzhen Institute of Advanced Technology, Chinese Academy of Sciences, and other institutions have proposed a simple and effective method for detecting data leakage. This method leverages the interchangeable nature of multiple-choice options by shuffling the options in the original dataset to generate derived data. The log-probability distribution of the derived dataset is then computed using the model to detect whether the original dataset has been leaked.
148
+
149
+ We conducted data leakage detection experiments on three benchmark datasets: MMLU, CMMLU, and C-Eval.
 
 
150
 
151
+ More details can be found in the paper: https://web3.arxiv.org/pdf/2409.01790.
152
+
153
+ Test code: https://github.com/nishiwen1214/Benchmark-leakage-detection.
154
+
155
+ |Threshold 0.2|Qwen2.5 32B|Qwen1.5 32B|Orion 8x7B|Orion 14B|Mixtral 8x7B|
156
  |------|------|------|------|------|------|
157
+ |MMLU | 0.30 | 0.27 | 0.22 | 0.28 | 0.25 |
158
+ |CEval | 0.39 | 0.38 | 0.27 | 0.26 | 0.26 |
159
+ |CMMLU | 0.38 | 0.39 | 0.23 | 0.27 | 0.22 |
160
 
161
+ ### 3.1.6. Inference speed[Todo]
162
  Based on 8x Nvidia RTX3090, in unit of tokens per second.
163
  |OrionLLM_V2.4.6.1 | 1para_out62 | 1para_out85 | 1para_out125 | 1para_out210 |
164
  |----|----|----|----|----|
 
225
  CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 python demo/text_generation_base.py --model OrionStarAI/Orion-MOE8x7B-Base --tokenizer OrionStarAI/Orion-MOE8x7B-Base --prompt hello
226
 
227
  ```
228
+ ## 4.3. [Todo] vLLM inference code
229
+
230
 
231
  <a name="declarations-license"></a><br>
232
  # 5. Declarations, License
README_zh.md CHANGED
@@ -44,8 +44,32 @@
44
  - 同规模参数级别基座大模型综合评测效果表现优异
45
  - 多语言能力强,在日语、韩语测试集上显著领先,在阿拉伯语、德语、法语、西班牙语测试集上也全面领先
46
 
47
-
48
-
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
49
 
50
 
51
  <a name="zh_model-download"></a><br>
@@ -65,76 +89,78 @@
65
  ## 3.1. 基座模型Orion-MOE8x7B-Base评估
66
 
67
  ### 3.1.1. 基座模型基准测试对比
68
- |TestSet | Mixtral 8*7B | Qwen1.5-32b | Qwen2.5-32b | Orion 14B | Orion 8*7B|
69
- | -- | -- | -- | -- | -- | -- |
70
- |ceval | 54.0861 | 83.5 | 87.7414 | 72.8 | 89.74|
71
- |cmmlu | 53.21 | 82.3 | 89.0088 | 70.57 | 89.1555|
72
- |mmlu | 70.4 | 73.4 | 82.9 | 69.94 | 85.9|
73
- |mmlu_pro | 38.5 | 45.25 | 58.01 | 33.95 | 58.31|
74
- |ARC_c | 85.0847 | 90.1695 | 94.2373 | 79.66 | 91.8644|
75
- |hellaswag | 81.9458 | 81.9757 | 82.5134 | 78.53 | 89.19|
76
- |lambada | 76.7902 | 73.7434 | 75.3736 | 78.83 | 79.7399|
77
- |bbh | 50.87 | 57.28 | 67.69 | 50.35 | 55.82|
78
- |musr | 43.21 | 42.65 | 49.78 | 43.61 | 49.93|
79
- |piqa | 83.41 | 82.15 | 80.05 | 79.54 | 87.32|
80
- |commonsense_qa | 69.62 | 74.69 | 72.97 | 66.91 | 73.05|
81
- |IFEval | 24.15 | 32.97 | 41.59 | 29.08 | 30.06|
82
- |GQPA | 30.9 | 33.49 | 49.5 | 28.53 | 52.17|
83
- |human-eval | 33.5366 | 35.9756 | 46.9512 | 20.12 | 44.5122|
84
- |MBPP | 60.7 | 49.4 | 71 | 30 | 43.4|
85
- |math lv5 | 9 | 25 | 31.72 | 2.54 | 5.07|
86
- |gsm8k | 47.5 | 77.4 | 80.363 | 52.01 | 59.82|
87
- |math | 28.4 | 36.1 | 48.88 | 7.84 | 23.68|
88
 
89
 
90
 
91
  ### 3.1.2. 小语种: 日文
92
- | Model | jsquad | jcommonsenseqa | jnli | marc_ja | jaqket_v2 | paws_ja | avg |
93
- |-------|---------|--------|-------|----------|-------|-----------|-----|
94
- |Mixtral-8x7B | 0.8900 | 0.7873 | 0.3213 | 0.9544 | 0.7886 | 44.5000 | 8.0403 |
95
- |Qwen1.5-32B | 0.8986 | 0.8454 | 0.5099 | 0.9708 | 0.8214 | 0.4380 | 0.7474 |
96
- |Qwen2.5-32B | 0.8909 | 0.9383 | 0.7214 | 0.9786 | 0.8927 | 0.4215 | 0.8073 |
97
- |Orion-14B-Base | 0.7422 | 0.8820 | 0.7285 | 0.9406 | 0.6620 | 0.4990 | 0.7424 |
98
- |Orion 8x7B |0.9177 |0.9043 |0.9046 |0.9640 |0.8119 |0.4735 |0.8293 |
99
 
100
 
101
  ### 3.1.3. 小语种�� 韩文
102
- |Model | haerae | kobest boolq | kobest copa | kobest hellaswag | kobest sentineg | kobest wic | paws_ko | avg |
103
- |--------|----|----|----|----|----|----|----|----|
104
- |Mixtral-8x7B | 53.16 | 78.56 | 66.2 | 56.6 | 77.08 | 49.37 | 44.05 | 60.71714286 |
105
- |Qwen1.5-32B | 46.38 | 76.28 | 60.4 | 53 | 78.34 | 52.14 | 43.4 | 58.56285714 |
106
- |Qwen2.5-32B | 70.67 | 80.27 | 76.7 | 61.2 | 96.47 | 77.22 | 37.05 | 71.36857143 |
107
- |Orion-14B-Base | 69.66 | 80.63 | 77.1 | 58.2 | 92.44 | 51.19 | 44.55 | 67.68142857 |
108
- |Orion 8x7B |65.17 |85.4 |80.4 |56 |96.98 |73.57 |46.35 |71.98142857 |
109
 
110
 
111
 
112
  ### 3.1.4. 小语种: 阿拉伯语,德语,法语,西班牙语
113
  | Lang | ar | | de | | fr | | es | |
114
- |------|----|--|----|--|----|--|----|--|
115
- |**model**|**hellaswag**|**arc**|**hellaswag**|**arc**|**hellaswag**|**arc**|**hellaswag**|**arc**|
116
- |Mixtral-8x7B | 47.93 | 36.27 | 69.17 | 52.35 | 73.9 | 55.86 | 74.25 | 54.79 |
117
- |Qwen1.5-32B | 50.07 | 39.95 | 63.77 | 50.81 | 68.86 | 55.95 | 70.5 | 55.13 |
118
- |Qwen2.5-32B | 59.76 | 52.87 | 69.82 | 61.76 | 74.15 | 62.7 | 75.04 | 65.3 |
119
- |Orion-14B-Base | 42.26 | 33.88 | 54.65 | 38.92 | 60.21 | 42.34 | 62 | 44.62 |
120
- |Orion 8x7B |69.39 |54.32 |80.6 |63.47 |85.56 |68.78 |87.41 |70.09 |
121
 
122
 
123
  ### 3.1.5. 泄漏检测结果
124
- 检测测试题目的泄露程度,值越大泄露的越严重
125
- - 检测代码: https://github.com/nishiwen1214/Benchmark-leakage-detection
126
- - 论文: https://web3.arxiv.org/pdf/2409.01790
127
- - 英文测试:mmlu
128
- - 中文测试:ceval, cmmlu
129
 
130
- |Threshold 0.2 | qwen2.5 32b | qwen1.5 32b | orion 8x7b | orion 14b | mixtral 8x7b |
131
- |----|----|----|----|----|----|
132
- |mmlu | 0.3 | 0.27 | 0.22 | 0.28 | 0.25 |
133
- |ceval | 0.39 | 0.38 | 0.27 | 0.26 | 0.26 |
134
- |cmmlu | 0.38 | 0.39 | 0.23 | 0.27 | 0.22 |
135
 
 
136
 
137
- ### 3.1.6. 推理速度
 
 
 
 
 
 
 
 
 
138
  基于8卡Nvidia RTX3090,单位是令牌每秒
139
  |OrionLLM_V2.4.6.1 | 1并发_输出62 | 1并发_输出85 | 1并发_输出125 | 1并发_输出210 |
140
  |----|----|----|----|----|
@@ -198,7 +224,7 @@ print(response)
198
  CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 python demo/text_generation_base.py --model OrionStarAI/Orion-MOE8x7B-Base --tokenizer OrionStarAI/Orion-MOE8x7B-Base --prompt 你好,你叫什么名字
199
 
200
  ```
201
-
202
 
203
 
204
  <a name="zh_declarations-license"></a><br>
 
44
  - 同规模参数级别基座大模型综合评测效果表现优异
45
  - 多语言能力强,在日语、韩语测试集上显著领先,在阿拉伯语、德语、法语、西班牙语测试集上也全面领先
46
 
47
+ - Orion-MOE8x7B-Base模型超参
48
+ - Orion-MOE8x7B-Base模型架构接近Mixtral 8x7B,超参细节请参考下表
49
+
50
+ |Configuration |OrionMOE 8*7B|
51
+ |-------------------|-------------|
52
+ |Hidden Size | 4096 |
53
+ |# Layers | 32 |
54
+ |# Query Heads | 32 |
55
+ |# KV Heads | 8 |
56
+ |Intermediate Size | 14592 |
57
+ |# Experts | 8 |
58
+ |# Activated Experts| 2 |
59
+ |Embedding Tying | False |
60
+ |Position embedding | RoPE |
61
+ |seq_len | 8192 |
62
+ |Vocabulary Size | 1136664 |
63
+
64
+ - Orion-MOE8x7B-Base训练超参
65
+ - 我们使用AdamW优化器将超参数设置为 𝛽1 = 0.9, 𝛽2 = 0.95,权重衰减为0.1。
66
+ - 训练开始时进行2000次预热阶段迭代,学习率线性增加至峰值3e-4,之后采用余弦调度,逐渐将学习率降低到3e-5以完成整个训练过程。
67
+ - 模型训练采用BF16/FP32混合精度,批量大小为2600,每步处理大约2200万个token。
68
+ - Orion-MOE8x7B-Base训练数据组成
69
+ - 预训练数据语种上主要由英语、中文和其他多语言语言组成,分别占比50%、25%和12%。数据分类上,代码占9%,数学文本占4%,分布参考下图。
70
+ <div align="center">
71
+ <img src="./assets/imgs/data_src_dist.png" alt="logo" width="80%" />
72
+ </div>
73
 
74
 
75
  <a name="zh_model-download"></a><br>
 
89
  ## 3.1. 基座模型Orion-MOE8x7B-Base评估
90
 
91
  ### 3.1.1. 基座模型基准测试对比
92
+ |TestSet|Mixtral 8*7B|Qwen1.5-32b|Qwen2.5-32b|Orion 14B|Orion 8*7B|
93
+ | ----------- | ----- | ----- | ----- | ----- | ----- |
94
+ |CEval | 54.09 | 83.50 | 87.74 | 72.80 | 89.74 |
95
+ |CMMLU | 53.21 | 82.30 | 89.01 | 70.57 | 89.16 |
96
+ |MMLU | 70.40 | 73.40 | 82.90 | 69.94 | 85.90 |
97
+ |MMLU Pro | 38.50 | 45.25 | 58.01 | 33.95 | 58.31 |
98
+ |ARC_c | 85.08 | 90.17 | 94.24 | 79.66 | 91.86 |
99
+ |HellaSwag | 81.95 | 81.98 | 82.51 | 78.53 | 89.19 |
100
+ |LAMBADA | 76.79 | 73.74 | 75.37 | 78.83 | 79.74 |
101
+ |BBH | 50.87 | 57.28 | 67.69 | 50.35 | 55.82 |
102
+ |MuSR | 43.21 | 42.65 | 49.78 | 43.61 | 49.93 |
103
+ |PIQA | 83.41 | 82.15 | 80.05 | 79.54 | 87.32 |
104
+ |CommonSenseQA| 69.62 | 74.69 | 72.97 | 66.91 | 73.05 |
105
+ |IFEval | 24.15 | 32.97 | 41.59 | 29.08 | 30.06 |
106
+ |GPQA | 30.90 | 33.49 | 49.50 | 28.53 | 52.17 |
107
+ |HumanEval | 33.54 | 35.98 | 46.95 | 20.12 | 44.51 |
108
+ |MBPP | 60.70 | 49.40 | 71.00 | 30.00 | 43.40 |
109
+ |MATH Lv5 | 9.00 | 25.00 | 31.72 | 2.54 | 5.07 |
110
+ |GSM8K | 47.50 | 77.40 | 80.36 | 52.01 | 59.82 |
111
+ |MATH | 28.40 | 36.10 | 48.88 | 7.84 | 23.68 |
112
 
113
 
114
 
115
  ### 3.1.2. 小语种: 日文
116
+ | Model | JSQuAD | JCommonSenseQA | JNLI | MARC-ja | JAQKET v2 | PAWS-ja | avg |
117
+ |--------------|-------|-------|-------|-------|-------|-------|-------|
118
+ |Mixtral-8x7B | 89.00 | 78.73 | 32.13 | 95.44 | 78.86 | 44.50 | 69.78 |
119
+ |Qwen1.5-32B | 89.86 | 84.54 | 50.99 | 97.08 | 82.14 | 43.80 | 74.74 |
120
+ |Qwen2.5-32B | 89.09 | 93.83 | 72.14 | 97.86 | 89.27 | 42.15 | 80.73 |
121
+ |Orion-14B-Base| 74.22 | 88.20 | 72.85 | 94.06 | 66.20 | 49.90 | 74.24 |
122
+ |Orion 8x7B | 91.77 | 90.43 | 90.46 | 96.40 | 81.19 | 47.35 | 82.93 |
123
 
124
 
125
  ### 3.1.3. 小语种�� 韩文
126
+ |Model | HAE-RAE | KoBEST BoolQ | KoBEST COPA | KoBEST HellaSwag | KoBEST SentiNeg | KoBEST WiC | PAWS-ko | avg |
127
+ |--------------|-------|-------|-------|-------|-------|-------|-------|-------|
128
+ |Mixtral-8x7B | 53.16 | 78.56 | 66.20 | 56.60 | 77.08 | 49.37 | 44.05 | 60.72 |
129
+ |Qwen1.5-32B | 46.38 | 76.28 | 60.40 | 53.00 | 78.34 | 52.14 | 43.40 | 58.56 |
130
+ |Qwen2.5-32B | 70.67 | 80.27 | 76.70 | 61.20 | 96.47 | 77.22 | 37.05 | 71.37 |
131
+ |Orion-14B-Base| 69.66 | 80.63 | 77.10 | 58.20 | 92.44 | 51.19 | 44.55 | 67.68 |
132
+ |Orion 8x7B | 65.17 | 85.40 | 80.40 | 56.00 | 96.98 | 73.57 | 46.35 | 71.98 |
133
 
134
 
135
 
136
  ### 3.1.4. 小语种: 阿拉伯语,德语,法语,西班牙语
137
  | Lang | ar | | de | | fr | | es | |
138
+ |----|----|----|----|----|----|----|----|----|
139
+ |**Model**|**HellaSwag**|**ARC**|**HellaSwag**|**ARC**|**HellaSwag**|**ARC**|**HellaSwag**|**ARC**|
140
+ |Mixtral-8x7B | 53.16 | 78.56 | 66.20 | 56.60 | 77.08 | 49.37 | 44.05 | 60.72 |
141
+ |Qwen1.5-32B | 46.38 | 76.28 | 60.40 | 53.00 | 78.34 | 52.14 | 43.40 | 58.56 |
142
+ |Qwen2.5-32B | 70.67 | 80.27 | 76.70 | 61.20 | 96.47 | 77.22 | 37.05 | 71.37 |
143
+ |Orion-14B-Base| 69.66 | 80.63 | 77.10 | 58.20 | 92.44 | 51.19 | 44.55 | 67.68 |
144
+ |Orion 8x7B | 65.17 | 85.40 | 80.40 | 56.00 | 96.98 | 73.57 | 46.35 | 71.98 |
145
 
146
 
147
  ### 3.1.5. 泄漏检测结果
148
+ 当大型语言模型的预训练数据包含特定数据集的内容时,该模型在该数据集上的表现可能会被人为提高,从而导致不准确的性能评估。为了解决这个问题,来自中国科学院深圳先进技术研究院和其他机构的研究人员提出了一种简单有效的数据泄露检测方法。该方法利用多选项的可互换性,通过打乱原始数据集中的选项生成派生数据。然后,使用模型计算派生数据集的对数概率分布,以检测原始数据集是否存在泄露。
 
 
 
 
149
 
150
+ 我们在三个基准数据集上进行了数据泄露检测实验:MMLU、CMMLU C-Eval。
 
 
 
 
151
 
152
+ 更多细节可以在论文中找到:https://web3.arxiv.org/pdf/2409.01790。
153
 
154
+ 测试代码:https://github.com/nishiwen1214/Benchmark-leakage-detection。
155
+
156
+ |Threshold 0.2|Qwen2.5 32B|Qwen1.5 32B|Orion 8x7B|Orion 14B|Mixtral 8x7B|
157
+ |------|------|------|------|------|------|
158
+ |MMLU | 0.30 | 0.27 | 0.22 | 0.28 | 0.25 |
159
+ |CEval | 0.39 | 0.38 | 0.27 | 0.26 | 0.26 |
160
+ |CMMLU | 0.38 | 0.39 | 0.23 | 0.27 | 0.22 |
161
+
162
+
163
+ ### 3.1.6. 推理速度[Todo: Remove result of 14B, add more description of result]
164
  基于8卡Nvidia RTX3090,单位是令牌每秒
165
  |OrionLLM_V2.4.6.1 | 1并发_输出62 | 1并发_输出85 | 1并发_输出125 | 1并发_输出210 |
166
  |----|----|----|----|----|
 
224
  CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 python demo/text_generation_base.py --model OrionStarAI/Orion-MOE8x7B-Base --tokenizer OrionStarAI/Orion-MOE8x7B-Base --prompt 你好,你叫什么名字
225
 
226
  ```
227
+ ## 4.3. [Todo] vLLM推理代码
228
 
229
 
230
  <a name="zh_declarations-license"></a><br>
assets/imgs/data_src_dist.png ADDED
config.json CHANGED
@@ -1,13 +1,13 @@
1
  {
2
  "_name_or_path": "Orion-MoE 8x7b",
3
  "architectures": [
4
- "OrionCausalLM"
5
  ],
6
  "attention_bias": false,
7
  "attention_dropout": 0.0,
8
  "auto_map": {
9
- "AutoConfig": "configuration_orion.OrionConfig",
10
- "AutoModelForCausalLM": "modeling_orion.OrionForCausalLM"
11
  },
12
  "bos_token_id": 1,
13
  "eos_token_id": 2,
 
1
  {
2
  "_name_or_path": "Orion-MoE 8x7b",
3
  "architectures": [
4
+ "OrionMOECausalLM"
5
  ],
6
  "attention_bias": false,
7
  "attention_dropout": 0.0,
8
  "auto_map": {
9
+ "AutoConfig": "configuration_orion.OrionMOEConfig",
10
+ "AutoModelForCausalLM": "modeling_orion.OrionMOEForCausalLM"
11
  },
12
  "bos_token_id": 1,
13
  "eos_token_id": 2,
configuration_orion.py CHANGED
@@ -8,12 +8,12 @@ from transformers.utils import logging
8
  logger = logging.get_logger(__name__)
9
 
10
 
11
- class OrionConfig(PretrainedConfig):
12
  """
13
  Args:
14
  vocab_size (`int`, *optional*, defaults to 113664):
15
- Vocabulary size of the Orion model. Defines the number of different tokens that can be represented by the
16
- `inputs_ids` passed when calling [`OrionModel`]
17
  hidden_size (`int`, *optional*, defaults to 4096):
18
  Dimension of the hidden representations.
19
  intermediate_size (`int`, *optional*, defaults to 14592):
@@ -32,7 +32,7 @@ class OrionConfig(PretrainedConfig):
32
  hidden_act (`str` or `function`, *optional*, defaults to `"silu"`):
33
  The non-linear activation function (function or string) in the decoder.
34
  max_position_embeddings (`int`, *optional*, defaults to `8192`):
35
- The maximum sequence length that this model might ever be used with. Orion's sliding window attention
36
  allows sequence of up to 4096*32 tokens.
37
  initializer_range (`float`, *optional*, defaults to 0.02):
38
  The standard deviation of the truncated_normal_initializer for initializing all weight matrices.
 
8
  logger = logging.get_logger(__name__)
9
 
10
 
11
+ class OrionMOEConfig(PretrainedConfig):
12
  """
13
  Args:
14
  vocab_size (`int`, *optional*, defaults to 113664):
15
+ Vocabulary size of the OrionMOE model. Defines the number of different tokens that can be represented by the
16
+ `inputs_ids` passed when calling [`OrionMOEModel`]
17
  hidden_size (`int`, *optional*, defaults to 4096):
18
  Dimension of the hidden representations.
19
  intermediate_size (`int`, *optional*, defaults to 14592):
 
32
  hidden_act (`str` or `function`, *optional*, defaults to `"silu"`):
33
  The non-linear activation function (function or string) in the decoder.
34
  max_position_embeddings (`int`, *optional*, defaults to `8192`):
35
+ The maximum sequence length that this model might ever be used with. OrionMOE's sliding window attention
36
  allows sequence of up to 4096*32 tokens.
37
  initializer_range (`float`, *optional*, defaults to 0.02):
38
  The standard deviation of the truncated_normal_initializer for initializing all weight matrices.
modeling_orion.py CHANGED
@@ -34,7 +34,7 @@ from transformers.utils import (
34
  replace_return_docstrings,
35
  )
36
  from transformers.utils.import_utils import is_torch_fx_available
37
- from .configuration_orion import OrionConfig
38
 
39
 
40
  if is_flash_attn_2_available():
@@ -54,7 +54,7 @@ if is_torch_fx_available():
54
 
55
  logger = logging.get_logger(__name__)
56
 
57
- _CONFIG_FOR_DOC = "OrionConfig"
58
 
59
  def load_balancing_loss_func(
60
  gate_logits: torch.Tensor, num_experts: torch.Tensor = None, top_k=2, attention_mask: Optional[torch.Tensor] = None
@@ -145,10 +145,10 @@ def _get_unpad_data(attention_mask):
145
  )
146
 
147
 
148
- class OrionRMSNorm(nn.Module):
149
  def __init__(self, hidden_size, eps=1e-6):
150
  """
151
- OrionRMSNorm is equivalent to T5LayerNorm
152
  """
153
  super().__init__()
154
  self.weight = nn.Parameter(torch.ones(hidden_size))
@@ -162,7 +162,7 @@ class OrionRMSNorm(nn.Module):
162
  return self.weight * hidden_states.to(input_dtype)
163
 
164
 
165
- class OrionRotaryEmbedding(nn.Module):
166
  def __init__(self, dim, max_position_embeddings=2048, base=10000, device=None):
167
  super().__init__()
168
 
@@ -248,13 +248,13 @@ def repeat_kv(hidden_states: torch.Tensor, n_rep: int) -> torch.Tensor:
248
  return hidden_states.reshape(batch, num_key_value_heads * n_rep, slen, head_dim)
249
 
250
 
251
- class OrionAttention(nn.Module):
252
  """
253
  Multi-headed attention from 'Attention Is All You Need' paper. Modified to use sliding window attention: Longformer
254
  and "Generating Long Sequences with Sparse Transformers".
255
  """
256
 
257
- def __init__(self, config: OrionConfig, layer_idx: Optional[int] = None):
258
  super().__init__()
259
  self.config = config
260
  self.layer_idx = layer_idx
@@ -285,7 +285,7 @@ class OrionAttention(nn.Module):
285
  self.v_proj = nn.Linear(self.hidden_size, self.num_key_value_heads * self.head_dim, bias=False)
286
  self.o_proj = nn.Linear(self.num_heads * self.head_dim, self.hidden_size, bias=False)
287
 
288
- self.rotary_emb = OrionRotaryEmbedding(
289
  self.head_dim,
290
  max_position_embeddings=self.max_position_embeddings,
291
  base=self.rope_theta,
@@ -376,9 +376,9 @@ class OrionAttention(nn.Module):
376
  return attn_output, attn_weights, past_key_value
377
 
378
 
379
- class OrionFlashAttention2(OrionAttention):
380
  """
381
- Orion flash attention module. This module inherits from `OrionAttention` as the weights of the module stays
382
  untouched. The only required change would be on the forward pass where it needs to correctly call the public API of
383
  flash attention and deal with padding tokens in case the input contains any of them.
384
  """
@@ -670,14 +670,14 @@ class OrionFlashAttention2(OrionAttention):
670
  )
671
 
672
 
673
- class OrionSdpaAttention(OrionAttention):
674
  """
675
- Orion attention module using torch.nn.functional.scaled_dot_product_attention. This module inherits from
676
- `OrionAttention` as the weights of the module stays untouched. The only changes are on the forward pass to adapt to
677
  SDPA API.
678
  """
679
 
680
- # Adapted from OrionAttention.forward
681
  def forward(
682
  self,
683
  hidden_states: torch.Tensor,
@@ -690,7 +690,7 @@ class OrionSdpaAttention(OrionAttention):
690
  if output_attentions:
691
  # TODO: Improve this warning with e.g. `model.config.attn_implementation = "manual"` once this is implemented.
692
  logger.warning_once(
693
- "OrionModel is using OrionSdpaAttention, but `torch.nn.functional.scaled_dot_product_attention` does not support `output_attentions=True`. Falling back to the manual attention implementation, "
694
  'but specifying the manual implementation will be required from Transformers version v5.0.0 onwards. This warning can be removed using the argument `attn_implementation="eager"` when loading the model.'
695
  )
696
  return super().forward(
@@ -758,14 +758,14 @@ class OrionSdpaAttention(OrionAttention):
758
 
759
 
760
  ORION_ATTENTION_CLASSES = {
761
- "eager": OrionAttention,
762
- "flash_attention_2": OrionFlashAttention2,
763
- "sdpa": OrionSdpaAttention,
764
  }
765
 
766
 
767
- class OrionBlockSparseTop2MLP(nn.Module):
768
- def __init__(self, config: OrionConfig):
769
  super().__init__()
770
  self.ffn_dim = config.intermediate_size
771
  self.hidden_dim = config.hidden_size
@@ -782,7 +782,7 @@ class OrionBlockSparseTop2MLP(nn.Module):
782
  return current_hidden_states
783
 
784
 
785
- class OrionSparseMoeBlock(nn.Module):
786
  """
787
  This implementation is
788
  strictly equivalent to standard MoE with full capacity (no
@@ -804,7 +804,7 @@ class OrionSparseMoeBlock(nn.Module):
804
  # gating
805
  self.gate = nn.Linear(self.hidden_dim, self.num_experts, bias=False)
806
 
807
- self.experts = nn.ModuleList([OrionBlockSparseTop2MLP(config) for _ in range(self.num_experts)])
808
 
809
  # Jitter parameters
810
  self.jitter_noise = config.router_jitter_noise
@@ -847,16 +847,16 @@ class OrionSparseMoeBlock(nn.Module):
847
  return final_hidden_states, router_logits
848
 
849
 
850
- class OrionDecoderLayer(nn.Module):
851
- def __init__(self, config: OrionConfig, layer_idx: int):
852
  super().__init__()
853
  self.hidden_size = config.hidden_size
854
 
855
  self.self_attn = ORION_ATTENTION_CLASSES[config._attn_implementation](config, layer_idx)
856
 
857
- self.block_sparse_moe = OrionSparseMoeBlock(config)
858
- self.input_layernorm = OrionRMSNorm(config.hidden_size, eps=config.rms_norm_eps)
859
- self.post_attention_layernorm = OrionRMSNorm(config.hidden_size, eps=config.rms_norm_eps)
860
 
861
  def forward(
862
  self,
@@ -935,7 +935,7 @@ ORION_START_DOCSTRING = r"""
935
  and behavior.
936
 
937
  Parameters:
938
- config ([`OrionConfig`]):
939
  Model configuration class with all the parameters of the model. Initializing with a config file does not
940
  load the weights associated with the model, only the configuration. Check out the
941
  [`~PreTrainedModel.from_pretrained`] method to load the model weights.
@@ -943,15 +943,15 @@ ORION_START_DOCSTRING = r"""
943
 
944
 
945
  @add_start_docstrings(
946
- "The bare Orion Model outputting raw hidden-states without any specific head on top.",
947
  ORION_START_DOCSTRING,
948
  )
949
 
950
- class OrionPreTrainedModel(PreTrainedModel):
951
- config_class = OrionConfig
952
  base_model_prefix = "model"
953
  supports_gradient_checkpointing = True
954
- _no_split_modules = ["OrionDecoderLayer"]
955
  _skip_keys_device_placement = "past_key_values"
956
  _supports_flash_attn_2 = True
957
  _supports_sdpa = True
@@ -1037,28 +1037,28 @@ ORION_INPUTS_DOCSTRING = r"""
1037
 
1038
 
1039
  @add_start_docstrings(
1040
- "The bare Orion Model outputting raw hidden-states without any specific head on top.",
1041
  ORION_START_DOCSTRING,
1042
  )
1043
- class OrionModel(OrionPreTrainedModel):
1044
  """
1045
- Transformer decoder consisting of *config.num_hidden_layers* layers. Each layer is a [`OrionDecoderLayer`]
1046
 
1047
  Args:
1048
- config: OrionConfig
1049
  """
1050
 
1051
- def __init__(self, config: OrionConfig):
1052
  super().__init__(config)
1053
  self.padding_idx = config.pad_token_id
1054
  self.vocab_size = config.vocab_size
1055
 
1056
  self.embed_tokens = nn.Embedding(config.vocab_size, config.hidden_size, self.padding_idx)
1057
  self.layers = nn.ModuleList(
1058
- [OrionDecoderLayer(config, layer_idx) for layer_idx in range(config.num_hidden_layers)]
1059
  )
1060
  self._attn_implementation = config._attn_implementation
1061
- self.norm = OrionRMSNorm(config.hidden_size, eps=config.rms_norm_eps)
1062
 
1063
  self.gradient_checkpointing = False
1064
  # Initialize weights and apply final processing
@@ -1138,7 +1138,7 @@ class OrionModel(OrionPreTrainedModel):
1138
  if is_padding_right:
1139
  raise ValueError(
1140
  "You are attempting to perform batched generation with padding_side='right'"
1141
- " this may lead to unexpected behaviour for Flash Attention version of Orion. Make sure to "
1142
  " call `tokenizer.padding_side = 'left'` before tokenizing the input. "
1143
  )
1144
 
@@ -1235,12 +1235,12 @@ class OrionModel(OrionPreTrainedModel):
1235
  )
1236
 
1237
 
1238
- class OrionForCausalLM(OrionPreTrainedModel):
1239
  _tied_weights_keys = ["lm_head.weight"]
1240
 
1241
  def __init__(self, config):
1242
  super().__init__(config)
1243
- self.model = OrionModel(config)
1244
  self.vocab_size = config.vocab_size
1245
  self.lm_head = nn.Linear(config.hidden_size, config.vocab_size, bias=False)
1246
  self.router_aux_loss_coef = config.router_aux_loss_coef
@@ -1438,9 +1438,9 @@ class OrionForCausalLM(OrionPreTrainedModel):
1438
 
1439
  @add_start_docstrings(
1440
  """
1441
- The Orion Model transformer with a sequence classification head on top (linear layer).
1442
 
1443
- [`OrionForSequenceClassification`] uses the last token in order to do the classification, as other causal models
1444
  (e.g. GPT-2) do.
1445
 
1446
  Since it does classification on the last token, it requires to know the position of the last token. If a
@@ -1451,11 +1451,11 @@ class OrionForCausalLM(OrionPreTrainedModel):
1451
  """,
1452
  ORION_START_DOCSTRING,
1453
  )
1454
- class OrionForSequenceClassification(OrionPreTrainedModel):
1455
  def __init__(self, config):
1456
  super().__init__(config)
1457
  self.num_labels = config.num_labels
1458
- self.model = OrionModel(config)
1459
  self.score = nn.Linear(config.hidden_size, self.num_labels, bias=False)
1460
 
1461
  # Initialize weights and apply final processing
 
34
  replace_return_docstrings,
35
  )
36
  from transformers.utils.import_utils import is_torch_fx_available
37
+ from .configuration_orion import OrionMOEConfig
38
 
39
 
40
  if is_flash_attn_2_available():
 
54
 
55
  logger = logging.get_logger(__name__)
56
 
57
+ _CONFIG_FOR_DOC = "OrionMOEConfig"
58
 
59
  def load_balancing_loss_func(
60
  gate_logits: torch.Tensor, num_experts: torch.Tensor = None, top_k=2, attention_mask: Optional[torch.Tensor] = None
 
145
  )
146
 
147
 
148
+ class OrionMOERMSNorm(nn.Module):
149
  def __init__(self, hidden_size, eps=1e-6):
150
  """
151
+ OrionMOERMSNorm is equivalent to T5LayerNorm
152
  """
153
  super().__init__()
154
  self.weight = nn.Parameter(torch.ones(hidden_size))
 
162
  return self.weight * hidden_states.to(input_dtype)
163
 
164
 
165
+ class OrionMOERotaryEmbedding(nn.Module):
166
  def __init__(self, dim, max_position_embeddings=2048, base=10000, device=None):
167
  super().__init__()
168
 
 
248
  return hidden_states.reshape(batch, num_key_value_heads * n_rep, slen, head_dim)
249
 
250
 
251
+ class OrionMOEAttention(nn.Module):
252
  """
253
  Multi-headed attention from 'Attention Is All You Need' paper. Modified to use sliding window attention: Longformer
254
  and "Generating Long Sequences with Sparse Transformers".
255
  """
256
 
257
+ def __init__(self, config: OrionMOEConfig, layer_idx: Optional[int] = None):
258
  super().__init__()
259
  self.config = config
260
  self.layer_idx = layer_idx
 
285
  self.v_proj = nn.Linear(self.hidden_size, self.num_key_value_heads * self.head_dim, bias=False)
286
  self.o_proj = nn.Linear(self.num_heads * self.head_dim, self.hidden_size, bias=False)
287
 
288
+ self.rotary_emb = OrionMOERotaryEmbedding(
289
  self.head_dim,
290
  max_position_embeddings=self.max_position_embeddings,
291
  base=self.rope_theta,
 
376
  return attn_output, attn_weights, past_key_value
377
 
378
 
379
+ class OrionMOEFlashAttention2(OrionMOEAttention):
380
  """
381
+ OrionMOE flash attention module. This module inherits from `OrionMOEAttention` as the weights of the module stays
382
  untouched. The only required change would be on the forward pass where it needs to correctly call the public API of
383
  flash attention and deal with padding tokens in case the input contains any of them.
384
  """
 
670
  )
671
 
672
 
673
+ class OrionMOESdpaAttention(OrionMOEAttention):
674
  """
675
+ OrionMOE attention module using torch.nn.functional.scaled_dot_product_attention. This module inherits from
676
+ `OrionMOEAttention` as the weights of the module stays untouched. The only changes are on the forward pass to adapt to
677
  SDPA API.
678
  """
679
 
680
+ # Adapted from OrionMOEAttention.forward
681
  def forward(
682
  self,
683
  hidden_states: torch.Tensor,
 
690
  if output_attentions:
691
  # TODO: Improve this warning with e.g. `model.config.attn_implementation = "manual"` once this is implemented.
692
  logger.warning_once(
693
+ "OrionMOEModel is using OrionMOESdpaAttention, but `torch.nn.functional.scaled_dot_product_attention` does not support `output_attentions=True`. Falling back to the manual attention implementation, "
694
  'but specifying the manual implementation will be required from Transformers version v5.0.0 onwards. This warning can be removed using the argument `attn_implementation="eager"` when loading the model.'
695
  )
696
  return super().forward(
 
758
 
759
 
760
  ORION_ATTENTION_CLASSES = {
761
+ "eager": OrionMOEAttention,
762
+ "flash_attention_2": OrionMOEFlashAttention2,
763
+ "sdpa": OrionMOESdpaAttention,
764
  }
765
 
766
 
767
+ class OrionMOEBlockSparseTop2MLP(nn.Module):
768
+ def __init__(self, config: OrionMOEConfig):
769
  super().__init__()
770
  self.ffn_dim = config.intermediate_size
771
  self.hidden_dim = config.hidden_size
 
782
  return current_hidden_states
783
 
784
 
785
+ class OrionMOESparseMoeBlock(nn.Module):
786
  """
787
  This implementation is
788
  strictly equivalent to standard MoE with full capacity (no
 
804
  # gating
805
  self.gate = nn.Linear(self.hidden_dim, self.num_experts, bias=False)
806
 
807
+ self.experts = nn.ModuleList([OrionMOEBlockSparseTop2MLP(config) for _ in range(self.num_experts)])
808
 
809
  # Jitter parameters
810
  self.jitter_noise = config.router_jitter_noise
 
847
  return final_hidden_states, router_logits
848
 
849
 
850
+ class OrionMOEDecoderLayer(nn.Module):
851
+ def __init__(self, config: OrionMOEConfig, layer_idx: int):
852
  super().__init__()
853
  self.hidden_size = config.hidden_size
854
 
855
  self.self_attn = ORION_ATTENTION_CLASSES[config._attn_implementation](config, layer_idx)
856
 
857
+ self.block_sparse_moe = OrionMOESparseMoeBlock(config)
858
+ self.input_layernorm = OrionMOERMSNorm(config.hidden_size, eps=config.rms_norm_eps)
859
+ self.post_attention_layernorm = OrionMOERMSNorm(config.hidden_size, eps=config.rms_norm_eps)
860
 
861
  def forward(
862
  self,
 
935
  and behavior.
936
 
937
  Parameters:
938
+ config ([`OrionMOEConfig`]):
939
  Model configuration class with all the parameters of the model. Initializing with a config file does not
940
  load the weights associated with the model, only the configuration. Check out the
941
  [`~PreTrainedModel.from_pretrained`] method to load the model weights.
 
943
 
944
 
945
  @add_start_docstrings(
946
+ "The bare OrionMOE Model outputting raw hidden-states without any specific head on top.",
947
  ORION_START_DOCSTRING,
948
  )
949
 
950
+ class OrionMOEPreTrainedModel(PreTrainedModel):
951
+ config_class = OrionMOEConfig
952
  base_model_prefix = "model"
953
  supports_gradient_checkpointing = True
954
+ _no_split_modules = ["OrionMOEDecoderLayer"]
955
  _skip_keys_device_placement = "past_key_values"
956
  _supports_flash_attn_2 = True
957
  _supports_sdpa = True
 
1037
 
1038
 
1039
  @add_start_docstrings(
1040
+ "The bare OrionMOE Model outputting raw hidden-states without any specific head on top.",
1041
  ORION_START_DOCSTRING,
1042
  )
1043
+ class OrionMOEModel(OrionMOEPreTrainedModel):
1044
  """
1045
+ Transformer decoder consisting of *config.num_hidden_layers* layers. Each layer is a [`OrionMOEDecoderLayer`]
1046
 
1047
  Args:
1048
+ config: OrionMOEConfig
1049
  """
1050
 
1051
+ def __init__(self, config: OrionMOEConfig):
1052
  super().__init__(config)
1053
  self.padding_idx = config.pad_token_id
1054
  self.vocab_size = config.vocab_size
1055
 
1056
  self.embed_tokens = nn.Embedding(config.vocab_size, config.hidden_size, self.padding_idx)
1057
  self.layers = nn.ModuleList(
1058
+ [OrionMOEDecoderLayer(config, layer_idx) for layer_idx in range(config.num_hidden_layers)]
1059
  )
1060
  self._attn_implementation = config._attn_implementation
1061
+ self.norm = OrionMOERMSNorm(config.hidden_size, eps=config.rms_norm_eps)
1062
 
1063
  self.gradient_checkpointing = False
1064
  # Initialize weights and apply final processing
 
1138
  if is_padding_right:
1139
  raise ValueError(
1140
  "You are attempting to perform batched generation with padding_side='right'"
1141
+ " this may lead to unexpected behaviour for Flash Attention version of OrionMOE. Make sure to "
1142
  " call `tokenizer.padding_side = 'left'` before tokenizing the input. "
1143
  )
1144
 
 
1235
  )
1236
 
1237
 
1238
+ class OrionMOEForCausalLM(OrionMOEPreTrainedModel):
1239
  _tied_weights_keys = ["lm_head.weight"]
1240
 
1241
  def __init__(self, config):
1242
  super().__init__(config)
1243
+ self.model = OrionMOEModel(config)
1244
  self.vocab_size = config.vocab_size
1245
  self.lm_head = nn.Linear(config.hidden_size, config.vocab_size, bias=False)
1246
  self.router_aux_loss_coef = config.router_aux_loss_coef
 
1438
 
1439
  @add_start_docstrings(
1440
  """
1441
+ The OrionMOE Model transformer with a sequence classification head on top (linear layer).
1442
 
1443
+ [`OrionMOEForSequenceClassification`] uses the last token in order to do the classification, as other causal models
1444
  (e.g. GPT-2) do.
1445
 
1446
  Since it does classification on the last token, it requires to know the position of the last token. If a
 
1451
  """,
1452
  ORION_START_DOCSTRING,
1453
  )
1454
+ class OrionMOEForSequenceClassification(OrionMOEPreTrainedModel):
1455
  def __init__(self, config):
1456
  super().__init__(config)
1457
  self.num_labels = config.num_labels
1458
+ self.model = OrionMOEModel(config)
1459
  self.score = nn.Linear(config.hidden_size, self.num_labels, bias=False)
1460
 
1461
  # Initialize weights and apply final processing