Buckets:

rtrm's picture
download
raw
55.1 kB
import{s as Vl,o as Zl,n as Hl}from"../chunks/scheduler.37c15a92.js";import{S as zl,i as Gl,g as f,s as o,r as T,A as ql,h as y,f as n,c,j as Nl,u as h,x as b,k as dt,y as Bl,a,v as J,t as m,b as R,d as M,w as U,m as Sl,n as Ll,p as W}from"../chunks/index.2bf4358c.js";import{T as Ql}from"../chunks/Tip.363c041f.js";import{Y as Dl}from"../chunks/Youtube.1e50a667.js";import{C as w}from"../chunks/CodeBlock.4e987730.js";import{C as El}from"../chunks/CourseFloatingBanner.6add7356.js";import{F as Rl}from"../chunks/FrameworkSwitchCourse.8d4d4ab6.js";import{H as Ms,E as Wl}from"../chunks/getInferenceSnippets.ebf8be91.js";function Fl(d){let t,r;return t=new El({props:{chapter:2,classNames:"absolute z-10 right-0 top-0",notebooks:[{label:"English",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/en/chapter2/section2_tf.ipynb"},{label:"Français",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/fr/chapter2/section2_tf.ipynb"},{label:"English",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/en/chapter2/section2_tf.ipynb"},{label:"Français",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/fr/chapter2/section2_tf.ipynb"}]}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function Xl(d){let t,r;return t=new El({props:{chapter:2,classNames:"absolute z-10 right-0 top-0",notebooks:[{label:"English",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/en/chapter2/section2_pt.ipynb"},{label:"Français",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/fr/chapter2/section2_pt.ipynb"},{label:"English",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/en/chapter2/section2_pt.ipynb"},{label:"Français",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/fr/chapter2/section2_pt.ipynb"}]}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function Pl(d){let t;return{c(){t=Sl("Il s'agit de la première section dont le contenu est légèrement différent selon que vous utilisez PyTorch ou TensorFlow. Cliquez sur le bouton situé au-dessus du titre pour sélectionner la plateforme que vous préférez !")},l(r){t=Ll(r,"Il s'agit de la première section dont le contenu est légèrement différent selon que vous utilisez PyTorch ou TensorFlow. Cliquez sur le bouton situé au-dessus du titre pour sélectionner la plateforme que vous préférez !")},m(r,s){a(r,t,s)},d(r){r&&n(t)}}}function Yl(d){let t,r;return t=new Dl({props:{id:"wVN12smEvqg"}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function Kl(d){let t,r;return t=new Dl({props:{id:"1pedAIvTWXk"}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function Ol(d){let t,r;return t=new w({props:{code:"cmF3X2lucHV0cyUyMCUzRCUyMCU1QiUwQSUyMCUyMCUyMCUyMCUyMkkndmUlMjBiZWVuJTIwd2FpdGluZyUyMGZvciUyMGElMjBIdWdnaW5nRmFjZSUyMGNvdXJzZSUyMG15JTIwd2hvbGUlMjBsaWZlLiUyMiUyQyUwQSUyMCUyMCUyMCUyMCUyMyUyMEonYWklMjBhdHRlbmR1JTIwdW4lMjBjb3VycyUyMGRlJTIwSHVnZ2luZ0ZhY2UlMjB0b3V0ZSUyMG1hJTIwdmllLiUwQSUyMCUyMCUyMCUyMCUyMkklMjBoYXRlJTIwdGhpcyUyMHNvJTIwbXVjaCElMjIlMkMlMjAlMjAlMjMlMjBKZSUyMGQlQzMlQTl0ZXN0ZSUyMHRlbGxlbWVudCUyMCVDMyVBN2ElMjAhJTBBJTVEJTBBaW5wdXRzJTIwJTNEJTIwdG9rZW5pemVyKHJhd19pbnB1dHMlMkMlMjBwYWRkaW5nJTNEVHJ1ZSUyQyUyMHRydW5jYXRpb24lM0RUcnVlJTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJ0ZiUyMiklMEFwcmludChpbnB1dHMp",highlighted:`raw_inputs = [
<span class="hljs-string">&quot;I&#x27;ve been waiting for a HuggingFace course my whole life.&quot;</span>,
<span class="hljs-comment"># J&#x27;ai attendu un cours de HuggingFace toute ma vie.</span>
<span class="hljs-string">&quot;I hate this so much!&quot;</span>, <span class="hljs-comment"># Je déteste tellement ça !</span>
]
inputs = tokenizer(raw_inputs, padding=<span class="hljs-literal">True</span>, truncation=<span class="hljs-literal">True</span>, return_tensors=<span class="hljs-string">&quot;tf&quot;</span>)
<span class="hljs-built_in">print</span>(inputs)`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function en(d){let t,r;return t=new w({props:{code:"cmF3X2lucHV0cyUyMCUzRCUyMCU1QiUwQSUyMCUyMCUyMCUyMCUyMkkndmUlMjBiZWVuJTIwd2FpdGluZyUyMGZvciUyMGElMjBIdWdnaW5nRmFjZSUyMGNvdXJzZSUyMG15JTIwd2hvbGUlMjBsaWZlLiUyMiUyQyUwQSUyMCUyMCUyMCUyMCUyMyUyMEonYWklMjBhdHRlbmR1JTIwdW4lMjBjb3VycyUyMGRlJTIwSHVnZ2luZ0ZhY2UlMjB0b3V0ZSUyMG1hJTIwdmllLiUwQSUyMCUyMCUyMCUyMCUyMkklMjBoYXRlJTIwdGhpcyUyMHNvJTIwbXVjaCElMjIlMkMlMjAlMjAlMjMlMjBKZSUyMGQlQzMlQTl0ZXN0ZSUyMHRlbGxlbWVudCUyMCVDMyVBN2ElMjAhJTBBJTVEJTBBaW5wdXRzJTIwJTNEJTIwdG9rZW5pemVyKHJhd19pbnB1dHMlMkMlMjBwYWRkaW5nJTNEVHJ1ZSUyQyUyMHRydW5jYXRpb24lM0RUcnVlJTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJwdCUyMiklMEFwcmludChpbnB1dHMp",highlighted:`raw_inputs = [
<span class="hljs-string">&quot;I&#x27;ve been waiting for a HuggingFace course my whole life.&quot;</span>,
<span class="hljs-comment"># J&#x27;ai attendu un cours de HuggingFace toute ma vie.</span>
<span class="hljs-string">&quot;I hate this so much!&quot;</span>, <span class="hljs-comment"># Je déteste tellement ça !</span>
]
inputs = tokenizer(raw_inputs, padding=<span class="hljs-literal">True</span>, truncation=<span class="hljs-literal">True</span>, return_tensors=<span class="hljs-string">&quot;pt&quot;</span>)
<span class="hljs-built_in">print</span>(inputs)`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function sn(d){let t,r="Voici à quoi ressemblent les résultats sous forme de tenseurs TensorFlow :",s,u,p;return u=new w({props:{code:"JTdCJTBBJTIwJTIwJTIwJTIwJ2lucHV0X2lkcyclM0ElMjAlM0N0Zi5UZW5zb3IlM0ElMjBzaGFwZSUzRCgyJTJDJTIwMTYpJTJDJTIwZHR5cGUlM0RpbnQzMiUyQyUyMG51bXB5JTNEJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwYXJyYXkoJTVCJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVCJTIwJTIwMTAxJTJDJTIwJTIwMTA0NSUyQyUyMCUyMDEwMDUlMkMlMjAlMjAyMzEwJTJDJTIwJTIwMjA0MiUyQyUyMCUyMDM0MDMlMkMlMjAlMjAyMDA1JTJDJTIwJTIwMTAzNyUyQyUyMDE3NjYyJTJDJTIwMTIxNzIlMkMlMjAlMjAyNjA3JTJDJTIwJTIwMjAyNiUyQyUyMCUyMDI4NzglMkMlMjAlMjAyMTY2JTJDJTIwJTIwMTAxMiUyQyUyMCUyMCUyMDEwMiU1RCUyQyUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QiUyMCUyMDEwMSUyQyUyMCUyMDEwNDUlMkMlMjAlMjA1MjIzJTJDJTIwJTIwMjAyMyUyQyUyMCUyMDIwNjElMkMlMjAlMjAyMTcyJTJDJTIwJTIwJTIwOTk5JTJDJTIwJTIwJTIwMTAyJTJDJTIwJTIwJTIwJTIwJTIwMCUyQyUyMCUyMCUyMCUyMCUyMDAlMkMlMjAlMjAlMjAlMjAlMjAwJTJDJTIwJTIwJTIwJTIwJTIwMCUyQyUyMCUyMCUyMCUyMCUyMDAlMkMlMjAlMjAlMjAlMjAlMjAwJTJDJTIwJTIwJTIwJTIwJTIwMCUyQyUyMCUyMCUyMCUyMCUyMDAlNUQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUQlMkMlMjBkdHlwZSUzRGludDMyKSUzRSUyQyUyMCUwQSUyMCUyMCUyMCUyMCdhdHRlbnRpb25fbWFzayclM0ElMjAlM0N0Zi5UZW5zb3IlM0ElMjBzaGFwZSUzRCgyJTJDJTIwMTYpJTJDJTIwZHR5cGUlM0RpbnQzMiUyQyUyMG51bXB5JTNEJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwYXJyYXkoJTVCJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVCMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSU1RCUyQyUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QjElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAwJTJDJTIwMCUyQyUyMDAlMkMlMjAwJTJDJTIwMCUyQyUyMDAlMkMlMjAwJTJDJTIwMCUyQyUyMDAlNUQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUQlMkMlMjBkdHlwZSUzRGludDMyKSUzRSUwQSU3RA==",highlighted:`{
<span class="hljs-string">&#x27;input_ids&#x27;</span>: &lt;tf.Tensor: shape=(<span class="hljs-number">2</span>, <span class="hljs-number">16</span>), dtype=int32, numpy=
array([
[ <span class="hljs-number">101</span>, <span class="hljs-number">1045</span>, <span class="hljs-number">1005</span>, <span class="hljs-number">2310</span>, <span class="hljs-number">2042</span>, <span class="hljs-number">3403</span>, <span class="hljs-number">2005</span>, <span class="hljs-number">1037</span>, <span class="hljs-number">17662</span>, <span class="hljs-number">12172</span>, <span class="hljs-number">2607</span>, <span class="hljs-number">2026</span>, <span class="hljs-number">2878</span>, <span class="hljs-number">2166</span>, <span class="hljs-number">1012</span>, <span class="hljs-number">102</span>],
[ <span class="hljs-number">101</span>, <span class="hljs-number">1045</span>, <span class="hljs-number">5223</span>, <span class="hljs-number">2023</span>, <span class="hljs-number">2061</span>, <span class="hljs-number">2172</span>, <span class="hljs-number">999</span>, <span class="hljs-number">102</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>]
], dtype=int32)&gt;,
<span class="hljs-string">&#x27;attention_mask&#x27;</span>: &lt;tf.Tensor: shape=(<span class="hljs-number">2</span>, <span class="hljs-number">16</span>), dtype=int32, numpy=
array([
[<span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>],
[<span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>]
], dtype=int32)&gt;
}`,wrap:!1}}),{c(){t=f("p"),t.textContent=r,s=o(),T(u.$$.fragment)},l(i){t=y(i,"P",{"data-svelte-h":!0}),b(t)!=="svelte-2jqvkp"&&(t.textContent=r),s=c(i),h(u.$$.fragment,i)},m(i,j){a(i,t,j),a(i,s,j),J(u,i,j),p=!0},i(i){p||(M(u.$$.fragment,i),p=!0)},o(i){m(u.$$.fragment,i),p=!1},d(i){i&&(n(t),n(s)),U(u,i)}}}function tn(d){let t,r="Voici à quoi ressemblent les résultats sous forme de tenseurs PyTorch :",s,u,p;return u=new w({props:{code:"JTdCJTBBJTIwJTIwJTIwJTIwJ2lucHV0X2lkcyclM0ElMjB0ZW5zb3IoJTVCJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVCJTIwJTIwMTAxJTJDJTIwJTIwMTA0NSUyQyUyMCUyMDEwMDUlMkMlMjAlMjAyMzEwJTJDJTIwJTIwMjA0MiUyQyUyMCUyMDM0MDMlMkMlMjAlMjAyMDA1JTJDJTIwJTIwMTAzNyUyQyUyMDE3NjYyJTJDJTIwMTIxNzIlMkMlMjAyNjA3JTJDJTIwJTIwMjAyNiUyQyUyMCUyMDI4NzglMkMlMjAlMjAyMTY2JTJDJTIwJTIwMTAxMiUyQyUyMCUyMCUyMDEwMiU1RCUyQyUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QiUyMCUyMDEwMSUyQyUyMCUyMDEwNDUlMkMlMjAlMjA1MjIzJTJDJTIwJTIwMjAyMyUyQyUyMCUyMDIwNjElMkMlMjAlMjAyMTcyJTJDJTIwJTIwJTIwOTk5JTJDJTIwJTIwJTIwMTAyJTJDJTIwJTIwJTIwJTIwJTIwMCUyQyUyMCUyMCUyMCUyMCUyMDAlMkMlMjAlMjAlMjAlMjAlMjAwJTJDJTIwJTIwJTIwJTIwJTIwMCUyQyUyMCUyMCUyMCUyMCUyMDAlMkMlMjAlMjAlMjAlMjAlMjAwJTJDJTIwJTIwJTIwJTIwJTIwMCUyQyUyMCUyMCUyMCUyMCUyMDAlNUQlMEElMjAlMjAlMjAlMjAlNUQpJTJDJTIwJTBBJTIwJTIwJTIwJTIwJ2F0dGVudGlvbl9tYXNrJyUzQSUyMHRlbnNvciglNUIlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUIxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTVEJTJDJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVCMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDAlMkMlMjAwJTJDJTIwMCUyQyUyMDAlMkMlMjAwJTJDJTIwMCUyQyUyMDAlMkMlMjAwJTJDJTIwMCU1RCUwQSUyMCUyMCUyMCUyMCU1RCklMEElN0Q=",highlighted:`{
<span class="hljs-string">&#x27;input_ids&#x27;</span>: tensor([
[ <span class="hljs-number">101</span>, <span class="hljs-number">1045</span>, <span class="hljs-number">1005</span>, <span class="hljs-number">2310</span>, <span class="hljs-number">2042</span>, <span class="hljs-number">3403</span>, <span class="hljs-number">2005</span>, <span class="hljs-number">1037</span>, <span class="hljs-number">17662</span>, <span class="hljs-number">12172</span>, <span class="hljs-number">2607</span>, <span class="hljs-number">2026</span>, <span class="hljs-number">2878</span>, <span class="hljs-number">2166</span>, <span class="hljs-number">1012</span>, <span class="hljs-number">102</span>],
[ <span class="hljs-number">101</span>, <span class="hljs-number">1045</span>, <span class="hljs-number">5223</span>, <span class="hljs-number">2023</span>, <span class="hljs-number">2061</span>, <span class="hljs-number">2172</span>, <span class="hljs-number">999</span>, <span class="hljs-number">102</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>]
]),
<span class="hljs-string">&#x27;attention_mask&#x27;</span>: tensor([
[<span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>],
[<span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">1</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>, <span class="hljs-number">0</span>]
])
}`,wrap:!1}}),{c(){t=f("p"),t.textContent=r,s=o(),T(u.$$.fragment)},l(i){t=y(i,"P",{"data-svelte-h":!0}),b(t)!=="svelte-9kuapd"&&(t.textContent=r),s=c(i),h(u.$$.fragment,i)},m(i,j){a(i,t,j),a(i,s,j),J(u,i,j),p=!0},i(i){p||(M(u.$$.fragment,i),p=!0)},o(i){m(u.$$.fragment,i),p=!1},d(i){i&&(n(t),n(s)),U(u,i)}}}function ln(d){let t,r="Nous pouvons télécharger notre modèle prétraîné de la même manière que nous l’avons fait avec notre <em>tokenizer</em>. 🤗 <em>Transformers</em> fournit une classe <code>TFAutoModel</code> qui possède également une méthode <code>from_pretrained()</code> :",s,u,p;return u=new w({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMFRGQXV0b01vZGVsJTBBJTBBY2hlY2twb2ludCUyMCUzRCUyMCUyMmRpc3RpbGJlcnQtYmFzZS11bmNhc2VkLWZpbmV0dW5lZC1zc3QtMi1lbmdsaXNoJTIyJTBBbW9kZWwlMjAlM0QlMjBURkF1dG9Nb2RlbC5mcm9tX3ByZXRyYWluZWQoY2hlY2twb2ludCk=",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> TFAutoModel
checkpoint = <span class="hljs-string">&quot;distilbert-base-uncased-finetuned-sst-2-english&quot;</span>
model = TFAutoModel.from_pretrained(checkpoint)`,wrap:!1}}),{c(){t=f("p"),t.innerHTML=r,s=o(),T(u.$$.fragment)},l(i){t=y(i,"P",{"data-svelte-h":!0}),b(t)!=="svelte-t5x45s"&&(t.innerHTML=r),s=c(i),h(u.$$.fragment,i)},m(i,j){a(i,t,j),a(i,s,j),J(u,i,j),p=!0},i(i){p||(M(u.$$.fragment,i),p=!0)},o(i){m(u.$$.fragment,i),p=!1},d(i){i&&(n(t),n(s)),U(u,i)}}}function nn(d){let t,r="Nous pouvons télécharger notre modèle pré-entraîné de la même manière que nous l’avons fait avec notre <em>tokenizer</em>. 🤗 <em>Transformers</em> fournit une classe <code>AutoModel</code> qui possède également une méthode <code>from_pretrained()</code> :",s,u,p;return u=new w({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEF1dG9Nb2RlbCUwQSUwQWNoZWNrcG9pbnQlMjAlM0QlMjAlMjJkaXN0aWxiZXJ0LWJhc2UtdW5jYXNlZC1maW5ldHVuZWQtc3N0LTItZW5nbGlzaCUyMiUwQW1vZGVsJTIwJTNEJTIwQXV0b01vZGVsLmZyb21fcHJldHJhaW5lZChjaGVja3BvaW50KQ==",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoModel
checkpoint = <span class="hljs-string">&quot;distilbert-base-uncased-finetuned-sst-2-english&quot;</span>
model = AutoModel.from_pretrained(checkpoint)`,wrap:!1}}),{c(){t=f("p"),t.innerHTML=r,s=o(),T(u.$$.fragment)},l(i){t=y(i,"P",{"data-svelte-h":!0}),b(t)!=="svelte-10pz8zs"&&(t.innerHTML=r),s=c(i),h(u.$$.fragment,i)},m(i,j){a(i,t,j),a(i,s,j),J(u,i,j),p=!0},i(i){p||(M(u.$$.fragment,i),p=!0)},o(i){m(u.$$.fragment,i),p=!1},d(i){i&&(n(t),n(s)),U(u,i)}}}function an(d){let t,r,s,u;return t=new w({props:{code:"b3V0cHV0cyUyMCUzRCUyMG1vZGVsKGlucHV0cyklMEFwcmludChvdXRwdXRzLmxhc3RfaGlkZGVuX3N0YXRlLnNoYXBlKQ==",highlighted:`outputs = model(inputs)
<span class="hljs-built_in">print</span>(outputs.last_hidden_state.shape)`,wrap:!1}}),s=new w({props:{code:"KDIlMkMlMjAxNiUyQyUyMDc2OCk=",highlighted:'(<span class="hljs-number">2</span>, <span class="hljs-number">16</span>, <span class="hljs-number">768</span>)',wrap:!1}}),{c(){T(t.$$.fragment),r=o(),T(s.$$.fragment)},l(p){h(t.$$.fragment,p),r=c(p),h(s.$$.fragment,p)},m(p,i){J(t,p,i),a(p,r,i),J(s,p,i),u=!0},i(p){u||(M(t.$$.fragment,p),M(s.$$.fragment,p),u=!0)},o(p){m(t.$$.fragment,p),m(s.$$.fragment,p),u=!1},d(p){p&&n(r),U(t,p),U(s,p)}}}function rn(d){let t,r,s,u;return t=new w({props:{code:"b3V0cHV0cyUyMCUzRCUyMG1vZGVsKCoqaW5wdXRzKSUwQXByaW50KG91dHB1dHMubGFzdF9oaWRkZW5fc3RhdGUuc2hhcGUp",highlighted:`outputs = model(**inputs)
<span class="hljs-built_in">print</span>(outputs.last_hidden_state.shape)`,wrap:!1}}),s=new w({props:{code:"dG9yY2guU2l6ZSglNUIyJTJDJTIwMTYlMkMlMjA3NjglNUQp",highlighted:'torch.Size([<span class="hljs-number">2</span>, <span class="hljs-number">16</span>, <span class="hljs-number">768</span>])',wrap:!1}}),{c(){T(t.$$.fragment),r=o(),T(s.$$.fragment)},l(p){h(t.$$.fragment,p),r=c(p),h(s.$$.fragment,p)},m(p,i){J(t,p,i),a(p,r,i),J(s,p,i),u=!0},i(p){u||(M(t.$$.fragment,p),M(s.$$.fragment,p),u=!0)},o(p){m(t.$$.fragment,p),m(s.$$.fragment,p),u=!1},d(p){p&&n(r),U(t,p),U(s,p)}}}function un(d){let t,r="Pour notre exemple, nous avons besoin d’un modèle avec une tête de classification de séquence (pour pouvoir classer les phrases comme positives ou négatives). Donc, nous n’utilisons pas réellement la classe <code>TFAutoModel</code> mais plutôt <code>TFAutoModelForSequenceClassification</code> :",s,u,p;return u=new w({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMFRGQXV0b01vZGVsRm9yU2VxdWVuY2VDbGFzc2lmaWNhdGlvbiUwQSUwQWNoZWNrcG9pbnQlMjAlM0QlMjAlMjJkaXN0aWxiZXJ0LWJhc2UtdW5jYXNlZC1maW5ldHVuZWQtc3N0LTItZW5nbGlzaCUyMiUwQW1vZGVsJTIwJTNEJTIwVEZBdXRvTW9kZWxGb3JTZXF1ZW5jZUNsYXNzaWZpY2F0aW9uLmZyb21fcHJldHJhaW5lZChjaGVja3BvaW50KSUwQW91dHB1dHMlMjAlM0QlMjBtb2RlbChpbnB1dHMp",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> TFAutoModelForSequenceClassification
checkpoint = <span class="hljs-string">&quot;distilbert-base-uncased-finetuned-sst-2-english&quot;</span>
model = TFAutoModelForSequenceClassification.from_pretrained(checkpoint)
outputs = model(inputs)`,wrap:!1}}),{c(){t=f("p"),t.innerHTML=r,s=o(),T(u.$$.fragment)},l(i){t=y(i,"P",{"data-svelte-h":!0}),b(t)!=="svelte-4jk1kv"&&(t.innerHTML=r),s=c(i),h(u.$$.fragment,i)},m(i,j){a(i,t,j),a(i,s,j),J(u,i,j),p=!0},i(i){p||(M(u.$$.fragment,i),p=!0)},o(i){m(u.$$.fragment,i),p=!1},d(i){i&&(n(t),n(s)),U(u,i)}}}function pn(d){let t,r="Pour notre exemple, nous avons besoin d’un modèle avec une tête de classification de séquence (pour pouvoir classer les phrases comme positives ou négatives). Donc, nous n’utilisons pas réellement la classe <code>AutoModel</code> mais plutôt <code>AutoModelForSequenceClassification</code> :",s,u,p;return u=new w({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEF1dG9Nb2RlbEZvclNlcXVlbmNlQ2xhc3NpZmljYXRpb24lMEElMEFjaGVja3BvaW50JTIwJTNEJTIwJTIyZGlzdGlsYmVydC1iYXNlLXVuY2FzZWQtZmluZXR1bmVkLXNzdC0yLWVuZ2xpc2glMjIlMEFtb2RlbCUyMCUzRCUyMEF1dG9Nb2RlbEZvclNlcXVlbmNlQ2xhc3NpZmljYXRpb24uZnJvbV9wcmV0cmFpbmVkKGNoZWNrcG9pbnQpJTBBb3V0cHV0cyUyMCUzRCUyMG1vZGVsKCoqaW5wdXRzKQ==",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoModelForSequenceClassification
checkpoint = <span class="hljs-string">&quot;distilbert-base-uncased-finetuned-sst-2-english&quot;</span>
model = AutoModelForSequenceClassification.from_pretrained(checkpoint)
outputs = model(**inputs)`,wrap:!1}}),{c(){t=f("p"),t.innerHTML=r,s=o(),T(u.$$.fragment)},l(i){t=y(i,"P",{"data-svelte-h":!0}),b(t)!=="svelte-eg8y2f"&&(t.innerHTML=r),s=c(i),h(u.$$.fragment,i)},m(i,j){a(i,t,j),a(i,s,j),J(u,i,j),p=!0},i(i){p||(M(u.$$.fragment,i),p=!0)},o(i){m(u.$$.fragment,i),p=!1},d(i){i&&(n(t),n(s)),U(u,i)}}}function on(d){let t,r;return t=new w({props:{code:"KDIlMkMlMjAyKQ==",highlighted:'(<span class="hljs-number">2</span>, <span class="hljs-number">2</span>)',wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function cn(d){let t,r;return t=new w({props:{code:"dG9yY2guU2l6ZSglNUIyJTJDJTIwMiU1RCk=",highlighted:'torch.Size([<span class="hljs-number">2</span>, <span class="hljs-number">2</span>])',wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function mn(d){let t,r;return t=new w({props:{code:"JTNDdGYuVGVuc29yJTNBJTIwc2hhcGUlM0QoMiUyQyUyMDIpJTJDJTIwZHR5cGUlM0RmbG9hdDMyJTJDJTIwbnVtcHklM0QlMEElMjAlMjAlMjAlMjBhcnJheSglNUIlNUItMS41NjA2OTkxJTJDJTIwJTIwMS42MTIyODQyJTVEJTJDJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVCJTIwNC4xNjkyMzElMjAlMkMlMjAtMy4zNDY0NDcyJTVEJTVEJTJDJTIwZHR5cGUlM0RmbG9hdDMyKSUzRQ==",highlighted:`&lt;tf.Tensor: shape=(<span class="hljs-number">2</span>, <span class="hljs-number">2</span>), dtype=float32, numpy=
array([[-<span class="hljs-number">1.5606991</span>, <span class="hljs-number">1.6122842</span>],
[ <span class="hljs-number">4.169231</span> , -<span class="hljs-number">3.3464472</span>]], dtype=float32)&gt;`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function Mn(d){let t,r;return t=new w({props:{code:"dGVuc29yKCU1QiU1Qi0xLjU2MDclMkMlMjAlMjAxLjYxMjMlNUQlMkMlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUIlMjA0LjE2OTIlMkMlMjAtMy4zNDY0JTVEJTVEJTJDJTIwZ3JhZF9mbiUzRCUzQ0FkZG1tQmFja3dhcmQlM0Up",highlighted:`tensor([[-<span class="hljs-number">1.5607</span>, <span class="hljs-number">1.6123</span>],
[ <span class="hljs-number">4.1692</span>, -<span class="hljs-number">3.3464</span>]], grad_fn=&lt;AddmmBackward&gt;)`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function dn(d){let t,r;return t=new w({props:{code:"aW1wb3J0JTIwdGVuc29yZmxvdyUyMGFzJTIwdGYlMEElMEFwcmVkaWN0aW9ucyUyMCUzRCUyMHRmLm1hdGguc29mdG1heChvdXRwdXRzLmxvZ2l0cyUyQyUyMGF4aXMlM0QtMSklMEFwcmludChwcmVkaWN0aW9ucyk=",highlighted:`<span class="hljs-keyword">import</span> tensorflow <span class="hljs-keyword">as</span> tf
predictions = tf.math.softmax(outputs.logits, axis=-<span class="hljs-number">1</span>)
<span class="hljs-built_in">print</span>(predictions)`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function fn(d){let t,r;return t=new w({props:{code:"aW1wb3J0JTIwdG9yY2glMEElMEFwcmVkaWN0aW9ucyUyMCUzRCUyMHRvcmNoLm5uLmZ1bmN0aW9uYWwuc29mdG1heChvdXRwdXRzLmxvZ2l0cyUyQyUyMGRpbSUzRC0xKSUwQXByaW50KHByZWRpY3Rpb25zKQ==",highlighted:`<span class="hljs-keyword">import</span> torch
predictions = torch.nn.functional.softmax(outputs.logits, dim=-<span class="hljs-number">1</span>)
<span class="hljs-built_in">print</span>(predictions)`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function yn(d){let t,r;return t=new w({props:{code:"dGYuVGVuc29yKCUwQSU1QiU1QjQuMDE5NTE2NzFlLTAyJTIwOS41OTgwNDgzM2UtMDElNUQlMEElMjAlNUI5Ljk5NDU1ODdlLTAxJTIwNS40NDE4NDI0ZS0wNCU1RCU1RCUyQyUyMHNoYXBlJTNEKDIlMkMlMjAyKSUyQyUyMGR0eXBlJTNEZmxvYXQzMik=",highlighted:`tf.Tensor(
[[<span class="hljs-number">4.01951671e-02</span> <span class="hljs-number">9.59804833e-01</span>]
[<span class="hljs-number">9.9945587e-01</span> <span class="hljs-number">5.4418424e-04</span>]], shape=(<span class="hljs-number">2</span>, <span class="hljs-number">2</span>), dtype=float32)`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function bn(d){let t,r;return t=new w({props:{code:"dGVuc29yKCU1QiU1QjQuMDE5NWUtMDIlMkMlMjA5LjU5ODBlLTAxJTVEJTJDJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVCOS45OTQ2ZS0wMSUyQyUyMDUuNDQxOGUtMDQlNUQlNUQlMkMlMjBncmFkX2ZuJTNEJTNDU29mdG1heEJhY2t3YXJkJTNFKQ==",highlighted:`tensor([[<span class="hljs-number">4.0195e-02</span>, <span class="hljs-number">9.5980e-01</span>],
[<span class="hljs-number">9.9946e-01</span>, <span class="hljs-number">5.4418e-04</span>]], grad_fn=&lt;SoftmaxBackward&gt;)`,wrap:!1}}),{c(){T(t.$$.fragment)},l(s){h(t.$$.fragment,s)},m(s,u){J(t,s,u),r=!0},i(s){r||(M(t.$$.fragment,s),r=!0)},o(s){m(t.$$.fragment,s),r=!1},d(s){U(t,s)}}}function Tn(d){let t,r="✏️ <strong>Essayez !</strong> Choisissez deux (ou plus) textes de votre choix (en anglais) et faites-les passer par le pipeline <code>sentiment-analysis</code>. Reproduisez ensuite vous-même les étapes vues ici et vérifiez que vous obtenez les mêmes résultats !";return{c(){t=f("p"),t.innerHTML=r},l(s){t=y(s,"P",{"data-svelte-h":!0}),b(t)!=="svelte-1qzh364"&&(t.innerHTML=r)},m(s,u){a(s,t,u)},p:Hl,d(s){s&&n(t)}}}function hn(d){let t,r,s,u,p,i,j,fs,_,$,ts,F,ys,C,k,ls,K,Ct='Commençons par un exemple complet en regardant ce qui s’est passé en coulisses lorsque nous avons exécuté le code suivant dans le <a href="/course/chapter1">chapitre 1</a> :',bs,O,Ts,ee,kt="la sortie :",hs,se,Js,te,gt='Comme nous l’avons vu dans le <a href="/course/fr/chapter1">chapitre 1</a>, ce pipeline regroupe trois étapes : le prétraitement, le passage des entrées dans le modèle et le post-traitement.',Us,X,It='<img class="block dark:hidden" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/full_nlp_pipeline.svg" alt="The full NLP pipeline: tokenization of text, conversion to IDs, and inference through the Transformer model and the model head."/> <img class="hidden dark:block" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/full_nlp_pipeline-dark.svg" alt="The full NLP pipeline: tokenization of text, conversion to IDs, and inference through the Transformer model and the model head."/>',js,le,vt="Passons rapidement en revue chacun de ces éléments.",ws,ne,_s,ae,xt="Comme d’autres réseaux de neurones, les <em>transformers</em> ne peuvent pas traiter directement le texte brut, donc la première étape de notre pipeline est de convertir les entrées textuelles en nombres afin que le modèle puisse les comprendre. Pour ce faire, nous utilisons un <em>tokenizer</em>, qui sera responsable de :",$s,re,At="<li>diviser l’entrée en mots, sous-mots, ou symboles (comme la ponctuation) qui sont appelés <em>tokens</em>,</li> <li>associer chaque <em>token</em> à un nombre entier,</li> <li>ajouter des entrées supplémentaires qui peuvent être utiles au modèle.</li>",Cs,ie,Nt='Tout ce prétraitement doit être effectué exactement de la même manière que celui appliqué lors du pré-entraînement du modèle. Nous devons donc d’abord télécharger ces informations depuis le <a href="https://huggingface.co/models" rel="nofollow"><em>Hub</em></a>. Pour ce faire, nous utilisons la classe <code>AutoTokenizer</code> et sa méthode <code>from_pretrained()</code>. En utilisant le nom du <em>checkpoint</em> de notre modèle, elle va automatiquement récupérer les données associées au <em>tokenizer</em> du modèle et les mettre en cache (afin qu’elles ne soient téléchargées que la première fois que vous exécutez le code ci-dessous).',ks,ue,Qt='Puisque le <em>checkpoint</em> par défaut du pipeline <code>sentiment-analysis</code> (analyse de sentiment) est <code>distilbert-base-uncased-finetuned-sst-2-english</code> (vous pouvez voir la carte de ce modèle <a href="https://huggingface.co/distilbert-base-uncased-finetuned-sst-2-english" rel="nofollow">ici</a>), nous exécutons ce qui suit :',gs,pe,Is,oe,Dt="Une fois que nous avons le <em>tokenizer</em> nous pouvons lui passer directement nos phrases et obtenir un dictionnaire prêt à être donné à notre modèle ! La seule chose qui reste à faire est de convertir en tenseurs la liste des identifiants d’entrée.",vs,ce,Et="Vous pouvez utiliser 🤗 <em>Transformers</em> sans avoir à vous soucier du <em>framework</em> utilisé comme <em>backend</em>. Il peut s’agir de PyTorch, de TensorFlow ou de Flax pour certains modèles. Cependant, les <em>transformers</em> n’acceptent que les <em>tenseurs</em> en entrée. Si c’est la première fois que vous entendez parler de tenseurs, vous pouvez les considérer comme des tableaux NumPy. Un tableau NumPy peut être un scalaire (0D), un vecteur (1D), une matrice (2D), ou avoir davantage de dimensions. Les tenseurs des autres <em>frameworks</em> d’apprentissage machine se comportent de manière similaire et sont généralement aussi simples à instancier que les tableaux NumPy.",xs,me,Vt="Pour spécifier le type de tenseurs que nous voulons récupérer (PyTorch, TensorFlow, ou simplement NumPy), nous utilisons l’argument <code>return_tensors</code> :",As,g,I,ns,Me,Zt="Ne vous préoccupez pas encore du remplissage (<em>padding</em>) et de la troncature, nous les expliquerons plus tard. Les principales choses à retenir ici sont que vous pouvez passer une phrase ou une liste de phrases, ainsi que spécifier le type de tenseurs que vous voulez récupérer (si aucun type n’est passé, par défaut vous obtiendrez une liste de listes comme résultat).",Ns,v,x,as,de,Ht="La sortie elle-même est un dictionnaire contenant deux clés : <code>input_ids</code> et <code>attention_mask</code>. <code>input_ids</code> contient deux lignes d’entiers (une pour chaque phrase) qui sont les identifiants uniques des <em>tokens</em> dans chaque phrase. Nous expliquerons ce qu’est l’<code>attention_mask</code> plus tard dans ce chapitre.",Qs,fe,Ds,A,N,rs,ye,zt="Dans cet extrait de code, nous avons téléchargé le même <em>checkpoint</em> que nous avons utilisé dans notre pipeline auparavant (il devrait en fait avoir déjà été mis en cache) et instancié un modèle avec lui.",Es,be,Gt=`Cette architecture ne contient que le module de <em>transformer</em> de base : étant donné certaines entrées, il produit ce que nous appellerons des <em>états cachés</em>, également connus sous le nom de <em>caractéristiques</em>.
Pour chaque entrée du modèle, nous récupérons un vecteur en grande dimension représentant la <strong>compréhension contextuelle de cette entrée par le <em>transformer</em></strong>.`,Vs,Te,qt="Si cela n’a pas de sens, ne vous inquiétez pas. Nous expliquons tout plus tard.",Zs,he,Bt='Bien que ces états cachés puissent être utiles en eux-mêmes, ils sont généralement les entrées d’une autre partie du modèle, connue sous le nom de <em>tête</em>. Dans le <a href="/course/fr/chapter1">chapitre 1</a>, les différentes tâches auraient pu être réalisées avec la même architecture mais en ayant chacune d’elles une tête différente.',Hs,Je,zs,Ue,St="Le vecteur produit en sortie par le <em>transformer</em> est généralement de grande dimension. Il a généralement trois dimensions :",Gs,je,Lt="<li><strong>la taille du lot</strong> : le nombre de séquences traitées à la fois (2 dans notre exemple),</li> <li><strong>la longueur de la séquence</strong> : la longueur de la représentation numérique de la séquence (16 dans notre exemple),</li> <li><strong>la taille cachée</strong> : la dimension du vecteur de chaque entrée du modèle.</li>",qs,we,Rt="On dit qu’il est de « grande dimension » en raison de la dernière valeur. La taille cachée peut être très grande (généralement 768 pour les petits modèles et pour les grands modèles cela peut atteindre 3072 voire plus).",Bs,_e,Wt="Nous pouvons le constater si nous alimentons notre modèle avec les entrées que nous avons prétraitées :",Ss,Q,D,is,$e,Ft="Notez que les sorties des modèles de la bibliothèque 🤗 <em>Transformers</em> se comportent comme des <code>namedtuples</code> ou des dictionnaires. Vous pouvez accéder aux éléments par attributs (comme nous l’avons fait), par clé (<code>outputs[&quot;last_hidden_state&quot;]</code>), ou même par l’index si vous savez exactement où se trouve la chose que vous cherchez (<code>outputs[0]</code>).",Ls,Ce,Rs,ke,Xt="Les têtes des modèles prennent en entrée le vecteur de grande dimension des états cachés et le projettent sur une autre dimension. Elles sont généralement composées d’une ou de quelques couches linéaires :",Ws,P,Pt='<img class="block dark:hidden" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/transformer_and_head.svg" alt="A Transformer network alongside its head."/> <img class="hidden dark:block" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/transformer_and_head-dark.svg" alt="A Transformer network alongside its head."/>',Fs,ge,Yt=`La sortie du <em>transformer</em> est envoyée directement à la tête du modèle pour être traitée.
Dans ce diagramme, le modèle est représenté par sa couche d’enchâssement et les couches suivantes. La couche d’enchâssement convertit chaque identifiant d’entrée dans l’entrée tokenisée en un vecteur qui représente le <em>token</em> associé. Les couches suivantes manipulent ces vecteurs en utilisant le mécanisme d’attention pour produire la représentation finale des phrases.
Il existe de nombreuses architectures différentes disponibles dans la bibliothèque 🤗 <em>Transformers</em>, chacune étant conçue autour de la prise en charge d’une tâche spécifique. En voici une liste non exhaustive :`,Xs,Ie,Kt="<li><code>*Model</code> (récupérer les états cachés)</li> <li><code>*ForCausalLM</code></li> <li><code>*ForMaskedLM</code></li> <li><code>*ForMultipleChoice</code></li> <li><code>*ForQuestionAnswering</code></li> <li><code>*ForSequenceClassification</code></li> <li><code>*ForTokenClassification</code></li> <li>et autres 🤗</li>",Ps,E,V,us,ve,Ot="Maintenant, si nous examinons la forme de nos entrées, la dimensionnalité est beaucoup plus faible. La tête du modèle prend en entrée les vecteurs de grande dimension que nous avons vus précédemment et elle produit des vecteurs contenant deux valeurs (une par étiquette) :",Ys,xe,Ks,Z,H,ps,Ae,el="Comme nous n’avons que deux phrases et deux étiquettes, le résultat que nous obtenons est de forme 2 x 2",Os,Ne,et,Qe,sl="Les valeurs que nous obtenons en sortie de notre modèle n’ont pas nécessairement de sens en elles-mêmes. Jetons-y un coup d’œil :",st,De,tt,z,G,os,Ee,tl='Notre modèle a prédit <code>[-1.5607, 1.6123]</code> pour la première phrase et <code>[ 4.1692, -3.3464]</code> pour la seconde. Ce ne sont pas des probabilités mais des <em>logits</em>, les scores bruts, non normalisés, produits par la dernière couche du modèle. Pour être convertis en probabilités, ils doivent passer par une couche <a href="https://fr.wikipedia.org/wiki/Fonction_softmax" rel="nofollow">SoftMax</a> (tous les modèles de la bibliothèque 🤗 <em>Transformers</em> sortent les logits car la fonction de perte de l’entraînement fusionne généralement la dernière fonction d’activation, comme la SoftMax, avec la fonction de perte réelle, comme l’entropie croisée) :',lt,q,B,cs,S,L,ms,Ve,ll="Maintenant nous pouvons voir que le modèle a prédit <code>[0.0402, 0.9598]</code> pour la première phrase et <code>[0.9995, 0.0005]</code> pour la seconde. Ce sont des scores de probabilité reconnaissables.",nt,Ze,nl="Pour obtenir les étiquettes correspondant à chaque position, nous pouvons inspecter l’attribut <code>id2label</code> de la configuration du modèle (plus de détails dans la section suivante) :",at,He,rt,ze,it,Ge,al="Nous pouvons maintenant conclure que le modèle a prédit ce qui suit :",ut,qe,rl="<li>première phrase : NEGATIVE: 0.0402, POSITIVE: 0.9598</li> <li>deuxième phrase : NEGATIVE: 0.9995, POSITIVE: 0.0005</li>",pt,Be,il="Nous avons reproduit avec succès les trois étapes du pipeline : prétraitement avec les <em>tokenizers</em>, passage des entrées dans le modèle et post-traitement ! Prenons maintenant le temps de nous plonger plus profondément dans chacune de ces étapes.",ot,Y,ct,Se,mt,ds,Mt;p=new Rl({props:{fw:d[0]}}),j=new Ms({props:{title:"Derrière le pipeline",local:"derrière-le-pipeline",headingTag:"h1"}});const ul=[Xl,Fl],Le=[];function pl(e,l){return e[0]==="pt"?0:1}_=pl(d),$=Le[_]=ul[_](d),F=new Ql({props:{$$slots:{default:[Pl]},$$scope:{ctx:d}}});const ol=[Kl,Yl],Re=[];function cl(e,l){return e[0]==="pt"?0:1}C=cl(d),k=Re[C]=ol[C](d),O=new w({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMHBpcGVsaW5lJTBBJTBBY2xhc3NpZmllciUyMCUzRCUyMHBpcGVsaW5lKCUyMnNlbnRpbWVudC1hbmFseXNpcyUyMiklMEFjbGFzc2lmaWVyKCUwQSUyMCUyMCUyMCUyMCU1QiUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMkkndmUlMjBiZWVuJTIwd2FpdGluZyUyMGZvciUyMGElMjBIdWdnaW5nRmFjZSUyMGNvdXJzZSUyMG15JTIwd2hvbGUlMjBsaWZlLiUyMiUyQyUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMyUyMEonYWklMjBhdHRlbmR1JTIwdW4lMjBjb3VycyUyMGRlJTIwSHVnZ2luZ0ZhY2UlMjB0b3V0ZSUyMG1hJTIwdmllLiUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMkklMjBoYXRlJTIwdGhpcyUyMHNvJTIwbXVjaCElMjIlMkMlMjAlMjAlMjMlMjBKZSUyMGQlQzMlQTl0ZXN0ZSUyMHRlbGxlbWVudCUyMCVDMyVBN2ElMjAhJTBBJTIwJTIwJTIwJTIwJTVEJTBBKQ==",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> pipeline
classifier = pipeline(<span class="hljs-string">&quot;sentiment-analysis&quot;</span>)
classifier(
[
<span class="hljs-string">&quot;I&#x27;ve been waiting for a HuggingFace course my whole life.&quot;</span>,
<span class="hljs-comment"># J&#x27;ai attendu un cours de HuggingFace toute ma vie.</span>
<span class="hljs-string">&quot;I hate this so much!&quot;</span>, <span class="hljs-comment"># Je déteste tellement ça !</span>
]
)`,wrap:!1}}),se=new w({props:{code:"JTVCJTdCJ2xhYmVsJyUzQSUyMCdQT1NJVElWRSclMkMlMjAnc2NvcmUnJTNBJTIwMC45NTk4MDQ3MTM3MjYwNDM3JTdEJTJDJTBBJTIwJTdCJ2xhYmVsJyUzQSUyMCdORUdBVElWRSclMkMlMjAnc2NvcmUnJTNBJTIwMC45OTk0NTU4MDk1OTMyMDA3JTdEJTVE",highlighted:`[{<span class="hljs-string">&#x27;label&#x27;</span>: <span class="hljs-string">&#x27;POSITIVE&#x27;</span>, <span class="hljs-string">&#x27;score&#x27;</span>: <span class="hljs-number">0.9598047137260437</span>},
{<span class="hljs-string">&#x27;label&#x27;</span>: <span class="hljs-string">&#x27;NEGATIVE&#x27;</span>, <span class="hljs-string">&#x27;score&#x27;</span>: <span class="hljs-number">0.9994558095932007</span>}]`,wrap:!1}}),ne=new Ms({props:{title:"Prétraitement avec un <i> tokenizer </i>",local:"prétraitement-avec-un-i-tokenizer-i",headingTag:"h2"}}),pe=new w({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEF1dG9Ub2tlbml6ZXIlMEElMEFjaGVja3BvaW50JTIwJTNEJTIwJTIyZGlzdGlsYmVydC1iYXNlLXVuY2FzZWQtZmluZXR1bmVkLXNzdC0yLWVuZ2xpc2glMjIlMEF0b2tlbml6ZXIlMjAlM0QlMjBBdXRvVG9rZW5pemVyLmZyb21fcHJldHJhaW5lZChjaGVja3BvaW50KQ==",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoTokenizer
checkpoint = <span class="hljs-string">&quot;distilbert-base-uncased-finetuned-sst-2-english&quot;</span>
tokenizer = AutoTokenizer.from_pretrained(checkpoint)`,wrap:!1}});const ml=[en,Ol],We=[];function Ml(e,l){return e[0]==="pt"?0:1}g=Ml(d),I=We[g]=ml[g](d);const dl=[tn,sn],Fe=[];function fl(e,l){return e[0]==="pt"?0:1}v=fl(d),x=Fe[v]=dl[v](d),fe=new Ms({props:{title:"Passage au modèle",local:"passage-au-modèle",headingTag:"h2"}});const yl=[nn,ln],Xe=[];function bl(e,l){return e[0]==="pt"?0:1}A=bl(d),N=Xe[A]=yl[A](d),Je=new Ms({props:{title:"Un vecteur de grande dimension ?",local:"un-vecteur-de-grande-dimension-",headingTag:"h3"}});const Tl=[rn,an],Pe=[];function hl(e,l){return e[0]==="pt"?0:1}Q=hl(d),D=Pe[Q]=Tl[Q](d),Ce=new Ms({props:{title:"Les têtes des modèles : donner du sens aux chiffres",local:"les-têtes-des-modèles--donner-du-sens-aux-chiffres",headingTag:"h3"}});const Jl=[pn,un],Ye=[];function Ul(e,l){return e[0]==="pt"?0:1}E=Ul(d),V=Ye[E]=Jl[E](d),xe=new w({props:{code:"cHJpbnQob3V0cHV0cy5sb2dpdHMuc2hhcGUp",highlighted:'<span class="hljs-built_in">print</span>(outputs.logits.shape)',wrap:!1}});const jl=[cn,on],Ke=[];function wl(e,l){return e[0]==="pt"?0:1}Z=wl(d),H=Ke[Z]=jl[Z](d),Ne=new Ms({props:{title:"Post-traitement de la sortie",local:"post-traitement-de-la-sortie",headingTag:"h2"}}),De=new w({props:{code:"cHJpbnQob3V0cHV0cy5sb2dpdHMp",highlighted:'<span class="hljs-built_in">print</span>(outputs.logits)',wrap:!1}});const _l=[Mn,mn],Oe=[];function $l(e,l){return e[0]==="pt"?0:1}z=$l(d),G=Oe[z]=_l[z](d);const Cl=[fn,dn],es=[];function kl(e,l){return e[0]==="pt"?0:1}q=kl(d),B=es[q]=Cl[q](d);const gl=[bn,yn],ss=[];function Il(e,l){return e[0]==="pt"?0:1}return S=Il(d),L=ss[S]=gl[S](d),He=new w({props:{code:"bW9kZWwuY29uZmlnLmlkMmxhYmVs",highlighted:"model.config.id2label",wrap:!1}}),ze=new w({props:{code:"JTdCMCUzQSUyMCdORUdBVElWRSclMkMlMjAxJTNBJTIwJ1BPU0lUSVZFJyU3RA==",highlighted:'{<span class="hljs-number">0</span>: <span class="hljs-string">&#x27;NEGATIVE&#x27;</span>, <span class="hljs-number">1</span>: <span class="hljs-string">&#x27;POSITIVE&#x27;</span>}',wrap:!1}}),Y=new Ql({props:{$$slots:{default:[Tn]},$$scope:{ctx:d}}}),Se=new Wl({props:{source:"https://github.com/huggingface/course/blob/main/chapters/fr/chapter2/2.mdx"}}),{c(){t=f("meta"),r=o(),s=f("p"),u=o(),T(p.$$.fragment),i=o(),T(j.$$.fragment),fs=o(),$.c(),ts=o(),T(F.$$.fragment),ys=o(),k.c(),ls=o(),K=f("p"),K.innerHTML=Ct,bs=o(),T(O.$$.fragment),Ts=o(),ee=f("p"),ee.textContent=kt,hs=o(),T(se.$$.fragment),Js=o(),te=f("p"),te.innerHTML=gt,Us=o(),X=f("div"),X.innerHTML=It,js=o(),le=f("p"),le.textContent=vt,ws=o(),T(ne.$$.fragment),_s=o(),ae=f("p"),ae.innerHTML=xt,$s=o(),re=f("ul"),re.innerHTML=At,Cs=o(),ie=f("p"),ie.innerHTML=Nt,ks=o(),ue=f("p"),ue.innerHTML=Qt,gs=o(),T(pe.$$.fragment),Is=o(),oe=f("p"),oe.innerHTML=Dt,vs=o(),ce=f("p"),ce.innerHTML=Et,xs=o(),me=f("p"),me.innerHTML=Vt,As=o(),I.c(),ns=o(),Me=f("p"),Me.innerHTML=Zt,Ns=o(),x.c(),as=o(),de=f("p"),de.innerHTML=Ht,Qs=o(),T(fe.$$.fragment),Ds=o(),N.c(),rs=o(),ye=f("p"),ye.innerHTML=zt,Es=o(),be=f("p"),be.innerHTML=Gt,Vs=o(),Te=f("p"),Te.textContent=qt,Zs=o(),he=f("p"),he.innerHTML=Bt,Hs=o(),T(Je.$$.fragment),zs=o(),Ue=f("p"),Ue.innerHTML=St,Gs=o(),je=f("ul"),je.innerHTML=Lt,qs=o(),we=f("p"),we.textContent=Rt,Bs=o(),_e=f("p"),_e.textContent=Wt,Ss=o(),D.c(),is=o(),$e=f("p"),$e.innerHTML=Ft,Ls=o(),T(Ce.$$.fragment),Rs=o(),ke=f("p"),ke.textContent=Xt,Ws=o(),P=f("div"),P.innerHTML=Pt,Fs=o(),ge=f("p"),ge.innerHTML=Yt,Xs=o(),Ie=f("ul"),Ie.innerHTML=Kt,Ps=o(),V.c(),us=o(),ve=f("p"),ve.textContent=Ot,Ys=o(),T(xe.$$.fragment),Ks=o(),H.c(),ps=o(),Ae=f("p"),Ae.textContent=el,Os=o(),T(Ne.$$.fragment),et=o(),Qe=f("p"),Qe.textContent=sl,st=o(),T(De.$$.fragment),tt=o(),G.c(),os=o(),Ee=f("p"),Ee.innerHTML=tl,lt=o(),B.c(),cs=o(),L.c(),ms=o(),Ve=f("p"),Ve.innerHTML=ll,nt=o(),Ze=f("p"),Ze.innerHTML=nl,at=o(),T(He.$$.fragment),rt=o(),T(ze.$$.fragment),it=o(),Ge=f("p"),Ge.textContent=al,ut=o(),qe=f("ul"),qe.innerHTML=rl,pt=o(),Be=f("p"),Be.innerHTML=il,ot=o(),T(Y.$$.fragment),ct=o(),T(Se.$$.fragment),mt=o(),ds=f("p"),this.h()},l(e){const l=ql("svelte-u9bgzb",document.head);t=y(l,"META",{name:!0,content:!0}),l.forEach(n),r=c(e),s=y(e,"P",{}),Nl(s).forEach(n),u=c(e),h(p.$$.fragment,e),i=c(e),h(j.$$.fragment,e),fs=c(e),$.l(e),ts=c(e),h(F.$$.fragment,e),ys=c(e),k.l(e),ls=c(e),K=y(e,"P",{"data-svelte-h":!0}),b(K)!=="svelte-19wr47f"&&(K.innerHTML=Ct),bs=c(e),h(O.$$.fragment,e),Ts=c(e),ee=y(e,"P",{"data-svelte-h":!0}),b(ee)!=="svelte-1ehr2ed"&&(ee.textContent=kt),hs=c(e),h(se.$$.fragment,e),Js=c(e),te=y(e,"P",{"data-svelte-h":!0}),b(te)!=="svelte-1stmi5u"&&(te.innerHTML=gt),Us=c(e),X=y(e,"DIV",{class:!0,"data-svelte-h":!0}),b(X)!=="svelte-fbe70j"&&(X.innerHTML=It),js=c(e),le=y(e,"P",{"data-svelte-h":!0}),b(le)!=="svelte-18cw5ul"&&(le.textContent=vt),ws=c(e),h(ne.$$.fragment,e),_s=c(e),ae=y(e,"P",{"data-svelte-h":!0}),b(ae)!=="svelte-1wybg9q"&&(ae.innerHTML=xt),$s=c(e),re=y(e,"UL",{"data-svelte-h":!0}),b(re)!=="svelte-jnfblc"&&(re.innerHTML=At),Cs=c(e),ie=y(e,"P",{"data-svelte-h":!0}),b(ie)!=="svelte-1ivw8j2"&&(ie.innerHTML=Nt),ks=c(e),ue=y(e,"P",{"data-svelte-h":!0}),b(ue)!=="svelte-1a6denb"&&(ue.innerHTML=Qt),gs=c(e),h(pe.$$.fragment,e),Is=c(e),oe=y(e,"P",{"data-svelte-h":!0}),b(oe)!=="svelte-v40vma"&&(oe.innerHTML=Dt),vs=c(e),ce=y(e,"P",{"data-svelte-h":!0}),b(ce)!=="svelte-3giksl"&&(ce.innerHTML=Et),xs=c(e),me=y(e,"P",{"data-svelte-h":!0}),b(me)!=="svelte-13ojzrd"&&(me.innerHTML=Vt),As=c(e),I.l(e),ns=c(e),Me=y(e,"P",{"data-svelte-h":!0}),b(Me)!=="svelte-p3z3ke"&&(Me.innerHTML=Zt),Ns=c(e),x.l(e),as=c(e),de=y(e,"P",{"data-svelte-h":!0}),b(de)!=="svelte-194e16q"&&(de.innerHTML=Ht),Qs=c(e),h(fe.$$.fragment,e),Ds=c(e),N.l(e),rs=c(e),ye=y(e,"P",{"data-svelte-h":!0}),b(ye)!=="svelte-aw0453"&&(ye.innerHTML=zt),Es=c(e),be=y(e,"P",{"data-svelte-h":!0}),b(be)!=="svelte-1ppdedx"&&(be.innerHTML=Gt),Vs=c(e),Te=y(e,"P",{"data-svelte-h":!0}),b(Te)!=="svelte-iplr45"&&(Te.textContent=qt),Zs=c(e),he=y(e,"P",{"data-svelte-h":!0}),b(he)!=="svelte-a149fz"&&(he.innerHTML=Bt),Hs=c(e),h(Je.$$.fragment,e),zs=c(e),Ue=y(e,"P",{"data-svelte-h":!0}),b(Ue)!=="svelte-spzt3d"&&(Ue.innerHTML=St),Gs=c(e),je=y(e,"UL",{"data-svelte-h":!0}),b(je)!=="svelte-12sddbn"&&(je.innerHTML=Lt),qs=c(e),we=y(e,"P",{"data-svelte-h":!0}),b(we)!=="svelte-kiq8k1"&&(we.textContent=Rt),Bs=c(e),_e=y(e,"P",{"data-svelte-h":!0}),b(_e)!=="svelte-jbyjqn"&&(_e.textContent=Wt),Ss=c(e),D.l(e),is=c(e),$e=y(e,"P",{"data-svelte-h":!0}),b($e)!=="svelte-1e89igc"&&($e.innerHTML=Ft),Ls=c(e),h(Ce.$$.fragment,e),Rs=c(e),ke=y(e,"P",{"data-svelte-h":!0}),b(ke)!=="svelte-16ldxci"&&(ke.textContent=Xt),Ws=c(e),P=y(e,"DIV",{class:!0,"data-svelte-h":!0}),b(P)!=="svelte-8mo6lt"&&(P.innerHTML=Pt),Fs=c(e),ge=y(e,"P",{"data-svelte-h":!0}),b(ge)!=="svelte-suyi13"&&(ge.innerHTML=Yt),Xs=c(e),Ie=y(e,"UL",{"data-svelte-h":!0}),b(Ie)!=="svelte-11pfien"&&(Ie.innerHTML=Kt),Ps=c(e),V.l(e),us=c(e),ve=y(e,"P",{"data-svelte-h":!0}),b(ve)!=="svelte-da89pl"&&(ve.textContent=Ot),Ys=c(e),h(xe.$$.fragment,e),Ks=c(e),H.l(e),ps=c(e),Ae=y(e,"P",{"data-svelte-h":!0}),b(Ae)!=="svelte-192fqvu"&&(Ae.textContent=el),Os=c(e),h(Ne.$$.fragment,e),et=c(e),Qe=y(e,"P",{"data-svelte-h":!0}),b(Qe)!=="svelte-ltudim"&&(Qe.textContent=sl),st=c(e),h(De.$$.fragment,e),tt=c(e),G.l(e),os=c(e),Ee=y(e,"P",{"data-svelte-h":!0}),b(Ee)!=="svelte-1qler67"&&(Ee.innerHTML=tl),lt=c(e),B.l(e),cs=c(e),L.l(e),ms=c(e),Ve=y(e,"P",{"data-svelte-h":!0}),b(Ve)!=="svelte-1wseff0"&&(Ve.innerHTML=ll),nt=c(e),Ze=y(e,"P",{"data-svelte-h":!0}),b(Ze)!=="svelte-lqmq3p"&&(Ze.innerHTML=nl),at=c(e),h(He.$$.fragment,e),rt=c(e),h(ze.$$.fragment,e),it=c(e),Ge=y(e,"P",{"data-svelte-h":!0}),b(Ge)!=="svelte-14o7ouv"&&(Ge.textContent=al),ut=c(e),qe=y(e,"UL",{"data-svelte-h":!0}),b(qe)!=="svelte-1e8u5b9"&&(qe.innerHTML=rl),pt=c(e),Be=y(e,"P",{"data-svelte-h":!0}),b(Be)!=="svelte-17qank7"&&(Be.innerHTML=il),ot=c(e),h(Y.$$.fragment,e),ct=c(e),h(Se.$$.fragment,e),mt=c(e),ds=y(e,"P",{}),Nl(ds).forEach(n),this.h()},h(){dt(t,"name","hf:doc:metadata"),dt(t,"content",Jn),dt(X,"class","flex justify-center"),dt(P,"class","flex justify-center")},m(e,l){Bl(document.head,t),a(e,r,l),a(e,s,l),a(e,u,l),J(p,e,l),a(e,i,l),J(j,e,l),a(e,fs,l),Le[_].m(e,l),a(e,ts,l),J(F,e,l),a(e,ys,l),Re[C].m(e,l),a(e,ls,l),a(e,K,l),a(e,bs,l),J(O,e,l),a(e,Ts,l),a(e,ee,l),a(e,hs,l),J(se,e,l),a(e,Js,l),a(e,te,l),a(e,Us,l),a(e,X,l),a(e,js,l),a(e,le,l),a(e,ws,l),J(ne,e,l),a(e,_s,l),a(e,ae,l),a(e,$s,l),a(e,re,l),a(e,Cs,l),a(e,ie,l),a(e,ks,l),a(e,ue,l),a(e,gs,l),J(pe,e,l),a(e,Is,l),a(e,oe,l),a(e,vs,l),a(e,ce,l),a(e,xs,l),a(e,me,l),a(e,As,l),We[g].m(e,l),a(e,ns,l),a(e,Me,l),a(e,Ns,l),Fe[v].m(e,l),a(e,as,l),a(e,de,l),a(e,Qs,l),J(fe,e,l),a(e,Ds,l),Xe[A].m(e,l),a(e,rs,l),a(e,ye,l),a(e,Es,l),a(e,be,l),a(e,Vs,l),a(e,Te,l),a(e,Zs,l),a(e,he,l),a(e,Hs,l),J(Je,e,l),a(e,zs,l),a(e,Ue,l),a(e,Gs,l),a(e,je,l),a(e,qs,l),a(e,we,l),a(e,Bs,l),a(e,_e,l),a(e,Ss,l),Pe[Q].m(e,l),a(e,is,l),a(e,$e,l),a(e,Ls,l),J(Ce,e,l),a(e,Rs,l),a(e,ke,l),a(e,Ws,l),a(e,P,l),a(e,Fs,l),a(e,ge,l),a(e,Xs,l),a(e,Ie,l),a(e,Ps,l),Ye[E].m(e,l),a(e,us,l),a(e,ve,l),a(e,Ys,l),J(xe,e,l),a(e,Ks,l),Ke[Z].m(e,l),a(e,ps,l),a(e,Ae,l),a(e,Os,l),J(Ne,e,l),a(e,et,l),a(e,Qe,l),a(e,st,l),J(De,e,l),a(e,tt,l),Oe[z].m(e,l),a(e,os,l),a(e,Ee,l),a(e,lt,l),es[q].m(e,l),a(e,cs,l),ss[S].m(e,l),a(e,ms,l),a(e,Ve,l),a(e,nt,l),a(e,Ze,l),a(e,at,l),J(He,e,l),a(e,rt,l),J(ze,e,l),a(e,it,l),a(e,Ge,l),a(e,ut,l),a(e,qe,l),a(e,pt,l),a(e,Be,l),a(e,ot,l),J(Y,e,l),a(e,ct,l),J(Se,e,l),a(e,mt,l),a(e,ds,l),Mt=!0},p(e,[l]){const vl={};l&1&&(vl.fw=e[0]),p.$set(vl);let ft=_;_=pl(e),_!==ft&&(W(),m(Le[ft],1,1,()=>{Le[ft]=null}),R(),$=Le[_],$||($=Le[_]=ul[_](e),$.c()),M($,1),$.m(ts.parentNode,ts));const xl={};l&2&&(xl.$$scope={dirty:l,ctx:e}),F.$set(xl);let yt=C;C=cl(e),C!==yt&&(W(),m(Re[yt],1,1,()=>{Re[yt]=null}),R(),k=Re[C],k||(k=Re[C]=ol[C](e),k.c()),M(k,1),k.m(ls.parentNode,ls));let bt=g;g=Ml(e),g!==bt&&(W(),m(We[bt],1,1,()=>{We[bt]=null}),R(),I=We[g],I||(I=We[g]=ml[g](e),I.c()),M(I,1),I.m(ns.parentNode,ns));let Tt=v;v=fl(e),v!==Tt&&(W(),m(Fe[Tt],1,1,()=>{Fe[Tt]=null}),R(),x=Fe[v],x||(x=Fe[v]=dl[v](e),x.c()),M(x,1),x.m(as.parentNode,as));let ht=A;A=bl(e),A!==ht&&(W(),m(Xe[ht],1,1,()=>{Xe[ht]=null}),R(),N=Xe[A],N||(N=Xe[A]=yl[A](e),N.c()),M(N,1),N.m(rs.parentNode,rs));let Jt=Q;Q=hl(e),Q!==Jt&&(W(),m(Pe[Jt],1,1,()=>{Pe[Jt]=null}),R(),D=Pe[Q],D||(D=Pe[Q]=Tl[Q](e),D.c()),M(D,1),D.m(is.parentNode,is));let Ut=E;E=Ul(e),E!==Ut&&(W(),m(Ye[Ut],1,1,()=>{Ye[Ut]=null}),R(),V=Ye[E],V||(V=Ye[E]=Jl[E](e),V.c()),M(V,1),V.m(us.parentNode,us));let jt=Z;Z=wl(e),Z!==jt&&(W(),m(Ke[jt],1,1,()=>{Ke[jt]=null}),R(),H=Ke[Z],H||(H=Ke[Z]=jl[Z](e),H.c()),M(H,1),H.m(ps.parentNode,ps));let wt=z;z=$l(e),z!==wt&&(W(),m(Oe[wt],1,1,()=>{Oe[wt]=null}),R(),G=Oe[z],G||(G=Oe[z]=_l[z](e),G.c()),M(G,1),G.m(os.parentNode,os));let _t=q;q=kl(e),q!==_t&&(W(),m(es[_t],1,1,()=>{es[_t]=null}),R(),B=es[q],B||(B=es[q]=Cl[q](e),B.c()),M(B,1),B.m(cs.parentNode,cs));let $t=S;S=Il(e),S!==$t&&(W(),m(ss[$t],1,1,()=>{ss[$t]=null}),R(),L=ss[S],L||(L=ss[S]=gl[S](e),L.c()),M(L,1),L.m(ms.parentNode,ms));const Al={};l&2&&(Al.$$scope={dirty:l,ctx:e}),Y.$set(Al)},i(e){Mt||(M(p.$$.fragment,e),M(j.$$.fragment,e),M($),M(F.$$.fragment,e),M(k),M(O.$$.fragment,e),M(se.$$.fragment,e),M(ne.$$.fragment,e),M(pe.$$.fragment,e),M(I),M(x),M(fe.$$.fragment,e),M(N),M(Je.$$.fragment,e),M(D),M(Ce.$$.fragment,e),M(V),M(xe.$$.fragment,e),M(H),M(Ne.$$.fragment,e),M(De.$$.fragment,e),M(G),M(B),M(L),M(He.$$.fragment,e),M(ze.$$.fragment,e),M(Y.$$.fragment,e),M(Se.$$.fragment,e),Mt=!0)},o(e){m(p.$$.fragment,e),m(j.$$.fragment,e),m($),m(F.$$.fragment,e),m(k),m(O.$$.fragment,e),m(se.$$.fragment,e),m(ne.$$.fragment,e),m(pe.$$.fragment,e),m(I),m(x),m(fe.$$.fragment,e),m(N),m(Je.$$.fragment,e),m(D),m(Ce.$$.fragment,e),m(V),m(xe.$$.fragment,e),m(H),m(Ne.$$.fragment,e),m(De.$$.fragment,e),m(G),m(B),m(L),m(He.$$.fragment,e),m(ze.$$.fragment,e),m(Y.$$.fragment,e),m(Se.$$.fragment,e),Mt=!1},d(e){e&&(n(r),n(s),n(u),n(i),n(fs),n(ts),n(ys),n(ls),n(K),n(bs),n(Ts),n(ee),n(hs),n(Js),n(te),n(Us),n(X),n(js),n(le),n(ws),n(_s),n(ae),n($s),n(re),n(Cs),n(ie),n(ks),n(ue),n(gs),n(Is),n(oe),n(vs),n(ce),n(xs),n(me),n(As),n(ns),n(Me),n(Ns),n(as),n(de),n(Qs),n(Ds),n(rs),n(ye),n(Es),n(be),n(Vs),n(Te),n(Zs),n(he),n(Hs),n(zs),n(Ue),n(Gs),n(je),n(qs),n(we),n(Bs),n(_e),n(Ss),n(is),n($e),n(Ls),n(Rs),n(ke),n(Ws),n(P),n(Fs),n(ge),n(Xs),n(Ie),n(Ps),n(us),n(ve),n(Ys),n(Ks),n(ps),n(Ae),n(Os),n(et),n(Qe),n(st),n(tt),n(os),n(Ee),n(lt),n(cs),n(ms),n(Ve),n(nt),n(Ze),n(at),n(rt),n(it),n(Ge),n(ut),n(qe),n(pt),n(Be),n(ot),n(ct),n(mt),n(ds)),n(t),U(p,e),U(j,e),Le[_].d(e),U(F,e),Re[C].d(e),U(O,e),U(se,e),U(ne,e),U(pe,e),We[g].d(e),Fe[v].d(e),U(fe,e),Xe[A].d(e),U(Je,e),Pe[Q].d(e),U(Ce,e),Ye[E].d(e),U(xe,e),Ke[Z].d(e),U(Ne,e),U(De,e),Oe[z].d(e),es[q].d(e),ss[S].d(e),U(He,e),U(ze,e),U(Y,e),U(Se,e)}}}const Jn='{"title":"Derrière le pipeline","local":"derrière-le-pipeline","sections":[{"title":"Prétraitement avec un <i> tokenizer </i>","local":"prétraitement-avec-un-i-tokenizer-i","sections":[],"depth":2},{"title":"Passage au modèle","local":"passage-au-modèle","sections":[{"title":"Un vecteur de grande dimension ?","local":"un-vecteur-de-grande-dimension-","sections":[],"depth":3},{"title":"Les têtes des modèles : donner du sens aux chiffres","local":"les-têtes-des-modèles--donner-du-sens-aux-chiffres","sections":[],"depth":3}],"depth":2},{"title":"Post-traitement de la sortie","local":"post-traitement-de-la-sortie","sections":[],"depth":2}],"depth":1}';function Un(d,t,r){let s="pt";return Zl(()=>{const u=new URLSearchParams(window.location.search);r(0,s=u.get("fw")||"pt")}),[s]}class vn extends zl{constructor(t){super(),Gl(this,t,Un,hn,Vl,{})}}export{vn as component};

Xet Storage Details

Size:
55.1 kB
·
Xet hash:
640127e5b4bd11fa393b59baf67370eb702c8332895fd4644c1d4ac937b04a41

Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.