prince-canuma commited on
Commit
072a4b3
·
verified ·
1 Parent(s): 66222a0

Create README.md

Browse files
Files changed (1) hide show
  1. README.md +536 -0
README.md ADDED
@@ -0,0 +1,536 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ language:
3
+ - en
4
+ - fr
5
+ - de
6
+ - es
7
+ - it
8
+ - pt
9
+ - zh
10
+ - ja
11
+ - ru
12
+ - ko
13
+ license: other
14
+ license_name: mrl
15
+ inference: false
16
+ license_link: https://mistral.ai/licenses/MRL-0.1.md
17
+ extra_gated_prompt: '# Mistral AI Research License
18
+
19
+ If You want to use a Mistral Model, a Derivative or an Output for any purpose that
20
+ is not expressly authorized under this Agreement, You must request a license from
21
+ Mistral AI, which Mistral AI may grant to You in Mistral AI''s sole discretion.
22
+ To discuss such a license, please contact Mistral AI via the website contact form:
23
+ https://mistral.ai/contact/
24
+
25
+ ## 1. Scope and acceptance
26
+
27
+ **1.1. Scope of the Agreement.** This Agreement applies to any use, modification,
28
+ or Distribution of any Mistral Model by You, regardless of the source You obtained
29
+ a copy of such Mistral Model.
30
+
31
+ **1.2. Acceptance.** By accessing, using, modifying, Distributing a Mistral Model,
32
+ or by creating, using or distributing a Derivative of the Mistral Model, You agree
33
+ to be bound by this Agreement.
34
+
35
+ **1.3. Acceptance on behalf of a third-party.** If You accept this Agreement on
36
+ behalf of Your employer or another person or entity, You warrant and represent that
37
+ You have the authority to act and accept this Agreement on their behalf. In such
38
+ a case, the word "You" in this Agreement will refer to Your employer or such other
39
+ person or entity.
40
+
41
+ ## 2. License
42
+
43
+ **2.1. Grant of rights**. Subject to Section 3 below, Mistral AI hereby grants
44
+ You a non-exclusive, royalty-free, worldwide, non-sublicensable, non-transferable,
45
+ limited license to use, copy, modify, and Distribute under the conditions provided
46
+ in Section 2.2 below, the Mistral Model and any Derivatives made by or for Mistral
47
+ AI and to create Derivatives of the Mistral Model.
48
+
49
+ **2.2. Distribution of Mistral Model and Derivatives made by or for Mistral AI.**
50
+ Subject to Section 3 below, You may Distribute copies of the Mistral Model and/or
51
+ Derivatives made by or for Mistral AI, under the following conditions: You must
52
+ make available a copy of this Agreement to third-party recipients of the Mistral
53
+ Models and/or Derivatives made by or for Mistral AI you Distribute, it being specified
54
+ that any rights to use the Mistral Models and/or Derivatives made by or for Mistral
55
+ AI shall be directly granted by Mistral AI to said third-party recipients pursuant
56
+ to the Mistral AI Research License agreement executed between these parties; You
57
+ must retain in all copies of the Mistral Models the following attribution notice
58
+ within a "Notice" text file distributed as part of such copies: "Licensed by Mistral
59
+ AI under the Mistral AI Research License".
60
+
61
+ **2.3. Distribution of Derivatives made by or for You.** Subject to Section 3 below,
62
+ You may Distribute any Derivatives made by or for You under additional or different
63
+ terms and conditions, provided that: In any event, the use and modification of Mistral
64
+ Model and/or Derivatives made by or for Mistral AI shall remain governed by the
65
+ terms and conditions of this Agreement; You include in any such Derivatives made
66
+ by or for You prominent notices stating that You modified the concerned Mistral
67
+ Model; and Any terms and conditions You impose on any third-party recipients relating
68
+ to Derivatives made by or for You shall neither limit such third-party recipients''
69
+ use of the Mistral Model or any Derivatives made by or for Mistral AI in accordance
70
+ with the Mistral AI Research License nor conflict with any of its terms and conditions.
71
+
72
+ ## 3. Limitations
73
+
74
+ **3.1. Misrepresentation.** You must not misrepresent or imply, through any means,
75
+ that the Derivatives made by or for You and/or any modified version of the Mistral
76
+ Model You Distribute under your name and responsibility is an official product of
77
+ Mistral AI or has been endorsed, approved or validated by Mistral AI, unless You
78
+ are authorized by Us to do so in writing.
79
+
80
+ **3.2. Usage Limitation.** You shall only use the Mistral Models, Derivatives (whether
81
+ or not created by Mistral AI) and Outputs for Research Purposes.
82
+
83
+ ## 4. Intellectual Property
84
+
85
+ **4.1. Trademarks.** No trademark licenses are granted under this Agreement, and
86
+ in connection with the Mistral Models, You may not use any name or mark owned by
87
+ or associated with Mistral AI or any of its affiliates, except (i) as required for
88
+ reasonable and customary use in describing and Distributing the Mistral Models and
89
+ Derivatives made by or for Mistral AI and (ii) for attribution purposes as required
90
+ by this Agreement.
91
+
92
+ **4.2. Outputs.** We claim no ownership rights in and to the Outputs. You are solely
93
+ responsible for the Outputs You generate and their subsequent uses in accordance
94
+ with this Agreement. Any Outputs shall be subject to the restrictions set out in
95
+ Section 3 of this Agreement.
96
+
97
+ **4.3. Derivatives.** By entering into this Agreement, You accept that any Derivatives
98
+ that You may create or that may be created for You shall be subject to the restrictions
99
+ set out in Section 3 of this Agreement.
100
+
101
+ ## 5. Liability
102
+
103
+ **5.1. Limitation of liability.** In no event, unless required by applicable law
104
+ (such as deliberate and grossly negligent acts) or agreed to in writing, shall Mistral
105
+ AI be liable to You for damages, including any direct, indirect, special, incidental,
106
+ or consequential damages of any character arising as a result of this Agreement
107
+ or out of the use or inability to use the Mistral Models and Derivatives (including
108
+ but not limited to damages for loss of data, loss of goodwill, loss of expected
109
+ profit or savings, work stoppage, computer failure or malfunction, or any damage
110
+ caused by malware or security breaches), even if Mistral AI has been advised of
111
+ the possibility of such damages.
112
+
113
+ **5.2. Indemnification.** You agree to indemnify and hold harmless Mistral AI from
114
+ and against any claims, damages, or losses arising out of or related to Your use
115
+ or Distribution of the Mistral Models and Derivatives.
116
+
117
+ ## 6. Warranty
118
+
119
+ **6.1. Disclaimer.** Unless required by applicable law or prior agreed to by Mistral
120
+ AI in writing, Mistral AI provides the Mistral Models and Derivatives on an "AS
121
+ IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied,
122
+ including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT,
123
+ MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. Mistral AI does not represent
124
+ nor warrant that the Mistral Models and Derivatives will be error-free, meet Your
125
+ or any third party''s requirements, be secure or will allow You or any third party
126
+ to achieve any kind of result or generate any kind of content. You are solely responsible
127
+ for determining the appropriateness of using or Distributing the Mistral Models
128
+ and Derivatives and assume any risks associated with Your exercise of rights under
129
+ this Agreement.
130
+
131
+ ## 7. Termination
132
+
133
+ **7.1. Term.** This Agreement is effective as of the date of your acceptance of
134
+ this Agreement or access to the concerned Mistral Models or Derivatives and will
135
+ continue until terminated in accordance with the following terms.
136
+
137
+ **7.2. Termination.** Mistral AI may terminate this Agreement at any time if You
138
+ are in breach of this Agreement. Upon termination of this Agreement, You must cease
139
+ to use all Mistral Models and Derivatives and shall permanently delete any copy
140
+ thereof. The following provisions, in their relevant parts, will survive any termination
141
+ or expiration of this Agreement, each for the duration necessary to achieve its
142
+ own intended purpose (e.g. the liability provision will survive until the end of
143
+ the applicable limitation period):Sections 5 (Liability), 6(Warranty), 7 (Termination)
144
+ and 8 (General Provisions).
145
+
146
+ **7.3. Litigation.** If You initiate any legal action or proceedings against Us
147
+ or any other entity (including a cross-claim or counterclaim in a lawsuit), alleging
148
+ that the Model or a Derivative, or any part thereof, infringe upon intellectual
149
+ property or other rights owned or licensable by You, then any licenses granted to
150
+ You under this Agreement will immediately terminate as of the date such legal action
151
+ or claim is filed or initiated.
152
+
153
+ ## 8. General provisions
154
+
155
+ **8.1. Governing laws.** This Agreement will be governed by the laws of France,
156
+ without regard to choice of law principles, and the UN Convention on Contracts for
157
+ the International Sale of Goods does not apply to this Agreement.
158
+
159
+ **8.2. Competent jurisdiction.** The courts of Paris shall have exclusive jurisdiction
160
+ of any dispute arising out of this Agreement.
161
+
162
+ **8.3. Severability.** If any provision of this Agreement is held to be invalid,
163
+ illegal or unenforceable, the remaining provisions shall be unaffected thereby and
164
+ remain valid as if such provision had not been set forth herein.
165
+
166
+ ## 9. Definitions
167
+
168
+ "Agreement": means this Mistral AI Research License agreement governing the access,
169
+ use, and Distribution of the Mistral Models, Derivatives and Outputs.
170
+
171
+ "Derivative": means any (i) modified version of the Mistral Model (including but
172
+ not limited to any customized or fine-tuned version thereof), (ii) work based on
173
+ the Mistral Model, or (iii) any other derivative work thereof.
174
+
175
+ "Distribution", "Distributing", "Distribute" or "Distributed": means supplying,
176
+ providing or making available, by any means, a copy of the Mistral Models and/or
177
+ the Derivatives as the case may be, subject to Section 3 of this Agreement.
178
+
179
+ "Mistral AI", "We" or "Us": means Mistral AI, a French société par actions simplifiée
180
+ registered in the Paris commercial registry under the number 952 418 325, and having
181
+ its registered seat at 15, rue des Halles, 75001 Paris.
182
+
183
+ "Mistral Model": means the foundational large language model(s), and its elements
184
+ which include algorithms, software, instructed checkpoints, parameters, source code
185
+ (inference code, evaluation code and, if applicable, fine-tuning code) and any other
186
+ elements associated thereto made available by Mistral AI under this Agreement, including,
187
+ if any, the technical documentation, manuals and instructions for the use and operation
188
+ thereof.
189
+
190
+ "Research Purposes": means any use of a Mistral Model, Derivative, or Output that
191
+ is solely for (a) personal, scientific or academic research, and (b) for non-profit
192
+ and non-commercial purposes, and not directly or indirectly connected to any commercial
193
+ activities or business operations. For illustration purposes, Research Purposes
194
+ does not include (1) any usage of the Mistral Model, Derivative or Output by individuals
195
+ or contractors employed in or engaged by companies in the context of (a) their daily
196
+ tasks, or (b) any activity (including but not limited to any testing or proof-of-concept)
197
+ that is intended to generate revenue, nor (2) any Distribution by a commercial entity
198
+ of the Mistral Model, Derivative or Output whether in return for payment or free
199
+ of charge, in any medium or form, including but not limited to through a hosted
200
+ or managed service (e.g. SaaS, cloud instances, etc.), or behind a software layer.
201
+
202
+ "Outputs": means any content generated by the operation of the Mistral Models or
203
+ the Derivatives from a prompt (i.e., text instructions) provided by users. For
204
+ the avoidance of doubt, Outputs do not include any components of a Mistral Models,
205
+ such as any fine-tuned versions of the Mistral Models, the weights, or parameters.
206
+
207
+ "You": means the individual or entity entering into this Agreement with Mistral
208
+ AI.
209
+
210
+
211
+ *Mistral AI processes your personal data below to provide the model and enforce
212
+ its license. If you are affiliated with a commercial entity, we may also send you
213
+ communications about our models. For more information on your rights and data handling,
214
+ please see our <a href="https://mistral.ai/terms/">privacy policy</a>.*'
215
+ extra_gated_fields:
216
+ First Name: text
217
+ Last Name: text
218
+ Country: country
219
+ Affiliation: text
220
+ Job title: text
221
+ I understand that I can only use the model, any derivative versions and their outputs for non-commercial research purposes: checkbox
222
+ ? I understand that if I am a commercial entity, I am not permitted to use or distribute
223
+ the model internally or externally, or expose it in my own offerings without a
224
+ commercial license
225
+ : checkbox
226
+ ? I understand that if I upload the model, or any derivative version, on any platform,
227
+ I must include the Mistral Research License
228
+ : checkbox
229
+ ? I understand that for commercial use of the model, I can contact Mistral or use
230
+ the Mistral AI API on la Plateforme or any of our cloud provider partners
231
+ : checkbox
232
+ ? By clicking Submit below I accept the terms of the license and acknowledge that
233
+ the information I provide will be collected stored processed and shared in accordance
234
+ with the Mistral Privacy Policy
235
+ : checkbox
236
+ geo: ip_location
237
+ extra_gated_description: Mistral AI processes your personal data below to provide
238
+ the model and enforce its license. If you are affiliated with a commercial entity,
239
+ we may also send you communications about our models. For more information on your
240
+ rights and data handling, please see our <a href="https://mistral.ai/terms/">privacy
241
+ policy</a>.
242
+ extra_gated_button_content: Submit
243
+ library_name: vllm
244
+ pipeline_tag: image-text-to-text
245
+ ---
246
+
247
+ # Model Card for Pixtral-Large-Instruct-2411
248
+
249
+ Pixtral-Large-Instruct-2411 is a 124B multimodal model built on top of Mistral Large 2, i.e., [Mistral-Large-Instruct-2407](https://huggingface.co/mistralai/Mistral-Large-Instruct-2407). Pixtral Large is the second model in our multimodal family and demonstrates frontier-level image understanding. Particularly, the model is able to understand documents, charts and natural images, while maintaining the leading text-only understanding of Mistral Large 2.
250
+
251
+ For more details about this model please refer to the [Pixtral Large blog post](https://mistral.ai/news/pixtral-large/) and the [Pixtral 12B blog post](https://mistral.ai/news/pixtral-12b/).
252
+
253
+
254
+ > [!IMPORTANT]
255
+ > ❗
256
+ > The Transformers implementation is not yet working (see [here](https://huggingface.co/mistralai/Pixtral-Large-Instruct-2411/discussions/3#673b8bfe55cb1761c8d50ce2)), please use the vLLM implementation
257
+ > as shown below.
258
+
259
+ ## Key features
260
+ - Frontier-class multimodal performance
261
+ - State-of-the-art on MathVista, DocVQA, VQAv2
262
+ - Extends Mistral Large 2 without compromising text performance
263
+ - 123B multimodal decoder, 1B parameter vision encoder
264
+ - 128K context window: fits minimum of 30 high-resolution images
265
+
266
+ <!--
267
+ - **Multi-lingual by design:** Dozens of languages supported, including English, French, German, Spanish, Italian, Chinese, Japanese, Korean, Portuguese, Dutch and Polish.
268
+ - **Proficient in coding:** Trained on 80+ coding languages such as Python, Java, C, C++, Javacsript, and Bash. Also trained on more specific languages such as Swift and Fortran.
269
+ - **Agentic-centric:** Best-in-class agentic capabilities with native function calling and JSON outputting.
270
+ - **Advanced Reasoning:** State-of-the-art mathematical and reasoning capabilities.
271
+ - **Mistral Research License:** Allows usage and modification for research and non-commercial usages.
272
+ - **Large Context:** A large 128k context window.
273
+ - **System Prompt:** Maintains strong adherence and support for more reliable system prompts.
274
+ - **Vision:** A 1B parameter Vision Encoder achieving SOTA vision capabilities.
275
+ -->
276
+
277
+ ### System Prompt Handling
278
+
279
+ We appreciate the feedback received from our community regarding our system prompt handling.
280
+ In response, we have implemented stronger support for system prompts.
281
+ To achieve optimal results, we recommend always including a system prompt that clearly outlines the bot's purpose, even if it is minimal.
282
+
283
+ ### Basic Instruct Template (V7)
284
+
285
+ ```
286
+ <s>[SYSTEM_PROMPT] <system prompt>[/SYSTEM_PROMPT][INST] <user message>[/INST] <assistant response></s>[INST] <user message>[/INST]
287
+ ```
288
+
289
+ **Be careful with subtle missing or trailing white spaces!**
290
+
291
+ *Please make sure to use [mistral-common](https://github.com/mistralai/mistral-common) as the source of truth*
292
+
293
+
294
+ ## Metrics
295
+
296
+ | Model | MathVista (CoT) | MMMU (CoT) | ChartQA (CoT) | DocVQA (ANLS) | VQAv2 (VQA Match) | AI2D (BBox) | MM MT-Bench |
297
+ |:----------------------------:|:---------------:|:----------:|:-------------:|:--------------:|:-----------------:|:-----------:|:-----------:|
298
+ | **Pixtral Large (124B)** | **<u>69.4</u>** | 64.0 | 88.1 | **<u>93.3</u>**| **<u>80.9</u>** | 93.8 | **<u>7.4</u>**|
299
+ | Gemini-1.5 Pro (measured) | 67.8 | 66.3 | 83.8 | 92.3 | 70.6 | **<u>94.6</u>**| 6.8 |
300
+ | GPT-4o (measured) | 65.4 | **<u>68.6</u>**| 85.2 | 88.5 | 76.4 | 93.2 | 6.7 |
301
+ | Claude-3.5 Sonnet (measured) | 67.1 | 68.4 | **<u>89.1</u>**| 88.6 | 69.5 | 76.9 | 7.3 |
302
+ | Llama-3.2 90B (measured) | 49.1 | 53.7 | 70.8 | 85.7 | 67.0 | - | 5.5 |
303
+
304
+ Specific model versions evaluated: Claude-3.5 Sonnet (new) [Oct 24], Gemini-1.5 Pro (002) [Sep 24], GPT-4o (2024-08-06) [Aug 24].
305
+
306
+ See [mistral-evals](https://github.com/mistralai/mistral-evals) for open-source MM MT-Bench evaluation scripts.
307
+
308
+ ## Usage
309
+
310
+ The model can be used with the following frameworks
311
+
312
+ - [`vllm`](https://github.com/vllm-project/vllm): See [here](#vLLM)
313
+
314
+ ### vLLM
315
+
316
+ We recommend using Pixtral-Large-Instruct-2411 with the [vLLM library](https://github.com/vllm-project/vllm)
317
+ to implement production-ready inference pipelines with Pixtral-Large-Instruct-2411.
318
+
319
+ **_Installation_**
320
+
321
+ Make sure you install [`vLLM >= v0.6.4.post1`](https://github.com/vllm-project/vllm/releases/tag/v0.6.4.post1):
322
+
323
+ ```
324
+ pip install --upgrade vllm
325
+ ```
326
+
327
+ Also make sure you have [`mistral_common >= 1.5.0`](https://github.com/mistralai/mistral-common/releases/tag/v1.5.0) installed:
328
+
329
+ ```
330
+ pip install --upgrade mistral_common
331
+ ```
332
+
333
+ You can also make use of a ready-to-go [docker image](https://github.com/vllm-project/vllm/blob/main/Dockerfile) or on the [docker hub](https://hub.docker.com/layers/vllm/vllm-openai/latest/images/sha256-55a88146a4da0b6e193431b5b1d3492dfd7bebdc16919df4d031273e85a6157c?context=explore).
334
+
335
+
336
+ #### Server (Image)
337
+ We recommend to use Pixtral-Large-Instruct-2411 in a server/client setting.
338
+
339
+ 1. Spin up a server:
340
+
341
+ ```
342
+ vllm serve mistralai/Pixtral-Large-Instruct-2411 --config-format mistral --load-format mistral --tokenizer_mode mistral --limit_mm_per_prompt 'image=10' --tensor-parallel-size 8
343
+ ```
344
+
345
+ 2. And ping the client:
346
+
347
+ ```py
348
+ import requests
349
+ import json
350
+ from huggingface_hub import hf_hub_download
351
+ from datetime import datetime, timedelta
352
+
353
+ url = "http://<your-server-url>:8000/v1/chat/completions"
354
+ headers = {"Content-Type": "application/json", "Authorization": "Bearer token"}
355
+
356
+ model = "mistralai/Pixtral-Large-Instruct-2411"
357
+
358
+
359
+ def load_system_prompt(repo_id: str, filename: str) -> str:
360
+ file_path = hf_hub_download(repo_id=repo_id, filename=filename)
361
+ with open(file_path, "r") as file:
362
+ system_prompt = file.read()
363
+ today = datetime.today().strftime("%Y-%m-%d")
364
+ yesterday = (datetime.today() - timedelta(days=1)).strftime("%Y-%m-%d")
365
+ model_name = repo_id.split("/")[-1]
366
+ return system_prompt.format(name=model_name, today=today, yesterday=yesterday)
367
+
368
+
369
+ SYSTEM_PROMPT = load_system_prompt(model, "SYSTEM_PROMPT.txt")
370
+
371
+ image_url = "https://huggingface.co/datasets/patrickvonplaten/random_img/resolve/main/europe.png"
372
+
373
+ messages = [
374
+ {"role": "system", "content": SYSTEM_PROMPT},
375
+ {
376
+ "role": "user",
377
+ "content": [
378
+ {
379
+ "type": "text",
380
+ "text": "Which of the depicted countries has the best food? Which the second and third and fourth? Name the country, its color on the map and one its city that is visible on the map, but is not the capital. Make absolutely sure to only name a city that can be seen on the map.",
381
+ },
382
+ {"type": "image_url", "image_url": {"url": image_url}},
383
+ ],
384
+ },
385
+ ]
386
+
387
+ data = {"model": model, "messages": messages}
388
+
389
+ response = requests.post(url, headers=headers, data=json.dumps(data))
390
+ print(response.json()["choices"][0]["message"]["content"])
391
+ # Determining which country has the "best" food can be subjective and depends on personal preferences. However, based on popular culinary reputations, here are some countries known for their cuisine:
392
+
393
+ #1. **Italy** (Brown) - Known for its pasta, pizza, and diverse regional dishes.
394
+ # - City: Milan
395
+
396
+ #2. **France** (Dark Brown) - Renowned for its fine dining, pastries, and wine.
397
+ # - City: Lyon
398
+
399
+ #3. **Spain** (Yellow) - Famous for tapas, paella, and a variety of seafood dishes.
400
+ # - City: Barcelona
401
+
402
+ #4. **Greece** (Yellow) - Known for its Mediterranean cuisine, including moussaka, souvlaki, and fresh seafood.
403
+ # - City: Thessaloniki
404
+
405
+ #These rankings are based on general culinary reputations and can vary widely depending on individual tastes.
406
+ ```
407
+
408
+ #### Server (Text-only)
409
+
410
+ You can also ping the client with a text-only example. The following example
411
+ shows how the system prompt can be used to make sure the model always knows
412
+ the current date.
413
+
414
+ ```py
415
+ import requests
416
+ import json
417
+ from huggingface_hub import hf_hub_download
418
+ from datetime import datetime, timedelta
419
+
420
+ url = "http://<your-server-url>:8000/v1/chat/completions"
421
+ headers = {"Content-Type": "application/json", "Authorization": "Bearer token"}
422
+
423
+ model = "mistralai/Pixtral-Large-Instruct-2411"
424
+
425
+
426
+ def load_system_prompt(repo_id: str, filename: str) -> str:
427
+ file_path = hf_hub_download(repo_id=repo_id, filename=filename)
428
+ with open(file_path, "r") as file:
429
+ system_prompt = file.read()
430
+ today = datetime.today().strftime("%Y-%m-%d")
431
+ yesterday = (datetime.today() - timedelta(days=1)).strftime("%Y-%m-%d")
432
+ model_name = repo_id.split("/")[-1]
433
+ return system_prompt.format(name=model_name, today=today, yesterday=yesterday)
434
+
435
+
436
+ SYSTEM_PROMPT = load_system_prompt(model, "SYSTEM_PROMPT.txt")
437
+
438
+ image_url = "https://huggingface.co/datasets/patrickvonplaten/random_img/resolve/main/europe.png"
439
+
440
+ messages = [
441
+ {"role": "system", "content": SYSTEM_PROMPT},
442
+ {
443
+ "role": "user",
444
+ "content": "Without browsing the web, how many days ago was Mistral founded?"
445
+ },
446
+ ]
447
+
448
+ data = {"model": model, "messages": messages}
449
+
450
+ response = requests.post(url, headers=headers, data=json.dumps(data))
451
+ print(response.json()["choices"][0]["message"]["content"])
452
+ # Mistral AI was founded in April 2023. Since the current date is November 18, 2024, we can calculate the number of days between April 2023 and November 18, 2024.
453
+
454
+ #First, calculate the days from April 2023 to the end of 2023:
455
+ #- April: 27 days (30 - 3)
456
+ #- May: 31 days
457
+ #- June: 30 days
458
+ #- July: 31 days
459
+ #- August: 31 days
460
+ #- September: 30 days
461
+ #- October: 31 days
462
+ #- November: 30 days
463
+ #- December: 31 days
464
+
465
+ #Total days from April 2023 to December 31, 2023: 27 + 31 + 30 + 31 + 31 + 30 + 31 + 30 + 31 = 272 days
466
+
467
+ #Next, calculate the days from January 1, 2024, to November 18, 2024:
468
+ #- January: 31 days
469
+ #- February: 29 days (2024 is a leap year)
470
+ #- March: 31 days
471
+ #- April: 30 days
472
+ #- May: 31 days
473
+ #- June: 30 days
474
+ #- July: 31 days
475
+ #- August: 31 days
476
+ #- September: 30 days
477
+ #- October: 31 days
478
+ #- November: 18 days
479
+
480
+ #Total days from January 1, 2024, to November 18, 2024: 31 + 29 + 31 + 30 + 31 + 30 + 31 + 31 + 30 + 31 + 18 = 323 days
481
+
482
+ #Adding the two periods together:
483
+ #272 days (from April 2023 to December 2023) + 323 days (from January 2024 to November 18, 2024) = 595 days
484
+
485
+ #Therefore, Mistral AI was founded 595 days ago from November 18, 2024.
486
+ ```
487
+
488
+ #### Offline Example
489
+ ```py
490
+ from vllm import LLM
491
+ from vllm.sampling_params import SamplingParams
492
+ from huggingface_hub import hf_hub_download
493
+ from datetime import datetime, timedelta
494
+
495
+ model_name = "mistralai/Pixtral-Large-Instruct-2411"
496
+
497
+ def load_system_prompt(repo_id: str, filename: str) -> str:
498
+ file_path = hf_hub_download(repo_id=repo_id, filename=filename)
499
+ with open(file_path, 'r') as file:
500
+ system_prompt = file.read()
501
+ today = datetime.today().strftime('%Y-%m-%d')
502
+ yesterday = (datetime.today() - timedelta(days=1)).strftime('%Y-%m-%d')
503
+ model_name = repo_id.split("/")[-1]
504
+ return system_prompt.format(name=model_name, today=today, yesterday=yesterday)
505
+
506
+ SYSTEM_PROMPT = load_system_prompt(model_name, "SYSTEM_PROMPT.txt")
507
+
508
+ image_url = "https://huggingface.co/datasets/patrickvonplaten/random_img/resolve/main/europe.png"
509
+
510
+ messages = [
511
+ {"role": "system", "content": SYSTEM_PROMPT},
512
+ {
513
+ "role": "user",
514
+ "content": [
515
+ {
516
+ "type": "text",
517
+ "text": "Which of the depicted countries has the best food? Which the second and third and fourth? Name the country, its color on the map and one its city that is visible on the map, but is not the capital. Make absolutely sure to only name a city that can be seen on the map.",
518
+ },
519
+ {"type": "image_url", "image_url": {"url": image_url}},
520
+ ],
521
+ },
522
+ ]
523
+
524
+ sampling_params = SamplingParams(max_tokens=512)
525
+
526
+ # note that running this model on GPU requires over 300 GB of GPU RAM
527
+ llm = LLM(model=model_name, config_format="mistral", load_format="mistral", tokenizer_mode="mistral", tensor_parallel_size=8, limit_mm_per_prompt={"image": 4})
528
+
529
+ outputs = llm.chat(messages, sampling_params=sampling_params)
530
+
531
+ print(outputs[0].outputs[0].text)
532
+ ```
533
+
534
+ ## The Mistral AI Team
535
+
536
+ Albert Jiang, Alexandre Sablayrolles, Alexis Tacnet, Alok Kothari, Antoine Roux, Arthur Mensch, Audrey Herblin-Stoop, Augustin Garreau, Austin Birky, Bam4d, Baptiste Bout, Baudouin de Monicault, Blanche Savary, Carole Rambaud, Caroline Feldman, Devendra Singh Chaplot, Diego de las Casas, Diogo Costa, Eleonore Arcelin, Emma Bou Hanna, Etienne Metzger, Gaspard Blanchet, Gianna Lengyel, Guillaume Bour, Guillaume Lample, Harizo Rajaona, Henri Roussez, Hichem Sattouf, Ian Mack, Jean-Malo Delignon, Jessica Chudnovsky, Justus Murke, Kartik Khandelwal, Lawrence Stewart, Louis Martin, Louis Ternon, Lucile Saulnier, Lélio Renard Lavaud, Margaret Jennings, Marie Pellat, Marie Torelli, Marie-Anne Lachaux, Marjorie Janiewicz, Mickaël Seznec, Nicolas Schuhl, Niklas Muhs, Olivier de Garrigues, Patrick von Platen, Paul Jacob, Pauline Buche, Pavan Kumar Reddy, Perry Savas, Pierre Stock, Romain Sauvestre, Sagar Vaze, Sandeep Subramanian, Saurabh Garg, Sophia Yang, Szymon Antoniak, Teven Le Scao, Thibault Schueller, Thibaut Lavril, Thomas Wang, Théophile Gervet, Timothée Lacroix, Valera Nemychnikova, Wendy Shang, William El Sayed, William Marshall