elswa-dev commited on
Commit
f4d6f51
·
verified ·
1 Parent(s): 1959180

Upload simple_grpo_fine_tune_course.ipynb

Browse files
Files changed (1) hide show
  1. simple_grpo_fine_tune_course.ipynb +534 -0
simple_grpo_fine_tune_course.ipynb ADDED
@@ -0,0 +1,534 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "cells": [
3
+ {
4
+ "cell_type": "markdown",
5
+ "source": [
6
+ "###Simple GRPO Fine-Tuning Course\n",
7
+ "In this simple example, we're going to fine-tune a large language model using GRPO (Group Relative Policy Optimization) from scratch.\n",
8
+ "\n",
9
+ "This notebook is part of the Simple GRPO Fine-Tuning Course, a free course designed for beginners, where you learn to fine-tune language models using the GRPO technique."
10
+ ],
11
+ "metadata": {
12
+ "id": "6S4koaD7fOLo"
13
+ }
14
+ },
15
+ {
16
+ "cell_type": "markdown",
17
+ "source": [
18
+ "![Easy Fine-Tune LLMs with GRPO - li_back.svg](data:image/svg+xml;base64,<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="1106" height="570" viewBox="0 0 1106 570" style="fill:none;stroke:none;fill-rule:evenodd;clip-rule:evenodd;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:1.5;" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><style class="text-font-style fontImports" data-font-family="Shantell Sans">@import url('https://fonts.googleapis.com/css2?family=Shantell+Sans:wght@300..800&amp;display=block');</style><rect id="" x="0" y="0" width="1106" height="569.614" style="fill: #ffffff;"></rect><g id="items" style="isolation: isolate"><g id="blend" style="mix-blend-mode: normal"><g id="g-root-tf_141qrkf1c1osuc-fill" data-item-order="-626646" transform="translate(-9, -9)"><g id="tf_141qrkf1c1osuc-fill" stroke="none" fill="#ffffff"><g><path d="M 10 10L 1114 10L 1114 577.61L 10 577.61Z"></path></g></g></g><g id="g-root-7.cu_sy_1czwmxb1brw8ax-fill" data-item-order="-55752" transform="translate(255.26434326171875, 447.8194580078125)"><g id="7.cu_sy_1czwmxb1brw8ax-fill" stroke="none" fill="#ffe4cb"><g><path d="M 127.336977 20.2322C 126.543977 29.7108 98.397177 34.4164 69.909777 39.6509C 48.711877 43.546 29.357977 45.288 21.745577 47.0136C 15.502477 48.4288 9.471377 52.8286 10.036877 61.629C 10.381077 66.9868 13.703477 71.4046 21.745577 72.035C 31.437377 72.7948 48.104077 69.9303 75.229277 65.242C 123.998977 56.8124 140.902977 48.3751 140.902977 31.5084C 140.902977 20.2322 125.553977 12.281 118.676977 10C 122.844977 11.6633 127.810977 14.562 127.336977 20.2322Z"></path></g></g></g><g id="g-root-7.cu_1_sy_18k34sv1brw936-fill" data-item-order="-55750" transform="translate(257.9600524902344, 441.5462646484375)"><g id="7.cu_1_sy_18k34sv1brw936-fill" stroke="none" fill="#ffe4cb"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.341 13.5695 117.352 16.811C 120.339 18.2371 124.813 20.893 124.686 26.0148C 124.538 31.9893 114.66 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771Z"></path></g></g></g><g id="g-root-6.cu_sy_zp2ln31brw6q3-fill" data-item-order="-55746" transform="translate(255.26434326171875, 390.7943115234375)"><g id="6.cu_sy_zp2ln31brw6q3-fill" stroke="none" fill="#f5e0ff"><g><path d="M 127.336977 20.2322C 126.543977 29.7108 98.397177 34.4164 69.909777 39.6509C 48.711877 43.546 29.357977 45.288 21.745577 47.0136C 15.502477 48.4288 9.471377 52.8286 10.036877 61.629C 10.381077 66.9868 13.703477 71.4046 21.745577 72.035C 31.437377 72.7948 48.104077 69.9303 75.229277 65.242C 123.998977 56.8124 140.902977 48.3751 140.902977 31.5084C 140.902977 20.2322 125.553977 12.281 118.676977 10C 122.844977 11.6633 127.810977 14.562 127.336977 20.2322Z"></path></g></g></g><g id="g-root-6.cu_1_sy_v993in1brw7ic-fill" data-item-order="-55744" transform="translate(257.9600524902344, 384.5218505859375)"><g id="6.cu_1_sy_v993in1brw7ic-fill" stroke="none" fill="#f5e0ff"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.341 13.5695 117.352 16.811C 120.339 18.2371 124.813 20.893 124.686 26.0148C 124.538 31.9893 114.66 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771Z"></path></g></g></g><g id="g-root-5.cu_sy_mdm39r1brw8b1-fill" data-item-order="-55740" transform="translate(255.26434326171875, 333.7701416015625)"><g id="5.cu_sy_mdm39r1brw8b1-fill" stroke="none" fill="#ffd7ef"><g><path d="M 127.336977 20.2322C 126.543977 29.7108 98.397177 34.4164 69.909777 39.6509C 48.711877 43.546 29.357977 45.288 21.745577 47.0136C 15.502477 48.4288 9.471377 52.8286 10.036877 61.629C 10.381077 66.9868 13.703477 71.4046 21.745577 72.035C 31.437377 72.7948 48.104077 69.9303 75.229277 65.242C 123.998977 56.8124 140.902977 48.3751 140.902977 31.5084C 140.902977 20.2322 125.553977 12.281 118.676977 10C 122.844977 11.6633 127.810977 14.562 127.336977 20.2322Z"></path></g></g></g><g id="g-root-5.cu_1_sy_hxsl5b1brw93a-fill" data-item-order="-55738" transform="translate(257.9600524902344, 327.4971923828125)"><g id="5.cu_1_sy_hxsl5b1brw93a-fill" stroke="none" fill="#ffd7ef"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.341 13.5695 117.352 16.811C 120.339 18.2371 124.813 20.893 124.686 26.0148C 124.538 31.9893 114.66 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771Z"></path></g></g></g><g id="g-root-4.cu_sy_92s1zj1brw6q7-fill" data-item-order="-55734" transform="translate(255.26434326171875, 276.7462158203125)"><g id="4.cu_sy_92s1zj1brw6q7-fill" stroke="none" fill="#d1f4ff"><g><path d="M 127.336977 20.2322C 126.543977 29.7108 98.397177 34.4164 69.909777 39.6509C 48.711877 43.546 29.357977 45.288 21.745577 47.0136C 15.502477 48.4288 9.471377 52.8286 10.036877 61.629C 10.381077 66.9868 13.703477 71.4046 21.745577 72.035C 31.437377 72.7948 48.104077 69.9303 75.229277 65.242C 123.998977 56.8124 140.902977 48.3751 140.902977 31.5084C 140.902977 20.2322 125.553977 12.281 118.676977 10C 122.844977 11.6633 127.810977 14.562 127.336977 20.2322Z"></path></g></g></g><g id="g-root-4.cu_1_sy_4myjv31brw7ig-fill" data-item-order="-55732" transform="translate(257.9600524902344, 270.4737548828125)"><g id="4.cu_1_sy_4myjv31brw7ig-fill" stroke="none" fill="#d1f4ff"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.341 13.5695 117.352 16.811C 120.339 18.2371 124.813 20.893 124.686 26.0148C 124.538 31.9893 114.66 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771Z"></path></g></g></g><g id="g-root-3.cu_sy_751qn1brw8ap-fill" data-item-order="-55728" transform="translate(255.26434326171875, 219.720703125)"><g id="3.cu_sy_751qn1brw8ap-fill" stroke="none" fill="#e9ffb9"><g><path d="M 127.336977 20.2322C 126.543977 29.7108 98.397177 34.4164 69.909777 39.6509C 48.711877 43.546 29.357977 45.288 21.745577 47.0136C 15.502477 48.4288 9.471377 52.8286 10.036877 61.629C 10.381077 66.9868 13.703477 71.4046 21.745577 72.035C 31.437377 72.7948 48.104077 69.9303 75.229277 65.242C 123.998977 56.8124 140.902977 48.3751 140.902977 31.5084C 140.902977 20.2322 125.553977 12.281 118.676977 10C 122.844977 11.6633 127.810977 14.562 127.336977 20.2322Z"></path></g></g></g><g id="g-root-3.cu_1_sy_1qcm3gv1brw8wa-fill" data-item-order="-55726" transform="translate(257.9600830078125, 213.4482421875)"><g id="3.cu_1_sy_1qcm3gv1brw8wa-fill" stroke="none" fill="#e9ffb9"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.341 13.5695 117.352 16.811C 120.339 18.2371 124.813 20.893 124.686 26.0148C 124.538 31.9893 114.66 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771Z"></path></g></g></g><g id="g-root-2.cu_sy_1lxf2fj1brw6ir-fill" data-item-order="-55722" transform="translate(255.26434326171875, 162.6962890625)"><g id="2.cu_sy_1lxf2fj1brw6ir-fill" stroke="none" fill="#c8ffe5"><g><path d="M 127.336977 20.2322C 126.543977 29.7108 98.397177 34.4164 69.909777 39.6509C 48.711877 43.546 29.357977 45.288 21.745577 47.0136C 15.502477 48.4288 9.471377 52.8286 10.036877 61.629C 10.381077 66.9868 13.703477 71.4046 21.745577 72.035C 31.437377 72.7948 48.104077 69.9303 75.229277 65.242C 123.998977 56.8124 140.902977 48.3751 140.902977 31.5084C 140.902977 20.2322 125.553977 12.281 118.676977 10C 122.844977 11.6633 127.810977 14.562 127.336977 20.2322Z"></path></g></g></g><g id="g-root-2.cu_1_sy_1d1s26n1brw7bg-fill" data-item-order="-55720" transform="translate(257.9600830078125, 156.4228515625)"><g id="2.cu_1_sy_1d1s26n1brw7bg-fill" stroke="none" fill="#c8ffe5"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.341 13.5695 117.352 16.811C 120.339 18.2371 124.813 20.893 124.686 26.0148C 124.538 31.9893 114.66 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771Z"></path></g></g></g><g id="g-root-1.cu_sy_1d1s26n1brw7bh-fill" data-item-order="-55716" transform="translate(255.26434326171875, 105.671875)"><g id="1.cu_sy_1d1s26n1brw7bh-fill" stroke="none" fill="#dce9ff"><g><path d="M 127.336977 20.2322C 126.543977 29.7108 98.397177 34.4164 69.909777 39.6509C 48.711877 43.546 29.357977 45.288 21.745577 47.0136C 15.502477 48.4288 9.471377 52.8286 10.036877 61.629C 10.381077 66.9868 13.703477 71.4046 21.745577 72.035C 31.437377 72.7948 48.104077 69.9303 75.229277 65.242C 123.998977 56.8124 140.902977 48.3751 140.902977 31.5084C 140.902977 20.2322 125.553977 12.281 118.676977 10C 122.844977 11.6633 127.810977 14.562 127.336977 20.2322Z"></path></g></g></g><g id="g-root-1.cu_1_sy_18lyk271brw83q-fill" data-item-order="-55714" transform="translate(255.30126953125, 87)"><g id="1.cu_1_sy_18lyk271brw83q-fill" stroke="none" fill="#dce9ff"><g><path d="M 21.6823 10.137885C 31.374 9.378085 48.067 11.794885 75.1922 16.483285C 90.003 19.043285 106.1882 22.819685 120.011 29.210385C 122.998 30.636385 127.472 33.292385 127.345 38.414185C 127.196 44.388685 117.319 48.153085 104.6598 51.344585C 104.3346 51.230585 102.9633 50.683785 102.6561 50.570685C 78.8756 41.626185 51.5585 39.244885 26.2368 35.204085C 24.7636 35.763885 21.9403 35.966885 20.221 35.763885C 15.9301 34.666285 10 31.373185 10 22.448585C 10 17.819185 13.6401 10.768285 21.6823 10.137885Z"></path></g></g></g><g id="g-root-1.Ellipse_sy_zqbjtb1brw8wf-fill" data-item-order="-55712" transform="translate(255.2646484375, 87.178955078125)"><g id="1.Ellipse_sy_zqbjtb1brw8wf-fill" stroke="none" fill="#dce9ff"><g><path d="M 10 22.846066C 9.998156 29.94019 15.498816 35.692136 22.284863 35.692136C 29.070909 35.692136 34.57157 29.94019 34.569726 22.846066C 34.57157 15.751942 29.070909 9.999996 22.284863 9.999996C 15.498816 9.999996 9.998156 15.751942 10 22.846066"></path></g></g></g><g id="g-root-tx_loaddata_1d310cv1brw9ho-fill" data-item-order="0" transform="translate(471.2643127441406, 231)"><g id="tx_loaddata_1d310cv1brw9ho-fill" stroke="none" fill="#484848"><g><text style="font: 20px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-size="20px" font-family="'Shantell Sans', cursive"><tspan x="12" y="35.6" dominant-baseline="ideographic">Load Dataset</tspan></text></g></g></g><g id="g-root-2_1upa32n1c1vrwl-fill" data-item-order="0" transform="translate(423.2643127441406, 225)"></g><g id="g-root-tx_installd_18ntzbj1brw745-fill" data-item-order="0" transform="translate(471.2643127441406, 171)"><g id="tx_installd_18ntzbj1brw745-fill" stroke="none" fill="#484848"><g><text style="font: 20px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-size="20px" font-family="'Shantell Sans', cursive"><tspan x="12" y="35.6" dominant-baseline="ideographic">Install Dependencies</tspan></text></g></g></g><g id="g-root-4_hvw0sv1c1dj40-fill" data-item-order="0" transform="translate(423.2643127441406, 285)"></g><g id="g-root-tx_pretrain_1qehiq71brw7wr-fill" data-item-order="0" transform="translate(471.2643127441406, 279)"><g id="tx_pretrain_1qehiq71brw7wr-fill" stroke="none" fill="#484848"><g><text style="font: 20px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-size="20px" font-family="'Shantell Sans', cursive"><tspan x="12" y="35.6" dominant-baseline="ideographic">Pre-trained Language Model with </tspan><tspan x="12" y="59.6" dominant-baseline="ideographic">LoRA</tspan></text></g></g></g><g id="g-root-pyth_93dh5b1c1rk75-fill" data-item-order="0" transform="translate(423.2643127441406, 165)"></g><g id="g-root-tx_choosegp_zs6z2n1brw7wu-fill" data-item-order="0" transform="translate(471.2643127441406, 111)"><g id="tx_choosegp_zs6z2n1brw7wu-fill" stroke="none" fill="#484848"><g><text style="font: 20px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-size="20px" font-family="'Shantell Sans', cursive"><tspan x="12" y="35.6" dominant-baseline="ideographic">Choose GPU Runtime</tspan></text></g></g></g><g id="g-root-shar_qs5btb1c1syyp-fill" data-item-order="0" transform="translate(423.2643127441406, 345)"></g><g id="g-root-tx_grpoopti_90gzz1brw7b6-fill" data-item-order="0" transform="translate(471.2643127441406, 351.0001220703125)"><g id="tx_grpoopti_90gzz1brw7b6-fill" stroke="none" fill="#484848"><g><text style="font: 20px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-size="20px" font-family="'Shantell Sans', cursive"><tspan x="12" y="35.6" dominant-baseline="ideographic">GRPO Optimization</tspan></text></g></g></g><g id="g-root-fire_1qcl4pb1c1ey2s-fill" data-item-order="0" transform="translate(423.2643127441406, 105)"></g><g id="g-root-tx_pushmode_vb4irz1brw6iw-fill" data-item-order="0" transform="translate(471.2643127441406, 471.0001220703125)"><g id="tx_pushmode_vb4irz1brw6iw-fill" stroke="none" fill="#484848"><g><text style="font: 20px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-size="20px" font-family="'Shantell Sans', cursive"><tspan x="12" y="35.6" dominant-baseline="ideographic">Push Model to Hub</tspan></text></g></g></g><g id="g-root-scri_1uqiuxb1c1eznn-fill" data-item-order="0" transform="translate(423.2643127441406, 405.0001220703125)"></g><g id="g-root-tx_textgene_djuia71brw8w1-fill" data-item-order="0" transform="translate(471.2643127441406, 411.0001220703125)"><g id="tx_textgene_djuia71brw8w1-fill" stroke="none" fill="#484848"><g><text style="font: 20px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-size="20px" font-family="'Shantell Sans', cursive"><tspan x="12" y="35.6" dominant-baseline="ideographic">Text Generation Output</tspan></text></g></g></g><g id="g-root-feat_hriivj1c1apzc-fill" data-item-order="0" transform="translate(423.2643127441406, 465.0001220703125)"></g><g id="g-root-tx_finetuni_vcdgy71brw8p3-fill" data-item-order="0" transform="translate(333.2642822265625, 27)"><g id="tx_finetuni_vcdgy71brw8p3-fill" stroke="none" fill="#484848"><g><text style="font: bold 25px &quot;Shantell Sans&quot;, cursive; white-space: pre;" font-weight="bold" font-size="25px" font-family="'Shantell Sans', cursive"><tspan x="16.14" y="44.2" dominant-baseline="ideographic">Easily Fine-Tune LLMs with GRPO</tspan></text></g></g></g><g id="g-root-tf_141qrkf1c1osuc-stroke" data-item-order="-626646" transform="translate(-9, -9)"></g><g id="g-root-7.cu_sy_1czwmxb1brw8ax-stroke" data-item-order="-55752" transform="translate(255.26434326171875, 447.8194580078125)"><g id="7.cu_sy_1czwmxb1brw8ax-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 69.909777 39.6509C 98.397177 34.4164 126.544077 29.7108 127.336877 20.2322C 127.811177 14.562 122.845377 11.6633 118.677377 10C 125.553977 12.281 140.902677 20.2322 140.902677 31.5084C 140.902677 48.3752 123.999377 56.8124 75.229277 65.242C 48.104077 69.9303 31.437377 72.7948 21.745577 72.035C 13.703477 71.4046 10.381077 66.9868 10.036877 61.629C 9.471377 52.8286 15.502477 48.4288 21.745577 47.0136C 29.357977 45.288 48.711877 43.546 69.909777 39.6509Z"></path></g></g></g><g id="g-root-7.cu_1_sy_18k34sv1brw936-stroke" data-item-order="-55750" transform="translate(257.9600524902344, 441.5462646484375)"><g id="7.cu_1_sy_18k34sv1brw936-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.3408 13.5695 117.3519 16.811C 120.3393 18.2371 124.8131 20.893 124.6859 26.0148C 124.5376 31.9893 114.6599 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771ZM 117.3519 16.811L 117.5995 16.9255"></path></g></g></g><g id="g-root-6.cu_sy_zp2ln31brw6q3-stroke" data-item-order="-55746" transform="translate(255.26434326171875, 390.7943115234375)"><g id="6.cu_sy_zp2ln31brw6q3-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 69.909777 39.6509C 98.397177 34.4164 126.544077 29.7108 127.336877 20.2322C 127.811177 14.562 122.845377 11.6633 118.677377 10C 125.553977 12.281 140.902677 20.2322 140.902677 31.5084C 140.902677 48.3752 123.999377 56.8124 75.229277 65.242C 48.104077 69.9303 31.437377 72.7948 21.745577 72.035C 13.703477 71.4046 10.381077 66.9868 10.036877 61.629C 9.471377 52.8286 15.502477 48.4288 21.745577 47.0136C 29.357977 45.288 48.711877 43.546 69.909777 39.6509Z"></path></g></g></g><g id="g-root-6.cu_1_sy_v993in1brw7ic-stroke" data-item-order="-55744" transform="translate(257.9600524902344, 384.5218505859375)"><g id="6.cu_1_sy_v993in1brw7ic-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.3408 13.5695 117.3519 16.811C 120.3393 18.2371 124.8131 20.893 124.6859 26.0148C 124.5376 31.9893 114.6599 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771ZM 117.3519 16.811L 117.5995 16.9255"></path></g></g></g><g id="g-root-5.cu_sy_mdm39r1brw8b1-stroke" data-item-order="-55740" transform="translate(255.26434326171875, 333.7701416015625)"><g id="5.cu_sy_mdm39r1brw8b1-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 69.909777 39.6509C 98.397177 34.4164 126.544077 29.7108 127.336877 20.2322C 127.811177 14.562 122.845377 11.6633 118.677377 10C 125.553977 12.281 140.902677 20.2322 140.902677 31.5084C 140.902677 48.3752 123.999377 56.8124 75.229277 65.242C 48.104077 69.9303 31.437377 72.7948 21.745577 72.035C 13.703477 71.4046 10.381077 66.9868 10.036877 61.629C 9.471377 52.8286 15.502477 48.4288 21.745577 47.0136C 29.357977 45.288 48.711877 43.546 69.909777 39.6509Z"></path></g></g></g><g id="g-root-5.cu_1_sy_hxsl5b1brw93a-stroke" data-item-order="-55738" transform="translate(257.9600524902344, 327.4971923828125)"><g id="5.cu_1_sy_hxsl5b1brw93a-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.3408 13.5695 117.3519 16.811C 120.3393 18.2371 124.8131 20.893 124.6859 26.0148C 124.5376 31.9893 114.6599 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771ZM 117.3519 16.811L 117.5995 16.9255"></path></g></g></g><g id="g-root-4.cu_sy_92s1zj1brw6q7-stroke" data-item-order="-55734" transform="translate(255.26434326171875, 276.7462158203125)"><g id="4.cu_sy_92s1zj1brw6q7-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 69.909777 39.6509C 98.397177 34.4164 126.544077 29.7108 127.336877 20.2322C 127.811177 14.562 122.845377 11.6633 118.677377 10C 125.553977 12.281 140.902677 20.2322 140.902677 31.5084C 140.902677 48.3752 123.999377 56.8124 75.229277 65.242C 48.104077 69.9303 31.437377 72.7948 21.745577 72.035C 13.703477 71.4046 10.381077 66.9868 10.036877 61.629C 9.471377 52.8286 15.502477 48.4288 21.745577 47.0136C 29.357977 45.288 48.711877 43.546 69.909777 39.6509Z"></path></g></g></g><g id="g-root-4.cu_1_sy_4myjv31brw7ig-stroke" data-item-order="-55732" transform="translate(257.9600524902344, 270.4737548828125)"><g id="4.cu_1_sy_4myjv31brw7ig-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.3408 13.5695 117.3519 16.811C 120.3393 18.2371 124.8131 20.893 124.6859 26.0148C 124.5376 31.9893 114.6599 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771ZM 117.3519 16.811L 117.5995 16.9255"></path></g></g></g><g id="g-root-3.cu_sy_751qn1brw8ap-stroke" data-item-order="-55728" transform="translate(255.26434326171875, 219.720703125)"><g id="3.cu_sy_751qn1brw8ap-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 69.909777 39.6509C 98.397177 34.4164 126.544077 29.7108 127.336877 20.2322C 127.811177 14.562 122.845377 11.6633 118.677377 10C 125.553977 12.281 140.902677 20.2322 140.902677 31.5084C 140.902677 48.3752 123.999377 56.8124 75.229277 65.242C 48.104077 69.9303 31.437377 72.7948 21.745577 72.035C 13.703477 71.4046 10.381077 66.9868 10.036877 61.629C 9.471377 52.8286 15.502477 48.4288 21.745577 47.0136C 29.357977 45.288 48.711877 43.546 69.909777 39.6509Z"></path></g></g></g><g id="g-root-3.cu_1_sy_1qcm3gv1brw8wa-stroke" data-item-order="-55726" transform="translate(257.9600830078125, 213.4482421875)"><g id="3.cu_1_sy_1qcm3gv1brw8wa-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.3408 13.5695 117.3519 16.811C 120.3393 18.2371 124.8131 20.893 124.6859 26.0148C 124.5376 31.9893 114.6599 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771ZM 117.3519 16.811L 117.5995 16.9255"></path></g></g></g><g id="g-root-2.cu_sy_1lxf2fj1brw6ir-stroke" data-item-order="-55722" transform="translate(255.26434326171875, 162.6962890625)"><g id="2.cu_sy_1lxf2fj1brw6ir-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 69.909777 39.6509C 98.397177 34.4164 126.544077 29.7108 127.336877 20.2322C 127.811177 14.562 122.845377 11.6633 118.677377 10C 125.553977 12.281 140.902677 20.2322 140.902677 31.5084C 140.902677 48.3752 123.999377 56.8124 75.229277 65.242C 48.104077 69.9303 31.437377 72.7948 21.745577 72.035C 13.703477 71.4046 10.381077 66.9868 10.036877 61.629C 9.471377 52.8286 15.502477 48.4288 21.745577 47.0136C 29.357977 45.288 48.711877 43.546 69.909777 39.6509Z"></path></g></g></g><g id="g-root-2.cu_1_sy_1d1s26n1brw7bg-stroke" data-item-order="-55720" transform="translate(257.9600830078125, 156.4228515625)"><g id="2.cu_1_sy_1d1s26n1brw7bg-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 38.0076 27.1771C 16.9757 24.0392 10.9029 18.5537 10 17.5313C 11.8743 19.5171 14.7922 20.8771 19.0033 21.2053C 28.7014 21.9611 45.379 19.1113 72.522 14.4469C 81.0593 12.9798 88.6207 11.5124 95.2864 10C 102.5445 12.184 110.3408 13.5695 117.3519 16.811C 120.3393 18.2371 124.8131 20.893 124.6859 26.0148C 124.5376 31.9893 114.6599 35.7537 102.0009 38.9452C 101.6757 38.8312 100.3044 38.2844 99.9973 38.1713C 92.3051 35.2781 65.1564 31.2276 38.0076 27.1771ZM 117.3519 16.811L 117.5995 16.9255"></path></g></g></g><g id="g-root-1.cu_sy_1d1s26n1brw7bh-stroke" data-item-order="-55716" transform="translate(255.26434326171875, 105.671875)"><g id="1.cu_sy_1d1s26n1brw7bh-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 69.909777 39.6509C 98.397177 34.4164 126.544077 29.7108 127.336877 20.2322C 127.811177 14.562 122.845377 11.6633 118.677377 10C 125.553977 12.281 140.902677 20.2322 140.902677 31.5084C 140.902677 48.3752 123.999377 56.8124 75.229277 65.242C 48.104077 69.9303 31.437377 72.7948 21.745577 72.035C 13.703477 71.4046 10.381077 66.9868 10.036877 61.629C 9.471377 52.8286 15.502477 48.4288 21.745577 47.0136C 29.357977 45.288 48.711877 43.546 69.909777 39.6509Z"></path></g></g></g><g id="g-root-1.cu_1_sy_18lyk271brw83q-stroke" data-item-order="-55714" transform="translate(255.30126953125, 87)"><g id="1.cu_1_sy_18lyk271brw83q-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 120.0108 29.210385C 122.9982 30.636385 127.4718 33.292385 127.3446 38.414185C 127.1963 44.388685 117.3187 48.153085 104.6598 51.344585C 104.3346 51.230585 102.9633 50.683785 102.6561 50.570685C 78.8756 41.626185 51.5585 39.244885 26.2368 35.204085C 24.7636 35.763885 21.9403 35.966885 20.221 35.763885C 15.9301 34.666285 10 31.373185 10 22.448585C 10 17.819185 13.6401 10.768285 21.6823 10.137885C 31.374 9.378085 48.067 11.794885 75.1922 16.483285C 90.003 19.043185 106.1882 22.819685 120.0108 29.210385ZM 120.0108 29.210385L 120.2583 29.324785"></path></g></g></g><g id="g-root-1.Ellipse_sy_zqbjtb1brw8wf-stroke" data-item-order="-55712" transform="translate(255.2646484375, 87.178955078125)"><g id="1.Ellipse_sy_zqbjtb1brw8wf-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ffffff" stroke-width="2"><g><path d="M 10 22.846066C 9.998156 29.94019 15.498816 35.692136 22.284863 35.692136C 29.070909 35.692136 34.57157 29.94019 34.569726 22.846066C 34.57157 15.751942 29.070909 9.999996 22.284863 9.999996C 15.498816 9.999996 9.998156 15.751942 10 22.846066"></path></g></g></g><g id="g-root-tx_loaddata_1d310cv1brw9ho-stroke" data-item-order="0" transform="translate(471.2643127441406, 231)"></g><g id="g-root-2_1upa32n1c1vrwl-stroke" data-item-order="0" transform="translate(423.2643127441406, 225)"><g id="2_1upa32n1c1vrwl-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#92bd39" stroke-width="2"><g><path d="M 17.125 25.750151C 20.438709 25.750151 23.125 24.675671 23.125 23.35018C 23.125 22.024704 20.438709 20.95018 17.125 20.95018C 13.81129 20.95018 11.125 22.024704 11.125 23.35018C 11.125 24.675671 13.81129 25.750151 17.125 25.750151ZM 11.125 23.349955L 11.125 32.950001C 11.125 34.300003 13.825 35.349998 17.125 35.349998C 20.424999 35.349998 23.125 34.300003 23.125 32.950001L 23.125 23.349955M 40.9021 15.05995C 43.022949 15.05995 44.7421 14.128705 44.7421 12.979959C 44.7421 11.8312 43.022949 10.899952 40.9021 10.899952C 38.781399 10.899952 37.062103 11.8312 37.062103 12.979959C 37.062103 14.128705 38.781399 15.05995 40.9021 15.05995ZM 37.062103 12.980035L 37.062103 18.420025C 37.062103 19.54003 38.822201 20.500031 40.9021 20.500031C 42.982151 20.500031 44.7421 19.54003 44.7421 18.420025L 44.7421 12.980035M 40.9021 27.520151C 43.022949 27.520151 44.7421 26.5888 44.7421 25.4401C 44.7421 24.291355 43.022949 23.360111 40.9021 23.360111C 38.781399 23.360111 37.062103 24.291355 37.062103 25.4401C 37.062103 26.5888 38.781399 27.520151 40.9021 27.520151ZM 37.062103 25.44025L 37.062103 30.88015C 37.062103 32.000198 38.822201 32.960201 40.9021 32.960201C 42.982151 32.960201 44.7421 32.000198 44.7421 30.88015L 44.7421 25.44025M 40.9021 39.65995C 43.022949 39.65995 44.7421 38.728752 44.7421 37.579903C 44.7421 36.431198 43.022949 35.5 40.9021 35.5C 38.781399 35.5 37.062103 36.431198 37.062103 37.579903C 37.062103 38.728752 38.781399 39.65995 40.9021 39.65995ZM 37.062103 37.580048L 37.062103 43.0201C 37.062103 44.139999 38.822201 45.099998 40.9021 45.099998C 42.982151 45.099998 44.7421 44.139999 44.7421 43.0201L 44.7421 37.580048M 33.4687 15.55L 30.4687 15.55L 30.4687 40.449997L 33.4687 40.449997M 33.4687 28L 26.7187 28M 11.125 28.19665C 11.125 29.465351 13.719595 30.503201 17.125031 30.503201C 20.530449 30.503201 23.125044 29.465351 23.125044 28.19665"></path></g></g></g><g id="g-root-tx_installd_18ntzbj1brw745-stroke" data-item-order="0" transform="translate(471.2643127441406, 171)"></g><g id="g-root-4_hvw0sv1c1dj40-stroke" data-item-order="0" transform="translate(423.2643127441406, 285)"><g id="4_hvw0sv1c1dj40-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#1eabda" stroke-width="2"><g><path d="M 25.375 26.7505L 31.393 26.7505L 31.243 31.75L 37.093002 26.7505L 43.243 26.7505C 43.77486 26.752495 44.285595 26.542509 44.662243 26.166988C 45.038887 25.79147 45.250404 25.281361 45.25 24.7495L 45.25 12.7495C 45.25 11.645206 44.354794 10.75 43.2505 10.75L 25.2505 10.75C 24.145622 10.749171 23.2495 11.644621 23.2495 12.7495L 23.2495 20.5M 31 22.75L 34.75 14.5L 38.5 22.75M 31.830999 20.921501L 37.668999 20.921501M 27.25 43.75C 27.25 44.578426 26.578428 45.25 25.75 45.25L 12.25 45.25C 11.421573 45.25 10.75 44.578426 10.75 43.75L 10.75 38.5C 10.75 33.943653 14.443651 30.250002 19 30.250002C 23.556349 30.250002 27.25 33.943653 27.25 38.5ZM 10.75 40.75L 27.25 40.75M 15.25 36.625C 15.25 36.832108 15.417893 37 15.625 37C 15.832107 37 16 36.832108 16 36.625C 16 36.417892 15.832107 36.25 15.625 36.25C 15.417893 36.25 15.25 36.417892 15.25 36.625M 22 36.625C 22 36.832108 22.167892 37 22.375 37C 22.582108 37 22.75 36.832108 22.75 36.625C 22.75 36.417892 22.582108 36.25 22.375 36.25C 22.167892 36.25 22 36.417892 22 36.625M 19 30.25L 19 27.25M 16.75 25C 16.75 26.242641 17.75736 27.25 19 27.25C 20.242641 27.25 21.25 26.242641 21.25 25C 21.25 23.75736 20.242641 22.75 19 22.75C 17.75736 22.75 16.75 23.75736 16.75 25"></path></g></g></g><g id="g-root-tx_pretrain_1qehiq71brw7wr-stroke" data-item-order="0" transform="translate(471.2643127441406, 279)"></g><g id="g-root-pyth_93dh5b1c1rk75-stroke" data-item-order="0" transform="translate(423.2643127441406, 165)"><g id="pyth_93dh5b1c1rk75-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#3cc583" stroke-width="2"><g><path d="M 19.75 20.5L 27.132999 20.5M 28.867001 35.5L 36.25 35.5M 30.25 40.75C 30.25 41.164215 30.585787 41.5 31 41.5C 31.414213 41.5 31.75 41.164215 31.75 40.75C 31.75 40.335785 31.414213 40 31 40C 30.585787 40 30.25 40.335785 30.25 40.75M 24.25 15.25C 24.25 15.664213 24.585787 16 25 16C 25.414213 16 25.75 15.664213 25.75 15.25C 25.75 14.835787 25.414213 14.5 25 14.5C 24.585787 14.5 24.25 14.835787 24.25 15.25M 44.152 21.549999C 43.955299 20.924536 43.375164 20.499306 42.719498 20.5L 36.25 20.5L 36.25 13.2805C 36.250694 12.624836 35.825462 12.044699 35.199997 11.848C 30.511684 10.383647 25.488316 10.383647 20.800001 11.848C 20.174536 12.044699 19.749306 12.624836 19.75 13.2805L 19.75 20.5L 13.2805 20.5C 12.624836 20.499306 12.044699 20.924536 11.848 21.549999C 10.382592 25.725149 10.382592 30.274849 11.848 34.449997C 12.044699 35.075462 12.624836 35.500694 13.2805 35.5L 19.75 35.5L 19.75 42.719498C 19.749306 43.375164 20.174536 43.955299 20.799999 44.152C 25.488316 45.616356 30.511684 45.616356 35.200001 44.152C 35.825462 43.955299 36.250694 43.375164 36.25 42.719498L 36.25 35.5L 42.719498 35.5C 43.375164 35.500694 43.955299 35.075462 44.152 34.449997C 45.617409 30.274849 45.617409 25.725149 44.152 21.549999ZM 19.75 35.5L 19.75 34C 19.75 30.686291 22.436291 28 25.75 28L 30.25 28C 33.563709 28 36.25 25.313709 36.25 22L 36.25 20.5"></path></g></g></g><g id="g-root-tx_choosegp_zs6z2n1brw7wu-stroke" data-item-order="0" transform="translate(471.2643127441406, 111)"></g><g id="g-root-shar_qs5btb1c1syyp-stroke" data-item-order="0" transform="translate(423.2643127441406, 345)"><g id="shar_qs5btb1c1syyp-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#de58a9" stroke-width="2"><g><path d="M 30.6835 10.75L 43.717003 10.75C 43.717003 10.75 45.25 10.75 45.25 12.283L 45.25 24.549999C 45.25 24.549999 45.25 26.083 43.717003 26.083L 30.6835 26.083C 30.6835 26.083 29.150501 26.083 29.150501 24.549999L 29.150501 12.283C 29.150501 12.283 29.150501 10.75 30.6835 10.75M 29.150501 15.9715L 45.25 15.9715M 29.150501 21.028L 45.25 21.028M 36.431499 15.9715L 36.431499 26.083M 40.748501 15.9715L 40.748501 26.083M 17.65 20.200001L 14.2 23.5L 14.2 20.200001C 14.249214 17.708704 16.309225 15.729294 18.800501 15.7795L 24.549999 15.7795M 10.75 20.200001L 14.2 23.5075M 21.1 12.4675L 24.549999 15.7795L 21.1 19.091499M 12.283 27.616001L 20.717501 27.616001C 20.717501 27.616001 22.2505 27.616001 22.2505 29.149002L 22.2505 43.717003C 22.2505 43.717003 22.2505 45.25 20.717501 45.25L 12.283 45.25C 12.283 45.25 10.75 45.25 10.75 43.717003L 10.75 29.149002C 10.75 29.149002 10.75 27.616001 12.283 27.616001M 10.75 40.649502L 22.2505 40.649502"></path></g></g></g><g id="g-root-tx_grpoopti_90gzz1brw7b6-stroke" data-item-order="0" transform="translate(471.2643127441406, 351.0001220703125)"></g><g id="g-root-fire_1qcl4pb1c1ey2s-stroke" data-item-order="0" transform="translate(423.2643127441406, 105)"><g id="fire_1qcl4pb1c1ey2s-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#4e88e7" stroke-width="2"><g><path d="M 33.25 28.75L 33.25 39.25C 33.25 40.078426 32.578426 40.75 31.75 40.75L 16.75 40.75C 15.921573 40.75 15.25 40.078426 15.25 39.25L 15.25 24.25C 15.25 23.421572 15.921573 22.75 16.75 22.75L 30.25 22.75M 24.25 40.75L 24.25 45.25M 30.25 40.75L 30.25 45.25M 24.25 18.25L 24.25 22.75M 18.25 40.75L 18.25 45.25M 18.25 18.25L 18.25 22.75M 33.25 37.75L 37.75 37.75M 15.25 31.75L 10.75 31.75M 37.75 31.75L 33.25 31.75M 15.25 25.75L 10.75 25.75M 15.25 37.75L 10.75 37.75M 18.25 25.75L 30.25 25.75L 30.25 37.75L 18.25 37.75ZM 37 10.75C 39.238403 12.564066 39.8685 15.714554 38.5 18.25C 37.715652 17.734364 37.174301 16.922337 37 16C 34.743034 16.750631 33.228069 18.871586 33.25 21.25C 33.25 24.563709 35.936291 27.25 39.25 27.25C 42.563709 27.25 45.25 24.563709 45.25 21.25C 45.199181 16.284149 41.812843 11.97426 37 10.75Z"></path></g></g></g><g id="g-root-tx_pushmode_vb4irz1brw6iw-stroke" data-item-order="0" transform="translate(471.2643127441406, 471.0001220703125)"></g><g id="g-root-scri_1uqiuxb1c1eznn-stroke" data-item-order="0" transform="translate(423.2643127441406, 405.0001220703125)"><g id="scri_1uqiuxb1c1eznn-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#ba5de5" stroke-width="2"><g><path d="M 12.25 10.75L 43.75 10.75C 43.75 10.75 45.25 10.75 45.25 12.25L 45.25 43.75C 45.25 43.75 45.25 45.25 43.75 45.25L 12.25 45.25C 12.25 45.25 10.75 45.25 10.75 43.75L 10.75 12.25C 10.75 12.25 10.75 10.75 12.25 10.75M 33.25 37C 33.25 39.071068 34.928932 40.75 37 40.75C 39.071068 40.75 40.75 39.071068 40.75 37C 40.75 34.93 39.25 34 37 33.25C 34.75 32.5 33.25 31.57 33.25 29.5C 33.25 27.428932 34.928932 25.75 37 25.75C 39.071068 25.75 40.75 27.428932 40.75 29.5M 20.5 25.75L 29.5 25.75M 25 25.75L 25 40.75"></path></g></g></g><g id="g-root-tx_textgene_djuia71brw8w1-stroke" data-item-order="0" transform="translate(471.2643127441406, 411.0001220703125)"></g><g id="g-root-feat_hriivj1c1apzc-stroke" data-item-order="0" transform="translate(423.2643127441406, 465.0001220703125)"><g id="feat_hriivj1c1apzc-stroke" fill="none" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="4" stroke="#de8431" stroke-width="2"><g><path d="M 10.75 23.5L 45.25 23.5L 45.25 32.5L 10.75 32.5ZM 23.5 10.75L 32.5 10.75L 32.5 19.75L 23.5 19.75ZM 23.5 36.25L 32.5 36.25L 32.5 45.25L 23.5 45.25Z"></path></g></g></g><g id="g-root-tx_finetuni_vcdgy71brw8p3-stroke" data-item-order="0" transform="translate(333.2642822265625, 27)"></g></g></g></svg>)\n",
19
+ "\n",
20
+ "\n",
21
+ "<small>*Repository: [elswa-dev/notebook-courses](https://huggingface.co/elswa-dev/notebook-courses)*</small>"
22
+ ],
23
+ "metadata": {
24
+ "id": "pZ3PeFCfiE0R"
25
+ }
26
+ },
27
+ {
28
+ "cell_type": "markdown",
29
+ "source": [
30
+ "# **For this course you should already understand basic concepts in large language models, so here's a quick recap in very simple terms.**\n",
31
+ "\n",
32
+ "\n",
33
+ "**What is LLM Training (from scratch)?**\n",
34
+ "\n",
35
+ "\n",
36
+ "\n",
37
+ "Imagine you have a big, empty coloring book. Training an LLM from scratch is like filling in that entire book with colors—starting with a completely blank page. The model begins with no idea of language; it must learn everything by looking at a vast amount of text and figuring out the patterns, grammar, and meaning on its own. This process needs a lot of time, huge amounts of data, and significant computational power, much like teaching a child language from zero.\n",
38
+ "\n",
39
+ "**What is LLM Fine-Tuning?**\n",
40
+ "\n",
41
+ "\n",
42
+ "\n",
43
+ "Now imagine that you already have a coloring book where most of the pictures are nicely colored in, but you want to change a few specific images to better suit your taste. Fine-tuning is like that: you take a pre-trained model (one that already has a good grasp of language) and give it extra, focused lessons to improve its performance on a specific task or style. Instead of starting all over again, you’re just tweaking and refining what the model already knows.\n",
44
+ "\n",
45
+ "**The Key Difference**\n",
46
+ "\n",
47
+ "\n",
48
+ "The big difference is where you start. Training from scratch means beginning with nothing and building up all the knowledge from the ground up, while fine-tuning starts with an already knowledgeable model and customizes it for a particular purpose for example reasoning."
49
+ ],
50
+ "metadata": {
51
+ "id": "jE2wyM7eKaB3"
52
+ }
53
+ },
54
+ {
55
+ "cell_type": "markdown",
56
+ "source": [
57
+ "#Prerequisites\n",
58
+ "\n",
59
+ "**Before you begin, please ensure the following:**\n",
60
+ "\n",
61
+ "Hugging Face Account:\n",
62
+ "Create an account at [Hugging Face](https://colab.research.google.com/drive/16wuZjYRKrwd0l9J6zAGN62sHq2vfmKqZ#scrollTo=BOUVMas8C_ep&line=1&uniqifier=1) if you haven’t already.\n",
63
+ "\n",
64
+ "Once signed in, go to your account settings and generate a personal access token. This token is useful when you need to download models or datasets that require authentication.\n",
65
+ "\n",
66
+ "\n",
67
+ "Weights & Biases (W&B) Account:\n",
68
+ "Sign up at [Weights & Biases](https://wandb.ai/register). After registration, head over to your profile or account settings to obtain your personal API token. This token allows you to log your experiments and track training metrics through W&B."
69
+ ],
70
+ "metadata": {
71
+ "id": "BOUVMas8C_ep"
72
+ }
73
+ },
74
+ {
75
+ "cell_type": "markdown",
76
+ "metadata": {
77
+ "id": "dd4GYb6a0geP"
78
+ },
79
+ "source": [
80
+ "# Fine-tune LLMs with GRPO for e.g. reasoning\n",
81
+ "\n",
82
+ "how to finetune an LLM with GRPO, using the `trl` library.\n",
83
+ "\n",
84
+ "1. **Introduction**\n",
85
+ "* Imagine you want to teach a language model to write or answer questions better. We do that by starting with a “pre-trained” language model (kind of like a well-read student) and then fine tuning it so it becomes even smarter on a specific topic or style. In this course, we will use a method called GRPO (Group Relative Policy Optimization) that trains the model by comparing groups of its answers and rewarding the best ones, much like giving praise to the best drawings in a classroom.\n",
86
+ "\n",
87
+ "2. **Setting Up Your Google Colab Notebook**\n",
88
+ "\n",
89
+ "* Change the runtime to use a GPU for faster training (from the menu, click Runtime > Change runtime type and select GPU).\n",
90
+ "\n",
91
+ "\n",
92
+ "**Why This Is Important:**\n",
93
+ "\n",
94
+ "The notebook is like your digital notebook where you write instructions (code) and explanations. Using a GPU is similar to having a super fast computer helper for heavy tasks.\n",
95
+ "\n",
96
+ "3. **Install the Necessary Dependencies**\n",
97
+ "\n",
98
+ "* In the first code cell, install all the libraries needed to run the training. For our example, we need tools that help manage data, work with language models, efficiently fine tune with reinforcement learning, and even track our progress with charts.\n",
99
+ "\n",
100
+ "\n",
101
+ "Here’s a simple version of the installation cell:"
102
+ ]
103
+ },
104
+ {
105
+ "cell_type": "code",
106
+ "execution_count": null,
107
+ "metadata": {
108
+ "id": "l3IstgzN63QW"
109
+ },
110
+ "outputs": [],
111
+ "source": [
112
+ "!pip install -qqq datasets==3.2.0 transformers==4.47.1 trl==0.14.0 peft==0.14.0 accelerate==1.2.1 bitsandbytes==0.45.2 wandb==0.19.7 --progress-bar off\n",
113
+ "!pip install -qqq flash-attn --no-build-isolation --progress-bar off"
114
+ ]
115
+ },
116
+ {
117
+ "cell_type": "markdown",
118
+ "source": [
119
+ "— when installing dependencies you might see a message like:\n",
120
+ "\n",
121
+ "> ERROR: pip's dependency resolver does not currently take into account all the packages that are installed.\n",
122
+ "\n",
123
+ "You can safely ignore it— the training and fine tuning will still work as expected.\n",
124
+ "\n",
125
+ "\n",
126
+ "**Why This Is Important:**\n",
127
+ "Each package is like a tool in our toolbox:\n",
128
+ "\n",
129
+ "* *datasets and transformers* help us work with text data and language models.\n",
130
+ "* *trl* (for reinforcement learning) and *peft* (for efficient training) help us customize the training process.\n",
131
+ "* *wandb* tracks what happens during training, so we can see progress and fix issues if needed."
132
+ ],
133
+ "metadata": {
134
+ "id": "vf4qs2LWnnQD"
135
+ }
136
+ },
137
+ {
138
+ "cell_type": "markdown",
139
+ "metadata": {
140
+ "id": "Q9MjbDWR0geT"
141
+ },
142
+ "source": [
143
+ "## Load Dataset"
144
+ ]
145
+ },
146
+ {
147
+ "cell_type": "markdown",
148
+ "source": [
149
+ "**What You Do:**\n",
150
+ "\n",
151
+ "Load a collection of examples (our dataset) from Hugging Face. In our case, the dataset has paired “prompts” (questions or instructions) and “completions” (answers or responses).\n",
152
+ "\n",
153
+ "Example code:"
154
+ ],
155
+ "metadata": {
156
+ "id": "7FPu2cpACZr-"
157
+ }
158
+ },
159
+ {
160
+ "cell_type": "code",
161
+ "execution_count": null,
162
+ "metadata": {
163
+ "collapsed": true,
164
+ "id": "5Y-X13wB7UP4"
165
+ },
166
+ "outputs": [],
167
+ "source": [
168
+ "import torch\n",
169
+ "import wandb\n",
170
+ "from datasets import load_dataset\n",
171
+ "from peft import LoraConfig, get_peft_model\n",
172
+ "from transformers import AutoModelForCausalLM, AutoTokenizer\n",
173
+ "from trl import GRPOConfig, GRPOTrainer\n",
174
+ "\n",
175
+ "# Log to Weights & Biases\n",
176
+ "wandb.login()\n",
177
+ "\n",
178
+ "# Load dataset\n",
179
+ "dataset = load_dataset(\"mlabonne/smoltldr\")\n",
180
+ "print(dataset)"
181
+ ]
182
+ },
183
+ {
184
+ "cell_type": "markdown",
185
+ "source": [
186
+ "**Why This Is Important:**\n",
187
+ "Think of the dataset like a set of flash cards. The model learns from these examples so that when it gets a new question, it knows what kinds of answers look good."
188
+ ],
189
+ "metadata": {
190
+ "id": "y4HqxagjqkI6"
191
+ }
192
+ },
193
+ {
194
+ "cell_type": "markdown",
195
+ "metadata": {
196
+ "id": "Y1tlrHXB0geU"
197
+ },
198
+ "source": [
199
+ "## Load Model"
200
+ ]
201
+ },
202
+ {
203
+ "cell_type": "markdown",
204
+ "source": [
205
+ "**What to do:**\n",
206
+ "\n",
207
+ "Load a pre-trained language model and its tokenizer. The tokenizer helps convert words into numbers that the model understands. We then add a special “LoRA” module to make the fine tuning process lighter and faster.\n",
208
+ "\n",
209
+ "Example code:"
210
+ ],
211
+ "metadata": {
212
+ "id": "69fISWv99oBX"
213
+ }
214
+ },
215
+ {
216
+ "cell_type": "code",
217
+ "execution_count": null,
218
+ "metadata": {
219
+ "id": "3tLRvi5i-Qls"
220
+ },
221
+ "outputs": [],
222
+ "source": [
223
+ "# Load model\n",
224
+ "model_id = \"HuggingFaceTB/SmolLM-135M-Instruct\"\n",
225
+ "model = AutoModelForCausalLM.from_pretrained(\n",
226
+ " model_id,\n",
227
+ " torch_dtype=\"auto\",\n",
228
+ " device_map=\"auto\",\n",
229
+ " attn_implementation=\"flash_attention_2\",\n",
230
+ ")\n",
231
+ "tokenizer = AutoTokenizer.from_pretrained(model_id)\n",
232
+ "\n",
233
+ "# Load LoRA\n",
234
+ "lora_config = LoraConfig(\n",
235
+ " task_type=\"CAUSAL_LM\",\n",
236
+ " r=16,\n",
237
+ " lora_alpha=32,\n",
238
+ " target_modules=\"all-linear\",\n",
239
+ ")\n",
240
+ "model = get_peft_model(model, lora_config)\n",
241
+ "print(model.print_trainable_parameters())"
242
+ ]
243
+ },
244
+ {
245
+ "cell_type": "markdown",
246
+ "source": [
247
+ "**Why This Is Important:**\n",
248
+ "\n",
249
+ "This step loads an already good “student” (the model) and prepares it to learn a little more without re-learning everything from scratch. The LoRA module acts like a shortcut to quickly tune only the important parts."
250
+ ],
251
+ "metadata": {
252
+ "id": "6spl1KEOq3GI"
253
+ }
254
+ },
255
+ {
256
+ "cell_type": "markdown",
257
+ "metadata": {
258
+ "id": "3P4Ww0-f0geV"
259
+ },
260
+ "source": [
261
+ "## Define Reward Function\n",
262
+ "\n",
263
+ "**What to do:**\n",
264
+ "\n",
265
+ "Set up a reward function. In reinforcement learning, the computer is given a score (reward) based on how good its answer is. For simplicity, we use a function that rewards answers that are about 50 characters long."
266
+ ]
267
+ },
268
+ {
269
+ "cell_type": "code",
270
+ "execution_count": null,
271
+ "metadata": {
272
+ "id": "745L0RC6-XBT"
273
+ },
274
+ "outputs": [],
275
+ "source": [
276
+ "# Reward function\n",
277
+ "def reward_len(completions, **kwargs):\n",
278
+ " return [-abs(50 - len(completion)) for completion in completions]"
279
+ ]
280
+ },
281
+ {
282
+ "cell_type": "markdown",
283
+ "source": [
284
+ "**Why This Is Important:**\n",
285
+ "\n",
286
+ "Imagine you’re playing a game where you get points based on how close you are to a target number. This function acts as the “score keeper” that tells the model whether it did well or needs more practice."
287
+ ],
288
+ "metadata": {
289
+ "id": "Kv3O4TrBrX7i"
290
+ }
291
+ },
292
+ {
293
+ "cell_type": "markdown",
294
+ "metadata": {
295
+ "id": "jFggiY3M0geX"
296
+ },
297
+ "source": [
298
+ "## Define Training Arguments\n",
299
+ "\n",
300
+ "**What You Do:**\n",
301
+ "\n",
302
+ "Set the parameters for training the model. This includes where to save your progress, how many examples to process at once, and how many times to go through the dataset.\n",
303
+ "Here’s a plain-English explanation of some key points:\n",
304
+ "1. output_dir: Where the computer saves its work (checkpoints).\n",
305
+ "2. learning_rate: How quickly the model adjusts its thinking. A small number means the model learns slowly and carefully.\n",
306
+ "3. per_device_train_batch_size: How many examples the model sees at once before making adjustments.\n",
307
+ "4. gradient_accumulation_steps: How many steps to combine so the model takes a smarter update (like saving multiple drafts before finalizing).\n",
308
+ "5. num_train_epochs: How many times the model goes through the entire set of examples.\n"
309
+ ]
310
+ },
311
+ {
312
+ "cell_type": "markdown",
313
+ "source": [
314
+ "## Fine Tune the Model with GRPOTrainer\n",
315
+ "\n",
316
+ "**What You Do:**\n",
317
+ "\n",
318
+ "Combine everything using a GRPO trainer. GRPO (Group Relative Policy Optimization) fine tunes the model by comparing groups of different answers and rewarding the best ones. We also use Weights & Biases (wandb) to track the training progress.\n",
319
+ "\n",
320
+ "A simplified version of the training cell might look like this:"
321
+ ],
322
+ "metadata": {
323
+ "id": "mQMYQSV5unk_"
324
+ }
325
+ },
326
+ {
327
+ "cell_type": "code",
328
+ "execution_count": null,
329
+ "metadata": {
330
+ "id": "NtiMrN480geX"
331
+ },
332
+ "outputs": [],
333
+ "source": [
334
+ "# Training arguments\n",
335
+ "training_args = GRPOConfig(\n",
336
+ " output_dir=\"GRPO\",\n",
337
+ " learning_rate=2e-5,\n",
338
+ " per_device_train_batch_size=8,\n",
339
+ " gradient_accumulation_steps=2,\n",
340
+ " max_prompt_length=512,\n",
341
+ " max_completion_length=96,\n",
342
+ " num_generations=8,\n",
343
+ " optim=\"adamw_8bit\",\n",
344
+ " num_train_epochs=1,\n",
345
+ " bf16=True,\n",
346
+ " report_to=[\"wandb\"],\n",
347
+ " remove_unused_columns=False,\n",
348
+ " logging_steps=1,\n",
349
+ ")\n",
350
+ "\n",
351
+ "# Trainer\n",
352
+ "trainer = GRPOTrainer(\n",
353
+ " model=model,\n",
354
+ " reward_funcs=[reward_len],\n",
355
+ " args=training_args,\n",
356
+ " train_dataset=dataset[\"train\"],\n",
357
+ ")\n",
358
+ "\n",
359
+ "# Train model\n",
360
+ "wandb.init(project=\"GRPO\")\n",
361
+ "trainer.train()"
362
+ ]
363
+ },
364
+ {
365
+ "cell_type": "markdown",
366
+ "source": [
367
+ "**Why This Is Important:**\n",
368
+ "\n",
369
+ "These configurations are like setting the rules and pace for studying. They ensure the model learns steadily without overwhelming the computer.\n",
370
+ "\n",
371
+ "The trainer goes over each example, checks the group of generated answers, and uses the reward function to figure out which answers are best. With every step, the model “learns” from its mistakes—much like practicing math problems and improving over time"
372
+ ],
373
+ "metadata": {
374
+ "id": "ILhtAr8-sL67"
375
+ }
376
+ },
377
+ {
378
+ "cell_type": "markdown",
379
+ "metadata": {
380
+ "id": "JUqHI2Ah0geX"
381
+ },
382
+ "source": [
383
+ "## Wrap-Up & Push Model to Hub\n",
384
+ "\n",
385
+ "After training, you can save your fine tuned model so that later you (or your colleagues) can use it to generate better answers. A code cell for saving might look like this: Where you need to give your fine-tuned model an name or enhance the existing as i did with ...*reason-we*"
386
+ ]
387
+ },
388
+ {
389
+ "cell_type": "code",
390
+ "execution_count": null,
391
+ "metadata": {
392
+ "id": "oKHhpA4z-sRF"
393
+ },
394
+ "outputs": [],
395
+ "source": [
396
+ "# Save model\n",
397
+ "merged_model = trainer.model.merge_and_unload()\n",
398
+ "merged_model.push_to_hub(\"HuggingFaceTB/SmolLM-135M-Instruct-reason-we\", private=False)"
399
+ ]
400
+ },
401
+ {
402
+ "cell_type": "markdown",
403
+ "source": [
404
+ "**Why This Is Important:**\n",
405
+ "\n",
406
+ "Saving the model is like keeping your best project in a folder—you can share it, build upon it, and use it to answer real-world questions."
407
+ ],
408
+ "metadata": {
409
+ "id": "KzVobAX0tNsw"
410
+ }
411
+ },
412
+ {
413
+ "cell_type": "markdown",
414
+ "metadata": {
415
+ "id": "oJcrL4z60geY"
416
+ },
417
+ "source": [
418
+ "## Generate Text\n",
419
+ "\n",
420
+ "In the final section, you use your newly fine tuned language model to produce written responses from text prompts. Once the model has learned during training, this section shows you how to \"ask\" the model for a response and then translate the model’s internal numerical output back into readable text. In simple terms, it’s the part where you put your model to the test by giving it a sentence or question and letting it complete or respond.\n",
421
+ "\n",
422
+ "**How It Works**\n",
423
+ "\n",
424
+ "Imagine your model is like a child who has just finished learning from lots of flash cards. Now, you give the child a prompt—like “Tell me a story about a brave knight”—and ask them to make up a story. The Generate Text section is where you let the model “speak” by running its built-in text-generation function. The steps typically include:\n",
425
+ "\n",
426
+ "* Preparing the Prompt: You write a prompt (the question or sentence you want the model to complete).\n",
427
+ "* Tokenizing the Prompt: The model doesn’t understand plain text; it turns your words into numbers using a process called tokenization.\n",
428
+ "\n",
429
+ "* Generating Output: The model then uses its learned knowledge to predict what token (number) comes next repeatedly until it creates a complete response.\n",
430
+ "* Decoding the Output: Finally, the sequence of numbers is converted back into human-readable text.\n",
431
+ "\n",
432
+ "\n",
433
+ "What the Code Looks Like\n",
434
+ "An example code snippet in a Google Colab notebook for the Generate Text section might be:"
435
+ ]
436
+ },
437
+ {
438
+ "cell_type": "code",
439
+ "execution_count": null,
440
+ "metadata": {
441
+ "id": "RsLvPu1z0geY"
442
+ },
443
+ "outputs": [],
444
+ "source": [
445
+ "prompt = \"\"\"\n",
446
+ "# A long document about the Cat\n",
447
+ "\n",
448
+ "The cat (Felis catus), also referred to as the domestic cat or house cat, is a small\n",
449
+ "domesticated carnivorous mammal. It is the only domesticated species of the family Felidae.\n",
450
+ "Advances in archaeology and genetics have shown that the domestication of the cat occurred\n",
451
+ "in the Near East around 7500 BC. It is commonly kept as a pet and farm cat, but also ranges\n",
452
+ "freely as a feral cat avoiding human contact. It is valued by humans for companionship and\n",
453
+ "its ability to kill vermin. Its retractable claws are adapted to killing small prey species\n",
454
+ "such as mice and rats. It has a strong, flexible body, quick reflexes, and sharp teeth,\n",
455
+ "and its night vision and sense of smell are well developed. It is a social species,\n",
456
+ "but a solitary hunter and a crepuscular predator. Cat communication includes\n",
457
+ "vocalizations—including meowing, purring, trilling, hissing, growling, and grunting—as\n",
458
+ "well as body language. It can hear sounds too faint or too high in frequency for human ears,\n",
459
+ "such as those made by small mammals. It secretes and perceives pheromones.\n",
460
+ "\"\"\"\n",
461
+ "\n",
462
+ "messages = [\n",
463
+ " {\"role\": \"user\", \"content\": prompt},\n",
464
+ "]"
465
+ ]
466
+ },
467
+ {
468
+ "cell_type": "code",
469
+ "execution_count": null,
470
+ "metadata": {
471
+ "id": "6jbz8DYd-o7A"
472
+ },
473
+ "outputs": [],
474
+ "source": [
475
+ "# Generate text\n",
476
+ "from transformers import pipeline\n",
477
+ "\n",
478
+ "generator = pipeline(\"text-generation\", model=\"<your-model-id>\")\n",
479
+ "\n",
480
+ "## Or use the model and tokenizer we defined earlier\n",
481
+ "# generator = pipeline(\"text-generation\", model=model, tokenizer=tokenizer)\n",
482
+ "\n",
483
+ "generate_kwargs = {\n",
484
+ " \"max_new_tokens\": 256,\n",
485
+ " \"do_sample\": True,\n",
486
+ " \"temperature\": 0.5,\n",
487
+ " \"min_p\": 0.1,\n",
488
+ "}\n",
489
+ "\n",
490
+ "generated_text = generator(messages, generate_kwargs=generate_kwargs)\n",
491
+ "\n",
492
+ "print(generated_text)"
493
+ ]
494
+ },
495
+ {
496
+ "cell_type": "markdown",
497
+ "source": [
498
+ "**Why This Section Is Important**\n",
499
+ "\n",
500
+ "Imagine if after studying, you never got to answer any questions—you wouldn’t know if you understood the information! The Generate Text section is like a pop quiz for your model, showing you in real time if it learned properly during training. It gives you immediate feedback: you can see if the responses are clear, on-topic, or if further adjustments are needed."
501
+ ],
502
+ "metadata": {
503
+ "id": "9b9swdoo-59d"
504
+ }
505
+ },
506
+ {
507
+ "cell_type": "markdown",
508
+ "source": [
509
+ "### Greate! ✨\n",
510
+ "### You have fine-tuned your first model ✅"
511
+ ],
512
+ "metadata": {
513
+ "id": "WfNDbbD_D842"
514
+ }
515
+ }
516
+ ],
517
+ "metadata": {
518
+ "accelerator": "GPU",
519
+ "colab": {
520
+ "gpuType": "A100",
521
+ "machine_shape": "hm",
522
+ "provenance": []
523
+ },
524
+ "kernelspec": {
525
+ "display_name": "Python 3",
526
+ "name": "python3"
527
+ },
528
+ "language_info": {
529
+ "name": "python"
530
+ }
531
+ },
532
+ "nbformat": 4,
533
+ "nbformat_minor": 0
534
+ }