Buckets:
| import{s as ve,n as he,o as Me}from"../chunks/scheduler.37c15a92.js";import{S as xe,i as ye,g as _,s as a,r as n,A as qe,h as X,f as r,c as o,j as fe,u as l,x as be,k as $e,y as ze,a as t,v as s,d as p,t as u,w as c}from"../chunks/index.2bf4358c.js";import{C as Je}from"../chunks/CodeBlock.4e987730.js";import{C as je}from"../chunks/CourseFloatingBanner.9ff4c771.js";import{Q as g}from"../chunks/Question.668688bc.js";import{H as d,E as Te}from"../chunks/getInferenceSnippets.39afd8fb.js";function Ue(me){let m,B,G,W,f,Q,b,I,$,de="Mettiamo alla prova quello che hai imparato in questo capitolo!",Y,v,N,h,H,M,E,x,F,y,D,q,V,z,ge="Quale dei seguenti potrebbe essere una buona scelta per il titolo di un topic del forum per chiedere aiuto?",O,J,K,j,ee,T,ie,U,re,Z,te,C,ae,S,oe,w,ne,A,le,k,se,P,pe,L,ue,R,ce;return f=new d({props:{title:"Quiz di fine capitolo",local:"quiz-di-fine-capitolo",headingTag:"h1"}}),b=new je({props:{chapter:8,classNames:"absolute z-10 right-0 top-0"}}),v=new d({props:{title:"1. In quale ordine si deve leggere un traceback di Python?",local:"1-in-quale-ordine-si-deve-leggere-un-traceback-di-python",headingTag:"h3"}}),h=new g({props:{choices:[{text:"Dall'alto verso il basso",explain:"Riprova -- sebbene la maggior parte degli altri linguaggi di programmazione stampi gli errori in alto, Python è unico in questo senso."},{text:"Dal basso verso l'alto",explain:"Corretto! Un vantaggio dei traceback di Python, che mostrano l'errore in fondo, è che è più facile fare il debug quando si lavora nel terminale e questa è l'ultima riga che si vede.",correct:!0}]}}),M=new d({props:{title:"2. Che cos’è un minimo esempio riproducibile?",local:"2-che-cosè-un-minimo-esempio-riproducibile",headingTag:"h3"}}),x=new g({props:{choices:[{text:"Una semplice implementazione di un'architettura Transformer tratta da un articolo di ricerca",explain:"Anche se è molto formativo implementare i propri modelli Transformer da zero, non è di questo che stiamo parlando."},{text:"Un blocco di codice compatto e autocontenuto che può essere eseguito senza alcuna dipendenza esterna da file o dati privati",explain:"Corretto! Minimi esempi riproducibili aiutano i maintainers della libreria a riprodurre il problema che si sta verificando, in modo da trovare soluzioni più velocemente",correct:!0},{text:"Uno screenshot della traceback di Python",explain:"Riprova -- anche se è allettante includere una schermata dell'errore che si sta riscontrando quando si invia un issue, questo rende molto difficile per gli altri riprodurre l'errore"},{text:"Un notebook che contiene la tua analisi intera, comprese le parti non correlate all'errore",explain:"Non proprio -- anche se può essere utile condividere un notebook di Google Colab che mostri l'errore, assicurati che sia breve e che contenga solo il codice rilevante"}]}}),y=new d({props:{title:"3. Supponiamo di provare a eseguire il codice seguente, il quale produce un errore:",local:"3-supponiamo-di-provare-a-eseguire-il-codice-seguente-il-quale-produce-un-errore",headingTag:"h3"}}),q=new Je({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEdQVDNGb3JTZXF1ZW5jZUNsYXNzaWZpY2F0aW9uJTBBJTBBJTIzJTIwSW1wb3J0RXJyb3IlM0ElMjBjYW5ub3QlMjBpbXBvcnQlMjBuYW1lJTIwJ0dQVDNGb3JTZXF1ZW5jZUNsYXNzaWZpY2F0aW9uJyUyMGZyb20lMjAndHJhbnNmb3JtZXJzJyUyMCglMkZVc2VycyUyRmxld3R1biUyRm1pbmljb25kYTMlMkZlbnZzJTJGaHVnZ2luZ2ZhY2UlMkZsaWIlMkZweXRob24zLjglMkZzaXRlLXBhY2thZ2VzJTJGdHJhbnNmb3JtZXJzJTJGX19pbml0X18ucHkpJTBBJTIzJTIwLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tJTBBJTIzJTIwSW1wb3J0RXJyb3IlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBUcmFjZWJhY2slMjAobW9zdCUyMHJlY2VudCUyMGNhbGwlMjBsYXN0KSUwQSUyMyUyMCUyRnZhciUyRmZvbGRlcnMlMkYyOCUyRms0Y3k1cTdzMmhzOTJ4cTdfaDg5X3ZnbTAwMDBnbiUyRlQlMkZpcHlrZXJuZWxfMzA4NDglMkYzMzM4NTg4NzgucHklMjBpbiUyMCUzQ21vZHVsZSUzRSUwQSUyMyUyMC0tLS0lM0UlMjAxJTIwZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEdQVDNGb3JTZXF1ZW5jZUNsYXNzaWZpY2F0aW9uJTBBJTBBJTIzJTIwSW1wb3J0RXJyb3IlM0ElMjBjYW5ub3QlMjBpbXBvcnQlMjBuYW1lJTIwJ0dQVDNGb3JTZXF1ZW5jZUNsYXNzaWZpY2F0aW9uJyUyMGZyb20lMjAndHJhbnNmb3JtZXJzJyUyMCglMkZVc2VycyUyRmxld3R1biUyRm1pbmljb25kYTMlMkZlbnZzJTJGaHVnZ2luZ2ZhY2UlMkZsaWIlMkZweXRob24zLjglMkZzaXRlLXBhY2thZ2VzJTJGdHJhbnNmb3JtZXJzJTJGX19pbml0X18ucHkp",highlighted:`<span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> GPT3ForSequenceClassification | |
| <span class="hljs-comment"># ImportError: cannot import name 'GPT3ForSequenceClassification' from 'transformers' (/Users/lewtun/miniconda3/envs/huggingface/lib/python3.8/site-packages/transformers/__init__.py)</span> | |
| <span class="hljs-comment"># ---------------------------------------------------------------------------</span> | |
| <span class="hljs-comment"># ImportError Traceback (most recent call last)</span> | |
| <span class="hljs-comment"># /var/folders/28/k4cy5q7s2hs92xq7_h89_vgm0000gn/T/ipykernel_30848/333858878.py in <module></span> | |
| <span class="hljs-comment"># ----> 1 from transformers import GPT3ForSequenceClassification</span> | |
| <span class="hljs-comment"># ImportError: cannot import name 'GPT3ForSequenceClassification' from 'transformers' (/Users/lewtun/miniconda3/envs/huggingface/lib/python3.8/site-packages/transformers/__init__.py)</span>`,wrap:!1}}),J=new g({props:{choices:[{text:"<code>ImportError: cannot import name 'GPT3ForSequenceClassification' from 'transformers' (/Users/lewtun/miniconda3/envs/huggingface/lib/python3.8/site-packages/transformers/__init__.py)</code>",explain:"Includere l'ultima riga del traceback può essere esplicativo, ma è meglio riservarlo al corpo principale del topic. Riprov!"},{text:"Problema con <code>from transformers import GPT3ForSequenceClassification</code>",explain:"Riprova -- sebbene questo fornisca informazioni utili, è probabilmente meglio riservarle al corpo principale del testo."},{text:"Perché non posso importare <code>GPT3ForSequenceClassification</code>?",explain:"Ottima scelta! Questo titolo è conciso e dà al lettore un indizio su ciò che potrebbe essere sbagliato (ad esempio, che il GPT-3 non è supportato nei 🤗 Transformers).",correct:!0},{text:"GPT-3 è supportato in 🤗 Transformers?",explain:"Buona questa! Usare domande come titoli dei topic è un ottimo modo per comunicare il problema alla community.",correct:!0}]}}),j=new d({props:{title:"4. Supponiamo di aver provato a eseguire trainer.train() e di trovarci di fronte a un errore criptico che non ci dice esattamente da dove proviene. Quale dei seguenti è il primo posto in cui cercare gli errori nella training pipeline?",local:"4-supponiamo-di-aver-provato-a-eseguire-trainertrain-e-di-trovarci-di-fronte-a-un-errore-criptico-che-non-ci-dice-esattamente-da-dove-proviene-quale-dei-seguenti-è-il-primo-posto-in-cui-cercare-gli-errori-nella-training-pipeline",headingTag:"h3"}}),T=new g({props:{choices:[{text:"La fase di ottimizzazione in cui si calcolano i gradienti e si esegue la backpropagation",explain:"Anche se potrebbero esserci dei bug nell'ottimizzatore, di solito si tratta di diverse fasi della training pipeline, quindi ci sono altre cose da controllare prima. Riprova!"},{text:"La fase di valutazione in cui si calcolano le metriche",explain:"La valutazione è di solito fatta dopo aver fatto training per un'intera epoch, quindi dovresti controllare in qualche punto della training pipeline precedente."},{text:"I dataset",explain:"Corretto! Dare un'occhiata ai dati è quasi sempre la prima cosa da fare, per assicurarsi che il testo sia codificato correttamente, che abbia le dimensioni previste e così via.",correct:!0},{text:"I dataloader",explain:"Prova ancora -- è molto vicino alla prima cosa che si dovrebbe controllare. Ti ricordi quale oggetto forniamo ai dataloader?"}]}}),U=new d({props:{title:"5. Qual è il modo migliore per fare il debug di un errore CUDA?",local:"5-qual-è-il-modo-migliore-per-fare-il-debug-di-un-errore-cuda",headingTag:"h3"}}),Z=new g({props:{choices:[{text:"Pubblicare il messaggio di errore sul forum o su GitHub.",explain:"Questo non aiuterà nessuno, poiché i messaggi di errore di CUDA sono solitamente poco esplicativi."},{text:"Eseguire lo stesso codice sulla CPU.",explain:"Esattamente, questo dovrebbe darti un messaggio di errore migliore!",correct:!0},{text:"Leggere il traceback per scoprire cosa ha causato l'errore.",explain:"È quello che si farebbe per qualsiasi altro errore, ma gli errori di CUDA di solito non vengono segnalati nel punto in cui si sono verificati, perché la maggior parte delle operazioni di CUDA sono asincrone."},{text:"Ridurre la dimensione del batch.",explain:"Ridurre la dimensione del batch è di solito una buona strategia per gestire gli errori out-of-memory di CUDA, ma non per questo particolare problema. Riprova!"},{text:"Riavviare il Jupyter kernel.",explain:"Riprova -- riavviare il kernel non farà scomparire magicamente l'errore!"}]}}),C=new d({props:{title:"6. Qual è il modo migliore per far risolvere un problema su GitHub?",local:"6-qual-è-il-modo-migliore-per-far-risolvere-un-problema-su-github",headingTag:"h3"}}),S=new g({props:{choices:[{text:"Pubblicare un esempio completo e riproducibile del bug.",explain:"Sì, questo è il modo migliore per aiutare i maintainer a trovare il tuo bug. Cos'altro si dovrebbe fare?",correct:!0},{text:"Chiedere un aggiornamento ogni giorno.",explain:"È improbabile che questo ti aiuti; probabilmente la gente ti ignorerà di più."},{text:"Ispezionare il codice sorgente intorno al bug e cercare di trovare il motivo per cui si verifica. Pubblicare i risultati nel problema.",explain:"Questo aiuterà sicuramente i maintainer! E se si trova la fonte del bug e una soluzione, si può anche aprire una pull request. Cos'altro dovreste fare?",correct:!0}]}}),w=new d({props:{title:"7. Perché l’overfitting di un batch è di solito una buona tecnica di debugging?",local:"7-perché-loverfitting-di-un-batch-è-di-solito-una-buona-tecnica-di-debugging",headingTag:"h3"}}),A=new g({props:{choices:[{text:"Non lo è; l'overfitting è sempre un male e va evitato.",explain:"Quando si fa l'addestramento sull'intero dataset, l'overfitting può essere un segno che il modello non generalizzerà bene a nuovi esempi. Per il debug, tuttavia, di solito non si addestra sull'intero dataset. Riprova!"},{text:"Ci permette di verificare che il modello sia in grado di ridurre la loss a zero.",explain:"Corretto! Con un piccolo batch di soli due esempi, possiamo verificare rapidamente se il modello è in grado di apprendere.",correct:!0},{text:"Ci permette di verificare che le dimensioni dei tensori dei nostri input e delle nostre label siano corrette.",explain:"Prova ancora -- se le dimensioni dei tensori sono scorrette, non sarai certamente in grado di fare l'addestramento, nemmeno su un singolo batch."}]}}),k=new d({props:{title:"8. Perché è una buona idea includere dettagli sul proprio ambiente di sviluppo con transformers-cli env quando si crea un nuovo issue nel repo di 🤗 Transformers?",local:"8-perché-è-una-buona-idea-includere-dettagli-sul-proprio-ambiente-di-sviluppo-con-transformers-cli-env-quando-si-crea-un-nuovo-issue-nel-repo-di--transformers",headingTag:"h3"}}),P=new g({props:{choices:[{text:"Permette ai maintainer di capire quale versione della libreria si sta utilizzando.",explain:"Corretto! Poiché ogni versione principale della libreria può presentare modifiche all'API, sapere quale versione specifica si sta utilizzando può aiutare a circoscrivere il problema. Quali sono gli altri vantaggi?",correct:!0},{text:"Permette ai maintainer di sapere se il codice viene eseguito su Windows, macOS o Linux.",explain:"Corretto! A volte gli errori possono essere causati dallo specifico sistema operativo in uso e saperlo aiuta i maintainer a riprodurli localmente. Ma non è il solo motivo.",correct:!0},{text:"Permette ai maintainer di sapere se il codice viene eseguito su una GPU o su una CPU.",explain:"Corretto! Come abbiamo visto in questo capitolo, il codice eseguito su GPU o CPU può produrre risultati o errori diversi e sapere quale hardware si sta usando può aiutare a concentrare l'attenzione dei maintainer. Ma questo non è l'unico vantaggio...",correct:!0}]}}),L=new Te({props:{source:"https://github.com/huggingface/course/blob/main/chapters/it/chapter8/7.mdx"}}),{c(){m=_("meta"),B=a(),G=_("p"),W=a(),n(f.$$.fragment),Q=a(),n(b.$$.fragment),I=a(),$=_("p"),$.textContent=de,Y=a(),n(v.$$.fragment),N=a(),n(h.$$.fragment),H=a(),n(M.$$.fragment),E=a(),n(x.$$.fragment),F=a(),n(y.$$.fragment),D=a(),n(q.$$.fragment),V=a(),z=_("p"),z.textContent=ge,O=a(),n(J.$$.fragment),K=a(),n(j.$$.fragment),ee=a(),n(T.$$.fragment),ie=a(),n(U.$$.fragment),re=a(),n(Z.$$.fragment),te=a(),n(C.$$.fragment),ae=a(),n(S.$$.fragment),oe=a(),n(w.$$.fragment),ne=a(),n(A.$$.fragment),le=a(),n(k.$$.fragment),se=a(),n(P.$$.fragment),pe=a(),n(L.$$.fragment),ue=a(),R=_("p"),this.h()},l(e){const i=qe("svelte-u9bgzb",document.head);m=X(i,"META",{name:!0,content:!0}),i.forEach(r),B=o(e),G=X(e,"P",{}),fe(G).forEach(r),W=o(e),l(f.$$.fragment,e),Q=o(e),l(b.$$.fragment,e),I=o(e),$=X(e,"P",{"data-svelte-h":!0}),be($)!=="svelte-1ogea8z"&&($.textContent=de),Y=o(e),l(v.$$.fragment,e),N=o(e),l(h.$$.fragment,e),H=o(e),l(M.$$.fragment,e),E=o(e),l(x.$$.fragment,e),F=o(e),l(y.$$.fragment,e),D=o(e),l(q.$$.fragment,e),V=o(e),z=X(e,"P",{"data-svelte-h":!0}),be(z)!=="svelte-idikgo"&&(z.textContent=ge),O=o(e),l(J.$$.fragment,e),K=o(e),l(j.$$.fragment,e),ee=o(e),l(T.$$.fragment,e),ie=o(e),l(U.$$.fragment,e),re=o(e),l(Z.$$.fragment,e),te=o(e),l(C.$$.fragment,e),ae=o(e),l(S.$$.fragment,e),oe=o(e),l(w.$$.fragment,e),ne=o(e),l(A.$$.fragment,e),le=o(e),l(k.$$.fragment,e),se=o(e),l(P.$$.fragment,e),pe=o(e),l(L.$$.fragment,e),ue=o(e),R=X(e,"P",{}),fe(R).forEach(r),this.h()},h(){$e(m,"name","hf:doc:metadata"),$e(m,"content",Ze)},m(e,i){ze(document.head,m),t(e,B,i),t(e,G,i),t(e,W,i),s(f,e,i),t(e,Q,i),s(b,e,i),t(e,I,i),t(e,$,i),t(e,Y,i),s(v,e,i),t(e,N,i),s(h,e,i),t(e,H,i),s(M,e,i),t(e,E,i),s(x,e,i),t(e,F,i),s(y,e,i),t(e,D,i),s(q,e,i),t(e,V,i),t(e,z,i),t(e,O,i),s(J,e,i),t(e,K,i),s(j,e,i),t(e,ee,i),s(T,e,i),t(e,ie,i),s(U,e,i),t(e,re,i),s(Z,e,i),t(e,te,i),s(C,e,i),t(e,ae,i),s(S,e,i),t(e,oe,i),s(w,e,i),t(e,ne,i),s(A,e,i),t(e,le,i),s(k,e,i),t(e,se,i),s(P,e,i),t(e,pe,i),s(L,e,i),t(e,ue,i),t(e,R,i),ce=!0},p:he,i(e){ce||(p(f.$$.fragment,e),p(b.$$.fragment,e),p(v.$$.fragment,e),p(h.$$.fragment,e),p(M.$$.fragment,e),p(x.$$.fragment,e),p(y.$$.fragment,e),p(q.$$.fragment,e),p(J.$$.fragment,e),p(j.$$.fragment,e),p(T.$$.fragment,e),p(U.$$.fragment,e),p(Z.$$.fragment,e),p(C.$$.fragment,e),p(S.$$.fragment,e),p(w.$$.fragment,e),p(A.$$.fragment,e),p(k.$$.fragment,e),p(P.$$.fragment,e),p(L.$$.fragment,e),ce=!0)},o(e){u(f.$$.fragment,e),u(b.$$.fragment,e),u(v.$$.fragment,e),u(h.$$.fragment,e),u(M.$$.fragment,e),u(x.$$.fragment,e),u(y.$$.fragment,e),u(q.$$.fragment,e),u(J.$$.fragment,e),u(j.$$.fragment,e),u(T.$$.fragment,e),u(U.$$.fragment,e),u(Z.$$.fragment,e),u(C.$$.fragment,e),u(S.$$.fragment,e),u(w.$$.fragment,e),u(A.$$.fragment,e),u(k.$$.fragment,e),u(P.$$.fragment,e),u(L.$$.fragment,e),ce=!1},d(e){e&&(r(B),r(G),r(W),r(Q),r(I),r($),r(Y),r(N),r(H),r(E),r(F),r(D),r(V),r(z),r(O),r(K),r(ee),r(ie),r(re),r(te),r(ae),r(oe),r(ne),r(le),r(se),r(pe),r(ue),r(R)),r(m),c(f,e),c(b,e),c(v,e),c(h,e),c(M,e),c(x,e),c(y,e),c(q,e),c(J,e),c(j,e),c(T,e),c(U,e),c(Z,e),c(C,e),c(S,e),c(w,e),c(A,e),c(k,e),c(P,e),c(L,e)}}}const Ze='{"title":"Quiz di fine capitolo","local":"quiz-di-fine-capitolo","sections":[{"title":"1. In quale ordine si deve leggere un traceback di Python?","local":"1-in-quale-ordine-si-deve-leggere-un-traceback-di-python","sections":[],"depth":3},{"title":"2. Che cos’è un minimo esempio riproducibile?","local":"2-che-cosè-un-minimo-esempio-riproducibile","sections":[],"depth":3},{"title":"3. Supponiamo di provare a eseguire il codice seguente, il quale produce un errore:","local":"3-supponiamo-di-provare-a-eseguire-il-codice-seguente-il-quale-produce-un-errore","sections":[],"depth":3},{"title":"4. Supponiamo di aver provato a eseguire trainer.train() e di trovarci di fronte a un errore criptico che non ci dice esattamente da dove proviene. Quale dei seguenti è il primo posto in cui cercare gli errori nella training pipeline?","local":"4-supponiamo-di-aver-provato-a-eseguire-trainertrain-e-di-trovarci-di-fronte-a-un-errore-criptico-che-non-ci-dice-esattamente-da-dove-proviene-quale-dei-seguenti-è-il-primo-posto-in-cui-cercare-gli-errori-nella-training-pipeline","sections":[],"depth":3},{"title":"5. Qual è il modo migliore per fare il debug di un errore CUDA?","local":"5-qual-è-il-modo-migliore-per-fare-il-debug-di-un-errore-cuda","sections":[],"depth":3},{"title":"6. Qual è il modo migliore per far risolvere un problema su GitHub?","local":"6-qual-è-il-modo-migliore-per-far-risolvere-un-problema-su-github","sections":[],"depth":3},{"title":"7. Perché l’overfitting di un batch è di solito una buona tecnica di debugging?","local":"7-perché-loverfitting-di-un-batch-è-di-solito-una-buona-tecnica-di-debugging","sections":[],"depth":3},{"title":"8. Perché è una buona idea includere dettagli sul proprio ambiente di sviluppo con transformers-cli env quando si crea un nuovo issue nel repo di 🤗 Transformers?","local":"8-perché-è-una-buona-idea-includere-dettagli-sul-proprio-ambiente-di-sviluppo-con-transformers-cli-env-quando-si-crea-un-nuovo-issue-nel-repo-di--transformers","sections":[],"depth":3}],"depth":1}';function Ce(me){return Me(()=>{new URLSearchParams(window.location.search).get("fw")}),[]}class Ge extends xe{constructor(m){super(),ye(this,m,Ce,Ue,ve,{})}}export{Ge as component}; | |
Xet Storage Details
- Size:
- 17.8 kB
- Xet hash:
- 9280e1b7045f978e7a2200fbb5fec57e3fe9985771cfa0cb3a45249de67a7efb
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.