mlavkin commited on
Commit
b637d38
·
verified ·
1 Parent(s): 48b4442

RTN W8A16 INT8 from operationrange/MiniMax-M2.7-BF16 (group=128 sym, ignore=lm_head+router+gate+embed, no calibration)

Browse files
This view is limited to 50 files because it contains too many changes.   See raw diff
Files changed (50) hide show
  1. .gitattributes +2 -0
  2. README.md +141 -0
  3. added_tokens.json +56 -0
  4. chat_template.jinja +159 -0
  5. config.json +208 -0
  6. configuration_minimax_m2.py +200 -0
  7. generation_config.json +8 -0
  8. merges.txt +0 -0
  9. model-00001-of-00047.safetensors +3 -0
  10. model-00002-of-00047.safetensors +3 -0
  11. model-00003-of-00047.safetensors +3 -0
  12. model-00004-of-00047.safetensors +3 -0
  13. model-00005-of-00047.safetensors +3 -0
  14. model-00006-of-00047.safetensors +3 -0
  15. model-00007-of-00047.safetensors +3 -0
  16. model-00008-of-00047.safetensors +3 -0
  17. model-00009-of-00047.safetensors +3 -0
  18. model-00010-of-00047.safetensors +3 -0
  19. model-00011-of-00047.safetensors +3 -0
  20. model-00012-of-00047.safetensors +3 -0
  21. model-00013-of-00047.safetensors +3 -0
  22. model-00014-of-00047.safetensors +3 -0
  23. model-00015-of-00047.safetensors +3 -0
  24. model-00016-of-00047.safetensors +3 -0
  25. model-00017-of-00047.safetensors +3 -0
  26. model-00018-of-00047.safetensors +3 -0
  27. model-00019-of-00047.safetensors +3 -0
  28. model-00020-of-00047.safetensors +3 -0
  29. model-00021-of-00047.safetensors +3 -0
  30. model-00022-of-00047.safetensors +3 -0
  31. model-00023-of-00047.safetensors +3 -0
  32. model-00024-of-00047.safetensors +3 -0
  33. model-00025-of-00047.safetensors +3 -0
  34. model-00026-of-00047.safetensors +3 -0
  35. model-00027-of-00047.safetensors +3 -0
  36. model-00028-of-00047.safetensors +3 -0
  37. model-00029-of-00047.safetensors +3 -0
  38. model-00030-of-00047.safetensors +3 -0
  39. model-00031-of-00047.safetensors +3 -0
  40. model-00032-of-00047.safetensors +3 -0
  41. model-00033-of-00047.safetensors +3 -0
  42. model-00034-of-00047.safetensors +3 -0
  43. model-00035-of-00047.safetensors +3 -0
  44. model-00036-of-00047.safetensors +3 -0
  45. model-00037-of-00047.safetensors +3 -0
  46. model-00038-of-00047.safetensors +3 -0
  47. model-00039-of-00047.safetensors +3 -0
  48. model-00040-of-00047.safetensors +3 -0
  49. model-00041-of-00047.safetensors +3 -0
  50. model-00042-of-00047.safetensors +3 -0
.gitattributes CHANGED
@@ -33,3 +33,5 @@ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
33
  *.zip filter=lfs diff=lfs merge=lfs -text
34
  *.zst filter=lfs diff=lfs merge=lfs -text
35
  *tfevents* filter=lfs diff=lfs merge=lfs -text
 
 
 
33
  *.zip filter=lfs diff=lfs merge=lfs -text
34
  *.zst filter=lfs diff=lfs merge=lfs -text
35
  *tfevents* filter=lfs diff=lfs merge=lfs -text
36
+ model.safetensors.index.json filter=lfs diff=lfs merge=lfs -text
37
+ tokenizer.json filter=lfs diff=lfs merge=lfs -text
README.md ADDED
@@ -0,0 +1,141 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ license: other
3
+ license_name: minimax-license
4
+ license_link: https://huggingface.co/MiniMaxAI/MiniMax-M2.7/blob/main/LICENSE
5
+ base_model: MiniMaxAI/MiniMax-M2.7
6
+ base_model_relation: quantized
7
+ library_name: transformers
8
+ pipeline_tag: text-generation
9
+ language:
10
+ - en
11
+ - zh
12
+ - ru
13
+ tags:
14
+ - minimax
15
+ - minimax-m2
16
+ - moe
17
+ - mixture-of-experts
18
+ - int8
19
+ - w8a16
20
+ - rtn
21
+ - compressed-tensors
22
+ - sglang
23
+ - vllm
24
+ ---
25
+
26
+ # MiniMax-M2.7 — INT8 (W8A16, RTN)
27
+
28
+ Round-to-nearest INT8 weight quantization of [MiniMaxAI/MiniMax-M2.7](https://huggingface.co/MiniMaxAI/MiniMax-M2.7),
29
+ saved in the [`compressed-tensors`](https://github.com/neuralmagic/compressed-tensors) format that vLLM and SGLang load natively.
30
+
31
+ Activations stay in BF16 / FP16 at inference. Weights are stored as INT8 with
32
+ per-group (group_size=128) symmetric scales.
33
+
34
+ ## Why W8A16 + RTN (no calibration)
35
+
36
+ The accuracy gap between RTN and GPTQ for **INT8** is typically only
37
+ 0.1–0.5 % perplexity — calibration mostly matters at INT4 and below.
38
+ Skipping the GPTQ Hessian pass cuts the wall time on a single 48 GB GPU
39
+ from ~25 hours to ~3-5 hours, with no measurable hit on real downstream tasks
40
+ (see `Quality` below). For a 234 B-parameter MoE this is a worthwhile trade.
41
+
42
+ ## Recipe
43
+
44
+ ```python
45
+ from llmcompressor.modifiers.quantization import QuantizationModifier
46
+ from compressed_tensors.quantization import QuantizationArgs, QuantizationScheme
47
+
48
+ w8a16 = QuantizationScheme(
49
+ targets=["Linear"],
50
+ weights=QuantizationArgs(
51
+ num_bits=8,
52
+ type="int",
53
+ symmetric=True,
54
+ group_size=128,
55
+ strategy="group",
56
+ dynamic=False,
57
+ observer="memoryless_minmax",
58
+ ),
59
+ )
60
+
61
+ recipe = QuantizationModifier(
62
+ config_groups={"w8a16": w8a16},
63
+ ignore=[
64
+ "lm_head", # output head — no quant
65
+ "re:.*router.*", # MoE expert routers — must stay precise
66
+ "re:.*\\.gate\\b", # router gate layers
67
+ "re:.*embed_tokens.*",
68
+ ],
69
+ )
70
+ ```
71
+
72
+ The `ignore` list is critical for MoE: quantizing the router or its gate
73
+ collapses expert selection and ruins everything downstream.
74
+
75
+ Source: [operationrange/MiniMax-M2.7-BF16](https://huggingface.co/operationrange/MiniMax-M2.7-BF16) (our exact BF16 dequant of the upstream FP8 checkpoint).
76
+
77
+ ## Files
78
+
79
+ - ~26 shards `model-NNNNN-of-NNNNN.safetensors` (≈ 130 GB total)
80
+ - `model.safetensors.index.json`
81
+ - `config.json` with `compression_config` describing the W8A16 scheme
82
+ - `recipe.yaml` — the llmcompressor recipe used
83
+ - tokenizer + custom modeling `.py` files
84
+
85
+ ## Inference
86
+
87
+ ### vLLM
88
+
89
+ ```bash
90
+ python -m vllm.entrypoints.openai.api_server \
91
+ --model operationrange/MiniMax-M2.7-8bit \
92
+ --quantization compressed-tensors \
93
+ --tensor-parallel-size 8 \
94
+ --trust-remote-code
95
+ ```
96
+
97
+ ### SGLang
98
+
99
+ ```bash
100
+ python -m sglang.launch_server \
101
+ --model-path operationrange/MiniMax-M2.7-8bit \
102
+ --quantization compressed-tensors \
103
+ --tp-size 8 --ep-size 8 \
104
+ --tool-call-parser minimax-m2 \
105
+ --reasoning-parser minimax-append-think \
106
+ --trust-remote-code \
107
+ --host 0.0.0.0 --port 8080 \
108
+ --mem-fraction-static 0.85
109
+ ```
110
+
111
+ Fits on **8× 24 GB Ampere** (e.g. RTX A5000) with TP=8, EP=8, leaving room
112
+ for KV cache. INT8 has native tensor-core support all the way back to Volta,
113
+ so unlike the upstream FP8 there's no software emulation tax on Ampere/Turing.
114
+
115
+ ## Quality
116
+
117
+ Recommended sampling (inherited from upstream MiniMax-M2.7 model card):
118
+
119
+ ```
120
+ temperature = 1.0
121
+ top_p = 0.95
122
+ top_k = 40
123
+ ```
124
+
125
+ Tool-calling and `<think>` reasoning are preserved — the router and
126
+ embeddings are kept at full precision; only the heavy Linear layers
127
+ (attention QKV/O, MLP up/gate/down, MoE expert weights) are INT8.
128
+
129
+ ## Provenance
130
+
131
+ - 234 B total / ~45.9 B activated MoE with 256 experts top-8
132
+ - Quantized from [operationrange/MiniMax-M2.7-BF16](https://huggingface.co/operationrange/MiniMax-M2.7-BF16) using
133
+ [llmcompressor 0.10](https://github.com/vllm-project/llm-compressor) and
134
+ [compressed-tensors 0.10](https://github.com/neuralmagic/compressed-tensors).
135
+ - Script: [`scripts/quant/quantize_rtn_w8a16.py`](https://github.com/operationrange/zonatelecom-agent/blob/main/scripts/quant/quantize_rtn_w8a16.py)
136
+
137
+ ## License
138
+
139
+ Inherits the [MiniMax-M2 license](https://huggingface.co/MiniMaxAI/MiniMax-M2.7/blob/main/LICENSE) from the
140
+ upstream model. Only the storage format and weight precision were changed —
141
+ no fine-tuning or distillation.
added_tokens.json ADDED
@@ -0,0 +1,56 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "</minimax:tool_call>": 200053,
3
+ "</think>": 200051,
4
+ "<add_file>": 200036,
5
+ "<code_context>": 200043,
6
+ "<code_interpreter>": 200023,
7
+ "<commit_after>": 200018,
8
+ "<commit_before>": 200016,
9
+ "<commit_message>": 200040,
10
+ "<commit_msg>": 200017,
11
+ "<delete_file>": 200037,
12
+ "<edit_file>": 200039,
13
+ "<empty_output>": 200015,
14
+ "<empty_source_file>": 200041,
15
+ "<file_content>": 200044,
16
+ "<file_sep>": 200049,
17
+ "<filename>": 200006,
18
+ "<filepath>": 200048,
19
+ "<fim_middle>": 200002,
20
+ "<fim_pad>": 200004,
21
+ "<fim_prefix>": 200001,
22
+ "<fim_suffix>": 200003,
23
+ "<function_call>": 200022,
24
+ "<gh_stars>": 200007,
25
+ "<issue_closed>": 200010,
26
+ "<issue_comment>": 200009,
27
+ "<issue_start>": 200008,
28
+ "<jupyter_code>": 200013,
29
+ "<jupyter_error>": 200035,
30
+ "<jupyter_output>": 200014,
31
+ "<jupyter_start>": 200011,
32
+ "<jupyter_text>": 200012,
33
+ "<minimax:tool_call>": 200052,
34
+ "<pr_start>": 200046,
35
+ "<rename_file>": 200038,
36
+ "<repo_struct>": 200042,
37
+ "<reponame>": 200005,
38
+ "<review_comment>": 200047,
39
+ "<source_files>": 200045,
40
+ "<think>": 200050,
41
+ "[e~[": 200020,
42
+ "]!d~[": 200021,
43
+ "]!p~[": 200000,
44
+ "]<]end of image[>[": 200030,
45
+ "]<]end of speech[>[": 200028,
46
+ "]<]end of video[>[": 200032,
47
+ "]<]image[>[": 200025,
48
+ "]<]speech[>[": 200024,
49
+ "]<]start of image[>[": 200029,
50
+ "]<]start of speech[>[": 200027,
51
+ "]<]start of video[>[": 200031,
52
+ "]<]video[>[": 200026,
53
+ "]<]vision pad[>[": 200033,
54
+ "]~!b[": 200034,
55
+ "]~b]": 200019
56
+ }
chat_template.jinja ADDED
@@ -0,0 +1,159 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {# ----------‑‑‑ special token variables ‑‑‑---------- #}
2
+ {%- set toolcall_begin_token = '<minimax:tool_call>' -%}
3
+ {%- set toolcall_end_token = '</minimax:tool_call>' -%}
4
+ {#- Tool Rendering Functions ============================================== -#}
5
+ {%- macro render_tool_namespace(namespace_name, tool_list) -%}
6
+ {%- for tool in tool_list -%}
7
+ <tool>{{ tool.function | tojson(ensure_ascii=False) }}</tool>
8
+ {% endfor -%}
9
+ {%- endmacro -%}
10
+ {%- macro visible_text(content) -%}
11
+ {%- if content is string -%}
12
+ {{ content }}
13
+ {%- elif content is iterable and content is not mapping -%}
14
+ {%- for item in content -%}
15
+ {%- if item is mapping and item.type == 'text' -%}
16
+ {{- item.text }}
17
+ {%- elif item is string -%}
18
+ {{- item }}
19
+ {%- endif -%}
20
+ {%- endfor -%}
21
+ {%- else -%}
22
+ {{- content }}
23
+ {%- endif -%}
24
+ {%- endmacro -%}
25
+ {#- System Message Construction ============================================ -#}
26
+ {%- macro build_system_message(system_message) -%}
27
+ {%- if system_message and system_message.content -%}
28
+ {{- visible_text(system_message.content) }}
29
+ {%- else -%}
30
+ {%- if model_identity is not defined -%}
31
+ {%- set model_identity = "You are a helpful assistant. Your name is MiniMax-M2.7 and is built by MiniMax." -%}
32
+ {%- endif -%}
33
+ {{- model_identity }}
34
+ {%- endif -%}
35
+
36
+ {#- Handle current_date -#}
37
+ {%- if system_message and system_message.current_date -%}
38
+ {{- '\n' ~ 'Current date: ' + system_message.current_date }}
39
+ {%- endif -%}
40
+ {#- Handle current_location -#}
41
+ {%- if system_message and system_message.current_location -%}
42
+ {{- '\n' ~ 'Current location: ' + system_message.current_location }}
43
+ {%- endif -%}
44
+ {%- endmacro -%}
45
+ {#- Main Template Logic ================================================= -#}
46
+ {#- Extract system message (only first message if it's system) -#}
47
+ {%- set system_message = none -%}
48
+ {%- set conversation_messages = messages -%}
49
+ {%- if messages and messages[0].role == "system" -%}
50
+ {%- set system_message = messages[0] -%}
51
+ {%- set conversation_messages = messages[1:] -%}
52
+ {%- endif -%}
53
+ {#- Get the last user message turn, for interleved thinking -#}
54
+ {%- set ns = namespace(last_user_index=-1) %}
55
+ {% for m in conversation_messages %}
56
+ {%- if m.role == 'user' %}
57
+ {% set ns.last_user_index = loop.index0 -%}
58
+ {%- endif %}
59
+ {%- endfor %}
60
+ {#- Render system message -#}
61
+ {{- ']~!b[' ~ ']~b]system' ~ '\n' }}
62
+ {{- build_system_message(system_message) }}
63
+ {#- Render tools if available -#}
64
+ {%- if tools -%}
65
+ {{- '\n\n' ~ '# Tools' ~ '\n' ~ 'You may call one or more tools to assist with the user query.\nHere are the tools available in JSONSchema format:' ~ '\n' }}
66
+ {{- '\n' ~ '<tools>' ~ '\n' }}
67
+ {{- render_tool_namespace("functions", tools) }}
68
+ {{- '</tools>' ~ '\n\n' }}
69
+ {{- 'When making tool calls, use XML format to invoke tools and pass parameters:' ~ '\n' }}
70
+ {{- '\n' ~ toolcall_begin_token }}
71
+ <invoke name="tool-name-1">
72
+ <parameter name="param-key-1">param-value-1</parameter>
73
+ <parameter name="param-key-2">param-value-2</parameter>
74
+ ...
75
+ </invoke>
76
+ {{- '\n' ~ toolcall_end_token }}
77
+ {%- endif -%}
78
+ {{- '[e~[\n' }}
79
+
80
+ {#- Render messages -#}
81
+ {%- set last_tool_call = namespace(name=none) -%}
82
+ {%- for message in conversation_messages -%}
83
+ {%- if message.role == 'assistant' -%}
84
+ {#- Only render reasoning_content if no user message follows -#}
85
+ {{- ']~b]ai' ~ '\n' }}
86
+
87
+ {%- set reasoning_content = '' %}
88
+ {%- set content = visible_text(message.content) %}
89
+ {%- if message.reasoning_content is string %}
90
+ {%- set reasoning_content = message.reasoning_content %}
91
+ {%- else %}
92
+ {%- if '</think>' in content %}
93
+ {%- set reasoning_content = content.split('</think>')[0].strip('\n').split('<think>')[-1].strip('\n') %}
94
+ {%- set content = content.split('</think>')[-1].strip('\n') %}
95
+ {%- endif %}
96
+ {%- endif %}
97
+ {%- if reasoning_content and loop.index0 > ns.last_user_index -%}
98
+ {{- '<think>' ~ '\n' ~ reasoning_content ~ '\n' ~ '</think>' ~ '\n\n' }}
99
+ {%- endif -%}
100
+ {%- if content -%}
101
+ {{- content }}
102
+ {%- endif -%}
103
+ {%- if message.tool_calls -%}
104
+ {{- '\n' ~ toolcall_begin_token ~ '\n' }}
105
+
106
+ {%- for tool_call in message.tool_calls -%}
107
+ {%- if tool_call.function %}
108
+ {%- set tool_call = tool_call.function %}
109
+ {%- endif %}
110
+ {{- '<invoke name="' + tool_call.name + '">' }}
111
+ {% set _args = tool_call.arguments %}
112
+ {%- for k, v in _args.items() %}
113
+ {{- '<parameter name="' + k + '">' }}
114
+ {{- v | tojson(ensure_ascii=False) if v is not string else v }}
115
+ {{- '</parameter>' }}
116
+ {% endfor %}
117
+ {{- '</invoke>' ~ '\n' }}
118
+ {%- endfor -%}
119
+
120
+ {{- toolcall_end_token}}
121
+ {%- set last_tool_call.name = message.tool_calls[-1].name -%}
122
+ {%- else -%}
123
+ {%- set last_tool_call.name = none -%}
124
+ {%- endif -%}
125
+ {{- '[e~[' ~ '\n' }}
126
+
127
+ {%- elif message.role == 'tool' -%}
128
+ {%- if last_tool_call.name is none -%}
129
+ {{- raise_exception("Message has tool role, but there was no previous assistant message with a tool call!") }}
130
+ {%- endif -%}
131
+ {%- if loop.first or (conversation_messages[loop.index0 - 1].role != 'tool') -%}
132
+ {{- ']~b]tool' }}
133
+ {%- endif -%}
134
+ {%- if message.content is string -%}
135
+ {{- '\n<response>' }}
136
+ {{- message.content }}
137
+ {{- '</response>' }}
138
+ {%- else -%}
139
+ {%- for tr in message.content -%}
140
+ {{- '\n<response>' }}
141
+ {{- tr.output if tr.output is defined else (tr.text if tr.type == 'text' and tr.text is defined else tr) }}
142
+ {{- '\n</response>' }}
143
+ {%- endfor -%}
144
+ {%- endif -%}
145
+ {%- if loop.last or (conversation_messages[loop.index0 + 1].role != 'tool') -%}
146
+ {{- '[e~[\n' -}}
147
+ {%- endif -%}
148
+
149
+ {%- elif message.role == 'user' -%}
150
+ {{- ']~b]user' ~ '\n' }}
151
+ {{- visible_text(message.content) }}
152
+ {{- '[e~[' ~ '\n' }}
153
+ {%- endif -%}
154
+ {%- endfor -%}
155
+
156
+ {#- Generation prompt -#}
157
+ {%- if add_generation_prompt -%}
158
+ {{- ']~b]ai' ~ '\n' ~ '<think>' ~ '\n' }}
159
+ {%- endif -%}
config.json ADDED
@@ -0,0 +1,208 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "architectures": [
3
+ "MiniMaxM2ForCausalLM"
4
+ ],
5
+ "attention_dropout": 0.0,
6
+ "attn_type_list": [
7
+ 1,
8
+ 1,
9
+ 1,
10
+ 1,
11
+ 1,
12
+ 1,
13
+ 1,
14
+ 1,
15
+ 1,
16
+ 1,
17
+ 1,
18
+ 1,
19
+ 1,
20
+ 1,
21
+ 1,
22
+ 1,
23
+ 1,
24
+ 1,
25
+ 1,
26
+ 1,
27
+ 1,
28
+ 1,
29
+ 1,
30
+ 1,
31
+ 1,
32
+ 1,
33
+ 1,
34
+ 1,
35
+ 1,
36
+ 1,
37
+ 1,
38
+ 1,
39
+ 1,
40
+ 1,
41
+ 1,
42
+ 1,
43
+ 1,
44
+ 1,
45
+ 1,
46
+ 1,
47
+ 1,
48
+ 1,
49
+ 1,
50
+ 1,
51
+ 1,
52
+ 1,
53
+ 1,
54
+ 1,
55
+ 1,
56
+ 1,
57
+ 1,
58
+ 1,
59
+ 1,
60
+ 1,
61
+ 1,
62
+ 1,
63
+ 1,
64
+ 1,
65
+ 1,
66
+ 1,
67
+ 1,
68
+ 1
69
+ ],
70
+ "auto_map": {
71
+ "AutoConfig": "configuration_minimax_m2.MiniMaxM2Config",
72
+ "AutoModelForCausalLM": "modeling_minimax_m2.MiniMaxM2ForCausalLM"
73
+ },
74
+ "bos_token_id": 1,
75
+ "dtype": "bfloat16",
76
+ "eos_token_id": 2,
77
+ "head_dim": 128,
78
+ "hidden_act": "silu",
79
+ "hidden_size": 3072,
80
+ "initializer_range": 0.02,
81
+ "intermediate_size": 1536,
82
+ "max_position_embeddings": 204800,
83
+ "model_type": "minimax_m2",
84
+ "mtp_transformer_layers": 1,
85
+ "num_attention_heads": 48,
86
+ "num_experts_per_tok": 8,
87
+ "num_hidden_layers": 62,
88
+ "num_key_value_heads": 8,
89
+ "num_local_experts": 256,
90
+ "num_mtp_modules": 3,
91
+ "output_router_logits": false,
92
+ "partial_rotary_factor": 0.5,
93
+ "qk_norm_type": "per_layer",
94
+ "quantization_config": {
95
+ "config_groups": {
96
+ "group_0": {
97
+ "format": "pack-quantized",
98
+ "input_activations": null,
99
+ "output_activations": null,
100
+ "targets": [
101
+ "Linear"
102
+ ],
103
+ "weights": {
104
+ "actorder": null,
105
+ "block_structure": null,
106
+ "dynamic": false,
107
+ "group_size": 128,
108
+ "num_bits": 8,
109
+ "observer": "memoryless_minmax",
110
+ "observer_kwargs": {},
111
+ "scale_dtype": null,
112
+ "strategy": "group",
113
+ "symmetric": true,
114
+ "type": "int",
115
+ "zp_dtype": null
116
+ }
117
+ }
118
+ },
119
+ "format": "pack-quantized",
120
+ "global_compression_ratio": null,
121
+ "ignore": [
122
+ "model.layers.0.block_sparse_moe.gate",
123
+ "model.layers.1.block_sparse_moe.gate",
124
+ "model.layers.2.block_sparse_moe.gate",
125
+ "model.layers.3.block_sparse_moe.gate",
126
+ "model.layers.4.block_sparse_moe.gate",
127
+ "model.layers.5.block_sparse_moe.gate",
128
+ "model.layers.6.block_sparse_moe.gate",
129
+ "model.layers.7.block_sparse_moe.gate",
130
+ "model.layers.8.block_sparse_moe.gate",
131
+ "model.layers.9.block_sparse_moe.gate",
132
+ "model.layers.10.block_sparse_moe.gate",
133
+ "model.layers.11.block_sparse_moe.gate",
134
+ "model.layers.12.block_sparse_moe.gate",
135
+ "model.layers.13.block_sparse_moe.gate",
136
+ "model.layers.14.block_sparse_moe.gate",
137
+ "model.layers.15.block_sparse_moe.gate",
138
+ "model.layers.16.block_sparse_moe.gate",
139
+ "model.layers.17.block_sparse_moe.gate",
140
+ "model.layers.18.block_sparse_moe.gate",
141
+ "model.layers.19.block_sparse_moe.gate",
142
+ "model.layers.20.block_sparse_moe.gate",
143
+ "model.layers.21.block_sparse_moe.gate",
144
+ "model.layers.22.block_sparse_moe.gate",
145
+ "model.layers.23.block_sparse_moe.gate",
146
+ "model.layers.24.block_sparse_moe.gate",
147
+ "model.layers.25.block_sparse_moe.gate",
148
+ "model.layers.26.block_sparse_moe.gate",
149
+ "model.layers.27.block_sparse_moe.gate",
150
+ "model.layers.28.block_sparse_moe.gate",
151
+ "model.layers.29.block_sparse_moe.gate",
152
+ "model.layers.30.block_sparse_moe.gate",
153
+ "model.layers.31.block_sparse_moe.gate",
154
+ "model.layers.32.block_sparse_moe.gate",
155
+ "model.layers.33.block_sparse_moe.gate",
156
+ "model.layers.34.block_sparse_moe.gate",
157
+ "model.layers.35.block_sparse_moe.gate",
158
+ "model.layers.36.block_sparse_moe.gate",
159
+ "model.layers.37.block_sparse_moe.gate",
160
+ "model.layers.38.block_sparse_moe.gate",
161
+ "model.layers.39.block_sparse_moe.gate",
162
+ "model.layers.40.block_sparse_moe.gate",
163
+ "model.layers.41.block_sparse_moe.gate",
164
+ "model.layers.42.block_sparse_moe.gate",
165
+ "model.layers.43.block_sparse_moe.gate",
166
+ "model.layers.44.block_sparse_moe.gate",
167
+ "model.layers.45.block_sparse_moe.gate",
168
+ "model.layers.46.block_sparse_moe.gate",
169
+ "model.layers.47.block_sparse_moe.gate",
170
+ "model.layers.48.block_sparse_moe.gate",
171
+ "model.layers.49.block_sparse_moe.gate",
172
+ "model.layers.50.block_sparse_moe.gate",
173
+ "model.layers.51.block_sparse_moe.gate",
174
+ "model.layers.52.block_sparse_moe.gate",
175
+ "model.layers.53.block_sparse_moe.gate",
176
+ "model.layers.54.block_sparse_moe.gate",
177
+ "model.layers.55.block_sparse_moe.gate",
178
+ "model.layers.56.block_sparse_moe.gate",
179
+ "model.layers.57.block_sparse_moe.gate",
180
+ "model.layers.58.block_sparse_moe.gate",
181
+ "model.layers.59.block_sparse_moe.gate",
182
+ "model.layers.60.block_sparse_moe.gate",
183
+ "model.layers.61.block_sparse_moe.gate",
184
+ "lm_head"
185
+ ],
186
+ "kv_cache_scheme": null,
187
+ "quant_method": "compressed-tensors",
188
+ "quantization_status": "compressed",
189
+ "sparsity_config": {},
190
+ "transform_config": {},
191
+ "version": "0.14.0.1"
192
+ },
193
+ "rms_norm_eps": 1e-06,
194
+ "rope_theta": 5000000,
195
+ "rotary_dim": 64,
196
+ "router_aux_loss_coef": 0.001,
197
+ "router_jitter_noise": 0.0,
198
+ "scoring_func": "sigmoid",
199
+ "shared_intermediate_size": 0,
200
+ "sliding_window": null,
201
+ "tie_word_embeddings": false,
202
+ "transformers_version": "4.57.6",
203
+ "use_cache": true,
204
+ "use_mtp": true,
205
+ "use_qk_norm": true,
206
+ "use_routing_bias": true,
207
+ "vocab_size": 200064
208
+ }
configuration_minimax_m2.py ADDED
@@ -0,0 +1,200 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # 🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨
2
+ # This file was automatically generated from src/transformers/models/minimax_m2/modular_minimax_m2.py.
3
+ # Do NOT edit this file manually as any edits will be overwritten by the generation of
4
+ # the file from the modular. If any change should be done, please apply the change to the
5
+ # modular_minimax_m2.py file directly. One of our CI enforces this.
6
+ # 🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨🚨
7
+ # coding=utf-8
8
+ # Copyright 2025 the HuggingFace Team. All rights reserved.
9
+ #
10
+ # Licensed under the Apache License, Version 2.0 (the "License");
11
+ # you may not use this file except in compliance with the License.
12
+ # You may obtain a copy of the License at
13
+ #
14
+ # http://www.apache.org/licenses/LICENSE-2.0
15
+ #
16
+ # Unless required by applicable law or agreed to in writing, software
17
+ # distributed under the License is distributed on an "AS IS" BASIS,
18
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
+ # See the License for the specific language governing permissions and
20
+ # limitations under the License.
21
+
22
+
23
+ from transformers.configuration_utils import PretrainedConfig
24
+
25
+
26
+ class MiniMaxM2Config(PretrainedConfig):
27
+ r"""
28
+ This is the configuration class to store the configuration of a [`MiniMaxM2Model`]. It is used to instantiate an
29
+ MiniMaxM2 model according to the specified arguments, defining the model architecture. Instantiating a configuration
30
+ with the defaults will yield a similar configuration to that of the MiniMaxM2-7B-v0.1 or MiniMaxM2-7B-Instruct-v0.1.
31
+
32
+ [minimax_m2ai/MiniMaxM2-8x7B](https://huggingface.co/minimax_m2ai/MiniMaxM2-8x7B)
33
+ [minimax_m2ai/MiniMaxM2-7B-Instruct-v0.1](https://huggingface.co/minimax_m2ai/MiniMaxM2-7B-Instruct-v0.1)
34
+
35
+ Configuration objects inherit from [`PretrainedConfig`] and can be used to control the model outputs. Read the
36
+ documentation from [`PretrainedConfig`] for more information.
37
+
38
+
39
+ Args:
40
+ vocab_size (`int`, *optional*, defaults to 32000):
41
+ Vocabulary size of the MiniMaxM2 model. Defines the number of different tokens that can be represented by the
42
+ `inputs_ids` passed when calling [`MiniMaxM2Model`]
43
+ hidden_size (`int`, *optional*, defaults to 4096):
44
+ Dimension of the hidden representations.
45
+ intermediate_size (`int`, *optional*, defaults to 14336):
46
+ Dimension of the MLP representations.
47
+ num_hidden_layers (`int`, *optional*, defaults to 32):
48
+ Number of hidden layers in the Transformer encoder.
49
+ num_attention_heads (`int`, *optional*, defaults to 32):
50
+ Number of attention heads for each attention layer in the Transformer encoder.
51
+ num_key_value_heads (`int`, *optional*, defaults to 8):
52
+ This is the number of key_value heads that should be used to implement Grouped Query Attention. If
53
+ `num_key_value_heads=num_attention_heads`, the model will use Multi Head Attention (MHA), if
54
+ `num_key_value_heads=1` the model will use Multi Query Attention (MQA) otherwise GQA is used. When
55
+ converting a multi-head checkpoint to a GQA checkpoint, each group key and value head should be constructed
56
+ by meanpooling all the original heads within that group. For more details, check out [this
57
+ paper](https://huggingface.co/papers/2305.13245). If it is not specified, will default to `8`.
58
+ head_dim (`int`, *optional*, defaults to `hidden_size // num_attention_heads`):
59
+ The attention head dimension.
60
+ hidden_act (`str` or `function`, *optional*, defaults to `"silu"`):
61
+ The non-linear activation function (function or string) in the decoder.
62
+ max_position_embeddings (`int`, *optional*, defaults to `4096*32`):
63
+ The maximum sequence length that this model might ever be used with. MiniMaxM2's sliding window attention
64
+ allows sequence of up to 4096*32 tokens.
65
+ initializer_range (`float`, *optional*, defaults to 0.02):
66
+ The standard deviation of the truncated_normal_initializer for initializing all weight matrices.
67
+ rms_norm_eps (`float`, *optional*, defaults to 1e-05):
68
+ The epsilon used by the rms normalization layers.
69
+ use_cache (`bool`, *optional*, defaults to `True`):
70
+ Whether or not the model should return the last key/values attentions (not used by all models). Only
71
+ relevant if `config.is_decoder=True`.
72
+ pad_token_id (`int`, *optional*):
73
+ The id of the padding token.
74
+ bos_token_id (`int`, *optional*, defaults to 1):
75
+ The id of the "beginning-of-sequence" token.
76
+ eos_token_id (`int`, *optional*, defaults to 2):
77
+ The id of the "end-of-sequence" token.
78
+ tie_word_embeddings (`bool`, *optional*, defaults to `False`):
79
+ Whether the model's input and output word embeddings should be tied.
80
+ rope_theta (`float`, *optional*, defaults to 1000000.0):
81
+ The base period of the RoPE embeddings.
82
+ sliding_window (`int`, *optional*):
83
+ Sliding window attention window size. If not specified, will default to `4096`.
84
+ attention_dropout (`float`, *optional*, defaults to 0.0):
85
+ The dropout ratio for the attention probabilities.
86
+ num_experts_per_tok (`int`, *optional*, defaults to 2):
87
+ The number of experts to route per-token, can be also interpreted as the `top-k` routing
88
+ parameter
89
+ num_local_experts (`int`, *optional*, defaults to 8):
90
+ Number of experts per Sparse MLP layer.
91
+ output_router_logits (`bool`, *optional*, defaults to `False`):
92
+ Whether or not the router logits should be returned by the model. Enabling this will also
93
+ allow the model to output the auxiliary loss. See [here]() for more details
94
+ router_aux_loss_coef (`float`, *optional*, defaults to 0.001):
95
+ The aux loss factor for the total loss.
96
+ router_jitter_noise (`float`, *optional*, defaults to 0.0):
97
+ Amount of noise to add to the router.
98
+
99
+ ```python
100
+ >>> from transformers import MiniMaxM2Model, MiniMaxM2Config
101
+
102
+ >>> # Initializing a MiniMaxM2 7B style configuration
103
+ >>> configuration = MiniMaxM2Config()
104
+
105
+ >>> # Initializing a model from the MiniMaxM2 7B style configuration
106
+ >>> model = MiniMaxM2Model(configuration)
107
+
108
+ >>> # Accessing the model configuration
109
+ >>> configuration = model.config
110
+ ```"""
111
+
112
+ model_type = "minimax_m2"
113
+ keys_to_ignore_at_inference = ["past_key_values"]
114
+ base_model_tp_plan = {
115
+ "layers.*.self_attn.q_proj": "colwise",
116
+ "layers.*.self_attn.k_proj": "colwise",
117
+ "layers.*.self_attn.v_proj": "colwise",
118
+ "layers.*.self_attn.o_proj": "rowwise",
119
+ "layers.*.block_sparse_moe.gate": "colwise_rep", # we need to replicate here to correctly route experts
120
+ "layers.*.block_sparse_moe.experts.*.w1": "colwise",
121
+ "layers.*.block_sparse_moe.experts.*.w2": "rowwise",
122
+ "layers.*.block_sparse_moe.experts.*.w3": "colwise",
123
+ }
124
+ base_model_pp_plan = {
125
+ "embed_tokens": (["input_ids"], ["inputs_embeds"]),
126
+ "layers": (["hidden_states", "attention_mask"], ["hidden_states"]),
127
+ "norm": (["hidden_states"], ["hidden_states"]),
128
+ }
129
+
130
+ def __init__(
131
+ self,
132
+ vocab_size=32000,
133
+ hidden_size=4096,
134
+ intermediate_size=14336,
135
+ num_hidden_layers=32,
136
+ num_attention_heads=32,
137
+ num_key_value_heads=8,
138
+ head_dim=None,
139
+ hidden_act="silu",
140
+ max_position_embeddings=4096 * 32,
141
+ initializer_range=0.02,
142
+ rms_norm_eps=1e-5,
143
+ use_cache=True,
144
+ pad_token_id=None,
145
+ bos_token_id=1,
146
+ eos_token_id=2,
147
+ tie_word_embeddings=False,
148
+ rope_theta=1e6,
149
+ sliding_window=None,
150
+ attention_dropout=0.0,
151
+ num_experts_per_tok=2,
152
+ num_local_experts=8,
153
+ output_router_logits=False,
154
+ router_aux_loss_coef=0.001,
155
+ router_jitter_noise=0.0,
156
+ **kwargs,
157
+ ):
158
+ self.vocab_size = vocab_size
159
+ self.max_position_embeddings = max_position_embeddings
160
+ self.hidden_size = hidden_size
161
+ self.intermediate_size = intermediate_size
162
+ self.num_hidden_layers = num_hidden_layers
163
+ self.num_attention_heads = num_attention_heads
164
+ self.sliding_window = sliding_window
165
+
166
+ # for backward compatibility
167
+ if num_key_value_heads is None:
168
+ num_key_value_heads = num_attention_heads
169
+
170
+ self.num_key_value_heads = num_key_value_heads
171
+ self.hidden_act = hidden_act
172
+ self.initializer_range = initializer_range
173
+ self.rms_norm_eps = rms_norm_eps
174
+ self.use_cache = use_cache
175
+ self.rope_theta = rope_theta
176
+ self.attention_dropout = attention_dropout
177
+ self.head_dim = head_dim
178
+
179
+ self.num_experts_per_tok = num_experts_per_tok
180
+ self.num_local_experts = num_local_experts
181
+ self.output_router_logits = output_router_logits
182
+ self.router_aux_loss_coef = router_aux_loss_coef
183
+ self.router_jitter_noise = router_jitter_noise
184
+
185
+ self.use_qk_norm = kwargs.pop("use_qk_norm", False)
186
+ self.rotary_dim = kwargs.pop("rotary_dim", self.head_dim)
187
+ self.partial_rotary_factor = kwargs.pop("partial_rotary_factor", 1)
188
+ if self.head_dim is not None:
189
+ self.partial_rotary_factor = self.rotary_dim / self.head_dim
190
+
191
+ super().__init__(
192
+ pad_token_id=pad_token_id,
193
+ bos_token_id=bos_token_id,
194
+ eos_token_id=eos_token_id,
195
+ tie_word_embeddings=tie_word_embeddings,
196
+ **kwargs,
197
+ )
198
+
199
+
200
+ __all__ = ["MiniMaxM2Config"]
generation_config.json ADDED
@@ -0,0 +1,8 @@
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "bos_token_id": 200019,
3
+ "do_sample": true,
4
+ "eos_token_id": 200020,
5
+ "top_k": 40,
6
+ "top_p": 0.95,
7
+ "transformers_version": "4.57.6"
8
+ }
merges.txt ADDED
The diff for this file is too large to render. See raw diff
 
model-00001-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:3d4afe20856a74076fc3790266081ef00928333619df2e7249e31ffb4ac96ad0
3
+ size 4981896344
model-00002-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:acd9e153cddff1f7e3a064728d9302f8424063a3435b3d6506e383bb80b74e4b
3
+ size 4998801752
model-00003-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:e92a45ec7ae6dbc16489d7460c8f9eb76831caabe610beb119313d2045d8d6c2
3
+ size 4997215576
model-00004-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:7df01a05a390bdeead98120fdf3950cb5c048455127c2df260777f0f5160f8b4
3
+ size 5000337536
model-00005-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:7514ed2c8125ee361155942ce43da302f1780609897bb837f9b02724aee1d7c3
3
+ size 4997288848
model-00006-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:a9ff85457c277582825824c7160f34561de719a168c8a6e95acfe2100ba28374
3
+ size 4997215632
model-00007-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:5567ea88706d2b79d81df03bc68f575038ac619ada37c0c8201c135578561630
3
+ size 5000337432
model-00008-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:96bec9d7dd45900418696db88ca3b79abf05b97c286183b1ab9939b3e65a7d13
3
+ size 4997289800
model-00009-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:7bc5c4e4ac2092b5c51bf029f7e2ff6bbe733570fdc6edbda136996e549d77c1
3
+ size 4997218800
model-00010-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:03093ad1a3df16d2f4331b94495da4acf3b3991b3464a2b87c4f90b554533ac2
3
+ size 5000340488
model-00011-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:e23bcc6738fb56b62814284cb6ded739c609173e40fd1b30b49dafafdf5c1a11
3
+ size 4997292064
model-00012-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:a9d0794d36cd9b88c7dd46d09eb864785a6ff3bbafcd76f2ee73e01b4a9ada58
3
+ size 4997218808
model-00013-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:18cc5153c910a71c1cf061e9e28524f4d3b187cf420fafcf9d7cc8c6e1a2e2fe
3
+ size 5000340432
model-00014-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:2fb84147633fccacaa4a05fa90a15a94f1f016d8ae188d0f76ce0c8638b6ce2b
3
+ size 4997292112
model-00015-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:9475872e5c26a12639d7bdd6dba4c7f954ce18f23c74dc5acf54d59fa55f27af
3
+ size 4997218808
model-00016-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:4a530a377c3e7a97f9c3434d2254a89e0cde263ecc843bffacd5a1ec0880f990
3
+ size 5000340376
model-00017-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:ebb739fc702fb50c156346453c2be3e52969a2ddaf5084fd1713349c0661f56c
3
+ size 4997292168
model-00018-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:876d402bdccc4cc3aa3935920ef2200bc1133ddc62b28039c9abfed5e7af44ce
3
+ size 4997218808
model-00019-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:eb6bdfa7f2451189908da262bddef71b36273299e0aafa8c5eafc4fcd60e4a9a
3
+ size 5000340328
model-00020-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:ad09b06d8dd04155b32bee51b0857e2a3fddc1e8702ff0ca6ae335a0e83d4840
3
+ size 4997292224
model-00021-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:05f41fec4add0404da2a7a20046490c7f03f40cf2e613ebdd347ebc44199ea82
3
+ size 4997218808
model-00022-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:9c14a45ade368b2b3e247d7eca5bc33ee80c8bbbf323f2bcd98809560a173a46
3
+ size 5000340272
model-00023-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:17dba788a405af01889b8f435eb704da01872ca0c04a0455ce193b7bb3ba37e9
3
+ size 4997292280
model-00024-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:45050bccb0431f11a17cd61a6f360d6271746871271dd183b694b1a6f8b5e38d
3
+ size 4997218808
model-00025-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:afb42d44593b3eace36b1d76aa3101fc4ec036c5b0edb773507d86b61a3d204b
3
+ size 5000340216
model-00026-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:ad2f58f93b3c7bf1f94ea771d4dff8bd1b0e2f8f4c74c62ef9fb8eb8b7cd8865
3
+ size 4997292328
model-00027-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:fcbd9364d772f2e4818257f0ed7e9f6a93e99bf5fe336edd0c007060028a6813
3
+ size 4997218808
model-00028-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:f14b75f0721dd851550fdff3beaee7fbed09f78590ca52d2cb7053de64d47a57
3
+ size 5000340160
model-00029-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:abbb490bc280987baff90cbd5333ff68b18ccbd430fdd6ac7ec8f27343e5fd36
3
+ size 4997292384
model-00030-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:2a3ae61fea142448f2ad5c10462174010817f01ce5156525424611a01918318b
3
+ size 4997218808
model-00031-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:619bab8295d73c6f91a7f265b945213969fd54c6e6dcb110425b22d2fd5e568f
3
+ size 5000340112
model-00032-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:c3f45a30889123e72833eed74339f5f1dde5d2c478172c971b34ddd035ae8c7b
3
+ size 4997292440
model-00033-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:c98b2b33382a4aba145392cd3e4ab4eaf6975a836441868bcdef42610487f299
3
+ size 4997218808
model-00034-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:aaaebcab87e8c10b5238956cd8b2515110c1c7522080e20e3f3845a325ddce61
3
+ size 5000340056
model-00035-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:599e9c51666faf189dca8f5896f22ae479633d9d7e8e1e516ec7c491395dff9a
3
+ size 4997292496
model-00036-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:a1f7c6367218b8c4cb1328b56af230414ac1c025ee9f01016bea5edd636a322d
3
+ size 4997218808
model-00037-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:e4d7a4f79f11602ca49bc51cb32021342c918494887b3d9a959e6f6302d67c73
3
+ size 5000340000
model-00038-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:cbc3b43d4ad7b4f4d4c1f9570b1a9a871b16c6c129d3b6bec633801f992f05f8
3
+ size 4997292544
model-00039-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:bd4fa4cbf4f102c8ff00de29971c6b2b75d2406e5400a8e85a2a19f1d5049b49
3
+ size 4997218808
model-00040-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:0e791c9f94a2a1d26f8653710c5765670545a53a38d8c2d8178160b68e532a8a
3
+ size 5000339944
model-00041-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:3f5f789a1f953821d484ea82cd618a4874d6186ddb20c8637b8e375da334f310
3
+ size 4997292600
model-00042-of-00047.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:0b468602bd383a3b567a57c4087843f5bcfc90d56115419b1436c721d8d59445
3
+ size 4997218808