Text Generation
MLX
Safetensors
English
qwen3
aro
code-generation
dsl
4-bit precision
lora
fine-tuned
conversational
Instructions to use ARO-Lang/aro-coder-4bit with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- MLX
How to use ARO-Lang/aro-coder-4bit with MLX:
# Make sure mlx-lm is installed # pip install --upgrade mlx-lm # Generate text with mlx-lm from mlx_lm import load, generate model, tokenizer = load("ARO-Lang/aro-coder-4bit") prompt = "Write a story about Einstein" messages = [{"role": "user", "content": prompt}] prompt = tokenizer.apply_chat_template( messages, add_generation_prompt=True ) text = generate(model, tokenizer, prompt=prompt, verbose=True) - Notebooks
- Google Colab
- Kaggle
- Local Apps
- LM Studio
- Pi new
How to use ARO-Lang/aro-coder-4bit with Pi:
Start the MLX server
# Install MLX LM: uv tool install mlx-lm # Start a local OpenAI-compatible server: mlx_lm.server --model "ARO-Lang/aro-coder-4bit"
Configure the model in Pi
# Install Pi: npm install -g @mariozechner/pi-coding-agent # Add to ~/.pi/agent/models.json: { "providers": { "mlx-lm": { "baseUrl": "http://localhost:8080/v1", "api": "openai-completions", "apiKey": "none", "models": [ { "id": "ARO-Lang/aro-coder-4bit" } ] } } }Run Pi
# Start Pi in your project directory: pi
- Hermes Agent new
How to use ARO-Lang/aro-coder-4bit with Hermes Agent:
Start the MLX server
# Install MLX LM: uv tool install mlx-lm # Start a local OpenAI-compatible server: mlx_lm.server --model "ARO-Lang/aro-coder-4bit"
Configure Hermes
# Install Hermes: curl -fsSL https://hermes-agent.nousresearch.com/install.sh | bash hermes setup # Point Hermes at the local server: hermes config set model.provider custom hermes config set model.base_url http://127.0.0.1:8080/v1 hermes config set model.default ARO-Lang/aro-coder-4bit
Run Hermes
hermes
- MLX LM
How to use ARO-Lang/aro-coder-4bit with MLX LM:
Generate or start a chat session
# Install MLX LM uv tool install mlx-lm # Interactive chat REPL mlx_lm.chat --model "ARO-Lang/aro-coder-4bit"
Run an OpenAI-compatible server
# Install MLX LM uv tool install mlx-lm # Start the server mlx_lm.server --model "ARO-Lang/aro-coder-4bit" # Calling the OpenAI-compatible server with curl curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "ARO-Lang/aro-coder-4bit", "messages": [ {"role": "user", "content": "Hello"} ] }'
Upload ARO Coder 4-bit (distill_student)
Browse files- README.md +3 -3
- aro_system_prompt.txt +259 -0
- model.safetensors +1 -1
README.md
CHANGED
|
@@ -26,8 +26,8 @@ ARO is a domain-specific language where every statement follows the pattern:
|
|
| 26 |
| **Base model** | [mlx-community/Qwen3-Coder-30B-A3B-Instruct-4bit](https://huggingface.co/mlx-community/Qwen3-Coder-30B-A3B-Instruct-4bit) |
|
| 27 |
| **Quantization** | 4-bit (MLX) |
|
| 28 |
| **Language** | ARO |
|
| 29 |
-
| **Training samples** |
|
| 30 |
-
| **Syntax pass rate** |
|
| 31 |
| **Source label** | distill_student |
|
| 32 |
|
| 33 |
## Links
|
|
@@ -108,7 +108,7 @@ Key features:
|
|
| 108 |
|
| 109 |
This model was trained with the ARO training pipeline:
|
| 110 |
|
| 111 |
-
1. **Corpus collection** β
|
| 112 |
2. **Supervised fine-tuning** β LoRA on all code generation, debugging, Q&A, and explanation tasks
|
| 113 |
3. **DPO preference training** β using `aro check` validation to build chosen/rejected pairs
|
| 114 |
4. **Iterative self-improvement** β multiple rounds of generate-validate-retrain
|
|
|
|
| 26 |
| **Base model** | [mlx-community/Qwen3-Coder-30B-A3B-Instruct-4bit](https://huggingface.co/mlx-community/Qwen3-Coder-30B-A3B-Instruct-4bit) |
|
| 27 |
| **Quantization** | 4-bit (MLX) |
|
| 28 |
| **Language** | ARO |
|
| 29 |
+
| **Training samples** | 2943 |
|
| 30 |
+
| **Syntax pass rate** | 57% |
|
| 31 |
| **Source label** | distill_student |
|
| 32 |
|
| 33 |
## Links
|
|
|
|
| 108 |
|
| 109 |
This model was trained with the ARO training pipeline:
|
| 110 |
|
| 111 |
+
1. **Corpus collection** β 2943 samples from Examples, Book, Wiki, Proposals, and real-world ARO applications
|
| 112 |
2. **Supervised fine-tuning** β LoRA on all code generation, debugging, Q&A, and explanation tasks
|
| 113 |
3. **DPO preference training** β using `aro check` validation to build chosen/rejected pairs
|
| 114 |
4. **Iterative self-improvement** β multiple rounds of generate-validate-retrain
|
aro_system_prompt.txt
ADDED
|
@@ -0,0 +1,259 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
You are an expert ARO (Action Result Object) coding assistant.
|
| 2 |
+
ARO is a DSL where every statement follows: Verb the <Result> preposition [the] <Object>.
|
| 3 |
+
|
| 4 |
+
ARO SYNTAX RULES:
|
| 5 |
+
## Core Syntax Examples
|
| 6 |
+
(* Feature set names match operationIds from openapi.yaml *)
|
| 7 |
+
|
| 8 |
+
(listUsers: User API) {
|
| 9 |
+
Retrieve the <users> from the <user-repository>.
|
| 10 |
+
Return an <OK: status> with <users>.
|
| 11 |
+
}
|
| 12 |
+
|
| 13 |
+
(createUser: User API) {
|
| 14 |
+
Extract the <data> from the <request: body>.
|
| 15 |
+
Create the <user> with <data>.
|
| 16 |
+
Emit a <UserCreated: event> with <user>.
|
| 17 |
+
Return a <Created: status> with <user>.
|
| 18 |
+
}
|
| 19 |
+
|
| 20 |
+
(getUser: User API) {
|
| 21 |
+
Extract the <id> from the <pathParameters: id>.
|
| 22 |
+
Retrieve the <user> from the <user-repository> where id = <id>.
|
| 23 |
+
Return an <OK: status> with <user>.
|
| 24 |
+
}
|
| 25 |
+
|
| 26 |
+
(* Event handlers still work as before *)
|
| 27 |
+
(Send Welcome Email: UserCreated Handler) {
|
| 28 |
+
Extract the <user> from the <event: user>.
|
| 29 |
+
Send the <welcome-email> to the <user: email>.
|
| 30 |
+
Return an <OK: status> for the <notification>.
|
| 31 |
+
}
|
| 32 |
+
---
|
| 33 |
+
(* Plugin qualifiers use handler namespace *)
|
| 34 |
+
Compute the <random-item: collections.pick-random> from the <items>.
|
| 35 |
+
Compute the <sorted-list: stats.sort> from the <numbers>.
|
| 36 |
+
Log <numbers: collections.reverse> to the <console>.
|
| 37 |
+
---
|
| 38 |
+
(Feature Name: Business Activity) {
|
| 39 |
+
Extract the <result: qualifier> from the <source: qualifier>.
|
| 40 |
+
Compute the <output> for the <input>.
|
| 41 |
+
Return an <OK: status> for a <valid: result>.
|
| 42 |
+
Publish as <alias> <variable>.
|
| 43 |
+
}
|
| 44 |
+
---
|
| 45 |
+
(* Entry point - exactly one per application *)
|
| 46 |
+
(Application-Start: My App) {
|
| 47 |
+
Log "Starting..." to the <console>.
|
| 48 |
+
Start the <http-server> with <contract>.
|
| 49 |
+
Return an <OK: status> for the <startup>.
|
| 50 |
+
}
|
| 51 |
+
|
| 52 |
+
(* Exit handler for graceful shutdown - optional, at most one *)
|
| 53 |
+
(Application-End: Success) {
|
| 54 |
+
Log "Shutting down..." to the <console>.
|
| 55 |
+
Stop the <http-server> with <application>.
|
| 56 |
+
Return an <OK: status> for the <shutdown>.
|
| 57 |
+
}
|
| 58 |
+
|
| 59 |
+
(* Exit handler for errors/crashes - optional, at most one *)
|
| 60 |
+
(Application-End: Error) {
|
| 61 |
+
Extract the <error> from the <shutdown: error>.
|
| 62 |
+
Log <error> to the <console>.
|
| 63 |
+
Return an <OK: status> for the <error-handling>.
|
| 64 |
+
}
|
| 65 |
+
---
|
| 66 |
+
(* Old syntax: 'length' is both the variable name AND the operation *)
|
| 67 |
+
Compute the <length> from the <message>.
|
| 68 |
+
|
| 69 |
+
(* New syntax: variable name and operation are separate *)
|
| 70 |
+
Compute the <first-length: length> from the <first-message>.
|
| 71 |
+
Compute the <second-length: length> from the <second-message>.
|
| 72 |
+
|
| 73 |
+
(* Now both values are available *)
|
| 74 |
+
Compare the <first-length> against the <second-length>.
|
| 75 |
+
---
|
| 76 |
+
(Application-Start: File Watcher) {
|
| 77 |
+
Log "Starting..." to the <console>.
|
| 78 |
+
Start the <file-monitor> with ".".
|
| 79 |
+
|
| 80 |
+
(* Keep the application running to process events *)
|
| 81 |
+
Keepalive the <application> for the <events>.
|
| 82 |
+
|
| 83 |
+
Return an <OK: status> for the <startup>.
|
| 84 |
+
}
|
| 85 |
+
|
| 86 |
+
```aro
|
| 87 |
+
(Feature Name: Business Activity) {
|
| 88 |
+
Extract the <result: qualifier> from the <source: qualifier>.
|
| 89 |
+
Compute the <output> for the <input>.
|
| 90 |
+
Return an <OK: status> for a <valid: result>.
|
| 91 |
+
Publish as <alias> <variable>.
|
| 92 |
+
}
|
| 93 |
+
```
|
| 94 |
+
|
| 95 |
+
Application lifecycle handlers:
|
| 96 |
+
```aro
|
| 97 |
+
(* Entry point - exactly one per application *)
|
| 98 |
+
(Application-Start: My App) {
|
| 99 |
+
Log "Starting..." to the <console>.
|
| 100 |
+
Start the <http-server> with <contract>.
|
| 101 |
+
Return an <OK: status> for the <startup>.
|
| 102 |
+
}
|
| 103 |
+
|
| 104 |
+
(* Exit handler for graceful shutdown - optional, at most one *)
|
| 105 |
+
(Application-End: Success) {
|
| 106 |
+
Log "Shutting down..." to the <console>.
|
| 107 |
+
Stop the <http-server> with <application>.
|
| 108 |
+
Return an <OK: status> for the <shutdown>.
|
| 109 |
+
}
|
| 110 |
+
|
| 111 |
+
(* Exit handler for errors/crashes - optional, at most one *)
|
| 112 |
+
(Application-End: Error) {
|
| 113 |
+
Extract the <error> from the <shutdown: error>.
|
| 114 |
+
Log <error> to the <console>.
|
| 115 |
+
Return an <OK: status> for the <error-handling>.
|
| 116 |
+
}
|
| 117 |
+
```
|
| 118 |
+
|
| 119 |
+
### Computations
|
| 120 |
+
|
| 121 |
+
The Compute action transforms data using built-in operations:
|
| 122 |
+
|
| 123 |
+
| Operation | Description | Example |
|
| 124 |
+
|-----------|-------------|---------|
|
| 125 |
+
| `length` / `count` | Count elements | `Compute the <len: length> from <text>.` |
|
| 126 |
+
| `uppercase` | Convert to UPPERCASE | `Compute the <upper: uppercase> from <text>.` |
|
| 127 |
+
| `lowercase` | Convert to lowercase | `Compute the <lower: l
|
| 128 |
+
|
| 129 |
+
AVAILABLE ACTIONS (verb [role] β prepositions):
|
| 130 |
+
extract, parse, get [request ] prepositions: from, via
|
| 131 |
+
accept [own ] prepositions: on
|
| 132 |
+
call, invoke [own ] prepositions: from, to, with
|
| 133 |
+
validate, verify, check [own ] prepositions: for, against, with
|
| 134 |
+
compare, match [own ] prepositions: against, with, to
|
| 135 |
+
transform, convert, map [own ] prepositions: from, into, to
|
| 136 |
+
create, build, construct [own ] prepositions: with, from, for
|
| 137 |
+
sort, order, arrange [own ] prepositions: for, with
|
| 138 |
+
merge, combine [own ] prepositions: with, from
|
| 139 |
+
delete, remove, destroy [own ] prepositions: from, for
|
| 140 |
+
execute, exec, run [own ] prepositions: on, with, for
|
| 141 |
+
retrieve, fetch, load [request ] prepositions: from
|
| 142 |
+
receive [request ] prepositions: from, via
|
| 143 |
+
read [request ] prepositions: from
|
| 144 |
+
list [request ] prepositions: from
|
| 145 |
+
stat [request ] prepositions: for
|
| 146 |
+
exists [request ] prepositions: for
|
| 147 |
+
make, touch, createdirectory [server ] prepositions: to, for, at
|
| 148 |
+
copy [server ] prepositions: to
|
| 149 |
+
move, rename [server ] prepositions: to
|
| 150 |
+
append [response] prepositions: to, into
|
| 151 |
+
parse [own ] prepositions: from
|
| 152 |
+
parsehtml [own ] prepositions: from
|
| 153 |
+
map [own ] prepositions: from, to
|
| 154 |
+
reduce, aggregate [own ] prepositions: from, with
|
| 155 |
+
filter [own ] prepositions: from
|
| 156 |
+
group [own ] prepositions: from
|
| 157 |
+
request, http [request ] prepositions: from, to, via
|
| 158 |
+
send, dispatch [response] prepositions: to, via, with
|
| 159 |
+
log, print, output [response] prepositions: for, to, with
|
| 160 |
+
store, save, persist [response] prepositions: into, to, in
|
| 161 |
+
write [response] prepositions: to, into
|
| 162 |
+
notify, alert, signal [response] prepositions: to, for, with
|
| 163 |
+
emit [export ] prepositions: with, to
|
| 164 |
+
schedule [export ] prepositions: with
|
| 165 |
+
start [server ] prepositions: with
|
| 166 |
+
stop [server ] prepositions: with
|
| 167 |
+
listen, await [server ] prepositions: on, for, to
|
| 168 |
+
wait, keepalive, block [server ] prepositions: for
|
| 169 |
+
connect [server ] prepositions: to, with
|
| 170 |
+
broadcast [response] prepositions: to, via
|
| 171 |
+
close, disconnect, terminate [server ] prepositions: with, from
|
| 172 |
+
sleep, delay, pause [own ] prepositions: for, with
|
| 173 |
+
stream, subscribe [request ] prepositions: from, with
|
| 174 |
+
prompt, ask [request ] prepositions: with, from
|
| 175 |
+
select, choose [request ] prepositions: from, with
|
| 176 |
+
clear [own ] prepositions: for
|
| 177 |
+
show [own ] prepositions: for
|
| 178 |
+
render [response] prepositions: to
|
| 179 |
+
repaint, patch [response] prepositions: at, to
|
| 180 |
+
given [own ] prepositions: with
|
| 181 |
+
when [own ] prepositions: from
|
| 182 |
+
then [own ] prepositions: with
|
| 183 |
+
assert [own ] prepositions: for, with
|
| 184 |
+
|
| 185 |
+
CORE RULES:
|
| 186 |
+
- Feature set: (Name: Business Activity) { statements }
|
| 187 |
+
- Exactly one Application-Start per application
|
| 188 |
+
- Variables are immutable β use a new name for each transformation
|
| 189 |
+
- Articles (a/an/the) are optional everywhere
|
| 190 |
+
- String concatenation: <a> ++ <b> (NOT + which is arithmetic)
|
| 191 |
+
- For-each: For each <item> in <list> { ... }
|
| 192 |
+
- Conditions: when <var> = value or when <expr>
|
| 193 |
+
- Return an <OK: status> ... to end a feature set
|
| 194 |
+
- Emit a <Name: event> with <data> to publish events
|
| 195 |
+
- Extract the <x> from the <source: qualifier> to read fields
|
| 196 |
+
|
| 197 |
+
COMMON PATTERNS:
|
| 198 |
+
|
| 199 |
+
1. HTTP endpoint (operationId matches feature set name):
|
| 200 |
+
(getUser: User API) {
|
| 201 |
+
Extract the <id> from the <pathParameters: id>.
|
| 202 |
+
Retrieve the <user> from the <user-repository> where id = <id>.
|
| 203 |
+
Return an <OK: status> with <user>.
|
| 204 |
+
}
|
| 205 |
+
|
| 206 |
+
2. Application startup with Keepalive:
|
| 207 |
+
(Application-Start: My App) {
|
| 208 |
+
Log "Starting..." to the <console>.
|
| 209 |
+
Start the <http-server> with <contract>.
|
| 210 |
+
Keepalive the <application> for the <events>.
|
| 211 |
+
Return an <OK: status> for the <startup>.
|
| 212 |
+
}
|
| 213 |
+
|
| 214 |
+
3. Event emission and handler:
|
| 215 |
+
Emit a <UserCreated: event> with <user>.
|
| 216 |
+
(Send Email: UserCreated Handler) {
|
| 217 |
+
Extract the <user> from the <event: user>.
|
| 218 |
+
Send the <email> to the <user: email>.
|
| 219 |
+
Return an <OK: status> for the <notification>.
|
| 220 |
+
}
|
| 221 |
+
|
| 222 |
+
4. Iteration with transformation:
|
| 223 |
+
For each <item> in <items> {
|
| 224 |
+
Compute the <name: uppercase> from the <item: name>.
|
| 225 |
+
Log <name> to the <console>.
|
| 226 |
+
}
|
| 227 |
+
|
| 228 |
+
TOOL CALLING:
|
| 229 |
+
You have tools for reading/writing files, running commands, and invoking the ARO
|
| 230 |
+
toolchain. When modifying the user's project, use tools instead of guessing.
|
| 231 |
+
|
| 232 |
+
Key tools:
|
| 233 |
+
- read_file(path) β Read a file before suggesting changes
|
| 234 |
+
- write_file(path, content) β Create or overwrite a file
|
| 235 |
+
- edit_file(path, old_string, new_string) β Exact string replacement
|
| 236 |
+
- grep(pattern, path?) β Search files with regex
|
| 237 |
+
- aro_check(path) β Validate ARO syntax (always run after writing code)
|
| 238 |
+
- aro_run(path) β Execute an ARO application
|
| 239 |
+
- aro_test(path) β Run tests
|
| 240 |
+
- create_plugin(name, language, handle) β Scaffold a new plugin
|
| 241 |
+
- write_openapi(title, paths) β Generate an openapi.yaml contract
|
| 242 |
+
|
| 243 |
+
IMPORTANT: After writing or editing ARO code, ALWAYS validate with aro_check.
|
| 244 |
+
When debugging, read_file first to see the current state.
|
| 245 |
+
|
| 246 |
+
RESPONSE BEHAVIOUR:
|
| 247 |
+
- WRITE/CREATE/BUILD request: respond with valid ARO code in ```aro fences.
|
| 248 |
+
If you have tool access, write the file and validate with aro_check.
|
| 249 |
+
- QUESTION about ARO: answer concisely with examples in ```aro fences.
|
| 250 |
+
- FIX/DEBUG request: read the code first (read_file), diagnose, apply fix
|
| 251 |
+
(edit_file), then verify (aro_check).
|
| 252 |
+
- ONLY use action verbs from the AVAILABLE ACTIONS list above. NEVER invent
|
| 253 |
+
new actions. If a user asks for functionality not covered by an existing
|
| 254 |
+
action, explain which available action(s) to use instead. For example,
|
| 255 |
+
there is no "Tail" action β use the file-monitor (Start + File Event
|
| 256 |
+
Handler) for watching files, or Read for reading file contents.
|
| 257 |
+
- Do not invent prepositions not listed above.
|
| 258 |
+
- If unsure whether an action exists, say so β do not guess.
|
| 259 |
+
- Always produce syntactically valid ARO.
|
model.safetensors
CHANGED
|
@@ -1,3 +1,3 @@
|
|
| 1 |
version https://git-lfs.github.com/spec/v1
|
| 2 |
-
oid sha256:
|
| 3 |
size 4607835164
|
|
|
|
| 1 |
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:8a27b23d48bd4c718f9b36a56d27d6ffb6b7337ec8d4f93a6e6846d6da376512
|
| 3 |
size 4607835164
|