TechxGenus commited on
Commit
24b1268
1 Parent(s): 29766b2

Upload folder using huggingface_hub

Browse files
README.md ADDED
@@ -0,0 +1,468 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ language:
3
+ - en
4
+ - fr
5
+ - de
6
+ - es
7
+ - it
8
+ - pt
9
+ - zh
10
+ - ja
11
+ - ru
12
+ - ko
13
+ base_model:
14
+ - mistralai/Mistral-Large-Instruct-2411
15
+ license: other
16
+ license_name: mrl
17
+ inference: false
18
+ license_link: https://mistral.ai/licenses/MRL-0.1.md
19
+ extra_gated_prompt: >-
20
+ # Mistral AI Research License
21
+
22
+ If You want to use a Mistral Model, a Derivative or an Output for any purpose that is not expressly authorized under this Agreement, You must request a license from Mistral AI, which Mistral AI may grant to You in Mistral AI's sole discretion. To discuss such a license, please contact Mistral AI via the website contact form: https://mistral.ai/contact/
23
+
24
+ ## 1. Scope and acceptance
25
+
26
+ **1.1. Scope of the Agreement.** This Agreement applies to any use, modification, or Distribution of any Mistral Model by You, regardless of the source You obtained a copy of such Mistral Model.
27
+
28
+ **1.2. Acceptance.** By accessing, using, modifying, Distributing a Mistral Model, or by creating, using or distributing a Derivative of the Mistral Model, You agree to be bound by this Agreement.
29
+
30
+ **1.3. Acceptance on behalf of a third-party.** If You accept this Agreement on behalf of Your employer or another person or entity, You warrant and represent that You have the authority to act and accept this Agreement on their behalf. In such a case, the word "You" in this Agreement will refer to Your employer or such other person or entity.
31
+
32
+ ## 2. License
33
+
34
+ **2.1. Grant of rights**. Subject to Section 3 below, Mistral AI hereby grants You a non-exclusive, royalty-free, worldwide, non-sublicensable, non-transferable, limited license to use, copy, modify, and Distribute under the conditions provided in Section 2.2 below, the Mistral Model and any Derivatives made by or for Mistral AI and to create Derivatives of the Mistral Model.
35
+
36
+ **2.2. Distribution of Mistral Model and Derivatives made by or for Mistral AI.** Subject to Section 3 below, You may Distribute copies of the Mistral Model and/or Derivatives made by or for Mistral AI, under the following conditions:
37
+ You must make available a copy of this Agreement to third-party recipients of the Mistral Models and/or Derivatives made by or for Mistral AI you Distribute, it being specified that any rights to use the Mistral Models and/or Derivatives made by or for Mistral AI shall be directly granted by Mistral AI to said third-party recipients pursuant to the Mistral AI Research License agreement executed between these parties;
38
+ You must retain in all copies of the Mistral Models the following attribution notice within a "Notice" text file distributed as part of such copies: "Licensed by Mistral AI under the Mistral AI Research License".
39
+
40
+ **2.3. Distribution of Derivatives made by or for You.** Subject to Section 3 below, You may Distribute any Derivatives made by or for You under additional or different terms and conditions, provided that:
41
+ In any event, the use and modification of Mistral Model and/or Derivatives made by or for Mistral AI shall remain governed by the terms and conditions of this Agreement;
42
+ You include in any such Derivatives made by or for You prominent notices stating that You modified the concerned Mistral Model; and
43
+ Any terms and conditions You impose on any third-party recipients relating to Derivatives made by or for You shall neither limit such third-party recipients' use of the Mistral Model or any Derivatives made by or for Mistral AI in accordance with the Mistral AI Research License nor conflict with any of its terms and conditions.
44
+
45
+ ## 3. Limitations
46
+
47
+ **3.1. Misrepresentation.** You must not misrepresent or imply, through any means, that the Derivatives made by or for You and/or any modified version of the Mistral Model You Distribute under your name and responsibility is an official product of Mistral AI or has been endorsed, approved or validated by Mistral AI, unless You are authorized by Us to do so in writing.
48
+
49
+ **3.2. Usage Limitation.** You shall only use the Mistral Models, Derivatives (whether or not created by Mistral AI) and Outputs for Research Purposes.
50
+
51
+ ## 4. Intellectual Property
52
+
53
+ **4.1. Trademarks.** No trademark licenses are granted under this Agreement, and in connection with the Mistral Models, You may not use any name or mark owned by or associated with Mistral AI or any of its affiliates, except (i) as required for reasonable and customary use in describing and Distributing the Mistral Models and Derivatives made by or for Mistral AI and (ii) for attribution purposes as required by this Agreement.
54
+
55
+ **4.2. Outputs.** We claim no ownership rights in and to the Outputs. You are solely responsible for the Outputs You generate and their subsequent uses in accordance with this Agreement. Any Outputs shall be subject to the restrictions set out in Section 3 of this Agreement.
56
+
57
+ **4.3. Derivatives.** By entering into this Agreement, You accept that any Derivatives that You may create or that may be created for You shall be subject to the restrictions set out in Section 3 of this Agreement.
58
+
59
+ ## 5. Liability
60
+
61
+ **5.1. Limitation of liability.** In no event, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall Mistral AI be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this Agreement or out of the use or inability to use the Mistral Models and Derivatives (including but not limited to damages for loss of data, loss of goodwill, loss of expected profit or savings, work stoppage, computer failure or malfunction, or any damage caused by malware or security breaches), even if Mistral AI has been advised of the possibility of such damages.
62
+
63
+ **5.2. Indemnification.** You agree to indemnify and hold harmless Mistral AI from and against any claims, damages, or losses arising out of or related to Your use or Distribution of the Mistral Models and Derivatives.
64
+
65
+ ## 6. Warranty
66
+
67
+ **6.1. Disclaimer.** Unless required by applicable law or prior agreed to by Mistral AI in writing, Mistral AI provides the Mistral Models and Derivatives on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. Mistral AI does not represent nor warrant that the Mistral Models and Derivatives will be error-free, meet Your or any third party's requirements, be secure or will allow You or any third party to achieve any kind of result or generate any kind of content. You are solely responsible for determining the appropriateness of using or Distributing the Mistral Models and Derivatives and assume any risks associated with Your exercise of rights under this Agreement.
68
+
69
+ ## 7. Termination
70
+
71
+ **7.1. Term.** This Agreement is effective as of the date of your acceptance of this Agreement or access to the concerned Mistral Models or Derivatives and will continue until terminated in accordance with the following terms.
72
+
73
+ **7.2. Termination.** Mistral AI may terminate this Agreement at any time if You are in breach of this Agreement. Upon termination of this Agreement, You must cease to use all Mistral Models and Derivatives and shall permanently delete any copy thereof. The following provisions, in their relevant parts, will survive any termination or expiration of this Agreement, each for the duration necessary to achieve its own intended purpose (e.g. the liability provision will survive until the end of the applicable limitation period):Sections 5 (Liability), 6(Warranty), 7 (Termination) and 8 (General Provisions).
74
+
75
+ **7.3. Litigation.** If You initiate any legal action or proceedings against Us or any other entity (including a cross-claim or counterclaim in a lawsuit), alleging that the Model or a Derivative, or any part thereof, infringe upon intellectual property or other rights owned or licensable by You, then any licenses granted to You under this Agreement will immediately terminate as of the date such legal action or claim is filed or initiated.
76
+
77
+ ## 8. General provisions
78
+
79
+ **8.1. Governing laws.** This Agreement will be governed by the laws of France, without regard to choice of law principles, and the UN Convention on Contracts for the International Sale of Goods does not apply to this Agreement.
80
+
81
+ **8.2. Competent jurisdiction.** The courts of Paris shall have exclusive jurisdiction of any dispute arising out of this Agreement.
82
+
83
+ **8.3. Severability.** If any provision of this Agreement is held to be invalid, illegal or unenforceable, the remaining provisions shall be unaffected thereby and remain valid as if such provision had not been set forth herein.
84
+
85
+ ## 9. Definitions
86
+
87
+ "Agreement": means this Mistral AI Research License agreement governing the access, use, and Distribution of the Mistral Models, Derivatives and Outputs.
88
+
89
+ "Derivative": means any (i) modified version of the Mistral Model (including but not limited to any customized or fine-tuned version thereof), (ii) work based on the Mistral Model, or (iii) any other derivative work thereof.
90
+
91
+ "Distribution", "Distributing", "Distribute" or "Distributed": means supplying, providing or making available, by any means, a copy of the Mistral Models and/or the Derivatives as the case may be, subject to Section 3 of this Agreement.
92
+
93
+ "Mistral AI", "We" or "Us": means Mistral AI, a French société par actions simplifiée registered in the Paris commercial registry under the number 952 418 325, and having its registered seat at 15, rue des Halles, 75001 Paris.
94
+
95
+ "Mistral Model": means the foundational large language model(s), and its elements which include algorithms, software, instructed checkpoints, parameters, source code (inference code, evaluation code and, if applicable, fine-tuning code) and any other elements associated thereto made available by Mistral AI under this Agreement, including, if any, the technical documentation, manuals and instructions for the use and operation thereof.
96
+
97
+ "Research Purposes": means any use of a Mistral Model, Derivative, or Output that is solely for (a) personal, scientific or academic research, and (b) for non-profit and non-commercial purposes, and not directly or indirectly connected to any commercial activities or business operations. For illustration purposes, Research Purposes does not include (1) any usage of the Mistral Model, Derivative or Output by individuals or contractors employed in or engaged by companies in the context of (a) their daily tasks, or (b) any activity (including but not limited to any testing or proof-of-concept) that is intended to generate revenue, nor (2) any Distribution by a commercial entity of the Mistral Model, Derivative or Output whether in return for payment or free of charge, in any medium or form, including but not limited to through a hosted or managed service (e.g. SaaS, cloud instances, etc.), or behind a software layer.
98
+
99
+ "Outputs": means any content generated by the operation of the Mistral Models or the Derivatives from a prompt (i.e., text instructions) provided by users. For the avoidance of doubt, Outputs do not include any components of a Mistral Models, such as any fine-tuned versions of the Mistral Models, the weights, or parameters.
100
+
101
+ "You": means the individual or entity entering into this Agreement with Mistral AI.
102
+
103
+
104
+ *Mistral AI processes your personal data below to provide the model and enforce its license. If you are affiliated with a commercial entity, we may also send you communications about our models. For more information on your rights and data handling, please see our <a href="https://mistral.ai/terms/">privacy policy</a>.*
105
+ extra_gated_fields:
106
+ First Name: text
107
+ Last Name: text
108
+ Country: country
109
+ Affiliation: text
110
+ Job title: text
111
+ I understand that I can only use the model, any derivative versions and their outputs for non-commercial research purposes: checkbox
112
+ I understand that if I am a commercial entity, I am not permitted to use or distribute the model internally or externally, or expose it in my own offerings without a commercial license: checkbox
113
+ I understand that if I upload the model, or any derivative version, on any platform, I must include the Mistral Research License: checkbox
114
+ I understand that for commercial use of the model, I can contact Mistral or use the Mistral AI API on la Plateforme or any of our cloud provider partners: checkbox
115
+ ? By clicking Submit below I accept the terms of the license and acknowledge that
116
+ the information I provide will be collected stored processed and shared in accordance
117
+ with the Mistral Privacy Policy
118
+ : checkbox
119
+ geo: ip_location
120
+ extra_gated_description: >-
121
+ Mistral AI processes your personal data below to provide the model and enforce its license. If you are affiliated with a commercial entity, we may also send you communications about our models. For more information on your rights and data handling, please see our <a href="https://mistral.ai/terms/">privacy policy</a>.
122
+ extra_gated_button_content: Submit
123
+ library_name: vllm
124
+ ---
125
+
126
+ AWQ quantized version of Mistral-Large-Instruct-2411 model.
127
+
128
+ ---
129
+
130
+ # Model Card for Mistral-Large-Instruct-2411
131
+
132
+ Mistral-Large-Instruct-2411 is an advanced dense Large Language Model (LLM) of 123B parameters with state-of-the-art reasoning, knowledge and coding capabilities extending [Mistral-Large-Instruct-2407](https://huggingface.co/mistralai/Mistral-Large-Instruct-2407) with better Long Context, Function Calling and System Prompt.
133
+
134
+ ## Key features
135
+ - **Multi-lingual by design:** Dozens of languages supported, including English, French, German, Spanish, Italian, Chinese, Japanese, Korean, Portuguese, Dutch and Polish.
136
+ - **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.
137
+ - **Agent-centric:** Best-in-class agentic capabilities with native function calling and JSON outputting.
138
+ - **Advanced Reasoning:** State-of-the-art mathematical and reasoning capabilities.
139
+ - **Mistral Research License:** Allows usage and modification for non-commercial usages.
140
+ - **Large Context:** A large 128k context window.
141
+ - **Robust Context Adherence:** Ensures strong adherence for RAG and large context applications.
142
+ - **System Prompt:** Maintains strong adherence and support for more reliable system prompts.
143
+
144
+ ### System Prompt
145
+ We appreciate the feedback received from our community regarding our system prompt handling.
146
+ In response, we have implemented stronger support for system prompts.
147
+ To achieve optimal results, we recommend always including a system prompt that clearly outlines the bot's purpose, even if it is minimal.
148
+
149
+ ### Basic Instruct Template (V7)
150
+
151
+ ```
152
+ <s>[SYSTEM_PROMPT] <system prompt>[/SYSTEM_PROMPT][INST] <user message>[/INST] <assistant response></s>[INST] <user message>[/INST]
153
+ ```
154
+
155
+ **Be careful with subtle missing or trailing white spaces!**
156
+
157
+ *Please make sure to use [mistral-common](https://github.com/mistralai/mistral-common) as the source of truth*
158
+
159
+ ## Usage
160
+
161
+ The model can be used with the following frameworks
162
+
163
+ - [`vllm`](https://github.com/vllm-project/vllm): See [here](#vLLM)
164
+
165
+ ### vLLM
166
+
167
+ We recommend using this model with the [vLLM library](https://github.com/vllm-project/vllm)
168
+ to implement production-ready inference pipelines.
169
+
170
+ **_Installation_**
171
+
172
+ Make sure you install [`vLLM >= v0.6.4.post1`](https://github.com/vllm-project/vllm/releases/tag/v0.6.4.post1):
173
+
174
+ ```
175
+ pip install --upgrade vllm
176
+ ```
177
+
178
+ Also make sure you have [`mistral_common >= 1.5.0`](https://github.com/mistralai/mistral-common/releases/tag/v1.5.0) installed:
179
+
180
+ ```
181
+ pip install --upgrade mistral_common
182
+ ```
183
+
184
+ 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).
185
+
186
+ ### Server
187
+
188
+ We recommand that you use Mistral-Large-Instruct-2411 in a server/client setting.
189
+
190
+ 1. Spin up a server:
191
+
192
+
193
+ ```
194
+ vllm serve mistralai/Mistral-Large-Instruct-2411 --tokenizer_mode mistral --config_format mistral --load_format mistral --tensor_parallel_size 8
195
+ ```
196
+
197
+ **Note:** Running Mistral-Large-Instruct-2411 on GPU requires over 300 GB of GPU RAM.
198
+
199
+
200
+ 2. To ping the client you can use a simple Python snippet.
201
+
202
+ ```py
203
+ import requests
204
+ import json
205
+ from huggingface_hub import hf_hub_download
206
+ from datetime import datetime, timedelta
207
+
208
+ url = "http://<your-server>:8000/v1/chat/completions"
209
+ headers = {"Content-Type": "application/json", "Authorization": "Bearer token"}
210
+
211
+ model = "mistralai/Mistral-Large-Instruct-2411"
212
+
213
+
214
+ def load_system_prompt(repo_id: str, filename: str) -> str:
215
+ file_path = hf_hub_download(repo_id=repo_id, filename=filename)
216
+ with open(file_path, "r") as file:
217
+ system_prompt = file.read()
218
+ today = datetime.today().strftime("%Y-%m-%d")
219
+ yesterday = (datetime.today() - timedelta(days=1)).strftime("%Y-%m-%d")
220
+ model_name = repo_id.split("/")[-1]
221
+ return system_prompt.format(name=model_name, today=today, yesterday=yesterday)
222
+
223
+
224
+ SYSTEM_PROMPT = load_system_prompt(model, "SYSTEM_PROMPT.txt")
225
+
226
+
227
+ messages = [
228
+ {"role": "system", "content": SYSTEM_PROMPT + "\n\nThink step by step. You're a math genius."},
229
+ {
230
+ "role": "user",
231
+ "content": "Think of four random numbers. Then add, substract or multiply them so that the solution is 10. If it's not possible, say it."
232
+ },
233
+ ]
234
+
235
+ data = {"model": model, "messages": messages}
236
+
237
+ response = requests.post(url, headers=headers, data=json.dumps(data))
238
+ print(response.json()["choices"][0]["message"]["content"])
239
+ # Sure, let's start by thinking of four random numbers. For example, let's take 3, 5, 2, and 1.
240
+ #
241
+ # Now, we need to find a combination of addition, subtraction, or multiplication that results in 10.
242
+
243
+ # Let's try:
244
+
245
+ # \[ 3 + 5 + 2 - 1 = 9 \]
246
+
247
+ # This doesn't work. Let's try another combination:
248
+
249
+ # \[ 3 \times 2 + 5 - 1 = 6 + 5 - 1 = 10 \]
250
+
251
+ # This works! So, with the numbers 3, 5, 2, and 1, we can achieve the result 10 by performing the operations \( 3 \times 2 + 5 - 1 \).
252
+ ```
253
+
254
+ ### Offline
255
+
256
+ ```py
257
+ from vllm import LLM
258
+ from vllm.sampling_params import SamplingParams
259
+ from huggingface_hub import hf_hub_download
260
+ from datetime import datetime, timedelta
261
+
262
+ model_name = "mistralai/Mistral-Large-Instruct-2411"
263
+
264
+ def load_system_prompt(repo_id: str, filename: str) -> str:
265
+ file_path = hf_hub_download(repo_id=repo_id, filename=filename)
266
+ with open(file_path, 'r') as file:
267
+ system_prompt = file.read()
268
+ today = datetime.today().strftime('%Y-%m-%d')
269
+ yesterday = (datetime.today() - timedelta(days=1)).strftime('%Y-%m-%d')
270
+ model_name = repo_id.split("/")[-1]
271
+ return system_prompt.format(name=model_name, today=today, yesterday=yesterday)
272
+
273
+
274
+ SYSTEM_PROMPT = load_system_prompt(model_name, "SYSTEM_PROMPT.txt") + "\n\nThink step by step. You're a math genius."
275
+
276
+ user_prompt = "Without browsing the web, how many days ago was Mistral founded?"
277
+
278
+ messages = [
279
+ {
280
+ "role": "system",
281
+ "content": SYSTEM_PROMPT
282
+ },
283
+ {
284
+ "role": "user",
285
+ "content": user_prompt
286
+ },
287
+ ]
288
+
289
+ # note that running this model on GPU requires over 300 GB of GPU RAM
290
+ llm = LLM(model=model_name, tokenizer_mode="mistral", tensor_parallel_size=8)
291
+
292
+ sampling_params = SamplingParams(max_tokens=512)
293
+
294
+ outputs = llm.chat(messages, sampling_params=sampling_params)
295
+
296
+ print(outputs[0].outputs[0].text)
297
+ # I don't have real-time web browsing capabilities or access to current data, but I can help you calculate the number of days based on the information I have.
298
+ #
299
+ #Mistral AI was founded in April 2023. To determine how many days ago that was from today's date, November 18, 2024, we need to calculate the total number of days between April 2023 and November 2024.
300
+ #
301
+ #Here's the step-by-step calculation:
302
+ #
303
+ #1. **Days from April 2023 to December 2023:**
304
+ # - April 2023: 30 days (April has 30 days)
305
+ # - May 2023: 31 days
306
+ # - June 2023: 30 days
307
+ # - July 2023: 31 days
308
+ # - August 2023: 31 days
309
+ # - September 2023: 30 days
310
+ # - October 2023: 31 days
311
+ # - November 2023: 30 days
312
+ # - December 2023: 31 days
313
+ #
314
+ # Total days in 2023 from April to December = 30 + 31 + 30 + 31 + 31 + 30 + 31 + 30 + 31 = 275 days
315
+ #
316
+ #2. **Days from January 2024 to November 18, 2024:**
317
+ # - January 2024: 31 days
318
+ # - February 2024: 29 days (2024 is a leap year)
319
+ # - March 2024: 31 days
320
+ # - April 2024: 30 days
321
+ # - May 2024: 31 days
322
+ # - June 2024: 30 days
323
+ # - July 2024: 31 days
324
+ # - August 2024: 31 days
325
+ # - September 2024: 30 days
326
+ # - October 2024: 31 days
327
+ # - November 2024 (up to the 18th): 18 days
328
+ #
329
+ # Total days in 2024 from January to November 18 = 31 + 29 + 31 + 30 + 31 + 30 + 31 + 31 + 30 + 31 + 18 = 323 days
330
+ #
331
+ #3. **Total days from April 2023 to November 18, 2024:**
332
+ # Total days = 275 days (2023) + 323 days (2024) = 598 days
333
+ #
334
+ #Therefore, Mistral AI was founded 598 days ago from today's date, November 18, 2024.
335
+ ```
336
+
337
+ ### Improved Function Calling
338
+
339
+ Mistral-Large-2411 has much improved function calling capabilities that are fully supported
340
+ using [`mistral_common >= 1.5.0`](https://github.com/mistralai/mistral-common/releases/tag/v1.5.0) and [`vLLM >= v0.6.4.post1`](https://github.com/vllm-project/vllm/releases/tag/v0.6.4.post1).
341
+
342
+ Make sure to serve the model with the following flags in vLLM:
343
+
344
+ ```
345
+ vllm serve mistralai/Pixtral-Large-Instruct-2411 --tokenizer_mode mistral --tensor-parallel-size 8 --tool-call-parser mistral --enable-auto-tool-choice
346
+ ```
347
+
348
+ <details>
349
+ <summary>Example</summary>
350
+
351
+ ```py
352
+ import requests
353
+ import json
354
+ from huggingface_hub import hf_hub_download
355
+ from datetime import datetime, timedelta
356
+
357
+ url = "http://<your-server>:8000/v1/chat/completions"
358
+ headers = {"Content-Type": "application/json", "Authorization": "Bearer token"}
359
+
360
+ model = "mistralai/Mistral-Large-Instruct-2411"
361
+
362
+
363
+ def load_system_prompt(repo_id: str, filename: str) -> str:
364
+ file_path = hf_hub_download(repo_id=repo_id, filename=filename)
365
+ with open(file_path, "r") as file:
366
+ system_prompt = file.read()
367
+ today = datetime.today().strftime("%Y-%m-%d")
368
+ yesterday = (datetime.today() - timedelta(days=1)).strftime("%Y-%m-%d")
369
+ model_name = repo_id.split("/")[-1]
370
+ return system_prompt.format(name=model_name, today=today, yesterday=yesterday)
371
+
372
+
373
+ SYSTEM_PROMPT = load_system_prompt(model, "SYSTEM_PROMPT.txt")
374
+
375
+
376
+ tools = [
377
+ {
378
+ "type": "function",
379
+ "function": {
380
+ "name": "get_current_weather",
381
+ "description": "Get the current weather in a given location",
382
+ "parameters": {
383
+ "type": "object",
384
+ "properties": {
385
+ "city": {
386
+ "type": "string",
387
+ "description": "The city to find the weather for, e.g. 'San Francisco'",
388
+ },
389
+ "state": {
390
+ "type": "string",
391
+ "description": "The state abbreviation, e.g. 'CA' for California",
392
+ },
393
+ "unit": {
394
+ "type": "string",
395
+ "description": "The unit for temperature",
396
+ "enum": ["celsius", "fahrenheit"],
397
+ },
398
+ },
399
+ "required": ["city", "state", "unit"],
400
+ },
401
+ },
402
+ },
403
+ {
404
+ "type": "function",
405
+ "function": {
406
+ "name": "rewrite",
407
+ "description": "Rewrite a given text for improved clarity",
408
+ "parameters": {
409
+ "type": "object",
410
+ "properties": {
411
+ "text": {
412
+ "type": "string",
413
+ "description": "The input text to rewrite",
414
+ }
415
+ },
416
+ },
417
+ },
418
+ },
419
+ ]
420
+
421
+ messages = [
422
+ {"role": "system", "content": SYSTEM_PROMPT},
423
+ {
424
+ "role": "user",
425
+ "content": "Could you please make the below article more concise?\n\nOpenAI is an artificial intelligence research laboratory consisting of the non-profit OpenAI Incorporated and its for-profit subsidiary corporation OpenAI Limited Partnership.",
426
+ },
427
+ {
428
+ "role": "assistant",
429
+ "content": "",
430
+ "tool_calls": [
431
+ {
432
+ "id": "bbc5b7ede",
433
+ "type": "function",
434
+ "function": {
435
+ "name": "rewrite",
436
+ "arguments": '{"text": "OpenAI is an artificial intelligence research laboratory consisting of the non-profit OpenAI Incorporated and its for-profit subsidiary corporation OpenAI Limited Partnership."}',
437
+ },
438
+ }
439
+ ],
440
+ },
441
+ {
442
+ "role": "tool",
443
+ "content": '{"action":"rewrite","outcome":"OpenAI is a FOR-profit company."}',
444
+ "tool_call_id": "bbc5b7ede",
445
+ "name": "rewrite",
446
+ },
447
+ {
448
+ "role": "assistant",
449
+ "content": "---\n\nOpenAI is a FOR-profit company.",
450
+ },
451
+ {
452
+ "role": "user",
453
+ "content": "Can you tell me what the temperature will be in Dallas, in Fahrenheit?",
454
+ },
455
+ ]
456
+
457
+ data = {"model": model, "messages": messages, "tools": tools}
458
+
459
+ response = requests.post(url, headers=headers, data=json.dumps(data))
460
+ print(response.json()["choices"][0]["message"]["tool_calls"])
461
+ # [{'id': '8PdihwL6d', 'type': 'function', 'function': {'name': 'get_current_weather', 'arguments': '{"city": "Dallas", "state": "TX", "unit": "fahrenheit"}'}}]
462
+ ```
463
+
464
+ </details>
465
+
466
+ ## The Mistral AI Team
467
+
468
+ 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
SYSTEM_PROMPT.txt ADDED
@@ -0,0 +1,18 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ You are {name}, a Large Language Model (LLM) created by Mistral AI, a French startup headquartered in Paris.
2
+ You power an AI assistant called Le Chat.
3
+ Your knowledge base was last updated on 2023-10-01.
4
+ The current date is {today}.
5
+
6
+ When you're not sure about some information, you say that you don't have the information and don't make up anything.
7
+ If the user's question is not clear, ambiguous, or does not provide enough context for you to accurately answer the question, you do not try to answer it right away and you rather ask the user to clarify their request (e.g. "What are some good restaurants around me?" => "Where are you?" or "When is the next flight to Tokyo" => "Where do you travel from?").
8
+ You are always very attentive to dates, in particular you try to resolve dates (e.g. "yesterday" is {yesterday}) and when asked about information at specific dates, you discard information that is at another date.
9
+ You follow these instructions in all languages, and always respond to the user in the language they use or request.
10
+ Next sections describe the capabilities that you have.
11
+
12
+ # WEB BROWSING INSTRUCTIONS
13
+
14
+ You cannot perform any web search or access internet to open URLs, links etc. If it seems like the user is expecting you to do so, you clarify the situation and ask the user to copy paste the text directly in the chat.
15
+
16
+ # MULTI-MODAL INSTRUCTIONS
17
+
18
+ You do not have any multimodal capability, in particular you cannot read nor generate images, or transcribe audio files or videos.
config.json ADDED
@@ -0,0 +1,35 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "_name_or_path": "mistralai/Mistral-Large-Instruct-2411",
3
+ "architectures": [
4
+ "MistralForCausalLM"
5
+ ],
6
+ "attention_dropout": 0.0,
7
+ "bos_token_id": 1,
8
+ "eos_token_id": 2,
9
+ "head_dim": 128,
10
+ "hidden_act": "silu",
11
+ "hidden_size": 12288,
12
+ "initializer_range": 0.02,
13
+ "intermediate_size": 28672,
14
+ "max_position_embeddings": 131072,
15
+ "model_type": "mistral",
16
+ "num_attention_heads": 96,
17
+ "num_hidden_layers": 88,
18
+ "num_key_value_heads": 8,
19
+ "quantization_config": {
20
+ "bits": 4,
21
+ "group_size": 128,
22
+ "modules_to_not_convert": null,
23
+ "quant_method": "awq",
24
+ "version": "gemm",
25
+ "zero_point": true
26
+ },
27
+ "rms_norm_eps": 1e-05,
28
+ "rope_theta": 1000000.0,
29
+ "sliding_window": null,
30
+ "tie_word_embeddings": false,
31
+ "torch_dtype": "float16",
32
+ "transformers_version": "4.46.2",
33
+ "use_cache": true,
34
+ "vocab_size": 32768
35
+ }
generation_config.json ADDED
@@ -0,0 +1,7 @@
 
 
 
 
 
 
 
 
1
+ {
2
+ "_from_model_config": true,
3
+ "bos_token_id": 1,
4
+ "do_sample": true,
5
+ "eos_token_id": 2,
6
+ "transformers_version": "4.46.2"
7
+ }
model-00001-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:54bfa1ae2581a8795186d9641a8d589f67d59e342f8a87b7097bd54fc258ef07
3
+ size 4937087912
model-00002-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:8bf91392101f5d17db12a918dffa5438d749b9dd0f0fbd9fe8c57e07a48cc781
3
+ size 4850976432
model-00003-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:2684ee56c5aced2a1fd0eb153e0fa5e92b538252828919f92cd4d8b4eafd3bda
3
+ size 4850976520
model-00004-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:0ace90f66b2b363b84e41d55343f403508abeb9cb19c7900122b26b3c5da6a36
3
+ size 4955571976
model-00005-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:7b3129e746e6485e89b0b4c5f01b05256c0df542ff70dd50bc5bb1e869b064dd
3
+ size 4942496848
model-00006-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:dcb756bca18a3da526f2d05487e1eac7d29f0c4a9d44340193bd7b9cd95df1b2
3
+ size 4850927136
model-00007-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:85f7b19e5be1c40147735c87dc0e52bf1f0ceaf47fc64e48c8251d03910c582c
3
+ size 4850976528
model-00008-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:95822d6e30685c4e3d30b1f5640ef0740e93876538ecc5789a8fcd002dbf2a98
3
+ size 4850976520
model-00009-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:1a79a96cb75701a746a8592048e44e96541138ffc1c949d58831601fd65a9e9d
3
+ size 4955571976
model-00010-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:ff9df30b3996cc12505658d83fbea5a6a63157e2eb8ec216e34fd36fd9ee1ab3
3
+ size 4942496848
model-00011-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:788b43bd47005ddf09d1f8502ca1fe09f1a2de7d4c21e70c34c9a1cbe6be4771
3
+ size 4850927136
model-00012-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:0fce6f5475a06d4ec1b2cd962595050a0be04c565eed6e37d3be305c31afc89d
3
+ size 4850976528
model-00013-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:875e4015f0cbd3acb0ab49b676c984275d5f5a1551f7f13d2d7de41714bea161
3
+ size 4850976520
model-00014-of-00014.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:487c4f8d548cc41b91610615628f9973ffea7cd2913a94766afa5915fdac515d
3
+ size 1354507696
model.safetensors.index.json ADDED
The diff for this file is too large to render. See raw diff
 
params.json ADDED
@@ -0,0 +1,11 @@
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "dim": 12288,
3
+ "n_layers": 88,
4
+ "head_dim": 128,
5
+ "hidden_dim": 28672,
6
+ "n_heads": 96,
7
+ "n_kv_heads": 8,
8
+ "norm_eps": 1e-05,
9
+ "vocab_size": 32768,
10
+ "rope_theta": 1000000.0
11
+ }
special_tokens_map.json ADDED
@@ -0,0 +1,23 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "bos_token": {
3
+ "content": "<s>",
4
+ "lstrip": false,
5
+ "normalized": false,
6
+ "rstrip": false,
7
+ "single_word": false
8
+ },
9
+ "eos_token": {
10
+ "content": "</s>",
11
+ "lstrip": false,
12
+ "normalized": false,
13
+ "rstrip": false,
14
+ "single_word": false
15
+ },
16
+ "unk_token": {
17
+ "content": "<unk>",
18
+ "lstrip": false,
19
+ "normalized": false,
20
+ "rstrip": false,
21
+ "single_word": false
22
+ }
23
+ }
tokenizer.json ADDED
The diff for this file is too large to render. See raw diff
 
tokenizer.model ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:1b968b8dc352f42192367337c78ccc61e1eaddc6d641a579372d4f20694beb7a
3
+ size 587562
tokenizer.model.v7 ADDED
Binary file (588 kB). View file
 
tokenizer_config.json ADDED
The diff for this file is too large to render. See raw diff