jukofyork commited on
Commit
2f9063d
·
verified ·
1 Parent(s): e807055

Upload README.md with huggingface_hub

Browse files
Files changed (1) hide show
  1. README.md +606 -0
README.md ADDED
@@ -0,0 +1,606 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ language:
3
+ - en
4
+ - fr
5
+ - de
6
+ - es
7
+ - it
8
+ - pt
9
+ - ja
10
+ - ko
11
+ - zh
12
+ - ar
13
+ license: cc-by-nc-4.0
14
+ library_name: transformers
15
+ extra_gated_prompt: "By submitting this form, you agree to the [License Agreement](https://cohere.com/c4ai-cc-by-nc-license) and acknowledge that the information you provide will be collected, used, and shared in accordance with Cohere’s [Privacy Policy]( https://cohere.com/privacy)."
16
+ extra_gated_fields:
17
+ Name: text
18
+ Affiliation: text
19
+ Country:
20
+ type: select
21
+ options:
22
+ - Aruba
23
+ - Afghanistan
24
+ - Angola
25
+ - Anguilla
26
+ - Åland Islands
27
+ - Albania
28
+ - Andorra
29
+ - United Arab Emirates
30
+ - Argentina
31
+ - Armenia
32
+ - American Samoa
33
+ - Antarctica
34
+ - French Southern Territories
35
+ - Antigua and Barbuda
36
+ - Australia
37
+ - Austria
38
+ - Azerbaijan
39
+ - Burundi
40
+ - Belgium
41
+ - Benin
42
+ - Bonaire Sint Eustatius and Saba
43
+ - Burkina Faso
44
+ - Bangladesh
45
+ - Bulgaria
46
+ - Bahrain
47
+ - Bahamas
48
+ - Bosnia and Herzegovina
49
+ - Saint Barthélemy
50
+ - Belarus
51
+ - Belize
52
+ - Bermuda
53
+ - Plurinational State of Bolivia
54
+ - Brazil
55
+ - Barbados
56
+ - Brunei-Darussalam
57
+ - Bhutan
58
+ - Bouvet-Island
59
+ - Botswana
60
+ - Central African Republic
61
+ - Canada
62
+ - Cocos (Keeling) Islands
63
+ - Switzerland
64
+ - Chile
65
+ - China
66
+ - Côte-dIvoire
67
+ - Cameroon
68
+ - Democratic Republic of the Congo
69
+ - Cook Islands
70
+ - Colombia
71
+ - Comoros
72
+ - Cabo Verde
73
+ - Costa Rica
74
+ - Cuba
75
+ - Curaçao
76
+ - Christmas Island
77
+ - Cayman Islands
78
+ - Cyprus
79
+ - Czechia
80
+ - Germany
81
+ - Djibouti
82
+ - Dominica
83
+ - Denmark
84
+ - Dominican Republic
85
+ - Algeria
86
+ - Ecuador
87
+ - Egypt
88
+ - Eritrea
89
+ - Western Sahara
90
+ - Spain
91
+ - Estonia
92
+ - Ethiopia
93
+ - Finland
94
+ - Fiji
95
+ - Falkland Islands (Malvinas)
96
+ - France
97
+ - Faroe Islands
98
+ - Federated States of Micronesia
99
+ - Gabon
100
+ - United Kingdom
101
+ - Georgia
102
+ - Guernsey
103
+ - Ghana
104
+ - Gibraltar
105
+ - Guinea
106
+ - Guadeloupe
107
+ - Gambia
108
+ - Guinea Bissau
109
+ - Equatorial Guinea
110
+ - Greece
111
+ - Grenada
112
+ - Greenland
113
+ - Guatemala
114
+ - French Guiana
115
+ - Guam
116
+ - Guyana
117
+ - Hong Kong
118
+ - Heard Island and McDonald Islands
119
+ - Honduras
120
+ - Croatia
121
+ - Haiti
122
+ - Hungary
123
+ - Indonesia
124
+ - Isle of Man
125
+ - India
126
+ - British Indian Ocean Territory
127
+ - Ireland
128
+ - Islamic Republic of Iran
129
+ - Iraq
130
+ - Iceland
131
+ - Israel
132
+ - Italy
133
+ - Jamaica
134
+ - Jersey
135
+ - Jordan
136
+ - Japan
137
+ - Kazakhstan
138
+ - Kenya
139
+ - Kyrgyzstan
140
+ - Cambodia
141
+ - Kiribati
142
+ - Saint-Kitts-and-Nevis
143
+ - South Korea
144
+ - Kuwait
145
+ - Lao-Peoples-Democratic-Republic
146
+ - Lebanon
147
+ - Liberia
148
+ - Libya
149
+ - Saint-Lucia
150
+ - Liechtenstein
151
+ - Sri Lanka
152
+ - Lesotho
153
+ - Lithuania
154
+ - Luxembourg
155
+ - Latvia
156
+ - Macao
157
+ - Saint Martin (French-part)
158
+ - Morocco
159
+ - Monaco
160
+ - Republic of Moldova
161
+ - Madagascar
162
+ - Maldives
163
+ - Mexico
164
+ - Marshall Islands
165
+ - North Macedonia
166
+ - Mali
167
+ - Malta
168
+ - Myanmar
169
+ - Montenegro
170
+ - Mongolia
171
+ - Northern Mariana Islands
172
+ - Mozambique
173
+ - Mauritania
174
+ - Montserrat
175
+ - Martinique
176
+ - Mauritius
177
+ - Malawi
178
+ - Malaysia
179
+ - Mayotte
180
+ - Namibia
181
+ - New Caledonia
182
+ - Niger
183
+ - Norfolk Island
184
+ - Nigeria
185
+ - Nicaragua
186
+ - Niue
187
+ - Netherlands
188
+ - Norway
189
+ - Nepal
190
+ - Nauru
191
+ - New Zealand
192
+ - Oman
193
+ - Pakistan
194
+ - Panama
195
+ - Pitcairn
196
+ - Peru
197
+ - Philippines
198
+ - Palau
199
+ - Papua New Guinea
200
+ - Poland
201
+ - Puerto Rico
202
+ - North Korea
203
+ - Portugal
204
+ - Paraguay
205
+ - State of Palestine
206
+ - French Polynesia
207
+ - Qatar
208
+ - Réunion
209
+ - Romania
210
+ - Russia
211
+ - Rwanda
212
+ - Saudi Arabia
213
+ - Sudan
214
+ - Senegal
215
+ - Singapore
216
+ - South Georgia and the South Sandwich Islands
217
+ - Saint Helena Ascension and Tristan da Cunha
218
+ - Svalbard and Jan Mayen
219
+ - Solomon Islands
220
+ - Sierra Leone
221
+ - El Salvador
222
+ - San Marino
223
+ - Somalia
224
+ - Saint Pierre and Miquelon
225
+ - Serbia
226
+ - South Sudan
227
+ - Sao Tome and Principe
228
+ - Suriname
229
+ - Slovakia
230
+ - Slovenia
231
+ - Sweden
232
+ - Eswatini
233
+ - Sint Maarten (Dutch-part)
234
+ - Seychelles
235
+ - Syrian Arab Republic
236
+ - Turks and Caicos Islands
237
+ - Chad
238
+ - Togo
239
+ - Thailand
240
+ - Tajikistan
241
+ - Tokelau
242
+ - Turkmenistan
243
+ - Timor Leste
244
+ - Tonga
245
+ - Trinidad and Tobago
246
+ - Tunisia
247
+ - Turkey
248
+ - Tuvalu
249
+ - Taiwan
250
+ - United Republic of Tanzania
251
+ - Uganda
252
+ - Ukraine
253
+ - United States Minor Outlying Islands
254
+ - Uruguay
255
+ - United-States
256
+ - Uzbekistan
257
+ - Holy See (Vatican City State)
258
+ - Saint Vincent and the Grenadines
259
+ - Bolivarian Republic of Venezuela
260
+ - Virgin Islands British
261
+ - Virgin Islands U.S.
262
+ - VietNam
263
+ - Vanuatu
264
+ - Wallis and Futuna
265
+ - Samoa
266
+ - Yemen
267
+ - South Africa
268
+ - Zambia
269
+ - Zimbabwe
270
+ Receive email updates on C4AI and Cohere research, events, products and services?:
271
+ type: select
272
+ options:
273
+ - Yes
274
+ - No
275
+ I agree to use this model for non-commercial use ONLY: checkbox
276
+ ---
277
+
278
+
279
+ # Model Card for C4AI Command R 08-2024
280
+
281
+ ## Model Summary
282
+ <!-- Provide a quick summary of what the model is/does. -->
283
+ C4AI Command R 08-2024 is a research release of a 35 billion parameter highly performant generative model. Command R 08-2024 is a large language model with open weights optimized for a variety of use cases including reasoning, summarization, and question answering. Command R 08-2024 has the capability for multilingual generation, trained on 23 languages and evaluated in 10 languages and highly performant RAG capabilities.
284
+
285
+ Developed by: Cohere and [Cohere For AI](https://cohere.for.ai)
286
+
287
+ - Point of Contact: Cohere For AI: [cohere.for.ai](https://cohere.for.ai/)
288
+ - License: [CC-BY-NC](https://cohere.com/c4ai-cc-by-nc-license), requires also adhering to [C4AI's Acceptable Use Policy](https://docs.cohere.com/docs/c4ai-acceptable-use-policy)
289
+ - Model: c4ai-command-r-08-2024
290
+ - Model Size: 35 billion parameters
291
+ - Context length: 128K
292
+
293
+ **Try C4AI Command R**
294
+
295
+ If you want to try Command R before downloading the weights, the model is hosted in a hugging face space [here](https://huggingface.co/spaces/CohereForAI/c4ai-command?model=command-r-08-2024).
296
+
297
+
298
+ **Usage**
299
+
300
+ Please use `transformers` version 4.39.1 or higher
301
+ ```python
302
+ # pip install 'transformers>=4.39.1'
303
+ from transformers import AutoTokenizer, AutoModelForCausalLM
304
+
305
+ model_id = "CohereForAI/c4ai-command-r-08-2024"
306
+ tokenizer = AutoTokenizer.from_pretrained(model_id)
307
+ model = AutoModelForCausalLM.from_pretrained(model_id)
308
+
309
+ # Format message with the command-r-08-2024 chat template
310
+ messages = [{"role": "user", "content": "Hello, how are you?"}]
311
+ input_ids = tokenizer.apply_chat_template(messages, tokenize=True, add_generation_prompt=True, return_tensors="pt")
312
+ ## <BOS_TOKEN><|START_OF_TURN_TOKEN|><|USER_TOKEN|>Hello, how are you?<|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|CHATBOT_TOKEN|>
313
+
314
+ gen_tokens = model.generate(
315
+ input_ids,
316
+ max_new_tokens=100,
317
+ do_sample=True,
318
+ temperature=0.3,
319
+ )
320
+
321
+ gen_text = tokenizer.decode(gen_tokens[0])
322
+ print(gen_text)
323
+ ```
324
+
325
+ ## Model Details
326
+
327
+ **Input**: Models input text only.
328
+
329
+ **Output**: Models generate text only.
330
+
331
+ **Model Architecture**: This is an auto-regressive language model that uses an optimized transformer architecture. After pretraining, this model uses supervised fine-tuning (SFT) and preference training to align model behavior to human preferences for helpfulness and safety. We use grouped query attention (GQA) to improve inference speed.
332
+
333
+ **Languages covered**: The model has been trained on 23 languages (English, French, Spanish, Italian, German, Portuguese, Japanese, Korean, Arabic, Simplified Chinese, Russian, Polish, Turkish, Vietnamese, Dutch, Czech, Indonesian, Ukrainian, Romanian, Greek, Hindi, Hebrew, and Persian) and evaluated on 10 languages (English, French, Spanish, Italian, German, Portuguese, Japanese, Korean, Arabic, Simplified Chinese).
334
+
335
+ **Context length**: Command R 08-2024 supports a context length of 128K.
336
+
337
+ ### Tool use & Agent capabilities:
338
+ Command R 08-2024 has been specifically trained with conversational tool use capabilities. These have been trained into the model via a mixture of supervised fine-tuning and preference fine-tuning, using a specific prompt template. Deviating from this prompt template will likely reduce performance.
339
+
340
+ Command R 08-2024’s tool use functionality takes a conversation as input (with an optional user-system preamble), along with a list of available tools. The model will then generate a json-formatted list of actions to execute on a subset of those tools. Command R 08-2024 may use one of its supplied tools more than once.
341
+
342
+ The model has been trained to recognise a special `directly_answer` tool, which it uses to indicate that it doesn’t want to use any of its other tools. The ability to abstain from calling a specific tool can be useful in a range of situations, such as greeting a user, or asking clarifying questions. We recommend including the `directly_answer` tool, but it can be removed or renamed if required.
343
+
344
+ Comprehensive documentation for working with Command R 08-2024's tool use prompt template can be found [here](https://docs.cohere.com/docs/prompting-command-r).
345
+
346
+ Command R 08-2024 also supports Hugging Face's [tool use API](https://huggingface.co/docs/transformers/main/en/chat_templating#advanced-tool-use--function-calling)
347
+
348
+ The code snippet below shows a minimal working example on how to render a prompt.
349
+
350
+ <details>
351
+ <summary><b>Usage: Rendering Tool Use Prompts [CLICK TO EXPAND]</b> </summary>
352
+
353
+ ```python
354
+ from transformers import AutoTokenizer
355
+
356
+ model_id = "CohereForAI/c4ai-command-r-08-2024"
357
+ tokenizer = AutoTokenizer.from_pretrained(model_id)
358
+
359
+ # define conversation input:
360
+ conversation = [
361
+ {"role": "user", "content": "Whats the biggest penguin in the world?"}
362
+ ]
363
+ # Define tools available for the model to use:
364
+ tools = [
365
+ {
366
+ "name": "internet_search",
367
+ "description": "Returns a list of relevant document snippets for a textual query retrieved from the internet",
368
+ "parameter_definitions": {
369
+ "query": {
370
+ "description": "Query to search the internet with",
371
+ "type": 'str',
372
+ "required": True
373
+ }
374
+ }
375
+ },
376
+ {
377
+ 'name': "directly_answer",
378
+ "description": "Calls a standard (un-augmented) AI chatbot to generate a response given the conversation history",
379
+ 'parameter_definitions': {}
380
+ }
381
+ ]
382
+
383
+ # render the tool use prompt as a string:
384
+ tool_use_prompt = tokenizer.apply_tool_use_template(
385
+ conversation,
386
+ tools=tools,
387
+ tokenize=False,
388
+ add_generation_prompt=True,
389
+ )
390
+ print(tool_use_prompt)
391
+ ```
392
+
393
+ </details>
394
+
395
+
396
+ <details>
397
+ <summary><b>Usage: Rendering prompts with the Tool Use API [CLICK TO EXPAND]</b> </summary>
398
+
399
+ ```python
400
+ from transformers import AutoTokenizer
401
+
402
+ model_id = "CohereForAI/c4ai-command-r-08-2024"
403
+ tokenizer = AutoTokenizer.from_pretrained(model_id)
404
+
405
+ # define conversation input:
406
+ conversation = [
407
+ {"role": "user", "content": "Whats the biggest penguin in the world?"}
408
+ ]
409
+
410
+ # Define tools available for the model to use
411
+ # Type hints and docstrings from Python functions are automatically extracted
412
+ def internet_search(query: str):
413
+ """
414
+ Returns a list of relevant document snippets for a textual query retrieved from the internet
415
+
416
+ Args:
417
+ query: Query to search the internet with
418
+ """
419
+ pass
420
+
421
+ def directly_answer():
422
+ """
423
+ Calls a standard (un-augmented) AI chatbot to generate a response given the conversation history
424
+ """
425
+ pass
426
+
427
+ tools = [internet_search, directly_answer]
428
+
429
+ # render the tool use prompt as a string:
430
+ tool_use_prompt = tokenizer.apply_chat_template(
431
+ conversation,
432
+ tools=tools,
433
+ tokenize=False,
434
+ add_generation_prompt=True,
435
+ )
436
+ print(tool_use_prompt)
437
+ ```
438
+
439
+ </details>
440
+
441
+ <details>
442
+ <summary><b>Example Rendered Tool Use Prompt [CLICK TO EXPAND]</b></summary>
443
+
444
+ ````
445
+ <BOS_TOKEN><|START_OF_TURN_TOKEN|><|SYSTEM_TOKEN|># Safety Preamble
446
+ The instructions in this section override those in the task description and style guide sections. Don't answer questions that are harmful or immoral.
447
+
448
+ # System Preamble
449
+ ## Basic Rules
450
+ You are a powerful conversational AI trained by Cohere to help people. You are augmented by a number of tools, and your job is to use and consume the output of these tools to best help the user. You will see a conversation history between yourself and a user, ending with an utterance from the user. You will then see a specific instruction instructing you what kind of response to generate. When you answer the user's requests, you cite your sources in your answers, according to those instructions.
451
+
452
+ # User Preamble
453
+ ## Task and Context
454
+ You help people answer their questions and other requests interactively. You will be asked a very wide array of requests on all kinds of topics. You will be equipped with a wide range of search engines or similar tools to help you, which you use to research your answer. You should focus on serving the user's needs as best you can, which will be wide-ranging.
455
+
456
+ ## Style Guide
457
+ Unless the user asks for a different style of answer, you should answer in full sentences, using proper grammar and spelling.
458
+
459
+ ## Available Tools
460
+ Here is a list of tools that you have available to you:
461
+
462
+ ```python
463
+ def internet_search(query: str) -> List[Dict]:
464
+ """Returns a list of relevant document snippets for a textual query retrieved from the internet
465
+
466
+ Args:
467
+ query (str): Query to search the internet with
468
+ """
469
+ pass
470
+ ```
471
+
472
+ ```python
473
+ def directly_answer() -> List[Dict]:
474
+ """Calls a standard (un-augmented) AI chatbot to generate a response given the conversation history
475
+ """
476
+ pass
477
+ ```<|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|USER_TOKEN|>Whats the biggest penguin in the world?<|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|SYSTEM_TOKEN|>Write 'Action:' followed by a json-formatted list of actions that you want to perform in order to produce a good response to the user's last input. You can use any of the supplied tools any number of times, but you should aim to execute the minimum number of necessary actions for the input. You should use the `directly-answer` tool if calling the other tools is unnecessary. The list of actions you want to call should be formatted as a list of json objects, for example:
478
+ ```json
479
+ [
480
+ {
481
+ "tool_name": title of the tool in the specification,
482
+ "parameters": a dict of parameters to input into the tool as they are defined in the specs, or {} if it takes no parameters
483
+ }
484
+ ]```<|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|CHATBOT_TOKEN|>
485
+ ````
486
+
487
+ </details>
488
+
489
+ <details>
490
+ <summary><b>Example Rendered Tool Use Completion [CLICK TO EXPAND]</b></summary>
491
+
492
+ ````
493
+ Action: ```json
494
+ [
495
+ {
496
+ "tool_name": "internet_search",
497
+ "parameters": {
498
+ "query": "biggest penguin in the world"
499
+ }
500
+ }
501
+ ]
502
+ ```
503
+ ````
504
+ </details>
505
+
506
+
507
+ ### Grounded Generation and RAG Capabilities:
508
+
509
+ Command R 08-2024 has been specifically trained with grounded generation capabilities. This means that it can generate responses based on a list of supplied document snippets, and it will include grounding spans (citations) in its response indicating the source of the information. This can be used to enable behaviors such as grounded summarization and the final step of Retrieval Augmented Generation (RAG).This behavior has been trained into the model via a mixture of supervised fine-tuning and preference fine-tuning, using a specific prompt template. Deviating from this prompt template may reduce performance, but we encourage experimentation.
510
+
511
+ Command R 08-2024’s grounded generation behavior takes a conversation as input (with an optional user-supplied system preamble, indicating task, context and desired output style), along with a list of retrieved document snippets. The document snippets should be chunks, rather than long documents, typically around 100-400 words per chunk. Document snippets consist of key-value pairs. The keys should be short descriptive strings, the values can be text or semi-structured.
512
+
513
+ By default, Command R 08-2024 will generate grounded responses by first predicting which documents are relevant, then predicting which ones it will cite, then generating an answer. Finally, it will then insert grounding spans into the answer. See below for an example. This is referred to as `accurate` grounded generation.
514
+
515
+ The model is trained with a number of other answering modes, which can be selected by prompt changes. A `fast` citation mode is supported in the tokenizer, which will directly generate an answer with grounding spans in it, without first writing the answer out in full. This sacrifices some grounding accuracy in favor of generating fewer tokens.
516
+
517
+ Comprehensive documentation for working with Command R 08-2024's grounded generation prompt template can be found [here](https://docs.cohere.com/docs/prompting-command-r).
518
+
519
+ The code snippet below shows a minimal working example on how to render a prompt.
520
+
521
+ <details>
522
+ <summary> <b>Usage: Rendering Grounded Generation prompts [CLICK TO EXPAND]</b> </summary>
523
+
524
+ ````python
525
+ from transformers import AutoTokenizer
526
+
527
+ model_id = "CohereForAI/c4ai-command-r-08-2024"
528
+ tokenizer = AutoTokenizer.from_pretrained(model_id)
529
+
530
+ # define conversation input:
531
+ conversation = [
532
+ {"role": "user", "content": "Whats the biggest penguin in the world?"}
533
+ ]
534
+ # define documents to ground on:
535
+ documents = [
536
+ { "title": "Tall penguins", "text": "Emperor penguins are the tallest growing up to 122 cm in height." },
537
+ { "title": "Penguin habitats", "text": "Emperor penguins only live in Antarctica."}
538
+ ]
539
+
540
+ # render the tool use prompt as a string:
541
+ grounded_generation_prompt = tokenizer.apply_grounded_generation_template(
542
+ conversation,
543
+ documents=documents,
544
+ citation_mode="accurate", # or "fast"
545
+ tokenize=False,
546
+ add_generation_prompt=True,
547
+ )
548
+ print(grounded_generation_prompt)
549
+ ````
550
+ </details>
551
+
552
+ <details>
553
+ <summary><b>Example Rendered Grounded Generation Prompt [CLICK TO EXPAND]</b></summary>
554
+
555
+ ````
556
+ <BOS_TOKEN><|START_OF_TURN_TOKEN|><|SYSTEM_TOKEN|># Safety Preamble
557
+ The instructions in this section override those in the task description and style guide sections. Don't answer questions that are harmful or immoral.
558
+
559
+ # System Preamble
560
+ ## Basic Rules
561
+ You are a powerful conversational AI trained by Cohere to help people. You are augmented by a number of tools, and your job is to use and consume the output of these tools to best help the user. You will see a conversation history between yourself and a user, ending with an utterance from the user. You will then see a specific instruction instructing you what kind of response to generate. When you answer the user's requests, you cite your sources in your answers, according to those instructions.
562
+
563
+ # User Preamble
564
+ ## Task and Context
565
+ You help people answer their questions and other requests interactively. You will be asked a very wide array of requests on all kinds of topics. You will be equipped with a wide range of search engines or similar tools to help you, which you use to research your answer. You should focus on serving the user's needs as best you can, which will be wide-ranging.
566
+
567
+ ## Style Guide
568
+ Unless the user asks for a different style of answer, you should answer in full sentences, using proper grammar and spelling.<|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|USER_TOKEN|>Whats the biggest penguin in the world?<|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|SYSTEM_TOKEN|><results>
569
+ Document: 0
570
+ title: Tall penguins
571
+ text: Emperor penguins are the tallest growing up to 122 cm in height.
572
+
573
+ Document: 1
574
+ title: Penguin habitats
575
+ text: Emperor penguins only live in Antarctica.
576
+ </results><|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|SYSTEM_TOKEN|>Carefully perform the following instructions, in order, starting each with a new line.
577
+ Firstly, Decide which of the retrieved documents are relevant to the user's last input by writing 'Relevant Documents:' followed by comma-separated list of document numbers. If none are relevant, you should instead write 'None'.
578
+ Secondly, Decide which of the retrieved documents contain facts that should be cited in a good answer to the user's last input by writing 'Cited Documents:' followed a comma-separated list of document numbers. If you dont want to cite any of them, you should instead write 'None'.
579
+ Thirdly, Write 'Answer:' followed by a response to the user's last input in high quality natural english. Use the retrieved documents to help you. Do not insert any citations or grounding markup.
580
+ Finally, Write 'Grounded answer:' followed by a response to the user's last input in high quality natural english. Use the symbols <co: doc> and </co: doc> to indicate when a fact comes from a document in the search result, e.g <co: 0>my fact</co: 0> for a fact from document 0.<|END_OF_TURN_TOKEN|><|START_OF_TURN_TOKEN|><|CHATBOT_TOKEN|>
581
+ ````
582
+
583
+ </details>
584
+
585
+ <details>
586
+ <summary><b>Example Rendered Grounded Generation Completion [CLICK TO EXPAND]</b></summary>
587
+
588
+ ````
589
+ Relevant Documents: 0,1
590
+ Cited Documents: 0,1
591
+ Answer: The Emperor Penguin is the tallest or biggest penguin in the world. It is a bird that lives only in Antarctica and grows to a height of around 122 centimetres.
592
+ Grounded answer: The <co: 0>Emperor Penguin</co: 0> is the <co: 0>tallest</co: 0> or biggest penguin in the world. It is a bird that <co: 1>lives only in Antarctica</co: 1> and <co: 0>grows to a height of around 122 centimetres.</co: 0>
593
+ ````
594
+ </details>
595
+
596
+ ### Code Capabilities:
597
+ Command R 08-2024 has been optimized to interact with your code, by requesting code snippets, code explanations, or code rewrites. It might not perform well out-of-the-box for pure code completion. For better performance, we also recommend using a low temperature (and even greedy decoding) for code-generation related instructions.
598
+
599
+ ### Model Card Contact
600
+ For errors or additional questions about details in this model card, contact [[email protected]](mailto:[email protected]).
601
+
602
+ ### Terms of Use:
603
+ We hope that the release of this model will make community-based research efforts more accessible, by releasing the weights of a highly performant 35 billion parameter model to researchers all over the world. This model is governed by a [CC-BY-NC](https://cohere.com/c4ai-cc-by-nc-license) License with an acceptable use addendum, and also requires adhering to [C4AI's Acceptable Use Policy](https://docs.cohere.com/docs/c4ai-acceptable-use-policy).
604
+
605
+ ### Try Chat:
606
+ You can try Command-R chat in the playground [here](https://dashboard.cohere.com/playground/chat).