Buckets:

rtrm's picture
download
raw
20.3 kB
import{s as te,o as ne}from"../chunks/scheduler.37c15a92.js";import{S as oe,i as se,g as O,s as l,r as d,A as re,h as W,f as n,c as i,j as ee,u as m,x as le,k as ae,y as ie,a as r,v as p,t as c,b as ce,d as u,w as f,p as ue}from"../chunks/index.2bf4358c.js";import{C as de}from"../chunks/CourseFloatingBanner.6add7356.js";import{Q as I}from"../chunks/Question.668688bc.js";import{F as me}from"../chunks/FrameworkSwitchCourse.8d4d4ab6.js";import{H as y}from"../chunks/Heading.8ada512a.js";import{E as pe}from"../chunks/getInferenceSnippets.b37612c0.js";function fe(B){let $,j,g,w,x,C,q,h,v,z,_,T;return $=new y({props:{title:"4. ¿Qué ocurre cuando instancias una de las clases TFAutoModelForXxx con un modelo del lenguaje preentrenado (como bert-base-uncased ) que corresponde a una tarea distinta de aquella para la que fue entrenado?",local:"4-qué-ocurre-cuando-instancias-una-de-las-clases-tfautomodelforxxx-con-un-modelo-del-lenguaje-preentrenado-como-bert-base-uncased--que-corresponde-a-una-tarea-distinta-de-aquella-para-la-que-fue-entrenado",headingTag:"h3"}}),g=new I({props:{choices:[{text:"Nada, pero recibes una advertencia.",explain:"Recibes una advertencia, pero eso no es todo."},{text:"La cabeza del modelo preentrenado se elimina y en su lugar se inserta una nueva cabeza adecuada para la tarea.",explain:"Correcto. Por ejemplo, cuando usamos <code>TFAutoModelForSequenceClassification</code> con <code>bert-base-uncased</code>, recibimos una advertencia al instanciar el modelo. La cabeza preentrenada no se puede utilizar para la tarea de clasificación de secuencias, por lo que es eliminada y se instancia una nueva cabeza con pesos aleatorios.",correct:!0},{text:"La cabeza del modelo preentrenado es eliminada",explain:"Se necesita hacer algo más, inténtalo de nuevo."},{text:"Nada, ya que el modelo se puede seguir ajustando para la otra tarea.",explain:"La cabeza del modelo preentrenado no fue entrenada para resolver esta tarea, ¡así que deberíamos eliminarla!"}]}}),x=new y({props:{title:"5. Los modelos TensorFlow de transformers ya son modelos Keras. ¿Qué ventajas ofrece esto?",local:"5-los-modelos-tensorflow-de-transformers-ya-son-modelos-keras-qué-ventajas-ofrece-esto",headingTag:"h3"}}),q=new I({props:{choices:[{text:"Los modelos funcionan directamente en una TPU.",explain:"¡Casi! Se necesitan unos pequeños cambios adicionales. Por ejemplo, es necesario ejecutar todo en un entorno <code>TPUStrategy</code>, incluyendo la inicialización del modelo."},{text:"Puede aprovechar los métodos existentes, como <code>compile()</code>, <code>fit()</code> y <code>predict()</code>.",explain:"¡Correcto! Una vez que tienes los datos, entrenar el modelo requiere muy poco esfuerzo.",correct:!0},{text:"Tienes la oportunidad de aprender Keras a la vez que transformadores.",explain:"Correcto, pero estamos buscando otra respuesta :)",correct:!0},{text:"Puede calcular fácilmente las métricas relacionadas con el dataset.",explain:"Keras nos ayuda con el entrenamiento y la evaluación del modelo, no con el cálculo de métricas relacionadas con el dataset."}]}}),v=new y({props:{title:"6. ¿Cómo puedes definir tu propia métrica personalizada?",local:"6-cómo-puedes-definir-tu-propia-métrica-personalizada",headingTag:"h3"}}),_=new I({props:{choices:[{text:"Creando una subclase de <code>tf.keras.metrics.Metric</code>.",explain:"¡Genial!",correct:!0},{text:"Utilizando la API funcional de Keras.",explain:"¡Inténtalo de nuevo!"},{text:"Utilizando una función cuya firma sea <code>metric_fn(y_true, y_pred)</code>.",explain:"¡Correcto!",correct:!0},{text:"Buscándolo en Google.",explain:"Esta no es la respuesta que estamos buscando, pero te podría ayudar a encontrarla.",correct:!0}]}}),{c(){d($.$$.fragment),j=l(),d(g.$$.fragment),w=l(),d(x.$$.fragment),C=l(),d(q.$$.fragment),h=l(),d(v.$$.fragment),z=l(),d(_.$$.fragment)},l(t){m($.$$.fragment,t),j=i(t),m(g.$$.fragment,t),w=i(t),m(x.$$.fragment,t),C=i(t),m(q.$$.fragment,t),h=i(t),m(v.$$.fragment,t),z=i(t),m(_.$$.fragment,t)},m(t,b){p($,t,b),r(t,j,b),p(g,t,b),r(t,w,b),p(x,t,b),r(t,C,b),p(q,t,b),r(t,h,b),p(v,t,b),r(t,z,b),p(_,t,b),T=!0},i(t){T||(u($.$$.fragment,t),u(g.$$.fragment,t),u(x.$$.fragment,t),u(q.$$.fragment,t),u(v.$$.fragment,t),u(_.$$.fragment,t),T=!0)},o(t){c($.$$.fragment,t),c(g.$$.fragment,t),c(x.$$.fragment,t),c(q.$$.fragment,t),c(v.$$.fragment,t),c(_.$$.fragment,t),T=!1},d(t){t&&(n(j),n(w),n(C),n(h),n(z)),f($,t),f(g,t),f(x,t),f(q,t),f(v,t),f(_,t)}}}function $e(B){let $,j,g,w,x,C,q,h,v,z,_,T,t,b,P,k,S,E,A,L,F,N,Q,U;return $=new y({props:{title:"4. ¿Cuáles son las ventajas del método Dataset.map() ?",local:"4-cuáles-son-las-ventajas-del-método-datasetmap-",headingTag:"h3"}}),g=new I({props:{choices:[{text:"Los resultados de la función se almacenan en caché, por lo que no tardaremos nada en volver a ejecutar el código.",explain:"Esta es una de las grandes ventajas de este método. Aunque no es la única...",correct:!0},{text:"Puede aplicar multiprocesamiento para ir más rápido que si se aplicara la función a cada elemento del conjunto de datos.",explain:"Esta es una característica interesante de este método, ¡pero no es la única.",correct:!0},{text:"No carga todo el conjunto de datos en memoria, sino que guarda los resultados en cuanto se procesa un elemento.",explain:"Es una de las ventajas de este método, ¡pero hay más!",correct:!0}]}}),x=new y({props:{title:"5. ¿Qué significa padding dinámico?",local:"5-qué-significa-padding-dinámico",headingTag:"h3"}}),q=new I({props:{choices:[{text:"Es cuando se rellenan las entradas de cada lote con la longitud máxima de todo el conjunto de datos.",explain:"Sí que implica rellenar al crear el lote, pero no hasta la longitud máxima en todo el conjunto de datos."},{text:"Es cuando rellenas tus entradas cuando se crea el lote, a la longitud máxima de las frases de ese lote.",explain:'¡Correcto! La parte "dinámica" proviene del hecho de que el tamaño de cada lote se determina en el momento de la creación, y como resultado todos sus lotes pueden tener diferentes formas.',correct:!0},{text:"Es cuando se rellenan las entradas para que cada frase tenga el mismo número de tokens que la anterior en el conjunto de datos.",explain:"Incorrecto, no tiene sentido mirar el orden de las muestras del conjunto de datos ya que lo barajamos durante el entrenamiento."}]}}),v=new y({props:{title:"6. ¿Cuál es el objetivo de la función “collate”?",local:"6-cuál-es-el-objetivo-de-la-función-collate",headingTag:"h3"}}),_=new I({props:{choices:[{text:"Se asegura de que todas las secuencias del conjunto de datos tengan la misma longitud.",explain:'Una función "collate" está relacionada con el procesamiento de lotes individuales, no del conjunto de datos al completo. Además, estamos hablando de funciones "collate" genéricas, no <code>DataCollatorWithPadding</code> en especial.'},{text:"Combina todas las muestras del conjunto de datos en un lote.",explain:'¡Correcto! Puedes pasar una función "collate" como argumento a un <code>DataLoader</code>. Nosotros usamos la función <code>DataCollatorWithPadding</code>, que rellena todos los elementos de un lote para que tengan la misma longitud.',correct:!0},{text:"Preprocesa todo el conjunto de datos.",explain:'Eso sería una función de preprocesamiento, no una función "collate".'},{text:"Trunca las secuencias del conjunto de datos.",explain:'Una función "collate" está relacionada con el procesamiento de lotes individuales, no del conjunto de datos completo. Si quieres truncar, puedes utilizar el argumento <code>truncate</code> del <code>tokenizer</code>.'}]}}),t=new y({props:{title:"7. ¿Qué ocurre cuando instancias una de las clases AutoModelForXxx con un modelo del lenguaje preentrenado (como bert-base-uncased ) que corresponde a una tarea distinta de aquella para la que fue entrenado?",local:"7-qué-ocurre-cuando-instancias-una-de-las-clases-automodelforxxx-con-un-modelo-del-lenguaje-preentrenado-como-bert-base-uncased--que-corresponde-a-una-tarea-distinta-de-aquella-para-la-que-fue-entrenado",headingTag:"h3"}}),P=new I({props:{choices:[{text:"Nada, pero recibes una advertencia.",explain:"Recibes una advertencia, pero eso no es todo."},{text:"La cabeza del modelo preentrenado se elimina y en su lugar se inserta una nueva cabeza adecuada para la tarea.",explain:"Correcto. Por ejemplo, cuando usamos <code>AutoModelForSequenceClassification</code> con <code>bert-base-uncased</code>, recibimos una advertencia al instanciar el modelo. La cabeza preentrenada no se puede utilizar para la tarea de clasificación de secuencias, por lo que es eliminada y se instancia una nueva cabeza con pesos aleatorios.",correct:!0},{text:"La cabeza del modelo preentrenado es eliminada.",explain:"Se necesita hacer algo más, inténtalo de nuevo."},{text:"Nada, ya que el modelo se puede seguir ajustando para la otra tarea.",explain:"La cabeza del modelo preentrenado no fue entrenada para resolver esta tarea, ¡así que deberíamos eliminarla!"}]}}),S=new y({props:{title:"8. ¿Para qué sirve TrainingArguments ?",local:"8-para-qué-sirve-trainingarguments-",headingTag:"h3"}}),A=new I({props:{choices:[{text:"Contiene todos los hiperparámetros utilizados para el entrenamiento y la evaluación con <code>Trainer</code>.",explain:"¡Correcto!",correct:!0},{text:"Especifica el tamaño del modelo.",explain:"El tamaño del modelo viene definido por la configuración del modelo, no por la clase <code>TrainingArguments</code>."},{text:"Solo contiene los hiperparámetros utilizados para la evaluación.",explain:"En el ejemplo especificamos dónde se guardarán el modelo y sus checkpoints. ¡Inténtalo de nuevo!"},{text:"Solo contiene los hiperparámetros utilizados para el entrenamiento.",explain:"En el ejemplo también utilizamos <code>evaluation_strategy</code>, que afecta a la evaluación. ¡Inténtalo de nuevo!"}]}}),F=new y({props:{title:"9. ¿Por qué deberías utilizar la librería 🤗 Accelerate?",local:"9-por-qué-deberías-utilizar-la-librería--accelerate",headingTag:"h3"}}),Q=new I({props:{choices:[{text:"Facilita acceso a modelos más rápidos.",explain:"No, la librería 🤗 Accelerate library no proporciona modelos."},{text:"Proporciona una API de alto nivel para que no tenga que implementar mi propio bucle de entrenamiento.",explain:"Eso es lo que hicimos con <code>Trainer</code>, no con la librería 🤗 Accelerate. ¡Vuelve a intentarlo!"},{text:"Hace que nuestros bucles de entrenamiento funcionen con estrategias distribuidas.",explain:"¡Correcto! Con 🤗 Accelerate, tus bucles de entrenamiento funcionarán para múltiples GPUs y TPUs.",correct:!0},{text:"Ofrece más funciones de optimización.",explain:"No, la librería 🤗 Accelerate no proporciona ninguna función de optimización."}]}}),{c(){d($.$$.fragment),j=l(),d(g.$$.fragment),w=l(),d(x.$$.fragment),C=l(),d(q.$$.fragment),h=l(),d(v.$$.fragment),z=l(),d(_.$$.fragment),T=l(),d(t.$$.fragment),b=l(),d(P.$$.fragment),k=l(),d(S.$$.fragment),E=l(),d(A.$$.fragment),L=l(),d(F.$$.fragment),N=l(),d(Q.$$.fragment)},l(a){m($.$$.fragment,a),j=i(a),m(g.$$.fragment,a),w=i(a),m(x.$$.fragment,a),C=i(a),m(q.$$.fragment,a),h=i(a),m(v.$$.fragment,a),z=i(a),m(_.$$.fragment,a),T=i(a),m(t.$$.fragment,a),b=i(a),m(P.$$.fragment,a),k=i(a),m(S.$$.fragment,a),E=i(a),m(A.$$.fragment,a),L=i(a),m(F.$$.fragment,a),N=i(a),m(Q.$$.fragment,a)},m(a,o){p($,a,o),r(a,j,o),p(g,a,o),r(a,w,o),p(x,a,o),r(a,C,o),p(q,a,o),r(a,h,o),p(v,a,o),r(a,z,o),p(_,a,o),r(a,T,o),p(t,a,o),r(a,b,o),p(P,a,o),r(a,k,o),p(S,a,o),r(a,E,o),p(A,a,o),r(a,L,o),p(F,a,o),r(a,N,o),p(Q,a,o),U=!0},i(a){U||(u($.$$.fragment,a),u(g.$$.fragment,a),u(x.$$.fragment,a),u(q.$$.fragment,a),u(v.$$.fragment,a),u(_.$$.fragment,a),u(t.$$.fragment,a),u(P.$$.fragment,a),u(S.$$.fragment,a),u(A.$$.fragment,a),u(F.$$.fragment,a),u(Q.$$.fragment,a),U=!0)},o(a){c($.$$.fragment,a),c(g.$$.fragment,a),c(x.$$.fragment,a),c(q.$$.fragment,a),c(v.$$.fragment,a),c(_.$$.fragment,a),c(t.$$.fragment,a),c(P.$$.fragment,a),c(S.$$.fragment,a),c(A.$$.fragment,a),c(F.$$.fragment,a),c(Q.$$.fragment,a),U=!1},d(a){a&&(n(j),n(w),n(C),n(h),n(z),n(T),n(b),n(k),n(E),n(L),n(N)),f($,a),f(g,a),f(x,a),f(q,a),f(v,a),f(_,a),f(t,a),f(P,a),f(S,a),f(A,a),f(F,a),f(Q,a)}}}function ge(B){let $,j,g,w,x,C,q,h,v,z,_,T="A ver qué has aprendido en este capítulo:",t,b,P,k,S,E,A,L,F,N,Q,U,a,o,M,D,H,G,K,X;x=new me({props:{fw:B[0]}}),q=new y({props:{title:"Quiz de final de capítulo",local:"quiz-de-final-de-capítulo",headingTag:"h1"}}),v=new de({props:{chapter:3,classNames:"absolute z-10 right-0 top-0"}}),b=new y({props:{title:"1. El dataset emotion contiene mensajes de Twitter etiquetados con emociones. Búscalo en el Hub , y lee la tarjeta del dataset. ¿Cuál de estas no es una de sus emociones básicas?",local:"1-el-dataset-emotion-contiene-mensajes-de-twitter-etiquetados-con-emociones-búscalo-en-el-hub--y-lee-la-tarjeta-del-dataset-cuál-de-estas-no-es-una-de-sus-emociones-básicas",headingTag:"h3"}}),k=new I({props:{choices:[{text:"Alegría",explain:"Inténtalo de nuevo: ¡esta emoción sí está presente en ese dataset!"},{text:"Amor",explain:"Inténtalo de nuevo: ¡esta emoción sí está presente en ese dataset!"},{text:"Confusión",explain:"¡Correcto! La confusión no es una de las seis emociones básicas.",correct:!0},{text:"Sorpresa",explain:"¡Sorpresa! Inténtalo de nuevo."}]}}),E=new y({props:{title:"2. Busca el dataset ar_sarcasm en el Hub . ¿Con qué tarea es compatible?",local:"2-busca-el-dataset-arsarcasm-en-el-hub--con-qué-tarea-es-compatible",headingTag:"h3"}}),L=new I({props:{choices:[{text:"Clasificación de sentimientos",explain:"¡Correcto! Dale las gracias a las etiquetas.",correct:!0},{text:"Traducción automática",explain:"No es correcto, echa otro vistazo a la <a href='https://huggingface.co/datasets/ar_sarcasm'>tarjeta del dataset</a>."},{text:"Reconocimiento de entidades nombradas",explain:"No es correcto, echa otro vistazo a la <a href='https://huggingface.co/datasets/ar_sarcasm'>tarjeta del dataset</a>."},{text:"Responder preguntas",explain:"No es correcto, echa otro vistazo a la <a href='https://huggingface.co/datasets/ar_sarcasm'>tarjeta del dataset</a>."}]}}),N=new y({props:{title:"3. ¿Cómo se procesan un par de frases según el modelo BERT?",local:"3-cómo-se-procesan-un-par-de-frases-según-el-modelo-bert",headingTag:"h3"}}),U=new I({props:{choices:[{text:"tokens_frase_1 [SEP] tokens_frase_2",explain:"Se necesita un token especial <code>[SEP]</code> para separar las dos frases, ¡pero falta algo más!"},{text:"[CLS] tokens_frase_1 tokens_frase_2",explain:"Se necesita un token especial <code>[CLS]</code> al principio, ¡pero falta algo más!"},{text:"[CLS] tokens_frase_1 [SEP] tokens_frase_2 [SEP]",explain:"¡Correcto!",correct:!0},{text:"[CLS] tokens_frase_1 [SEP] tokens_frase_2",explain:"Se necesita un token especial <code>[CLS]</code> al principio y un token especial <code>[SEP]</code> para separar las dos frases, ¡pero falta algo más!"}]}});const J=[$e,fe],R=[];function Y(e,s){return e[0]==="pt"?0:1}return o=Y(B),M=R[o]=J[o](B),H=new pe({props:{source:"https://github.com/huggingface/course/blob/main/chapters/es/chapter3/6.mdx"}}),{c(){$=O("meta"),j=l(),g=O("p"),w=l(),d(x.$$.fragment),C=l(),d(q.$$.fragment),h=l(),d(v.$$.fragment),z=l(),_=O("p"),_.textContent=T,t=l(),d(b.$$.fragment),P=l(),d(k.$$.fragment),S=l(),d(E.$$.fragment),A=l(),d(L.$$.fragment),F=l(),d(N.$$.fragment),Q=l(),d(U.$$.fragment),a=l(),M.c(),D=l(),d(H.$$.fragment),G=l(),K=O("p"),this.h()},l(e){const s=re("svelte-u9bgzb",document.head);$=W(s,"META",{name:!0,content:!0}),s.forEach(n),j=i(e),g=W(e,"P",{}),ee(g).forEach(n),w=i(e),m(x.$$.fragment,e),C=i(e),m(q.$$.fragment,e),h=i(e),m(v.$$.fragment,e),z=i(e),_=W(e,"P",{"data-svelte-h":!0}),le(_)!=="svelte-1i7hifw"&&(_.textContent=T),t=i(e),m(b.$$.fragment,e),P=i(e),m(k.$$.fragment,e),S=i(e),m(E.$$.fragment,e),A=i(e),m(L.$$.fragment,e),F=i(e),m(N.$$.fragment,e),Q=i(e),m(U.$$.fragment,e),a=i(e),M.l(e),D=i(e),m(H.$$.fragment,e),G=i(e),K=W(e,"P",{}),ee(K).forEach(n),this.h()},h(){ae($,"name","hf:doc:metadata"),ae($,"content",xe)},m(e,s){ie(document.head,$),r(e,j,s),r(e,g,s),r(e,w,s),p(x,e,s),r(e,C,s),p(q,e,s),r(e,h,s),p(v,e,s),r(e,z,s),r(e,_,s),r(e,t,s),p(b,e,s),r(e,P,s),p(k,e,s),r(e,S,s),p(E,e,s),r(e,A,s),p(L,e,s),r(e,F,s),p(N,e,s),r(e,Q,s),p(U,e,s),r(e,a,s),R[o].m(e,s),r(e,D,s),p(H,e,s),r(e,G,s),r(e,K,s),X=!0},p(e,[s]){const Z={};s&1&&(Z.fw=e[0]),x.$set(Z);let V=o;o=Y(e),o!==V&&(ue(),c(R[V],1,1,()=>{R[V]=null}),ce(),M=R[o],M||(M=R[o]=J[o](e),M.c()),u(M,1),M.m(D.parentNode,D))},i(e){X||(u(x.$$.fragment,e),u(q.$$.fragment,e),u(v.$$.fragment,e),u(b.$$.fragment,e),u(k.$$.fragment,e),u(E.$$.fragment,e),u(L.$$.fragment,e),u(N.$$.fragment,e),u(U.$$.fragment,e),u(M),u(H.$$.fragment,e),X=!0)},o(e){c(x.$$.fragment,e),c(q.$$.fragment,e),c(v.$$.fragment,e),c(b.$$.fragment,e),c(k.$$.fragment,e),c(E.$$.fragment,e),c(L.$$.fragment,e),c(N.$$.fragment,e),c(U.$$.fragment,e),c(M),c(H.$$.fragment,e),X=!1},d(e){e&&(n(j),n(g),n(w),n(C),n(h),n(z),n(_),n(t),n(P),n(S),n(A),n(F),n(Q),n(a),n(D),n(G),n(K)),n($),f(x,e),f(q,e),f(v,e),f(b,e),f(k,e),f(E,e),f(L,e),f(N,e),f(U,e),R[o].d(e),f(H,e)}}}const xe='{"title":"Quiz de final de capítulo","local":"quiz-de-final-de-capítulo","sections":[{"title":"1. El dataset emotion contiene mensajes de Twitter etiquetados con emociones. Búscalo en el Hub , y lee la tarjeta del dataset. ¿Cuál de estas no es una de sus emociones básicas?","local":"1-el-dataset-emotion-contiene-mensajes-de-twitter-etiquetados-con-emociones-búscalo-en-el-hub--y-lee-la-tarjeta-del-dataset-cuál-de-estas-no-es-una-de-sus-emociones-básicas","sections":[],"depth":3},{"title":"2. Busca el dataset ar_sarcasm en el Hub . ¿Con qué tarea es compatible?","local":"2-busca-el-dataset-arsarcasm-en-el-hub--con-qué-tarea-es-compatible","sections":[],"depth":3},{"title":"3. ¿Cómo se procesan un par de frases según el modelo BERT?","local":"3-cómo-se-procesan-un-par-de-frases-según-el-modelo-bert","sections":[],"depth":3},{"title":"4. ¿Cuáles son las ventajas del método Dataset.map() ?","local":"4-cuáles-son-las-ventajas-del-método-datasetmap-","sections":[],"depth":3},{"title":"5. ¿Qué significa padding dinámico?","local":"5-qué-significa-padding-dinámico","sections":[],"depth":3},{"title":"6. ¿Cuál es el objetivo de la función “collate”?","local":"6-cuál-es-el-objetivo-de-la-función-collate","sections":[],"depth":3},{"title":"7. ¿Qué ocurre cuando instancias una de las clases AutoModelForXxx con un modelo del lenguaje preentrenado (como bert-base-uncased ) que corresponde a una tarea distinta de aquella para la que fue entrenado?","local":"7-qué-ocurre-cuando-instancias-una-de-las-clases-automodelforxxx-con-un-modelo-del-lenguaje-preentrenado-como-bert-base-uncased--que-corresponde-a-una-tarea-distinta-de-aquella-para-la-que-fue-entrenado","sections":[],"depth":3},{"title":"8. ¿Para qué sirve TrainingArguments ?","local":"8-para-qué-sirve-trainingarguments-","sections":[],"depth":3},{"title":"9. ¿Por qué deberías utilizar la librería 🤗 Accelerate?","local":"9-por-qué-deberías-utilizar-la-librería--accelerate","sections":[],"depth":3},{"title":"4. ¿Qué ocurre cuando instancias una de las clases TFAutoModelForXxx con un modelo del lenguaje preentrenado (como bert-base-uncased ) que corresponde a una tarea distinta de aquella para la que fue entrenado?","local":"4-qué-ocurre-cuando-instancias-una-de-las-clases-tfautomodelforxxx-con-un-modelo-del-lenguaje-preentrenado-como-bert-base-uncased--que-corresponde-a-una-tarea-distinta-de-aquella-para-la-que-fue-entrenado","sections":[],"depth":3},{"title":"5. Los modelos TensorFlow de transformers ya son modelos Keras. ¿Qué ventajas ofrece esto?","local":"5-los-modelos-tensorflow-de-transformers-ya-son-modelos-keras-qué-ventajas-ofrece-esto","sections":[],"depth":3},{"title":"6. ¿Cómo puedes definir tu propia métrica personalizada?","local":"6-cómo-puedes-definir-tu-propia-métrica-personalizada","sections":[],"depth":3}],"depth":1}';function be(B,$,j){let g="pt";return ne(()=>{const w=new URLSearchParams(window.location.search);j(0,g=w.get("fw")||"pt")}),[g]}class ze extends oe{constructor($){super(),se(this,$,be,ge,te,{})}}export{ze as component};

Xet Storage Details

Size:
20.3 kB
·
Xet hash:
4b35831d53e9c3e423bce0c9edd18e9b858e3094c56621897cc99a251095e52b

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