Buckets:
| import{s as ws,o as Ts,n as _s}from"../chunks/scheduler.37c15a92.js";import{S as js,i as hs,g as i,s as n,r as o,A as Js,h as a,f as l,c as p,j as Cs,u as M,x as r,k as Ke,y as Us,a as s,v as c,t as u,b as Hs,d as $,w as b,p as zs}from"../chunks/index.7cb9c9b8.js";import{T as Vs}from"../chunks/Tip.d10b3fc9.js";import{Y as Oe}from"../chunks/Youtube.8666c400.js";import{C as x}from"../chunks/CodeBlock.abae2786.js";import{C as ks}from"../chunks/CourseFloatingBanner.df82c153.js";import{F as Is}from"../chunks/FrameworkSwitchCourse.97630871.js";import{H as k,E as Ls}from"../chunks/getInferenceSnippets.f9350a3f.js";function As(v){let m,y;return m=new ks({props:{chapter:2,classNames:"absolute z-10 right-0 top-0",notebooks:[{label:"Google Colab",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/en/chapter2/section4_tf.ipynb"},{label:"Aws Studio",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/en/chapter2/section4_tf.ipynb"}]}}),{c(){o(m.$$.fragment)},l(f){M(m.$$.fragment,f)},m(f,d){c(m,f,d),y=!0},i(f){y||($(m.$$.fragment,f),y=!0)},o(f){u(m.$$.fragment,f),y=!1},d(f){b(m,f)}}}function Ps(v){let m,y;return m=new ks({props:{chapter:2,classNames:"absolute z-10 right-0 top-0",notebooks:[{label:"Google Colab",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/en/chapter2/section4_pt.ipynb"},{label:"Aws Studio",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/en/chapter2/section4_pt.ipynb"}]}}),{c(){o(m.$$.fragment)},l(f){M(m.$$.fragment,f)},m(f,d){c(m,f,d),y=!0},i(f){y||($(m.$$.fragment,f),y=!0)},o(f){u(m.$$.fragment,f),y=!1},d(f){b(m,f)}}}function Zs(v){let m,y="<code>TFAutoModel</code> と同様に、<code>AutoTokenizer</code> クラスはチェックポイント名に基づいてライブラリ内の適切なトークナイザクラスを取得し、任意のチェックポイントを直接使用することができます。";return{c(){m=i("p"),m.innerHTML=y},l(f){m=a(f,"P",{"data-svelte-h":!0}),r(m)!=="svelte-1cpvu7f"&&(m.innerHTML=y)},m(f,d){s(f,m,d)},d(f){f&&l(m)}}}function Ds(v){let m,y="<code>AutoModel</code> と同様に、<code>AutoTokenizer</code> クラスはチェックポイント名に基づいてライブラリ内の適切なトークナイザクラスを取得し、任意のチェックポイントを直接使用することができます。";return{c(){m=i("p"),m.innerHTML=y},l(f){m=a(f,"P",{"data-svelte-h":!0}),r(m)!=="svelte-g5k5dl"&&(m.innerHTML=y)},m(f,d){s(f,m,d)},d(f){f&&l(m)}}}function Qs(v){let m,y="✏️ <strong>試してみよう!</strong> 最後の2つのステップ(トークン化と入力IDへの変換)を、セクション2で使った入力文(“I’ve been waiting for a HuggingFace course my whole life.” と “I hate this so much!“)に対して再現してみましょう。先ほどと同じ入力IDが得られるかどうかを確認してみてください。";return{c(){m=i("p"),m.innerHTML=y},l(f){m=a(f,"P",{"data-svelte-h":!0}),r(m)!=="svelte-hb8ypu"&&(m.innerHTML=y)},m(f,d){s(f,m,d)},p:_s,d(f){f&&l(m)}}}function Es(v){let m,y,f,d,T,et,U,tt,g,C,Xe,H,lt,z,_l="トークナイザはNLPパイプラインの重要な構成要素の1つです。トークナイザの目的は1つで、テキストをモデルが処理できるデータに変換することです。モデルが処理できるのは数値のみなので、トークナイザは入力されたテキストを数値データに変換する必要があります。このセクションでは、トークン化パイプラインで何が起きているのかを具体的に説明します。",st,V,jl="NLPのタスクにおいて、一般的に処理されるデータは生文で、以下はその例です。",nt,I,pt,L,hl="しかしながらモデルが処理できるのは数値のみなので、生文を数値に変換する方法を考える必要があります。トークナイザはまさにこの役割を担っているものであり、変換にはさまざまな方法があります。目的はモデルにとって最も意味のある表現を見つけることです。そして可能な限り、コンパクトな表現を見つけることも目的としています。",it,A,Jl="ここではトークン化アルゴリズムの例をいくつか見ながら、トークン化に関する疑問を解消していきます。",at,P,mt,Z,rt,D,Ul="最初に思い浮かぶトークナイズ方法は、<em>単語ベース</em> のものです。一般に、いくつかのルールを設定するだけで非常に簡単に使用でき、そして多くの場合において適切な結果を得ることができます。例えば、以下の画像のように生のテキストを単語に分割し、それぞれの数値表現を見つけることが目的です。",ft,_,Hl='<img class="block dark:hidden" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/word_based_tokenization.svg" alt="An example of word-based tokenization."/> <img class="hidden dark:block" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/word_based_tokenization-dark.svg" alt="An example of word-based tokenization."/>',ut,Q,zl="テキストの分け方にはさまざまな種類があります。例えば、Pythonの <code>split()</code> 関数を適用して、テキストを空白で区切ることで単語に分割することができます。",$t,E,ot,B,Mt,W,Vl="また、単語トークン化には句読点に関する特別なルールを持つものもあります。この種のトークナイザを使用すると、かなり大きな「語彙」が作成されることになります。語彙は、コーパスに含まれるトークンの総数で定義されます。",ct,R,Il="各単語には個別のID(0〜語彙のサイズの数値)が割り当てられます。モデルはこれらのIDを使用して各単語を識別します。",bt,G,Ll="単語ベースのトークナイザで言語を完全にカバーしようとすると、その言語の各単語に対応する識別子(ID)が必要になり、膨大な量のトークンが生成されることになります。例えば、英語には50万語以上の単語があるので、各単語から入力IDへのマップ(対応表)を作るには、それだけのIDを記録しておく必要があります。また、「dog」のような単語と「dogs」のような単語は表現が異なるため、モデルは初め “dog” と “dogs” が似ていることを知ることができず、無関係な単語として認識してしまいます。また、“run” と “running” のような類似した単語についても同様で、モデルは初期状態では類似しているとは認識できません。",yt,F,Al="最後に、語彙にない単語 (未知語)を表すためのトークンが必要です。これは “unknown” トークンと呼ばれ、”[UNK]” や ”<unk>” として表されます。トークナイザが多くの unknown トークンを生成している場合、単語の適切な表現を取得できず、情報が失われていると解釈できます。語彙を作成する際の目標は、unknownトークンにトークン化されてしまう単語(未知語)がより少なくなるようにすることです。",dt,S,Pl="unknown トークンの総数を減らす方法の1つは、<em>文字ベース</em> のトークナイザを使用することです。",xt,N,vt,X,gt,q,Zl="<em>文字ベース</em> トークナイザはテキストを単語単位ではなく文字単位で分割します。これには2つの主な利点があります。",Ct,Y,Dl="<li>語彙サイズがはるかに小さくなります</li> <li>すべての単語は文字で構成されるため、語彙外のトークン(未知語)がはるかに少なくなります</li>",kt,K,Ql="しかし、ここでも空白と句読点に関する問題が発生します。",wt,j,El='<img class="block dark:hidden" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/character_based_tokenization.svg" alt="An example of character-based tokenization."/> <img class="hidden dark:block" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/character_based_tokenization-dark.svg" alt="An example of character-based tokenization."/>',Tt,O,Bl="このアプローチも先と同様、完璧なものではありません。ここでは、表現が単語ではなく文字に基づいているので、直感的にはテキストの意味をうまく汲み取れないとも考えられます。各文字は単独ではあまり意味を持たないのに対し、単語はそのようなことはありません。しかし、言語によってはここでも違いがあります。例えば中国語の各文字は、ラテン語の文字よりも情報を持っています。(漢字1文字とアルファベット1文字では、表現している情報量が異なる場合がありますね。)",_t,ee,Wl="考慮すべきもう1つの点としては、モデルが処理する必要があるトークンの数が非常に多くなってしまうことです。単語ベースのトークナイザでは、単語は1つのトークンになりますが、文字ベースのトークナイザでは、単語は10個以上のトークンに変換される可能性があります。",jt,te,Rl="両者のいいとこ取りをするために、これらのアプローチを組み合わせた第3の手法を使用することができます。それが <em>サブワードトークン化</em> です。",ht,le,Jt,se,Ut,ne,Gl="サーブワードトークン化アルゴリズムは、「出現頻度の高い単語は小さなサブワードに分割されるべきではないが、出現頻度の低い単語は、意味を持ったサブワードに分割されるべきである」という原理に基づいています。",Ht,pe,Fl="例えば “annoyingly” は出現頻度の低い単語として扱われ、“annoying” と “ly” に分割されることがあります。これら2つのサブワードは、それぞれ単独で頻繁に出現する可能性がありますが、一方で “annoyingly” は稀な単語なので、その意味を “annoying” と “ly” の合成語として表現しようという考え方になります。",zt,ie,Sl="それではここで、サブワードトークン化アルゴリズムが “Let’s do tokenization!” という系列をトークン化する様子を見てみましょう。",Vt,h,Nl='<img class="block dark:hidden" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/bpe_subword.svg" alt="A subword tokenization algorithm."/> <img class="hidden dark:block" src="https://huggingface.co/datasets/huggingface-course/documentation-images/resolve/main/en/chapter2/bpe_subword-dark.svg" alt="A subword tokenization algorithm."/>',It,ae,Xl="これらのサブワードは最終的に、うまく意味を表現したものとして機能します。例えば上の例では “tokenization” は “token” と “ization” に分割されていましたが、これら2つのトークンは、空間効率が良く(2つのトークンだけで長い単語を表現できている)、意味論的にも有意なものとなっています。これにより、比較的小さな語彙で多くの単語をカバーすることができ、未知語がほとんど出ないようになります。",Lt,me,ql="このアプローチはトルコ語などの膠着語(機能語が自立語にくっついて文が構成される言語)において特に有効です。トルコ語では、サブワードを繋げることで(ほぼ)任意の長さの合成語を作ることができます。",At,re,Pt,fe,Yl="実は他にも多くのトークン化手法が存在し、例えば以下のようなものがあります。",Zt,ue,Kl="<li>Byte-level BPE: GPT-2で使用される手法</li> <li>WordPiece: BERTで使用される手法</li> <li>SentencePiece もしくは Unigram: いくつかの多言語モデルで使用される手法</li>",Dt,$e,Ol="ここまで読めば、APIを使ってトークナイザを使い始めるために必要な知識は十分に身についていると思います!",Qt,oe,Et,Me,es="トークナイザの読み込みと保存は、モデルと同様に簡単です。実際、これらは同じ2つのメソッド <code>from_pretrained()</code> と <code>save_pretrained()</code> に基づいています。これらのメソッドは、トークナイザが使用するアルゴリズム(モデルでいう <em>アーキテクチャ</em>)と、語彙(モデルでいう <em>重み</em>)を読み込むか保存するかを決定します。",Bt,ce,ts="BERTと同じチェックポイントで学習されたBERTトークナイザを読み込む方法は、モデルでの読み込み方法と同じです。ただし、<code>BertTokenizer</code> クラスを使う点だけが異なります。",Wt,be,Rt,qe,ye,Gt,de,ls="そして、前のセクションで見たようにトークナイザを使用することができます。",Ft,xe,St,ve,Nt,ge,ss="トークナイザの保存は、モデルの保存と同じ方法でできます。",Xt,Ce,qt,ke,ns='<code>token_type_ids</code> については<a href="/course/chapter3">Chapter3</a>で詳しく説明し、<code>attention_mask</code> についても後ほど説明します。まずは <code>input_ids</code> がどのように生成されるかを見てみましょう。',Yt,we,Kt,Te,Ot,_e,ps="テキストを数値に変換することを <em>エンコード</em> と呼びます。エンコードはトークン化とその後の入力IDへの変換の2段階のプロセスで行われます。",el,je,is="ここまで見てきたように、最初のステップはテキストをトークン(単語や単語の一部、句読点など)に分割することです。このプロセスを管理するためのルールがいくつか存在します。まずは、モデルの名前を使ってトークナイザをインスタンス化する必要があります。これにより、モデルが事前学習されたときに使用されたものと同じルールを使用することができます。",tl,he,as="2番目のステップはトークンを数値に変換することです。これにより、テンソルを構築し、モデルに入力することができます。これを行うために、トークナイザは <em>語彙</em> を有しています。これは、<code>from_pretrained()</code> メソッドでインスタンス化するときにダウンロードされる部分です。繰り返しになりますが、モデルの事前学習で使用された語彙と同じものを使用する必要があることに注意してください。",ll,Je,ms="この2つの理解を深めるために、それぞれのステップを別々に見ていきます。ステップの中間結果を表示するために、トークン化パイプラインの一部を別々に実行するメソッドを使用しますが、実際には(セクション2で見たように)入力に対して直接トークナイザを呼び出す必要があります。",sl,Ue,nl,He,rs="トークン化のプロセスは <code>tokenize()</code> メソッドによって行われます。",pl,ze,il,Ve,fs="このメソッドの出力はトークンもしくは文字のリストです。",al,Ie,ml,Le,us="ここではサブワードトークナイザを使用しているので、単語を語彙に含まれるトークンになるまで分割していきます。具体的には <code>transformer</code> が <code>transform</code> と <code>##er</code> に分割されているのがわかります。",rl,Ae,fl,Pe,$s="トークンからIDへの変換は <code>convert_tokens_to_ids()</code> のトークナイザメソッドによって行われます。",ul,Ze,$l,De,ol,Qe,os="これらの出力は、適切なフレームワークのテンソルに変換された後、前述のようにモデルの入力として使用できます。",Ml,J,cl,Ee,bl,Be,Ms="<em>デコーディング</em> はエンコーディングとは逆の処理になります。<code>decode()</code> メソッドを使うことで、語彙のインデックスから文字列を取得することができます。",yl,We,dl,Re,xl,Ge,cs="<code>decode</code> メソッドは語彙のインデックスをトークンに戻すだけでなく、同じ単語の一部であったトークンをまとめて、読みやすい文章に変換するところも担っています。この挙動は、プロンプトから生成されたテキストや、翻訳や要約などの系列から系列への変換などの問題を解くモデルを使うときに非常に役に立ちます。",vl,Fe,bs="ここまでで、トークナイザでできる基本的な処理(トークン化、IDへの変換、IDから文字列への変換)を理解できたのではないでしょうか。しかし、これは氷山の一角に過ぎません。次のセクションでは、これらの処理を限界まで拡張していき、その限界を超える方法を見ていきましょう。",gl,Se,Cl,Ye,kl;T=new Is({props:{fw:v[0]}}),U=new k({props:{title:"トークナイザ",local:"トークナイザ",headingTag:"h1"}});const ys=[Ps,As],Ne=[];function ds(e,t){return e[0]==="pt"?0:1}g=ds(v),C=Ne[g]=ys[g](v),H=new Oe({props:{id:"VFp38yj8h3A"}}),I=new x({props:{code:"SmltJTIwSGVuc29uJTIwd2FzJTIwYSUyMHB1cHBldGVlciUyMCVFRiVCQyU4OEppbSUyMEhlbnNvbiVFMyU4MSVBRiVFNCVCQSVCQSVFNSVCRCVBMiVFNSVCOCVBQiVFMyU4MSVBNyVFMyU4MSU5NyVFMyU4MSU5RiVFRiVCQyU4OQ==",highlighted:'<span class="hljs-keyword">Jim </span>Henson was a puppeteer (<span class="hljs-keyword">Jim </span>Hensonは人形師でした)',wrap:!1}}),P=new k({props:{title:"単語ベース",local:"単語ベース",headingTag:"h2"}}),Z=new Oe({props:{id:"nhJxYji1aho"}}),E=new x({props:{code:"dG9rZW5pemVkX3RleHQlMjAlM0QlMjAlMjJKaW0lMjBIZW5zb24lMjB3YXMlMjBhJTIwcHVwcGV0ZWVyJTIyLnNwbGl0KCklMEFwcmludCh0b2tlbml6ZWRfdGV4dCk=",highlighted:`tokenized_text = <span class="hljs-string">"Jim Henson was a puppeteer"</span>.split() | |
| <span class="hljs-built_in">print</span>(tokenized_text)`,wrap:!1}}),B=new x({props:{code:"JTVCJ0ppbSclMkMlMjAnSGVuc29uJyUyQyUyMCd3YXMnJTJDJTIwJ2EnJTJDJTIwJ3B1cHBldGVlciclNUQ=",highlighted:'[<span class="hljs-string">'Jim'</span>, <span class="hljs-string">'Henson'</span>, <span class="hljs-string">'was'</span>, <span class="hljs-string">'a'</span>, <span class="hljs-string">'puppeteer'</span>]',wrap:!1}}),N=new k({props:{title:"文字ベース",local:"文字ベース",headingTag:"h2"}}),X=new Oe({props:{id:"ssLq_EK2jLE"}}),le=new k({props:{title:"サブワードトークン化",local:"サブワードトークン化",headingTag:"h2"}}),se=new Oe({props:{id:"zHvTiHr506c"}}),re=new k({props:{title:"さらなるトークン化手法!",local:"さらなるトークン化手法",headingTag:"h3"}}),oe=new k({props:{title:"読み込みと保存",local:"読み込みと保存",headingTag:"h2"}}),be=new x({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEJlcnRUb2tlbml6ZXIlMEElMEF0b2tlbml6ZXIlMjAlM0QlMjBCZXJ0VG9rZW5pemVyLmZyb21fcHJldHJhaW5lZCglMjJiZXJ0LWJhc2UtY2FzZWQlMjIp",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> BertTokenizer | |
| tokenizer = BertTokenizer.from_pretrained(<span class="hljs-string">"bert-base-cased"</span>)`,wrap:!1}});function xs(e,t){return e[0]==="pt"?Ds:Zs}let wl=xs(v),w=wl(v);return ye=new x({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEF1dG9Ub2tlbml6ZXIlMEElMEF0b2tlbml6ZXIlMjAlM0QlMjBBdXRvVG9rZW5pemVyLmZyb21fcHJldHJhaW5lZCglMjJiZXJ0LWJhc2UtY2FzZWQlMjIp",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoTokenizer | |
| tokenizer = AutoTokenizer.from_pretrained(<span class="hljs-string">"bert-base-cased"</span>)`,wrap:!1}}),xe=new x({props:{code:"dG9rZW5pemVyKCUyMlVzaW5nJTIwYSUyMFRyYW5zZm9ybWVyJTIwbmV0d29yayUyMGlzJTIwc2ltcGxlJTIyKQ==",highlighted:'tokenizer(<span class="hljs-string">"Using a Transformer network is simple"</span>)',wrap:!1}}),ve=new x({props:{code:"JTdCJ2lucHV0X2lkcyclM0ElMjAlNUIxMDElMkMlMjA3OTkzJTJDJTIwMTcwJTJDJTIwMTEzMDMlMkMlMjAxMjAwJTJDJTIwMjQ0MyUyQyUyMDExMTAlMkMlMjAzMDE0JTJDJTIwMTAyJTVEJTJDJTBBJTIwJ3Rva2VuX3R5cGVfaWRzJyUzQSUyMCU1QjAlMkMlMjAwJTJDJTIwMCUyQyUyMDAlMkMlMjAwJTJDJTIwMCUyQyUyMDAlMkMlMjAwJTJDJTIwMCU1RCUyQyUwQSUyMCdhdHRlbnRpb25fbWFzayclM0ElMjAlNUIxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElMkMlMjAxJTJDJTIwMSUyQyUyMDElNUQlN0Q=",highlighted:`{<span class="hljs-string">'input_ids'</span>: [<span class="hljs-number">101</span>, <span class="hljs-number">7993</span>, <span class="hljs-number">170</span>, <span class="hljs-number">11303</span>, <span class="hljs-number">1200</span>, <span class="hljs-number">2443</span>, <span class="hljs-number">1110</span>, <span class="hljs-number">3014</span>, <span class="hljs-number">102</span>], | |
| <span class="hljs-string">'token_type_ids'</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>], | |
| <span class="hljs-string">'attention_mask'</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>]}`,wrap:!1}}),Ce=new x({props:{code:"dG9rZW5pemVyLnNhdmVfcHJldHJhaW5lZCglMjJkaXJlY3Rvcnlfb25fbXlfY29tcHV0ZXIlMjIp",highlighted:'tokenizer.save_pretrained(<span class="hljs-string">"directory_on_my_computer"</span>)',wrap:!1}}),we=new k({props:{title:"エンコーディング",local:"エンコーディング",headingTag:"h2"}}),Te=new Oe({props:{id:"Yffk5aydLzg"}}),Ue=new k({props:{title:"トークン化",local:"トークン化",headingTag:"h3"}}),ze=new x({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEF1dG9Ub2tlbml6ZXIlMEElMEF0b2tlbml6ZXIlMjAlM0QlMjBBdXRvVG9rZW5pemVyLmZyb21fcHJldHJhaW5lZCglMjJiZXJ0LWJhc2UtY2FzZWQlMjIpJTBBJTBBc2VxdWVuY2UlMjAlM0QlMjAlMjJVc2luZyUyMGElMjBUcmFuc2Zvcm1lciUyMG5ldHdvcmslMjBpcyUyMHNpbXBsZSUyMiUwQXRva2VucyUyMCUzRCUyMHRva2VuaXplci50b2tlbml6ZShzZXF1ZW5jZSklMEElMEFwcmludCh0b2tlbnMp",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoTokenizer | |
| tokenizer = AutoTokenizer.from_pretrained(<span class="hljs-string">"bert-base-cased"</span>) | |
| sequence = <span class="hljs-string">"Using a Transformer network is simple"</span> | |
| tokens = tokenizer.tokenize(sequence) | |
| <span class="hljs-built_in">print</span>(tokens)`,wrap:!1}}),Ie=new x({props:{code:"JTVCJ1VzaW5nJyUyQyUyMCdhJyUyQyUyMCd0cmFuc2Zvcm0nJTJDJTIwJyUyMyUyM2VyJyUyQyUyMCduZXR3b3JrJyUyQyUyMCdpcyclMkMlMjAnc2ltcGxlJyU1RA==",highlighted:'[<span class="hljs-string">'Using'</span>, <span class="hljs-string">'a'</span>, <span class="hljs-string">'transform'</span>, <span class="hljs-string">'##er'</span>, <span class="hljs-string">'network'</span>, <span class="hljs-string">'is'</span>, <span class="hljs-string">'simple'</span>]',wrap:!1}}),Ae=new k({props:{title:"トークンからIDへの変換",local:"トークンからidへの変換",headingTag:"h3"}}),Ze=new x({props:{code:"aWRzJTIwJTNEJTIwdG9rZW5pemVyLmNvbnZlcnRfdG9rZW5zX3RvX2lkcyh0b2tlbnMpJTBBJTBBcHJpbnQoaWRzKQ==",highlighted:`ids = tokenizer.convert_tokens_to_ids(tokens) | |
| <span class="hljs-built_in">print</span>(ids)`,wrap:!1}}),De=new x({props:{code:"JTVCNzk5MyUyQyUyMDE3MCUyQyUyMDExMzAzJTJDJTIwMTIwMCUyQyUyMDI0NDMlMkMlMjAxMTEwJTJDJTIwMzAxNCU1RA==",highlighted:'[<span class="hljs-number">7993</span>, <span class="hljs-number">170</span>, <span class="hljs-number">11303</span>, <span class="hljs-number">1200</span>, <span class="hljs-number">2443</span>, <span class="hljs-number">1110</span>, <span class="hljs-number">3014</span>]',wrap:!1}}),J=new Vs({props:{$$slots:{default:[Qs]},$$scope:{ctx:v}}}),Ee=new k({props:{title:"デコーディング",local:"デコーディング",headingTag:"h2"}}),We=new x({props:{code:"ZGVjb2RlZF9zdHJpbmclMjAlM0QlMjB0b2tlbml6ZXIuZGVjb2RlKCU1Qjc5OTMlMkMlMjAxNzAlMkMlMjAxMTMwMyUyQyUyMDEyMDAlMkMlMjAyNDQzJTJDJTIwMTExMCUyQyUyMDMwMTQlNUQpJTBBcHJpbnQoZGVjb2RlZF9zdHJpbmcp",highlighted:`decoded_string = tokenizer.decode([<span class="hljs-number">7993</span>, <span class="hljs-number">170</span>, <span class="hljs-number">11303</span>, <span class="hljs-number">1200</span>, <span class="hljs-number">2443</span>, <span class="hljs-number">1110</span>, <span class="hljs-number">3014</span>]) | |
| <span class="hljs-built_in">print</span>(decoded_string)`,wrap:!1}}),Re=new x({props:{code:"J1VzaW5nJTIwYSUyMFRyYW5zZm9ybWVyJTIwbmV0d29yayUyMGlzJTIwc2ltcGxlJw==",highlighted:'<span class="hljs-string">'Using a Transformer network is simple'</span>',wrap:!1}}),Se=new Ls({props:{source:"https://github.com/huggingface/course/blob/main/chapters/ja/chapter2/4.mdx"}}),{c(){m=i("meta"),y=n(),f=i("p"),d=n(),o(T.$$.fragment),et=n(),o(U.$$.fragment),tt=n(),C.c(),Xe=n(),o(H.$$.fragment),lt=n(),z=i("p"),z.textContent=_l,st=n(),V=i("p"),V.textContent=jl,nt=n(),o(I.$$.fragment),pt=n(),L=i("p"),L.textContent=hl,it=n(),A=i("p"),A.textContent=Jl,at=n(),o(P.$$.fragment),mt=n(),o(Z.$$.fragment),rt=n(),D=i("p"),D.innerHTML=Ul,ft=n(),_=i("div"),_.innerHTML=Hl,ut=n(),Q=i("p"),Q.innerHTML=zl,$t=n(),o(E.$$.fragment),ot=n(),o(B.$$.fragment),Mt=n(),W=i("p"),W.textContent=Vl,ct=n(),R=i("p"),R.textContent=Il,bt=n(),G=i("p"),G.textContent=Ll,yt=n(),F=i("p"),F.textContent=Al,dt=n(),S=i("p"),S.innerHTML=Pl,xt=n(),o(N.$$.fragment),vt=n(),o(X.$$.fragment),gt=n(),q=i("p"),q.innerHTML=Zl,Ct=n(),Y=i("ul"),Y.innerHTML=Dl,kt=n(),K=i("p"),K.textContent=Ql,wt=n(),j=i("div"),j.innerHTML=El,Tt=n(),O=i("p"),O.textContent=Bl,_t=n(),ee=i("p"),ee.textContent=Wl,jt=n(),te=i("p"),te.innerHTML=Rl,ht=n(),o(le.$$.fragment),Jt=n(),o(se.$$.fragment),Ut=n(),ne=i("p"),ne.textContent=Gl,Ht=n(),pe=i("p"),pe.textContent=Fl,zt=n(),ie=i("p"),ie.textContent=Sl,Vt=n(),h=i("div"),h.innerHTML=Nl,It=n(),ae=i("p"),ae.textContent=Xl,Lt=n(),me=i("p"),me.textContent=ql,At=n(),o(re.$$.fragment),Pt=n(),fe=i("p"),fe.textContent=Yl,Zt=n(),ue=i("ul"),ue.innerHTML=Kl,Dt=n(),$e=i("p"),$e.textContent=Ol,Qt=n(),o(oe.$$.fragment),Et=n(),Me=i("p"),Me.innerHTML=es,Bt=n(),ce=i("p"),ce.innerHTML=ts,Wt=n(),o(be.$$.fragment),Rt=n(),w.c(),qe=n(),o(ye.$$.fragment),Gt=n(),de=i("p"),de.textContent=ls,Ft=n(),o(xe.$$.fragment),St=n(),o(ve.$$.fragment),Nt=n(),ge=i("p"),ge.textContent=ss,Xt=n(),o(Ce.$$.fragment),qt=n(),ke=i("p"),ke.innerHTML=ns,Yt=n(),o(we.$$.fragment),Kt=n(),o(Te.$$.fragment),Ot=n(),_e=i("p"),_e.innerHTML=ps,el=n(),je=i("p"),je.textContent=is,tl=n(),he=i("p"),he.innerHTML=as,ll=n(),Je=i("p"),Je.textContent=ms,sl=n(),o(Ue.$$.fragment),nl=n(),He=i("p"),He.innerHTML=rs,pl=n(),o(ze.$$.fragment),il=n(),Ve=i("p"),Ve.textContent=fs,al=n(),o(Ie.$$.fragment),ml=n(),Le=i("p"),Le.innerHTML=us,rl=n(),o(Ae.$$.fragment),fl=n(),Pe=i("p"),Pe.innerHTML=$s,ul=n(),o(Ze.$$.fragment),$l=n(),o(De.$$.fragment),ol=n(),Qe=i("p"),Qe.textContent=os,Ml=n(),o(J.$$.fragment),cl=n(),o(Ee.$$.fragment),bl=n(),Be=i("p"),Be.innerHTML=Ms,yl=n(),o(We.$$.fragment),dl=n(),o(Re.$$.fragment),xl=n(),Ge=i("p"),Ge.innerHTML=cs,vl=n(),Fe=i("p"),Fe.textContent=bs,gl=n(),o(Se.$$.fragment),Cl=n(),Ye=i("p"),this.h()},l(e){const t=Js("svelte-u9bgzb",document.head);m=a(t,"META",{name:!0,content:!0}),t.forEach(l),y=p(e),f=a(e,"P",{}),Cs(f).forEach(l),d=p(e),M(T.$$.fragment,e),et=p(e),M(U.$$.fragment,e),tt=p(e),C.l(e),Xe=p(e),M(H.$$.fragment,e),lt=p(e),z=a(e,"P",{"data-svelte-h":!0}),r(z)!=="svelte-95gf60"&&(z.textContent=_l),st=p(e),V=a(e,"P",{"data-svelte-h":!0}),r(V)!=="svelte-7978fk"&&(V.textContent=jl),nt=p(e),M(I.$$.fragment,e),pt=p(e),L=a(e,"P",{"data-svelte-h":!0}),r(L)!=="svelte-e0gc2l"&&(L.textContent=hl),it=p(e),A=a(e,"P",{"data-svelte-h":!0}),r(A)!=="svelte-kc8t4k"&&(A.textContent=Jl),at=p(e),M(P.$$.fragment,e),mt=p(e),M(Z.$$.fragment,e),rt=p(e),D=a(e,"P",{"data-svelte-h":!0}),r(D)!=="svelte-14863s6"&&(D.innerHTML=Ul),ft=p(e),_=a(e,"DIV",{class:!0,"data-svelte-h":!0}),r(_)!=="svelte-1qoje79"&&(_.innerHTML=Hl),ut=p(e),Q=a(e,"P",{"data-svelte-h":!0}),r(Q)!=="svelte-jn25uo"&&(Q.innerHTML=zl),$t=p(e),M(E.$$.fragment,e),ot=p(e),M(B.$$.fragment,e),Mt=p(e),W=a(e,"P",{"data-svelte-h":!0}),r(W)!=="svelte-beu23e"&&(W.textContent=Vl),ct=p(e),R=a(e,"P",{"data-svelte-h":!0}),r(R)!=="svelte-1eavrvo"&&(R.textContent=Il),bt=p(e),G=a(e,"P",{"data-svelte-h":!0}),r(G)!=="svelte-1rysxdn"&&(G.textContent=Ll),yt=p(e),F=a(e,"P",{"data-svelte-h":!0}),r(F)!=="svelte-1o785hk"&&(F.textContent=Al),dt=p(e),S=a(e,"P",{"data-svelte-h":!0}),r(S)!=="svelte-1t4ivev"&&(S.innerHTML=Pl),xt=p(e),M(N.$$.fragment,e),vt=p(e),M(X.$$.fragment,e),gt=p(e),q=a(e,"P",{"data-svelte-h":!0}),r(q)!=="svelte-1rt4144"&&(q.innerHTML=Zl),Ct=p(e),Y=a(e,"UL",{"data-svelte-h":!0}),r(Y)!=="svelte-1fidb1u"&&(Y.innerHTML=Dl),kt=p(e),K=a(e,"P",{"data-svelte-h":!0}),r(K)!=="svelte-sxe1fk"&&(K.textContent=Ql),wt=p(e),j=a(e,"DIV",{class:!0,"data-svelte-h":!0}),r(j)!=="svelte-cwc099"&&(j.innerHTML=El),Tt=p(e),O=a(e,"P",{"data-svelte-h":!0}),r(O)!=="svelte-1y7wu37"&&(O.textContent=Bl),_t=p(e),ee=a(e,"P",{"data-svelte-h":!0}),r(ee)!=="svelte-1g38ez5"&&(ee.textContent=Wl),jt=p(e),te=a(e,"P",{"data-svelte-h":!0}),r(te)!=="svelte-18tbt4n"&&(te.innerHTML=Rl),ht=p(e),M(le.$$.fragment,e),Jt=p(e),M(se.$$.fragment,e),Ut=p(e),ne=a(e,"P",{"data-svelte-h":!0}),r(ne)!=="svelte-11qzak6"&&(ne.textContent=Gl),Ht=p(e),pe=a(e,"P",{"data-svelte-h":!0}),r(pe)!=="svelte-vepzf5"&&(pe.textContent=Fl),zt=p(e),ie=a(e,"P",{"data-svelte-h":!0}),r(ie)!=="svelte-zsim5a"&&(ie.textContent=Sl),Vt=p(e),h=a(e,"DIV",{class:!0,"data-svelte-h":!0}),r(h)!=="svelte-l1uqeh"&&(h.innerHTML=Nl),It=p(e),ae=a(e,"P",{"data-svelte-h":!0}),r(ae)!=="svelte-18intiv"&&(ae.textContent=Xl),Lt=p(e),me=a(e,"P",{"data-svelte-h":!0}),r(me)!=="svelte-1ehs25d"&&(me.textContent=ql),At=p(e),M(re.$$.fragment,e),Pt=p(e),fe=a(e,"P",{"data-svelte-h":!0}),r(fe)!=="svelte-1dojfju"&&(fe.textContent=Yl),Zt=p(e),ue=a(e,"UL",{"data-svelte-h":!0}),r(ue)!=="svelte-1wwsvin"&&(ue.innerHTML=Kl),Dt=p(e),$e=a(e,"P",{"data-svelte-h":!0}),r($e)!=="svelte-1ff03l4"&&($e.textContent=Ol),Qt=p(e),M(oe.$$.fragment,e),Et=p(e),Me=a(e,"P",{"data-svelte-h":!0}),r(Me)!=="svelte-ompgzp"&&(Me.innerHTML=es),Bt=p(e),ce=a(e,"P",{"data-svelte-h":!0}),r(ce)!=="svelte-1wfct7l"&&(ce.innerHTML=ts),Wt=p(e),M(be.$$.fragment,e),Rt=p(e),w.l(e),qe=p(e),M(ye.$$.fragment,e),Gt=p(e),de=a(e,"P",{"data-svelte-h":!0}),r(de)!=="svelte-18ssk57"&&(de.textContent=ls),Ft=p(e),M(xe.$$.fragment,e),St=p(e),M(ve.$$.fragment,e),Nt=p(e),ge=a(e,"P",{"data-svelte-h":!0}),r(ge)!=="svelte-7infmh"&&(ge.textContent=ss),Xt=p(e),M(Ce.$$.fragment,e),qt=p(e),ke=a(e,"P",{"data-svelte-h":!0}),r(ke)!=="svelte-1h07ivy"&&(ke.innerHTML=ns),Yt=p(e),M(we.$$.fragment,e),Kt=p(e),M(Te.$$.fragment,e),Ot=p(e),_e=a(e,"P",{"data-svelte-h":!0}),r(_e)!=="svelte-ve068o"&&(_e.innerHTML=ps),el=p(e),je=a(e,"P",{"data-svelte-h":!0}),r(je)!=="svelte-135n4r3"&&(je.textContent=is),tl=p(e),he=a(e,"P",{"data-svelte-h":!0}),r(he)!=="svelte-18yikfl"&&(he.innerHTML=as),ll=p(e),Je=a(e,"P",{"data-svelte-h":!0}),r(Je)!=="svelte-14gw7o7"&&(Je.textContent=ms),sl=p(e),M(Ue.$$.fragment,e),nl=p(e),He=a(e,"P",{"data-svelte-h":!0}),r(He)!=="svelte-16gfxvc"&&(He.innerHTML=rs),pl=p(e),M(ze.$$.fragment,e),il=p(e),Ve=a(e,"P",{"data-svelte-h":!0}),r(Ve)!=="svelte-543lb9"&&(Ve.textContent=fs),al=p(e),M(Ie.$$.fragment,e),ml=p(e),Le=a(e,"P",{"data-svelte-h":!0}),r(Le)!=="svelte-jbp3gs"&&(Le.innerHTML=us),rl=p(e),M(Ae.$$.fragment,e),fl=p(e),Pe=a(e,"P",{"data-svelte-h":!0}),r(Pe)!=="svelte-1ioswlc"&&(Pe.innerHTML=$s),ul=p(e),M(Ze.$$.fragment,e),$l=p(e),M(De.$$.fragment,e),ol=p(e),Qe=a(e,"P",{"data-svelte-h":!0}),r(Qe)!=="svelte-vnqzlw"&&(Qe.textContent=os),Ml=p(e),M(J.$$.fragment,e),cl=p(e),M(Ee.$$.fragment,e),bl=p(e),Be=a(e,"P",{"data-svelte-h":!0}),r(Be)!=="svelte-1pitvhl"&&(Be.innerHTML=Ms),yl=p(e),M(We.$$.fragment,e),dl=p(e),M(Re.$$.fragment,e),xl=p(e),Ge=a(e,"P",{"data-svelte-h":!0}),r(Ge)!=="svelte-93yina"&&(Ge.innerHTML=cs),vl=p(e),Fe=a(e,"P",{"data-svelte-h":!0}),r(Fe)!=="svelte-1m4m0f3"&&(Fe.textContent=bs),gl=p(e),M(Se.$$.fragment,e),Cl=p(e),Ye=a(e,"P",{}),Cs(Ye).forEach(l),this.h()},h(){Ke(m,"name","hf:doc:metadata"),Ke(m,"content",Bs),Ke(_,"class","flex justify-center"),Ke(j,"class","flex justify-center"),Ke(h,"class","flex justify-center")},m(e,t){Us(document.head,m),s(e,y,t),s(e,f,t),s(e,d,t),c(T,e,t),s(e,et,t),c(U,e,t),s(e,tt,t),Ne[g].m(e,t),s(e,Xe,t),c(H,e,t),s(e,lt,t),s(e,z,t),s(e,st,t),s(e,V,t),s(e,nt,t),c(I,e,t),s(e,pt,t),s(e,L,t),s(e,it,t),s(e,A,t),s(e,at,t),c(P,e,t),s(e,mt,t),c(Z,e,t),s(e,rt,t),s(e,D,t),s(e,ft,t),s(e,_,t),s(e,ut,t),s(e,Q,t),s(e,$t,t),c(E,e,t),s(e,ot,t),c(B,e,t),s(e,Mt,t),s(e,W,t),s(e,ct,t),s(e,R,t),s(e,bt,t),s(e,G,t),s(e,yt,t),s(e,F,t),s(e,dt,t),s(e,S,t),s(e,xt,t),c(N,e,t),s(e,vt,t),c(X,e,t),s(e,gt,t),s(e,q,t),s(e,Ct,t),s(e,Y,t),s(e,kt,t),s(e,K,t),s(e,wt,t),s(e,j,t),s(e,Tt,t),s(e,O,t),s(e,_t,t),s(e,ee,t),s(e,jt,t),s(e,te,t),s(e,ht,t),c(le,e,t),s(e,Jt,t),c(se,e,t),s(e,Ut,t),s(e,ne,t),s(e,Ht,t),s(e,pe,t),s(e,zt,t),s(e,ie,t),s(e,Vt,t),s(e,h,t),s(e,It,t),s(e,ae,t),s(e,Lt,t),s(e,me,t),s(e,At,t),c(re,e,t),s(e,Pt,t),s(e,fe,t),s(e,Zt,t),s(e,ue,t),s(e,Dt,t),s(e,$e,t),s(e,Qt,t),c(oe,e,t),s(e,Et,t),s(e,Me,t),s(e,Bt,t),s(e,ce,t),s(e,Wt,t),c(be,e,t),s(e,Rt,t),w.m(e,t),s(e,qe,t),c(ye,e,t),s(e,Gt,t),s(e,de,t),s(e,Ft,t),c(xe,e,t),s(e,St,t),c(ve,e,t),s(e,Nt,t),s(e,ge,t),s(e,Xt,t),c(Ce,e,t),s(e,qt,t),s(e,ke,t),s(e,Yt,t),c(we,e,t),s(e,Kt,t),c(Te,e,t),s(e,Ot,t),s(e,_e,t),s(e,el,t),s(e,je,t),s(e,tl,t),s(e,he,t),s(e,ll,t),s(e,Je,t),s(e,sl,t),c(Ue,e,t),s(e,nl,t),s(e,He,t),s(e,pl,t),c(ze,e,t),s(e,il,t),s(e,Ve,t),s(e,al,t),c(Ie,e,t),s(e,ml,t),s(e,Le,t),s(e,rl,t),c(Ae,e,t),s(e,fl,t),s(e,Pe,t),s(e,ul,t),c(Ze,e,t),s(e,$l,t),c(De,e,t),s(e,ol,t),s(e,Qe,t),s(e,Ml,t),c(J,e,t),s(e,cl,t),c(Ee,e,t),s(e,bl,t),s(e,Be,t),s(e,yl,t),c(We,e,t),s(e,dl,t),c(Re,e,t),s(e,xl,t),s(e,Ge,t),s(e,vl,t),s(e,Fe,t),s(e,gl,t),c(Se,e,t),s(e,Cl,t),s(e,Ye,t),kl=!0},p(e,[t]){const vs={};t&1&&(vs.fw=e[0]),T.$set(vs);let Tl=g;g=ds(e),g!==Tl&&(zs(),u(Ne[Tl],1,1,()=>{Ne[Tl]=null}),Hs(),C=Ne[g],C||(C=Ne[g]=ys[g](e),C.c()),$(C,1),C.m(Xe.parentNode,Xe)),wl!==(wl=xs(e))&&(w.d(1),w=wl(e),w&&(w.c(),w.m(qe.parentNode,qe)));const gs={};t&2&&(gs.$$scope={dirty:t,ctx:e}),J.$set(gs)},i(e){kl||($(T.$$.fragment,e),$(U.$$.fragment,e),$(C),$(H.$$.fragment,e),$(I.$$.fragment,e),$(P.$$.fragment,e),$(Z.$$.fragment,e),$(E.$$.fragment,e),$(B.$$.fragment,e),$(N.$$.fragment,e),$(X.$$.fragment,e),$(le.$$.fragment,e),$(se.$$.fragment,e),$(re.$$.fragment,e),$(oe.$$.fragment,e),$(be.$$.fragment,e),$(ye.$$.fragment,e),$(xe.$$.fragment,e),$(ve.$$.fragment,e),$(Ce.$$.fragment,e),$(we.$$.fragment,e),$(Te.$$.fragment,e),$(Ue.$$.fragment,e),$(ze.$$.fragment,e),$(Ie.$$.fragment,e),$(Ae.$$.fragment,e),$(Ze.$$.fragment,e),$(De.$$.fragment,e),$(J.$$.fragment,e),$(Ee.$$.fragment,e),$(We.$$.fragment,e),$(Re.$$.fragment,e),$(Se.$$.fragment,e),kl=!0)},o(e){u(T.$$.fragment,e),u(U.$$.fragment,e),u(C),u(H.$$.fragment,e),u(I.$$.fragment,e),u(P.$$.fragment,e),u(Z.$$.fragment,e),u(E.$$.fragment,e),u(B.$$.fragment,e),u(N.$$.fragment,e),u(X.$$.fragment,e),u(le.$$.fragment,e),u(se.$$.fragment,e),u(re.$$.fragment,e),u(oe.$$.fragment,e),u(be.$$.fragment,e),u(ye.$$.fragment,e),u(xe.$$.fragment,e),u(ve.$$.fragment,e),u(Ce.$$.fragment,e),u(we.$$.fragment,e),u(Te.$$.fragment,e),u(Ue.$$.fragment,e),u(ze.$$.fragment,e),u(Ie.$$.fragment,e),u(Ae.$$.fragment,e),u(Ze.$$.fragment,e),u(De.$$.fragment,e),u(J.$$.fragment,e),u(Ee.$$.fragment,e),u(We.$$.fragment,e),u(Re.$$.fragment,e),u(Se.$$.fragment,e),kl=!1},d(e){e&&(l(y),l(f),l(d),l(et),l(tt),l(Xe),l(lt),l(z),l(st),l(V),l(nt),l(pt),l(L),l(it),l(A),l(at),l(mt),l(rt),l(D),l(ft),l(_),l(ut),l(Q),l($t),l(ot),l(Mt),l(W),l(ct),l(R),l(bt),l(G),l(yt),l(F),l(dt),l(S),l(xt),l(vt),l(gt),l(q),l(Ct),l(Y),l(kt),l(K),l(wt),l(j),l(Tt),l(O),l(_t),l(ee),l(jt),l(te),l(ht),l(Jt),l(Ut),l(ne),l(Ht),l(pe),l(zt),l(ie),l(Vt),l(h),l(It),l(ae),l(Lt),l(me),l(At),l(Pt),l(fe),l(Zt),l(ue),l(Dt),l($e),l(Qt),l(Et),l(Me),l(Bt),l(ce),l(Wt),l(Rt),l(qe),l(Gt),l(de),l(Ft),l(St),l(Nt),l(ge),l(Xt),l(qt),l(ke),l(Yt),l(Kt),l(Ot),l(_e),l(el),l(je),l(tl),l(he),l(ll),l(Je),l(sl),l(nl),l(He),l(pl),l(il),l(Ve),l(al),l(ml),l(Le),l(rl),l(fl),l(Pe),l(ul),l($l),l(ol),l(Qe),l(Ml),l(cl),l(bl),l(Be),l(yl),l(dl),l(xl),l(Ge),l(vl),l(Fe),l(gl),l(Cl),l(Ye)),l(m),b(T,e),b(U,e),Ne[g].d(e),b(H,e),b(I,e),b(P,e),b(Z,e),b(E,e),b(B,e),b(N,e),b(X,e),b(le,e),b(se,e),b(re,e),b(oe,e),b(be,e),w.d(e),b(ye,e),b(xe,e),b(ve,e),b(Ce,e),b(we,e),b(Te,e),b(Ue,e),b(ze,e),b(Ie,e),b(Ae,e),b(Ze,e),b(De,e),b(J,e),b(Ee,e),b(We,e),b(Re,e),b(Se,e)}}}const Bs='{"title":"トークナイザ","local":"トークナイザ","sections":[{"title":"単語ベース","local":"単語ベース","sections":[],"depth":2},{"title":"文字ベース","local":"文字ベース","sections":[],"depth":2},{"title":"サブワードトークン化","local":"サブワードトークン化","sections":[{"title":"さらなるトークン化手法!","local":"さらなるトークン化手法","sections":[],"depth":3}],"depth":2},{"title":"読み込みと保存","local":"読み込みと保存","sections":[],"depth":2},{"title":"エンコーディング","local":"エンコーディング","sections":[{"title":"トークン化","local":"トークン化","sections":[],"depth":3},{"title":"トークンからIDへの変換","local":"トークンからidへの変換","sections":[],"depth":3}],"depth":2},{"title":"デコーディング","local":"デコーディング","sections":[],"depth":2}],"depth":1}';function Ws(v,m,y){let f="pt";return Ts(()=>{const d=new URLSearchParams(window.location.search);y(0,f=d.get("fw")||"pt")}),[f]}class Ks extends js{constructor(m){super(),hs(this,m,Ws,Es,ws,{})}}export{Ks as component}; | |
Xet Storage Details
- Size:
- 38.8 kB
- Xet hash:
- 64d1473c124b91d254fee795671c68d3a959710d8914bddce479e1956d0debfd
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.