Update README.md
Browse files
README.md
CHANGED
@@ -3,9 +3,8 @@ library_name: transformers
|
|
3 |
license: apache-2.0
|
4 |
language:
|
5 |
- en
|
6 |
-
base_model:
|
7 |
- mistralai/Mistral-Nemo-Base-2407
|
8 |
-
- Dans-DiscountModels/Mistral-Nemo-Base-2407-ChatML-Mod
|
9 |
tags:
|
10 |
- general-purpose
|
11 |
- roleplay
|
@@ -79,43 +78,45 @@ model-index:
|
|
79 |
results: []
|
80 |
pipeline_tag: text-generation
|
81 |
---
|
82 |
-
|
83 |
-
|
84 |
-
|
85 |
-
|
86 |
-
|
87 |
-
|
88 |
-
|
89 |
-
|
90 |
-
|
91 |
-
|
92 |
-
|
93 |
-
|
94 |
-
|
95 |
-
|
96 |
-
|
97 |
-
|
98 |
-
|
99 |
-
|
100 |
-
|
101 |
-
|
102 |
-
TEMPERATURE: 1.0
|
103 |
-
TOP_P: 0.95
|
104 |
-
MIN_P: 0.05</pre>
|
105 |
-
<h3>Prompting Format</h3>
|
106 |
-
<p>The model uses standard "ChatML" format:</p>
|
107 |
-
<pre>
|
108 |
<|im_start|>system
|
109 |
system prompt<|im_end|>
|
110 |
<|im_start|>user
|
111 |
Hi there!<|im_end|>
|
112 |
<|im_start|>assistant
|
113 |
-
Nice to meet you!<|im_end
|
|
|
|
|
|
|
|
|
|
|
114 |
|
115 |
-
|
116 |
-
|
117 |
-
|
118 |
-
|
|
|
|
|
|
|
119 |
{
|
120 |
"story_string": "<|im_start|>system\n{{#if system}}{{system}}\n{{/if}}{{#if wiBefore}}{{wiBefore}}\n{{/if}}{{#if description}}{{description}}\n{{/if}}{{#if personality}}{{char}}'s personality: {{personality}}\n{{/if}}{{#if scenario}}Scenario: {{scenario}}\n{{/if}}{{#if wiAfter}}{{wiAfter}}\n{{/if}}{{#if persona}}{{persona}}\n{{/if}}{{trim}}<|im_end|>\n",
|
121 |
"example_separator": "",
|
@@ -127,12 +128,13 @@ Nice to meet you!<|im_end|></pre>
|
|
127 |
"include_newline": false,
|
128 |
"single_line": false,
|
129 |
"name": "Dan-ChatML"
|
130 |
-
}
|
131 |
-
|
132 |
|
133 |
-
|
134 |
-
|
135 |
-
|
|
|
136 |
{
|
137 |
"system_prompt": "Write {{char}}'s actions and dialogue, user will write {{user}}'s.",
|
138 |
"input_sequence": "<|im_start|>user\n",
|
@@ -158,44 +160,135 @@ Nice to meet you!<|im_end|></pre>
|
|
158 |
"first_input_sequence": "",
|
159 |
"last_input_sequence": "",
|
160 |
"name": "Dan-ChatML"
|
161 |
-
}
|
162 |
-
|
163 |
|
164 |
-
|
165 |
-
|
166 |
-
|
167 |
-
|
168 |
-
|
169 |
-
|
170 |
-
|
171 |
-
|
172 |
-
|
173 |
-
|
174 |
-
|
175 |
-
|
176 |
-
|
177 |
-
|
178 |
-
|
179 |
-
|
180 |
-
|
181 |
-
|
182 |
-
|
183 |
-
|
184 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
185 |
from time import sleep
|
186 |
from multiprocessing.pool import ThreadPool
|
187 |
-
|
188 |
def task():
|
189 |
sleep(1)
|
190 |
return 'all done'
|
191 |
|
192 |
if __name__ == '__main__':
|
193 |
with ThreadPool() as pool:
|
194 |
-
result = pool.apply_async(task())
|
195 |
-
|
196 |
-
|
197 |
-
|
198 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
199 |
from time import sleep
|
200 |
from multiprocessing.pool import ThreadPool
|
201 |
|
@@ -207,286 +300,121 @@ if __name__ == '__main__':
|
|
207 |
with ThreadPool() as pool:
|
208 |
result = pool.apply_async(task) # Pass the function, not the result
|
209 |
value = result.get() # Wait for the result
|
210 |
-
print(value)
|
211 |
-
|
212 |
-
|
213 |
-
|
214 |
-
|
215 |
-
|
216 |
-
|
217 |
-
|
218 |
-
|
219 |
-
|
220 |
-
|
221 |
-
|
222 |
-
|
223 |
-
|
224 |
-
|
225 |
-
|
226 |
-
|
227 |
-
|
228 |
-
|
229 |
-
|
230 |
-
|
231 |
-
|
232 |
-
|
233 |
-
|
234 |
-
|
235 |
-
|
236 |
-
|
237 |
-
|
238 |
-
|
239 |
-
|
240 |
-
|
241 |
-
|
242 |
-
|
243 |
-
|
244 |
-
|
245 |
-
|
246 |
-
|
247 |
-
|
248 |
-
|
249 |
-
|
250 |
-
|
251 |
-
|
252 |
-
|
253 |
-
|
254 |
-
|
255 |
-
|
256 |
-
|
257 |
-
|
258 |
-
|
259 |
-
|
260 |
-
|
261 |
-
|
262 |
-
|
263 |
-
|
264 |
-
|
265 |
-
|
266 |
-
|
267 |
-
|
268 |
-
|
269 |
-
|
270 |
-
|
271 |
-
|
272 |
-
|
273 |
-
|
274 |
-
|
275 |
-
|
276 |
-
|
277 |
-
|
278 |
-
|
279 |
-
|
280 |
-
|
281 |
-
|
282 |
-
|
283 |
-
|
284 |
-
|
285 |
-
|
286 |
-
|
287 |
-
|
288 |
-
|
289 |
-
|
290 |
-
|
291 |
-
|
292 |
-
|
293 |
-
|
294 |
-
|
295 |
-
|
296 |
-
|
297 |
-
|
298 |
-
|
299 |
-
|
300 |
-
|
301 |
-
|
302 |
-
|
303 |
-
|
304 |
-
|
305 |
-
|
306 |
-
|
307 |
-
|
308 |
-
|
309 |
-
|
310 |
-
|
311 |
-
|
312 |
-
|
313 |
-
|
314 |
-
|
315 |
-
|
316 |
-
|
317 |
-
|
318 |
-
|
319 |
-
|
320 |
-
|
321 |
-
|
322 |
-
|
323 |
-
|
324 |
-
|
325 |
-
|
326 |
-
|
327 |
-
|
328 |
-
<p>Development is limited by funding and resources. To help support:</p>
|
329 |
-
<p>- Contact on HF</p>
|
330 |
-
<p>- Email: visuallyadequate@gmail.com</p>
|
331 |
-
<p class="coffee-container">
|
332 |
-
<a href="https://www.buymeacoffee.com/visually" target="_blank" rel="noopener noreferrer">
|
333 |
-
<img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" height="45" width="162">
|
334 |
-
</a>
|
335 |
-
</p>
|
336 |
-
</div>
|
337 |
-
</div>
|
338 |
-
</div>
|
339 |
-
</div>
|
340 |
-
</div>
|
341 |
-
<style>
|
342 |
-
@import url('https://fonts.googleapis.com/css2?family=VT323&display=swap');
|
343 |
-
.crt-container {
|
344 |
-
padding: 10px;
|
345 |
-
max-width: 1000px;
|
346 |
-
margin: 0 auto;
|
347 |
-
width: 95%;
|
348 |
-
}
|
349 |
-
.crt-case {
|
350 |
-
background: #e8d7c3;
|
351 |
-
border-radius: 10px;
|
352 |
-
padding: 15px;
|
353 |
-
box-shadow: inset -2px -2px 5px rgba(0,0,0,0.3), 2px 2px 5px rgba(0,0,0,0.2);
|
354 |
-
}
|
355 |
-
.crt-inner-case {
|
356 |
-
background: #e8d7c3;
|
357 |
-
border-radius: 8px;
|
358 |
-
padding: 3px;
|
359 |
-
box-shadow: inset -1px -1px 4px rgba(0,0,0,0.3), 1px 1px 4px rgba(0,0,0,0.2);
|
360 |
-
}
|
361 |
-
.crt-bezel {
|
362 |
-
background: linear-gradient(145deg, #1a1a1a, #2a2a2a);
|
363 |
-
padding: 15px;
|
364 |
-
border-radius: 5px;
|
365 |
-
border: 3px solid #0a0a0a;
|
366 |
-
position: relative;
|
367 |
-
box-shadow:
|
368 |
-
inset 0 0 20px rgba(0,0,0,0.5),
|
369 |
-
inset 0 0 4px rgba(0,0,0,0.4),
|
370 |
-
inset 2px 2px 4px rgba(255,255,255,0.05),
|
371 |
-
inset -2px -2px 4px rgba(0,0,0,0.8),
|
372 |
-
0 0 2px rgba(0,0,0,0.6),
|
373 |
-
-1px -1px 4px rgba(255,255,255,0.1),
|
374 |
-
1px 1px 4px rgba(0,0,0,0.3);
|
375 |
-
}
|
376 |
-
.crt-bezel::before {
|
377 |
-
content: '';
|
378 |
-
position: absolute;
|
379 |
-
top: 0;
|
380 |
-
left: 0;
|
381 |
-
right: 0;
|
382 |
-
bottom: 0;
|
383 |
-
background: linear-gradient(45deg,
|
384 |
-
rgba(255,255,255,0.03) 0%,
|
385 |
-
rgba(255,255,255,0) 40%,
|
386 |
-
rgba(0,0,0,0.1) 60%,
|
387 |
-
rgba(0,0,0,0.2) 100%);
|
388 |
-
border-radius: 3px;
|
389 |
-
pointer-events: none;
|
390 |
-
}
|
391 |
-
.terminal-screen {
|
392 |
-
background: #111112;
|
393 |
-
padding: 20px;
|
394 |
-
border-radius: 15px;
|
395 |
-
position: relative;
|
396 |
-
overflow: hidden;
|
397 |
-
font-family: 'VT323', monospace;
|
398 |
-
font-size: clamp(12px, 1.5vw, 16px);
|
399 |
-
color: #e49b3e;
|
400 |
-
line-height: 1.4;
|
401 |
-
text-shadow: 0 0 2px #e49b3e;
|
402 |
-
animation: flicker 0.15s infinite;
|
403 |
-
filter: brightness(1.1) contrast(1.1);
|
404 |
-
box-shadow:
|
405 |
-
inset 0 0 30px rgba(0,0,0,0.9),
|
406 |
-
inset 0 0 8px rgba(0,0,0,0.8),
|
407 |
-
0 0 5px rgba(0,0,0,0.6);
|
408 |
-
max-width: 80ch;
|
409 |
-
margin: 0 auto;
|
410 |
-
}
|
411 |
-
.terminal-screen h2, .terminal-screen h3 {
|
412 |
-
font-size: clamp(16px, 2vw, 20px);
|
413 |
-
margin-bottom: 1em;
|
414 |
-
}
|
415 |
-
.terminal-screen pre {
|
416 |
-
font-size: clamp(11px, 1.3vw, 14px);
|
417 |
-
white-space: pre-wrap;
|
418 |
-
margin: 1em 0;
|
419 |
-
}
|
420 |
-
.terminal-screen::before {
|
421 |
-
content: "";
|
422 |
-
position: absolute;
|
423 |
-
top: 0;
|
424 |
-
left: 0;
|
425 |
-
right: 0;
|
426 |
-
bottom: 0;
|
427 |
-
background: linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.25) 50%), url('');
|
428 |
-
background-size: 100% 2.5px;
|
429 |
-
animation: scan 1s linear infinite;
|
430 |
-
pointer-events: none;
|
431 |
-
z-index: 2;
|
432 |
-
}
|
433 |
-
.terminal-screen::after {
|
434 |
-
content: "";
|
435 |
-
position: absolute;
|
436 |
-
top: 0;
|
437 |
-
left: 0;
|
438 |
-
right: 0;
|
439 |
-
bottom: 0;
|
440 |
-
background: radial-gradient(circle at center, rgba(17, 17, 18, 0) 0%, rgba(17, 17, 18, 0.1) 75%, rgba(17, 17, 18, 0.4) 100%);
|
441 |
-
border-radius: 20px;
|
442 |
-
animation: vignette-pulse 3s infinite;
|
443 |
-
pointer-events: none;
|
444 |
-
z-index: 1;
|
445 |
-
}
|
446 |
-
.terminal-screen details {
|
447 |
-
margin: 1em 0;
|
448 |
-
padding: 0.5em;
|
449 |
-
border: 1px solid #e49b3e;
|
450 |
-
border-radius: 4px;
|
451 |
-
}
|
452 |
-
.terminal-screen summary {
|
453 |
-
cursor: pointer;
|
454 |
-
font-weight: bold;
|
455 |
-
margin: -0.5em;
|
456 |
-
padding: 0.5em;
|
457 |
-
border-bottom: 1px solid #e49b3e;
|
458 |
-
}
|
459 |
-
.terminal-screen details[open] summary {
|
460 |
-
margin-bottom: 0.5em;
|
461 |
-
}
|
462 |
-
.badge-container, .coffee-container {
|
463 |
-
text-align: center;
|
464 |
-
margin: 1em 0;
|
465 |
-
}
|
466 |
-
.badge-container img, .coffee-container img {
|
467 |
-
max-width: 100%;
|
468 |
-
height: auto;
|
469 |
-
}
|
470 |
-
.terminal-screen a {
|
471 |
-
color: #e49b3e;
|
472 |
-
text-decoration: underline;
|
473 |
-
transition: opacity 0.2s;
|
474 |
-
}
|
475 |
-
.terminal-screen a:hover {
|
476 |
-
opacity: 0.8;
|
477 |
-
}
|
478 |
-
@keyframes flicker {
|
479 |
-
0% { opacity: 0.98; }
|
480 |
-
50% { opacity: 1; }
|
481 |
-
100% { opacity: 0.99; }
|
482 |
-
}
|
483 |
-
@keyframes scan {
|
484 |
-
0% { transform: translateY(0); }
|
485 |
-
100% { transform: translateY(4px); }
|
486 |
-
}
|
487 |
-
@keyframes vignette-pulse {
|
488 |
-
0% { opacity: 0.8; }
|
489 |
-
50% { opacity: 1; }
|
490 |
-
100% { opacity: 0.8; }
|
491 |
-
}
|
492 |
-
</style>
|
|
|
3 |
license: apache-2.0
|
4 |
language:
|
5 |
- en
|
6 |
+
base_model:
|
7 |
- mistralai/Mistral-Nemo-Base-2407
|
|
|
8 |
tags:
|
9 |
- general-purpose
|
10 |
- roleplay
|
|
|
78 |
results: []
|
79 |
pipeline_tag: text-generation
|
80 |
---
|
81 |
+
## What is it?
|
82 |
+
|
83 |
+
This model series is intended to be multifarious in its capabilities and should be quite capable at both co-writing and roleplay as well as find itself quite at home performing sentiment analysis or summarization as part of a pipeline. It has been trained on a wide array of one shot instructions, multi turn instructions, tool use, role playing scenarios, text adventure games, co-writing, and much more. The full dataset is publicly available and can be found in the datasets section of the model page.
|
84 |
+
|
85 |
+
There has not been any form of harmfulness alignment done on this model, please take the appropriate precautions when using it in a production environment.
|
86 |
+
|
87 |
+
**Expected usable context length:** 32768 tokens
|
88 |
+
|
89 |
+
|
90 |
+
## Recommended samplers
|
91 |
+
|
92 |
+
**Temperature:** 1.0
|
93 |
+
**Top_P:** 0.95
|
94 |
+
**Min_P:** 0.05
|
95 |
+
|
96 |
+
## Prompting
|
97 |
+
|
98 |
+
The model has been trained on standard "ChatML" format prompting, an example of which is shown below:
|
99 |
+
|
100 |
+
```
|
|
|
|
|
|
|
|
|
|
|
|
|
101 |
<|im_start|>system
|
102 |
system prompt<|im_end|>
|
103 |
<|im_start|>user
|
104 |
Hi there!<|im_end|>
|
105 |
<|im_start|>assistant
|
106 |
+
Nice to meet you!<|im_end|>
|
107 |
+
<|im_start|>user
|
108 |
+
Can I ask a question?<|im_end|>
|
109 |
+
<|im_start|>assistant
|
110 |
+
```
|
111 |
+
|
112 |
|
113 |
+
## SillyTavern templates
|
114 |
+
|
115 |
+
Below are Instruct and Context templates for use within SillyTavern.
|
116 |
+
|
117 |
+
<details><summary>context template</summary>
|
118 |
+
|
119 |
+
```yaml
|
120 |
{
|
121 |
"story_string": "<|im_start|>system\n{{#if system}}{{system}}\n{{/if}}{{#if wiBefore}}{{wiBefore}}\n{{/if}}{{#if description}}{{description}}\n{{/if}}{{#if personality}}{{char}}'s personality: {{personality}}\n{{/if}}{{#if scenario}}Scenario: {{scenario}}\n{{/if}}{{#if wiAfter}}{{wiAfter}}\n{{/if}}{{#if persona}}{{persona}}\n{{/if}}{{trim}}<|im_end|>\n",
|
122 |
"example_separator": "",
|
|
|
128 |
"include_newline": false,
|
129 |
"single_line": false,
|
130 |
"name": "Dan-ChatML"
|
131 |
+
}
|
132 |
+
```
|
133 |
|
134 |
+
</details><br>
|
135 |
+
<details><summary>instruct template</summary>
|
136 |
+
|
137 |
+
```yaml
|
138 |
{
|
139 |
"system_prompt": "Write {{char}}'s actions and dialogue, user will write {{user}}'s.",
|
140 |
"input_sequence": "<|im_start|>user\n",
|
|
|
160 |
"first_input_sequence": "",
|
161 |
"last_input_sequence": "",
|
162 |
"name": "Dan-ChatML"
|
163 |
+
}
|
164 |
+
```
|
165 |
|
166 |
+
</details><br>
|
167 |
+
|
168 |
+
|
169 |
+
## Example outputs
|
170 |
+
|
171 |
+
### General assistance
|
172 |
+
|
173 |
+
<details><summary>General assistance example</summary>
|
174 |
+
|
175 |
+
> *Act as a personable virtual assistant.*
|
176 |
+
|
177 |
+
> I'm going to be in Chicago soon can you help me work up some restaurant ideas?
|
178 |
+
|
179 |
+
> I'd love to! Here are a few suggestions for restaurants in Chicago:
|
180 |
+
>
|
181 |
+
> - For deep dish pizza, I highly recommend Lou Malnati's Pizzeria or Giordano's. Both are iconic Chicago institutions and serve some of the best deep dish pizza in the city.
|
182 |
+
> - If you're looking for a classic steakhouse experience, Gibson's Bar & Steakhouse is a great choice. They offer high-quality steaks, seafood, and an extensive wine list in a sophisticated atmosphere.
|
183 |
+
> - For a more casual dining experience, check out Portillo's Hot Dogs. They're known for their Chicago-style hot dogs, Italian beef sandwiches, and other classic American fare.
|
184 |
+
> - For something a bit more unique, try Alinea. It's a high-end, avant-garde restaurant that offers a truly one-of-a-kind dining experience with innovative cuisine and cutting-edge presentation techniques.
|
185 |
+
>
|
186 |
+
> Let me know if you need any other recommendations or have specific dietary restrictions or preferences!
|
187 |
+
|
188 |
+
<details><summary>Raw Prompt</summary>
|
189 |
+
|
190 |
+
```
|
191 |
+
<|im_start|>system
|
192 |
+
Act as a personable virtual assistant.<|im_end|>
|
193 |
+
<|im_start|>user
|
194 |
+
I'm going to be in Chicago soon can you help me work up some restaurant ideas?<|im_end|>
|
195 |
+
<|im_start|>assistant
|
196 |
+
I'd love to! Here are a few suggestions for restaurants in Chicago:
|
197 |
+
|
198 |
+
- For deep dish pizza, I highly recommend Lou Malnati's Pizzeria or Giordano's. Both are iconic Chicago institutions and serve some of the best deep dish pizza in the city.
|
199 |
+
- If you're looking for a classic steakhouse experience, Gibson's Bar & Steakhouse is a great choice. They offer high-quality steaks, seafood, and an extensive wine list in a sophisticated atmosphere.
|
200 |
+
- For a more casual dining experience, check out Portillo's Hot Dogs. They're known for their Chicago-style hot dogs, Italian beef sandwiches, and other classic American fare.
|
201 |
+
- For something a bit more unique, try Alinea. It's a high-end, avant-garde restaurant that offers a truly one-of-a-kind dining experience with innovative cuisine and cutting-edge presentation techniques.
|
202 |
+
|
203 |
+
Let me know if you need any other recommendations or have specific dietary restrictions or preferences!
|
204 |
+
```
|
205 |
+
|
206 |
+
</details><br>
|
207 |
+
</details><br>
|
208 |
+
|
209 |
+
### Basic programming
|
210 |
+
|
211 |
+
<details><summary>Basic programming example</summary>
|
212 |
+
|
213 |
+
> *Answer the question or perform the task.*
|
214 |
+
|
215 |
+
> Explain the bug in the following code:
|
216 |
+
>
|
217 |
+
> ```python
|
218 |
+
> from time import sleep
|
219 |
+
> from multiprocessing.pool import ThreadPool
|
220 |
+
>
|
221 |
+
> def task():
|
222 |
+
> sleep(1)
|
223 |
+
> return 'all done'
|
224 |
+
>
|
225 |
+
> if __name__ == '__main__':
|
226 |
+
> with ThreadPool() as pool:
|
227 |
+
> result = pool.apply_async(task())
|
228 |
+
> ```
|
229 |
+
|
230 |
+
> The bug in this code is that the `task()` function is called immediately when the `apply_async()` method is invoked, not when the worker process is ready to execute it.
|
231 |
+
>
|
232 |
+
> Specifically, the line `result = pool.apply_async(task())` calls `task()` right away and passes its return value to `apply_async()`. The worker process will execute whatever `task()` returns at that moment, which is `'all done'` since `task()` completes execution almost immediately.
|
233 |
+
>
|
234 |
+
> What you likely intended was for `apply_async()` to pass the `task()` function itself to the worker process, so the worker could call `task()` when ready. However, `apply_async()` only accepts the result of calling the target function, not the function object itself.
|
235 |
+
>
|
236 |
+
> To fix this bug, you need to pass the `task` function itself to `apply_async()`, rather than calling `task()` beforehand. Here's how you can modify the code:
|
237 |
+
>
|
238 |
+
> ```python
|
239 |
+
> from time import sleep
|
240 |
+
> from multiprocessing.pool import ThreadPool
|
241 |
+
>
|
242 |
+
> def task():
|
243 |
+
> sleep(1)
|
244 |
+
> return 'all done'
|
245 |
+
>
|
246 |
+
> if __name__ == '__main__':
|
247 |
+
> with ThreadPool() as pool:
|
248 |
+
> result = pool.apply_async(task) # Pass the function, not the result
|
249 |
+
> value = result.get() # Wait for the result
|
250 |
+
> print(value)
|
251 |
+
> ```
|
252 |
+
>
|
253 |
+
> With this modification, the worker process will actually execute the `task()` function, wait for it to complete, and then retrieve the result using `get()`.
|
254 |
+
>
|
255 |
+
> So in summary, the original bug was that you were passing the result of calling `task()` to `apply_async()`, rather than passing the function object itself. The fix is to simply omit the parentheses after `task`, so `apply_async()` receives the function reference instead of its return value.
|
256 |
+
|
257 |
+
|
258 |
+
<details><summary>Raw Prompt</summary>
|
259 |
+
|
260 |
+
(Back slashes before triple backticks are not part of the prompt)
|
261 |
+
|
262 |
+
```
|
263 |
+
<|im_start|>system
|
264 |
+
Answer the question or perform the task.<|im_end|>
|
265 |
+
<|im_start|>user
|
266 |
+
Explain the bug in the following code:
|
267 |
+
|
268 |
+
\```
|
269 |
from time import sleep
|
270 |
from multiprocessing.pool import ThreadPool
|
271 |
+
|
272 |
def task():
|
273 |
sleep(1)
|
274 |
return 'all done'
|
275 |
|
276 |
if __name__ == '__main__':
|
277 |
with ThreadPool() as pool:
|
278 |
+
result = pool.apply_async(task())
|
279 |
+
value = result.get()
|
280 |
+
print(value)
|
281 |
+
\```<|im_end|>
|
282 |
+
<|im_start|>assistant
|
283 |
+
The bug in this code is that the `task()` function is called immediately when the `apply_async()` method is invoked, not when the worker process is ready to execute it.
|
284 |
+
|
285 |
+
Specifically, the line `result = pool.apply_async(task())` calls `task()` right away and passes its return value to `apply_async()`. The worker process will execute whatever `task()` returns at that moment, which is `'all done'` since `task()` completes execution almost immediately.
|
286 |
+
|
287 |
+
What you likely intended was for `apply_async()` to pass the `task()` function itself to the worker process, so the worker could call `task()` when ready. However, `apply_async()` only accepts the result of calling the target function, not the function object itself.
|
288 |
+
|
289 |
+
To fix this bug, you need to pass the `task` function itself to `apply_async()`, rather than calling `task()` beforehand. Here's how you can modify the code:
|
290 |
+
|
291 |
+
\```python
|
292 |
from time import sleep
|
293 |
from multiprocessing.pool import ThreadPool
|
294 |
|
|
|
300 |
with ThreadPool() as pool:
|
301 |
result = pool.apply_async(task) # Pass the function, not the result
|
302 |
value = result.get() # Wait for the result
|
303 |
+
print(value)
|
304 |
+
\```
|
305 |
+
|
306 |
+
With this modification, the worker process will actually execute the `task()` function, wait for it to complete, and then retrieve the result using `get()`.
|
307 |
+
|
308 |
+
So in summary, the original bug was that you were passing the result of calling `task()` to `apply_async()`, rather than passing the function object itself. The fix is to simply omit the parentheses after `task`, so `apply_async()` receives the function reference instead of its return value.
|
309 |
+
```
|
310 |
+
|
311 |
+
</details><br>
|
312 |
+
|
313 |
+
</details><br>
|
314 |
+
|
315 |
+
### Writing
|
316 |
+
|
317 |
+
<details><summary>Writing example</summary>
|
318 |
+
|
319 |
+
> *Take the users messages and use them as a writing prompt. Write 5 sentences.*
|
320 |
+
|
321 |
+
> Alpha Centauri has fallen, to the bears. This is a point of view tale about a soldier on the ground.
|
322 |
+
|
323 |
+
> "Sir, they are gone sir." The young corporal was out of breath.
|
324 |
+
>
|
325 |
+
> The soldier looked up. His grey eyes had been locked on his holofac display for hours now. He was in his late thirties and wore the rank of colonel. He was tall, with a well-muscled but slightly over weight body.
|
326 |
+
|
327 |
+
> "Who?"
|
328 |
+
|
329 |
+
> He turned and looked at the corporal.
|
330 |
+
>
|
331 |
+
> "The bears. They left. We checked the entire perimeter. No bears to be found sir."
|
332 |
+
>
|
333 |
+
> "Did you check the air?"
|
334 |
+
>
|
335 |
+
> "Not the air, sir. We didn't see any shuttles. But we have drones out now."
|
336 |
+
|
337 |
+
> "*Sigh*"
|
338 |
+
|
339 |
+
> "Ok, get me the status report. I need to know how many dead we have."
|
340 |
+
>
|
341 |
+
> "Yes sir." The corporal turned to leave.
|
342 |
+
>
|
343 |
+
> "Corporal…"
|
344 |
+
>
|
345 |
+
> "Sir?"
|
346 |
+
>
|
347 |
+
> "Get me a fresh cup of coffee. Black. I need the caffeine."
|
348 |
+
|
349 |
+
<details><summary>Raw Prompt</summary>
|
350 |
+
|
351 |
+
```
|
352 |
+
<|im_start|>system
|
353 |
+
Take the users messages and use them as a writing prompt. Write 5 sentences.<|im_end|>
|
354 |
+
<|im_start|>user
|
355 |
+
Alpha Centauri has fallen, to the bears. This is a point of view tale about a soldier on the ground.<|im_end|>
|
356 |
+
<|im_start|>assistant
|
357 |
+
"Sir, they are gone sir." The young corporal was out of breath.
|
358 |
+
|
359 |
+
The soldier looked up. His grey eyes had been locked on his holofac display for hours now. He was in his late thirties and wore the rank of colonel. He was tall, with a well-muscled but slightly over weight body.<|im_end|>
|
360 |
+
<|im_start|>user
|
361 |
+
"Who?"<|im_end|>
|
362 |
+
<|im_start|>assistant
|
363 |
+
He turned and looked at the corporal.
|
364 |
+
|
365 |
+
"The bears. They left. We checked the entire perimeter. No bears to be found sir."
|
366 |
+
|
367 |
+
"Did you check the air?"
|
368 |
+
|
369 |
+
"Not the air, sir. We didn't see any shuttles. But we have drones out now."<|im_end|>
|
370 |
+
<|im_start|>user
|
371 |
+
"*Sigh*"<|im_end|>
|
372 |
+
<|im_start|>assistant
|
373 |
+
"Ok, get me the status report. I need to know how many dead we have."
|
374 |
+
|
375 |
+
"Yes sir." The corporal turned to leave.
|
376 |
+
|
377 |
+
"Corporal…"
|
378 |
+
|
379 |
+
"Sir?"
|
380 |
+
|
381 |
+
"Get me a fresh cup of coffee. Black. I need the caffeine."
|
382 |
+
```
|
383 |
+
|
384 |
+
</details><br>
|
385 |
+
</details><br>
|
386 |
+
|
387 |
+
### Text editing
|
388 |
+
|
389 |
+
<details><summary>Text editing</summary>
|
390 |
+
|
391 |
+
> *You are a professional editor with decades of experience, help the user with any task they have for you.*
|
392 |
+
|
393 |
+
> Can you rewrite this to flow better? "I knew I probably shouldnt have done that but ohhh well i guess i just going to live with it since whats done is done"
|
394 |
+
|
395 |
+
> I knew I probably shouldn't have done that, but oh well. I guess I just going to live with it since what's done is done.
|
396 |
+
|
397 |
+
<details><summary>Raw Prompt</summary>
|
398 |
+
|
399 |
+
```
|
400 |
+
<|im_start|>system
|
401 |
+
You are a professional editor with decades of experience, help the user with any task they have for you.<|im_end|>
|
402 |
+
<|im_start|>user
|
403 |
+
Can you rewrite this to flow better? "I knew I probably shouldnt have done that but ohhh well i guess i just going to live with it since whats done is done"<|im_end|>
|
404 |
+
<|im_start|>assistant
|
405 |
+
I knew I probably shouldn't have done that, but oh well. I guess I just going to live with it since what's done is done.
|
406 |
+
```
|
407 |
+
|
408 |
+
</details><br>
|
409 |
+
</details><br>
|
410 |
+
|
411 |
+
## Training
|
412 |
+
|
413 |
+
This model was full finetuned for 2 epochs on 1x H200 SXM equating to 88 hours of training.
|
414 |
+
|
415 |
+
[<img src="https://raw.githubusercontent.com/OpenAccess-AI-Collective/axolotl/main/image/axolotl-badge-web.png" alt="Built with Axolotl" width="200" height="32"/>](https://github.com/OpenAccess-AI-Collective/axolotl)
|
416 |
+
|
417 |
+
## Give me your pocket change
|
418 |
+
The development and production of these datasets is severely limited by the funding and resources available to me. If you would like to help reach out to me here on HF, at visuallyadequate@gmail.com or you can leave something in the hat over at https://buymeacoffee.com/visually
|
419 |
+
|
420 |
+
<a href="https://www.buymeacoffee.com/visually"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" height="45" width="162"></a>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|