Buckets:

rtrm's picture
download
raw
16.8 kB
import{s as it,o as lt,n as nt}from"../chunks/scheduler.36a0863c.js";import{S as ot,i as at,g as a,s as n,r as m,A as st,h as s,f as i,c as o,j as et,u,x as r,k as tt,y as rt,a as l,v as d,d as c,t as f,w as b}from"../chunks/index.9c13489a.js";import{T as pt}from"../chunks/Tip.3b06990e.js";import{C as je}from"../chunks/CodeBlock.05d8ec32.js";import{H as S,E as mt}from"../chunks/EditOnGithub.e88f2b7b.js";function ut(D){let p,z="Nota che questa funzione può essere utilizzata anche nelle configurazioni multi GPU.";return{c(){p=a("p"),p.textContent=z},l(g){p=s(g,"P",{"data-svelte-h":!0}),r(p)!=="svelte-vzcdbv"&&(p.textContent=z)},m(g,O){l(g,p,O)},p:nt,d(g){g&&i(p)}}}function dt(D){let p,z,g,O,$,ee,T,Ie='Questo documento sarà presto completato con informazioni su come effetture l’inferenza su una singola GPU. Nel frattempo è possibile consultare <a href="perf_train_gpu_one">la guida per l’addestramento su una singola GPU</a> e <a href="perf_infer_cpu">la guida per l’inferenza su CPU</a>.',te,y,ie,v,Fe='Abbiamo recentemente integrato <code>BetterTransformer</code> per velocizzare l’inferenza su GPU per modelli di testo, immagini e audio. Per maggiori dettagli, consultare la documentazione su questa integrazione <a href="https://huggingface.co/docs/optimum/bettertransformer/overview" rel="nofollow">qui</a>.',le,h,ne,M,oe,U,Pe=`Dal paper <a href="https://arxiv.org/abs/2208.07339" rel="nofollow"><code>LLM.int8() : 8-bit Matrix Multiplication for Transformers at Scale</code></a>, noi supportiamo l’integrazione di Hugging Face per tutti i modelli dell’Hub con poche righe di codice.
Il metodo <code>nn.Linear</code> riduce la dimensione di 2 per i pesi <code>float16</code> e <code>bfloat16</code> e di 4 per i pesi <code>float32</code>, con un impatto quasi nullo sulla qualità, operando sugli outlier in half-precision.`,ae,x,Re='<img src="https://cdn-uploads.huggingface.co/production/uploads/1659861207959-62441d1d9fdefb55a0b7d12c.png" alt="HFxbitsandbytes.png"/>',se,_,Ee=`Il metodo Int8 mixed-precision matrix decomposition funziona separando la moltiplicazione tra matrici in due flussi: (1) una matrice di flusso di outlier di caratteristiche sistematiche moltiplicata in fp16, (2) in flusso regolare di moltiplicazione di matrici int8 (99,9%). Con questo metodo, è possibile effettutare inferenza int8 per modelli molto grandi senza degrado predittivo.
Per maggiori dettagli sul metodo, consultare il <a href="https://arxiv.org/abs/2208.07339" rel="nofollow">paper</a> o il nostro <a href="https://huggingface.co/blog/hf-bitsandbytes-integration" rel="nofollow">blogpost sull’integrazione</a>.`,re,C,ke='<img src="https://cdn-uploads.huggingface.co/production/uploads/1660567469965-62441d1d9fdefb55a0b7d12c.gif" alt="MixedInt8.gif"/>',pe,G,qe=`Nota che è necessaria una GPU per eseguire modelli di tipo mixed-8bit, poiché i kernel sono stati compilati solo per le GPU. Prima di utilizzare questa funzione, assicurarsi di disporre di memoria sufficiente sulla GPU per memorizzare un quarto del modello (o la metà se i pesi del modello sono in mezza precisione).
Di seguito sono riportate alcune note per aiutarvi a utilizzare questo modulo, oppure seguite le dimostrazioni su <a href="#colab-demos">Google colab</a>.`,me,J,ue,w,Be=`<li>Se si dispone di <code>bitsandbytes&lt;0.37.0</code>, assicurarsi di eseguire su GPU NVIDIA che supportano tensor cores a 8 bit (Turing, Ampere o architetture più recenti - ad esempio T4, RTX20s RTX30s, A40-A100). Per <code>bitsandbytes&gt;=0.37.0</code>, tutte le GPU dovrebbero essere supportate.</li> <li>Installare la versione corretta di <code>bitsandbytes</code> eseguendo:
<code>pip install bitsandbytes&gt;=0.31.5</code>.</li> <li>Installare <code>accelerate</code> <code>pip install accelerate&gt;=0.12.0</code></li>`,de,Z,ce,W,Ve="Dopo aver installato le librerie necessarie, per caricare il tuo modello mixed 8-bit è il seguente:",fe,j,be,I,He="Per la generazione di testo, si consiglia di:",ge,F,Xe="<li>utilizzare il metodo <code>generate()</code> del modello invece della funzione <code>pipeline()</code>. Sebbene l’inferenza sia possibile con la funzione <code>pipeline()</code>, essa non è ottimizzata per i modelli mixed-8bit e sarà più lenta rispetto all’uso del metodo <code>generate()</code>. Inoltre, alcune strategie di campionamento, come il campionamento nucleaus, non sono supportate dalla funzione <code>pipeline()</code> per i modelli mixed-8bit.</li> <li>collocare tutti gli ingressi sullo stesso dispositivo del modello.</li>",Me,P,Le="Ecco un semplice esempio:",ze,R,$e,E,Te,k,Ne="Usare il seguente modo caricare il modello mixed-8bit su più GPU (stesso comando della configurazione a GPU singola):",ye,q,ve,B,Qe="Puoi controllare la RAM della GPU che si vuole allocare su ogni GPU usando <code>accelerate</code>. Utilizzare l’argomento <code>max_memory</code> come segue:",he,V,Ue,H,Ae="In questo esempio, la prima GPU utilizzerà 1 GB di memoria e la seconda 2 GB.",xe,X,_e,L,Ye=`Con questo metodo è possibile inferire modelli che prima non era possibile inferire su Google Colab.
Guardate la demo per l’esecuzione di T5-11b (42GB in fp32)! Utilizzo la quantizzazione a 8 bit su Google Colab:`,Ce,N,Se='<a href="https://colab.research.google.com/drive/1YORPWx4okIHXnjW7MSAidXN29mPVNT7F?usp=sharing" rel="nofollow"><img src="https://colab.research.google.com/assets/colab-badge.svg" alt="Open In Colab: T5-11b demo"/></a>',Ge,Q,Oe="Oppure questa demo di BLOOM-3B:",Je,A,Ke='<a href="https://colab.research.google.com/drive/1qOjXfQIAULfKvZqwCen8-MoWKGdSatZ4?usp=sharing" rel="nofollow"><img src="https://colab.research.google.com/assets/colab-badge.svg" alt="Open In Colab: BLOOM-3b demo"/></a>',we,Y,Ze,K,We;return $=new S({props:{title:"Inferenza efficiente su GPU singola",local:"inferenza-efficiente-su-gpu-singola",headingTag:"h1"}}),y=new S({props:{title:"BetterTransformer per l’inferenza più veloce",local:"bettertransformer-per-linferenza-più-veloce",headingTag:"h2"}}),h=new S({props:{title:"Integrazione di bitsandbytes per Int8 mixed-precision matrix decomposition",local:"integrazione-di-bitsandbytes-per-int8-mixed-precision-matrix-decomposition",headingTag:"h2"}}),M=new pt({props:{$$slots:{default:[ut]},$$scope:{ctx:D}}}),J=new S({props:{title:"Requisiti",local:"requisiti",headingTag:"h3"}}),Z=new S({props:{title:"Esecuzione di modelli mixed-Int8 - configurazione per singola GPU",local:"esecuzione-di-modelli-mixed-int8---configurazione-per-singola-gpu",headingTag:"h3"}}),j=new je({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEF1dG9Nb2RlbEZvckNhdXNhbExNJTJDJTIwQml0c0FuZEJ5dGVzQ29uZmlnJTBBJTBBbW9kZWxfbmFtZSUyMCUzRCUyMCUyMmJpZ3NjaWVuY2UlMkZibG9vbS0yYjUlMjIlMEFtb2RlbF84Yml0JTIwJTNEJTIwQXV0b01vZGVsRm9yQ2F1c2FsTE0uZnJvbV9wcmV0cmFpbmVkKG1vZGVsX25hbWUlMkMlMjBxdWFudGl6YXRpb25fY29uZmlnJTNEQml0c0FuZEJ5dGVzQ29uZmlnKGxvYWRfaW5fOGJpdCUzRFRydWUpKQ==",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoModelForCausalLM, BitsAndBytesConfig
model_name = <span class="hljs-string">&quot;bigscience/bloom-2b5&quot;</span>
model_8bit = AutoModelForCausalLM.from_pretrained(model_name, quantization_config=BitsAndBytesConfig(load_in_8bit=<span class="hljs-literal">True</span>))`,wrap:!1}}),R=new je({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEF1dG9Nb2RlbEZvckNhdXNhbExNJTJDJTIwQXV0b1Rva2VuaXplciUyQyUyMEJpdHNBbmRCeXRlc0NvbmZpZyUwQSUwQW1vZGVsX25hbWUlMjAlM0QlMjAlMjJiaWdzY2llbmNlJTJGYmxvb20tMmI1JTIyJTBBdG9rZW5pemVyJTIwJTNEJTIwQXV0b1Rva2VuaXplci5mcm9tX3ByZXRyYWluZWQobW9kZWxfbmFtZSklMEFtb2RlbF84Yml0JTIwJTNEJTIwQXV0b01vZGVsRm9yQ2F1c2FsTE0uZnJvbV9wcmV0cmFpbmVkKG1vZGVsX25hbWUlMkMlMjBxdWFudGl6YXRpb25fY29uZmlnJTNEQml0c0FuZEJ5dGVzQ29uZmlnKGxvYWRfaW5fOGJpdCUzRFRydWUpKSUwQSUwQXRleHQlMjAlM0QlMjAlMjJIZWxsbyUyQyUyMG15JTIwbGxhbWElMjBpcyUyMGN1dGUlMjIlMEFpbnB1dHMlMjAlM0QlMjB0b2tlbml6ZXIocHJvbXB0JTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJwdCUyMikudG8oJTIyY3VkYSUyMiklMEFnZW5lcmF0ZWRfaWRzJTIwJTNEJTIwbW9kZWwuZ2VuZXJhdGUoKippbnB1dHMpJTBBb3V0cHV0cyUyMCUzRCUyMHRva2VuaXplci5iYXRjaF9kZWNvZGUoZ2VuZXJhdGVkX2lkcyUyQyUyMHNraXBfc3BlY2lhbF90b2tlbnMlM0RUcnVlKQ==",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoModelForCausalLM, AutoTokenizer, BitsAndBytesConfig
model_name = <span class="hljs-string">&quot;bigscience/bloom-2b5&quot;</span>
tokenizer = AutoTokenizer.from_pretrained(model_name)
model_8bit = AutoModelForCausalLM.from_pretrained(model_name, quantization_config=BitsAndBytesConfig(load_in_8bit=<span class="hljs-literal">True</span>))
text = <span class="hljs-string">&quot;Hello, my llama is cute&quot;</span>
inputs = tokenizer(prompt, return_tensors=<span class="hljs-string">&quot;pt&quot;</span>).to(<span class="hljs-string">&quot;cuda&quot;</span>)
generated_ids = model.generate(**inputs)
outputs = tokenizer.batch_decode(generated_ids, skip_special_tokens=<span class="hljs-literal">True</span>)`,wrap:!1}}),E=new S({props:{title:"Esecuzione di modelli mixed-8bit - configurazione multi GPU",local:"esecuzione-di-modelli-mixed-8bit---configurazione-multi-gpu",headingTag:"h3"}}),q=new je({props:{code:"bW9kZWxfbmFtZSUyMCUzRCUyMCUyMmJpZ3NjaWVuY2UlMkZibG9vbS0yYjUlMjIlMEFtb2RlbF84Yml0JTIwJTNEJTIwQXV0b01vZGVsRm9yQ2F1c2FsTE0uZnJvbV9wcmV0cmFpbmVkKG1vZGVsX25hbWUlMkMlMjBxdWFudGl6YXRpb25fY29uZmlnJTNEQml0c0FuZEJ5dGVzQ29uZmlnKGxvYWRfaW5fOGJpdCUzRFRydWUpKQ==",highlighted:`model_name = <span class="hljs-string">&quot;bigscience/bloom-2b5&quot;</span>
model_8bit = AutoModelForCausalLM.from_pretrained(model_name, quantization_config=BitsAndBytesConfig(load_in_8bit=<span class="hljs-literal">True</span>))`,wrap:!1}}),V=new je({props:{code:"bWF4X21lbW9yeV9tYXBwaW5nJTIwJTNEJTIwJTdCMCUzQSUyMCUyMjFHQiUyMiUyQyUyMDElM0ElMjAlMjIyR0IlMjIlN0QlMEFtb2RlbF9uYW1lJTIwJTNEJTIwJTIyYmlnc2NpZW5jZSUyRmJsb29tLTNiJTIyJTBBbW9kZWxfOGJpdCUyMCUzRCUyMEF1dG9Nb2RlbEZvckNhdXNhbExNLmZyb21fcHJldHJhaW5lZCglMEElMjAlMjAlMjAlMjBtb2RlbF9uYW1lJTJDJTIwZGV2aWNlX21hcCUzRCUyMmF1dG8lMjIlMkMlMjBsb2FkX2luXzhiaXQlM0RUcnVlJTJDJTIwbWF4X21lbW9yeSUzRG1heF9tZW1vcnlfbWFwcGluZyUwQSk=",highlighted:`max_memory_mapping = {<span class="hljs-number">0</span>: <span class="hljs-string">&quot;1GB&quot;</span>, <span class="hljs-number">1</span>: <span class="hljs-string">&quot;2GB&quot;</span>}
model_name = <span class="hljs-string">&quot;bigscience/bloom-3b&quot;</span>
model_8bit = AutoModelForCausalLM.from_pretrained(
model_name, device_map=<span class="hljs-string">&quot;auto&quot;</span>, load_in_8bit=<span class="hljs-literal">True</span>, max_memory=max_memory_mapping
)`,wrap:!1}}),X=new S({props:{title:"Colab demos",local:"colab-demos",headingTag:"h3"}}),Y=new mt({props:{source:"https://github.com/huggingface/transformers/blob/main/docs/source/it/perf_infer_gpu_one.md"}}),{c(){p=a("meta"),z=n(),g=a("p"),O=n(),m($.$$.fragment),ee=n(),T=a("p"),T.innerHTML=Ie,te=n(),m(y.$$.fragment),ie=n(),v=a("p"),v.innerHTML=Fe,le=n(),m(h.$$.fragment),ne=n(),m(M.$$.fragment),oe=n(),U=a("p"),U.innerHTML=Pe,ae=n(),x=a("p"),x.innerHTML=Re,se=n(),_=a("p"),_.innerHTML=Ee,re=n(),C=a("p"),C.innerHTML=ke,pe=n(),G=a("p"),G.innerHTML=qe,me=n(),m(J.$$.fragment),ue=n(),w=a("ul"),w.innerHTML=Be,de=n(),m(Z.$$.fragment),ce=n(),W=a("p"),W.textContent=Ve,fe=n(),m(j.$$.fragment),be=n(),I=a("p"),I.textContent=He,ge=n(),F=a("ul"),F.innerHTML=Xe,Me=n(),P=a("p"),P.textContent=Le,ze=n(),m(R.$$.fragment),$e=n(),m(E.$$.fragment),Te=n(),k=a("p"),k.textContent=Ne,ye=n(),m(q.$$.fragment),ve=n(),B=a("p"),B.innerHTML=Qe,he=n(),m(V.$$.fragment),Ue=n(),H=a("p"),H.textContent=Ae,xe=n(),m(X.$$.fragment),_e=n(),L=a("p"),L.textContent=Ye,Ce=n(),N=a("p"),N.innerHTML=Se,Ge=n(),Q=a("p"),Q.textContent=Oe,Je=n(),A=a("p"),A.innerHTML=Ke,we=n(),m(Y.$$.fragment),Ze=n(),K=a("p"),this.h()},l(e){const t=st("svelte-u9bgzb",document.head);p=s(t,"META",{name:!0,content:!0}),t.forEach(i),z=o(e),g=s(e,"P",{}),et(g).forEach(i),O=o(e),u($.$$.fragment,e),ee=o(e),T=s(e,"P",{"data-svelte-h":!0}),r(T)!=="svelte-nhozkm"&&(T.innerHTML=Ie),te=o(e),u(y.$$.fragment,e),ie=o(e),v=s(e,"P",{"data-svelte-h":!0}),r(v)!=="svelte-1z110ap"&&(v.innerHTML=Fe),le=o(e),u(h.$$.fragment,e),ne=o(e),u(M.$$.fragment,e),oe=o(e),U=s(e,"P",{"data-svelte-h":!0}),r(U)!=="svelte-om1tv8"&&(U.innerHTML=Pe),ae=o(e),x=s(e,"P",{"data-svelte-h":!0}),r(x)!=="svelte-1tsrdqi"&&(x.innerHTML=Re),se=o(e),_=s(e,"P",{"data-svelte-h":!0}),r(_)!=="svelte-1hgrk11"&&(_.innerHTML=Ee),re=o(e),C=s(e,"P",{"data-svelte-h":!0}),r(C)!=="svelte-y2mgdg"&&(C.innerHTML=ke),pe=o(e),G=s(e,"P",{"data-svelte-h":!0}),r(G)!=="svelte-1b4hp8z"&&(G.innerHTML=qe),me=o(e),u(J.$$.fragment,e),ue=o(e),w=s(e,"UL",{"data-svelte-h":!0}),r(w)!=="svelte-50hzsq"&&(w.innerHTML=Be),de=o(e),u(Z.$$.fragment,e),ce=o(e),W=s(e,"P",{"data-svelte-h":!0}),r(W)!=="svelte-14t427w"&&(W.textContent=Ve),fe=o(e),u(j.$$.fragment,e),be=o(e),I=s(e,"P",{"data-svelte-h":!0}),r(I)!=="svelte-7gz38r"&&(I.textContent=He),ge=o(e),F=s(e,"UL",{"data-svelte-h":!0}),r(F)!=="svelte-drw5lu"&&(F.innerHTML=Xe),Me=o(e),P=s(e,"P",{"data-svelte-h":!0}),r(P)!=="svelte-1s7g1s7"&&(P.textContent=Le),ze=o(e),u(R.$$.fragment,e),$e=o(e),u(E.$$.fragment,e),Te=o(e),k=s(e,"P",{"data-svelte-h":!0}),r(k)!=="svelte-df9yha"&&(k.textContent=Ne),ye=o(e),u(q.$$.fragment,e),ve=o(e),B=s(e,"P",{"data-svelte-h":!0}),r(B)!=="svelte-1qhnznq"&&(B.innerHTML=Qe),he=o(e),u(V.$$.fragment,e),Ue=o(e),H=s(e,"P",{"data-svelte-h":!0}),r(H)!=="svelte-80anhf"&&(H.textContent=Ae),xe=o(e),u(X.$$.fragment,e),_e=o(e),L=s(e,"P",{"data-svelte-h":!0}),r(L)!=="svelte-e4lo0z"&&(L.textContent=Ye),Ce=o(e),N=s(e,"P",{"data-svelte-h":!0}),r(N)!=="svelte-1yb5ek4"&&(N.innerHTML=Se),Ge=o(e),Q=s(e,"P",{"data-svelte-h":!0}),r(Q)!=="svelte-1u8p947"&&(Q.textContent=Oe),Je=o(e),A=s(e,"P",{"data-svelte-h":!0}),r(A)!=="svelte-6z7881"&&(A.innerHTML=Ke),we=o(e),u(Y.$$.fragment,e),Ze=o(e),K=s(e,"P",{}),et(K).forEach(i),this.h()},h(){tt(p,"name","hf:doc:metadata"),tt(p,"content",ct)},m(e,t){rt(document.head,p),l(e,z,t),l(e,g,t),l(e,O,t),d($,e,t),l(e,ee,t),l(e,T,t),l(e,te,t),d(y,e,t),l(e,ie,t),l(e,v,t),l(e,le,t),d(h,e,t),l(e,ne,t),d(M,e,t),l(e,oe,t),l(e,U,t),l(e,ae,t),l(e,x,t),l(e,se,t),l(e,_,t),l(e,re,t),l(e,C,t),l(e,pe,t),l(e,G,t),l(e,me,t),d(J,e,t),l(e,ue,t),l(e,w,t),l(e,de,t),d(Z,e,t),l(e,ce,t),l(e,W,t),l(e,fe,t),d(j,e,t),l(e,be,t),l(e,I,t),l(e,ge,t),l(e,F,t),l(e,Me,t),l(e,P,t),l(e,ze,t),d(R,e,t),l(e,$e,t),d(E,e,t),l(e,Te,t),l(e,k,t),l(e,ye,t),d(q,e,t),l(e,ve,t),l(e,B,t),l(e,he,t),d(V,e,t),l(e,Ue,t),l(e,H,t),l(e,xe,t),d(X,e,t),l(e,_e,t),l(e,L,t),l(e,Ce,t),l(e,N,t),l(e,Ge,t),l(e,Q,t),l(e,Je,t),l(e,A,t),l(e,we,t),d(Y,e,t),l(e,Ze,t),l(e,K,t),We=!0},p(e,[t]){const De={};t&2&&(De.$$scope={dirty:t,ctx:e}),M.$set(De)},i(e){We||(c($.$$.fragment,e),c(y.$$.fragment,e),c(h.$$.fragment,e),c(M.$$.fragment,e),c(J.$$.fragment,e),c(Z.$$.fragment,e),c(j.$$.fragment,e),c(R.$$.fragment,e),c(E.$$.fragment,e),c(q.$$.fragment,e),c(V.$$.fragment,e),c(X.$$.fragment,e),c(Y.$$.fragment,e),We=!0)},o(e){f($.$$.fragment,e),f(y.$$.fragment,e),f(h.$$.fragment,e),f(M.$$.fragment,e),f(J.$$.fragment,e),f(Z.$$.fragment,e),f(j.$$.fragment,e),f(R.$$.fragment,e),f(E.$$.fragment,e),f(q.$$.fragment,e),f(V.$$.fragment,e),f(X.$$.fragment,e),f(Y.$$.fragment,e),We=!1},d(e){e&&(i(z),i(g),i(O),i(ee),i(T),i(te),i(ie),i(v),i(le),i(ne),i(oe),i(U),i(ae),i(x),i(se),i(_),i(re),i(C),i(pe),i(G),i(me),i(ue),i(w),i(de),i(ce),i(W),i(fe),i(be),i(I),i(ge),i(F),i(Me),i(P),i(ze),i($e),i(Te),i(k),i(ye),i(ve),i(B),i(he),i(Ue),i(H),i(xe),i(_e),i(L),i(Ce),i(N),i(Ge),i(Q),i(Je),i(A),i(we),i(Ze),i(K)),i(p),b($,e),b(y,e),b(h,e),b(M,e),b(J,e),b(Z,e),b(j,e),b(R,e),b(E,e),b(q,e),b(V,e),b(X,e),b(Y,e)}}}const ct='{"title":"Inferenza efficiente su GPU singola","local":"inferenza-efficiente-su-gpu-singola","sections":[{"title":"BetterTransformer per l’inferenza più veloce","local":"bettertransformer-per-linferenza-più-veloce","sections":[],"depth":2},{"title":"Integrazione di bitsandbytes per Int8 mixed-precision matrix decomposition","local":"integrazione-di-bitsandbytes-per-int8-mixed-precision-matrix-decomposition","sections":[{"title":"Requisiti","local":"requisiti","sections":[],"depth":3},{"title":"Esecuzione di modelli mixed-Int8 - configurazione per singola GPU","local":"esecuzione-di-modelli-mixed-int8---configurazione-per-singola-gpu","sections":[],"depth":3},{"title":"Esecuzione di modelli mixed-8bit - configurazione multi GPU","local":"esecuzione-di-modelli-mixed-8bit---configurazione-multi-gpu","sections":[],"depth":3},{"title":"Colab demos","local":"colab-demos","sections":[],"depth":3}],"depth":2}],"depth":1}';function ft(D){return lt(()=>{new URLSearchParams(window.location.search).get("fw")}),[]}class Tt extends ot{constructor(p){super(),at(this,p,ft,dt,it,{})}}export{Tt as component};

Xet Storage Details

Size:
16.8 kB
·
Xet hash:
67c470dc36f4c29d9a7a2f6b796606820ebd5dd41d3c2ad42d4c198d18468b29

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