Buckets:
| import{s as Bn,o as En}from"../chunks/scheduler.37c15a92.js";import{S as Sn,i as An,g as Tn,s as e,r as u,A as Hn,h as _n,f as i,c as g,j as Mn,u as o,x as Dn,k as Pn,y as Ln,a as c,v as r,t as m,b as Nn,d as l,w as p,p as jn}from"../chunks/index.2bf4358c.js";import{Q as x}from"../chunks/Question.668688bc.js";import{F as Fn}from"../chunks/FrameworkSwitchCourse.8d4d4ab6.js";import{H as f,E as Qn}from"../chunks/getInferenceSnippets.ebf8be91.js";function Gn(d){let a,s,$,k;return a=new f({props:{title:"9. Vì sao không cần thiết chỉ định hàm mất mát khi gọi compile() trong mô hình Transformer?",local:"9-vì-sao-không-cần-thiết-chỉ-định-hàm-mất-mát-khi-gọi-compile-trong-mô-hình-transformer",headingTag:"h3"}}),$=new x({props:{choices:[{text:"Vì các mô hình Transformer models được huấn luyện phi giám sát",explain:"Không hẳn -- kể cả học phi giám sát cùng cần hàm mất mát!"},{text:"Vì mất mát bên trong của đầu ra được sử dụng theo mặc định",explain:"Chính xác!",correct:!0},{text:"Vì thay vào đó chúng ta tính các thước đo sau khi huấn luyện",explain:"Ta thường làm vậy, nhưng nó không giải thích cho việc nhận giá trị mất mát khi ta tối ưu trong khi huấn luyện."},{text:"Vì sự mất mát được chỉ định cụ thể trong `model.fit()`",explain:"Không, hàm mất mát luôn cố định khi bạn chạy `model.compile()`, và không thể thay đổi trong `model.fit()`."}]}}),{c(){u(a.$$.fragment),s=e(),u($.$$.fragment)},l(h){o(a.$$.fragment,h),s=g(h),o($.$$.fragment,h)},m(h,v){r(a,h,v),c(h,s,v),r($,h,v),k=!0},i(h){k||(l(a.$$.fragment,h),l($.$$.fragment,h),k=!0)},o(h){m(a.$$.fragment,h),m($.$$.fragment,h),k=!1},d(h){h&&i(s),p(a,h),p($,h)}}}function In(d){let a,s,$,k;return a=new f({props:{title:"8. Vì sao lại có lớp con Trainer cho các bài toán chuỗi sang chuỗi?",local:"8-vì-sao-lại-có-lớp-con-trainer-cho-các-bài-toán-chuỗi-sang-chuỗi",headingTag:"h3"}}),$=new x({props:{choices:[{text:"Vì các vấn đề chuỗi sang chuỗi sử dụng một hàm mất mát tuỳ chỉnh để bỏ qua tập hợp nhãn <code>-100</code>",explain:"Đây không phải là tuỳ chỉnh mất mát, mà là cách sự mất mát vẫn luôn được tính toán."},{text:"Vì các vấn đề chuỗi sang chuỗi cần một vòng đánh giá đặc biệt",explain:"Chính xác. Các dự đoán mô hình chuỗi sang chuỗi thường được chạy sử dụng phương thức <code>generate()</code>.",correct:!0},{text:"Bởi vì nhãn là văn bản trong bài toán chuỗi sang chuỗi",explain:"<code>Trainer</code> không thực sự quan tâm vì chúng đã được tiền xử lý trước đó."},{text:"Vì ta sử dụng hai mô hình trong bài toán chuỗi sang chuỗi",explain:"Chúng ta sử dụng hai mô hình cùng một cách, một trình mã hoá và một trình giải mã, nhưng ta sẽ nhóm chúng lại trong một mô hình."}]}}),{c(){u(a.$$.fragment),s=e(),u($.$$.fragment)},l(h){o(a.$$.fragment,h),s=g(h),o($.$$.fragment,h)},m(h,v){r(a,h,v),c(h,s,v),r($,h,v),k=!0},i(h){k||(l(a.$$.fragment,h),l($.$$.fragment,h),k=!0)},o(h){m(a.$$.fragment,h),m($.$$.fragment,h),k=!1},d(h){h&&i(s),p(a,h),p($,h)}}}function On(d){let a,s,$,k,h,v,w,X,T,Cn="Cùng kiểm tra xem bạn đã học được những gì trong chương này!",Y,_,Z,q,nn,C,tn,z,hn,V,cn,K,en,M,gn,P,mn,B,ln,E,un,S,on,A,rn,H,pn,D,an,b,y,J,L,$n,N,sn,j,kn,F,fn,Q,xn,G,vn,I,bn,O,yn,R,dn,W,wn;h=new Fn({props:{fw:d[0]}}),w=new f({props:{title:"Đố vui cuối chương",local:"đố-vui-cuối-chương",headingTag:"h1"}}),_=new f({props:{title:"1. Tác vụ nào sau đây có thể được coi là vấn đề phân loại token?",local:"1-tác-vụ-nào-sau-đây-có-thể-được-coi-là-vấn-đề-phân-loại-token",headingTag:"h3"}}),q=new x({props:{choices:[{text:"Tìm các thành phần ngữ pháp trong một câu.",explain:"Đúng! Sau đó, chúng tôi có thể gắn nhãn mỗi từ là danh từ, động từ, v.v.",correct:!0},{text:"Tìm xem một câu có đúng ngữ pháp hay không.",explain:"Không, đây là một bài toán phân loại chuỗi."},{text:"Tìm thực thể người được đề cập trong một câu.",explain:"Đúng! Chúng ta có thể gắn nhãn từng từ có phải là thực thể người không.",correct:!0},{text:"Tìm đoạn từ trong một câu trả lời cho một câu hỏi.",explain:"Không, đó sẽ là một vấn đề hỏi đáp."}]}}),C=new f({props:{title:"2. Phần tiền xử lý để phân loại token khác với các pipeline tiền xử lý khác ở điểm nào?",local:"2-phần-tiền-xử-lý-để-phân-loại-token-khác-với-các-pipeline-tiền-xử-lý-khác-ở-điểm-nào",headingTag:"h3"}}),z=new x({props:{choices:[{text:"Không cần phải làm gì cả; các văn bản đã được tokenize",explain:"Các văn bản thực sự được cung cấp dưới dạng các từ riêng biệt, nhưng chúng ta vẫn cần áp dụng mô hình tokenize từ phụ."},{text:"Các văn bản được cung cấp dưới dạng từ, vì vậy chúng ta chỉ cần áp dụng tokenize từ phụ.",explain:"Chính xác! Điều này khác với quy trình tiền xử lý thông thường, ở đó chúng ta cần áp dụng quy trình tokenize đầy đủ. Bạn có thể nghĩ xem còn sự khác biệt nào khác không?",correct:!0},{text:"Ta sử dụng <code>-100</code> để đánh nhãn các token đặc biệt.",explain:"Điều đó không dành riêng cho việc phân loại token -- ta luôn sử dụng <code>-100</code> như nhãn của token ta muốn bỏ quả trong hàm mất mát."},{text:"Chúng ta cần đảm bảo cắt bớt hoặc đệm các nhãn có cùng kích thước với các đầu vào khi áp dụng phép cắt bớt/đệm.",explain:"Thật vậy! Tuy nhiên đó không phải là sự khác biệt duy nhất.",correct:!0}]}}),V=new f({props:{title:"3. Vấn đề gì phát sinh khi ta tokenize các từ trong bài toán phân loại token và muốn đánh nhãn token?",local:"3-vấn-đề-gì-phát-sinh-khi-ta-tokenize-các-từ-trong-bài-toán-phân-loại-token-và-muốn-đánh-nhãn-token",headingTag:"h3"}}),K=new x({props:{choices:[{text:"Trình tokenizer thêm các kí tự token đặc biệt và ta không có nhãn cho chúng.",explain:"Ta đãnh nhãn <code>-100</code> cho chúng để chúng bị bỏ qua khi tính sự mất mát."},{text:"Mỗi từ có thể tạo ra nhiều token, nên đến cuối ta sẽ có nhiều token hơn số nhãn.",explain:"Đó là vấn đề chính và chúng ta cần phải căn chỉnh các nhãn gốc với các token.",correct:!0},{text:"Các token được thêm không có nhãn, nên không có vấn đề gì.",explain:"Không chính xác; ta cần số nhãn tương ứng số token nếu không mô hình sẽ báo lỗi."}]}}),M=new f({props:{title:"4. “Thích ứng chuyên môn” là gì?",local:"4-thích-ứng-chuyên-môn-là-gì",headingTag:"h3"}}),P=new x({props:{choices:[{text:"Đó là khi chúng ta chạy một mô hình trên tập dữ liệu và nhận các dự đoán cho từng mẫu trong tập dữ liệu đó.",explain:"Không, đây chỉ là chạy quá trình luận suy."},{text:"Đó là khi chúng ta huấn luyện một mô hình trên tập dữ liệu.",explain:"Không, đây là huấn luyện một mô hình; không có sự thích nghi ở đây."},{text:"Đó là khi chúng ta tinh chỉnh một mô hình được huấn luyện trước trên một tập dữ liệu mới và nó đưa ra các dự đoán phù hợp hơn với tập dữ liệu đó",explain:"Đúng! Mô hình đã điều chỉnh kiến thức của nó để phù hợp với tập dữ liệu mới.",correct:!0},{text:"Đó là khi chúng ta thêm các mẫu bị phân loại sai vào tập dữ liệu để làm cho mô hình mạnh mẽ hơn.",explain:"Đó chắc chắn là điều bạn nên làm nếu huấn luyện lại mô hình của mình thường xuyên, nhưng đó không phải là thích ứng chuyên môn."}]}}),B=new f({props:{title:"5. Các nhãn trong bài toán mô hình ngôn ngữ bị ẩn đi là gì?",local:"5-các-nhãn-trong-bài-toán-mô-hình-ngôn-ngữ-bị-ẩn-đi-là-gì",headingTag:"h3"}}),E=new x({props:{choices:[{text:"Một số token đầu vào bị che ngẫu nhiên và nhãn là các token đầu vào ban đầu.",explain:"Chính nó!",correct:!0},{text:"Một số token đầu vào bị che ngẫu nhiên và nhãn là các token đầu vào ban đầu, được dịch sang bên trái.",explain:"Không, dịch các nhãn sang bên trái tương ứng với dự đoán từ tiếp theo hay mô hình ngôn ngữ nhân quả."},{text:"Một số token đầu vào bị che ngẫu nhiên và nhãn là các câu phủ định hay khẳng định.",explain:"Đó là vấn đề phân loại chuỗi với tăng cường dữ liệu, không phải mô hình ngôn ngữ bị che đi."},{text:"Một số token trong hai câu đầu vào bị che đi ngẫu nhiên, và nhãn là hai câu đó có giống nhau hay không.",explain:"Đó là vấn đề phân loại chuỗi với tăng cường dữ liệu, không phải mô hình ngôn ngữ bị che đi."}]}}),S=new f({props:{title:"6. Tác vụ nào sau đây có thể được coi là bài toán chuỗi sang chuỗi?",local:"6-tác-vụ-nào-sau-đây-có-thể-được-coi-là-bài-toán-chuỗi-sang-chuỗi",headingTag:"h3"}}),A=new x({props:{choices:[{text:"Viết đánh giá ngắn về tài liệu dài",explain:"Đúng, đó là một bài toán tóm tắt. Hãy thử một câu trả lời khác!",correct:!0},{text:"Trả lời câu hỏi về một tài liệu",explain:"Đây có thể được coi là một bài toán chuỗi sang chuỗi. Tuy nhiên, đây không phải là câu trả lời đúng duy nhất.",correct:!0},{text:"Dịch một văn bản bằng tiếng Trung sang tiếng Anh",explain:"Đó chắc chắn là bài toán chuỗi sang chuỗi. Bạn có thể tìm thấy đáp án nào nữa không?",correct:!0},{text:"Sửa các tin nhắn do cháu trai/ bạn tôi gửi để chúng được viết bằng tiếng Anh chuẩn",explain:"Đó là một dạng dịch máy, nên chắc chắn là bài toán chuỗi sang chuỗi. Tuy nhiên, đó không phải là đáp án đúng duy nhất!",correct:!0}]}}),H=new f({props:{title:"7. Đây là phuwong pháp phù hợp để tiền xử lý dữ liệu cho bài toán chuỗi sang chuỗi?",local:"7-đây-là-phuwong-pháp-phù-hợp-để-tiền-xử-lý-dữ-liệu-cho-bài-toán-chuỗi-sang-chuỗi",headingTag:"h3"}}),D=new x({props:{choices:[{text:"Đầu vào và nhãn phải được gửi cùng nhau tới tokenizer qua <code>inputs=...</code> và <code>targets=...</code>.",explain:"Đây có thể là một API mà chúng tôi sẽ thêm vào trong tương lai, nhưng điều đó không khả thi ở thời điểm hiện tại."},{text:"Đầu vào và nhãn đều phải được tiền xử lý, trong hai lệch gọi riêng biệt tới tokenizer.",explain:"Điều đó đúng, nhưng chưa đủ. Bạn cần phải làm gì đó nữa để đảm bảo trình tokenizer xử lý đúng cả hai."},{text:"Như thường lệ, chúng ta chỉ phhải tokenize đầu vào.",explain:"Không phải với bài toán phân loại chuỗi; nhãn cũng là văn bản nên ta cần chuyển sang dạng số!"},{text:"Đầu vào phải đước gửi tới trình tokenizer, và nhãn cũng vậy, nhưng theo trình quản lý ngữ cảnh đặc biệt.",explain:"Đúng vậy, tokenizer cần xử lý nhãn dựa trên trình quản lý ngữ cảnh.",correct:!0}]}});const zn=[In,Gn],U=[];function Vn(n,t){return n[0]==="pt"?0:1}return b=Vn(d),y=U[b]=zn[b](d),L=new f({props:{title:"10. Khi nào bạn nên huấn luyện trước một mô hình mới?",local:"10-khi-nào-bạn-nên-huấn-luyện-trước-một-mô-hình-mới",headingTag:"h3"}}),N=new x({props:{choices:[{text:"Khi không có mô hình huấn luyện sẵn cho ngôn ngữ của bạn",explain:"Chính xác.",correct:!0},{text:"Khi bạn có rất nhiều dữ liệu có sẵn, ngay cả khi đã có một mô hình huấn luyện trước có thể hoạt động trên đó",explain:"Trong trường hợp này, bạn nên sử dụng mô hình đã được huấn luyện sẵn và tinh chỉnh theo dữ liệu của bạn, tránh chi phí tính toán lớn."},{text:"Khi bạn lăn tăn về sự sai lệch của mô hình huấn luyện trước bạn sử dụng",explain:"Đúng, nhưng bạn phải đảm bảo rằng dữ liệu bạn sử dụng cho huấn luyện sẽ luôn tốt hơn.",correct:!0},{text:"Khi các mô hình huấn luyện trước có sẵn không đủ tốt",explain:"Bạn có chắc là bạn đã gỡ lỗi đúng cách cho quá trình huấn luyện của mình không?"}]}}),j=new f({props:{title:"11. Vì sao ta dễ huấn luyện trước một mô hình ngôn ngữ khi có khối lượng văn bản khổng lồ?",local:"11-vì-sao-ta-dễ-huấn-luyện-trước-một-mô-hình-ngôn-ngữ-khi-có-khối-lượng-văn-bản-khổng-lồ",headingTag:"h3"}}),F=new x({props:{choices:[{text:"Vì có rất nhiều dữ liệu văn bản có sẵn trên mạng",explain:"Dù đúng, nhưng nó không thực sự là đáp án cho câu hỏi. Hãy thử lại!"},{text:"Vì mục đích huấn luyện trước không cần con người gán nhãn dữ liệu the pretraining objective does not require humans to label the data",explain:"Chính xác, mô hình ngôn ngữ là bài toán tự giám sát.",correct:!0},{text:"Vì thư viện 🤗 Transformers chỉ yêu cầu một vài dòng mã để bắt đầu huấn luyện",explain:"Dù đúng, nhưng nó không thực sự là đáp án cho câu hỏi. Hãy thử đáp án khác"}]}}),Q=new f({props:{title:"12. Đâu là những thách thức chính khi tiền xử lí dữ liệu cho tác vụ hỏi đáp?",local:"12-đâu-là-những-thách-thức-chính-khi-tiền-xử-lí-dữ-liệu-cho-tác-vụ-hỏi-đáp",headingTag:"h3"}}),G=new x({props:{choices:[{text:"Bạn cần tokenize đầu vào.",explain:"Chính xác, nhưng đó có thực sự là một thách thức chính?"},{text:"Bạn cần xử lý chuỗi ngữ cảnh dài nhận nhiều đặc trưng huấn luyện có thể chứa đáp án bên trong hoặc không.",explain:"Đây chắc chắn là một trong những thách thức.",correct:!0},{text:"Bạn cần tokenize câu trả lời của câu hỏi cũng như đầu vào.",explain:"Không, trừ khi bạn đang coi vấn đề hỏi đáp là một tác vụ chuỗi sang chuỗi."},{text:"Từ mảng câu trả lời trong văn bản, bạn phải tìm ra token bắt đầu và kết thúc trong đầu vào đã được tokenize.",explain:"Đây chính là một trong những phần khó nhất, chính xác!",correct:!0}]}}),I=new f({props:{title:"13. Làm thể nào để hậu xử lý trong bài toán hỏi đáp?",local:"13-làm-thể-nào-để-hậu-xử-lý-trong-bài-toán-hỏi-đáp",headingTag:"h3"}}),O=new x({props:{choices:[{text:"Mô hình cung cấp cho bạn vị trí bắt đầu và kết thúc của câu trả lời và bạn chỉ cần giải mã khoảng token tương ứng..",explain:"Đó có thể là một cách để làm điều đó, nhưng nó hơi quá đơn giản."},{text:"Mô hình cung cấp cho bạn vị trí bắt đầu và kết thúc của câu trả lời cho mỗi đặc trưng được tạo bởi một mẫu và bạn chỉ cần giải mã khoảng token tương ứng của cái có điểm tốt nhất.",explain:"Nó gần giống quá trình hậu xử lý chúng ta đã học, nhưng nó không hoàn toàn đúng."},{text:"Mô hình cung cấp cho bạn vị trí bắt đầu và kết thúc của câu trả lời cho mỗi đặc trưng được tạo bởi một mẫu và bạn chỉ cần đối sánh chúng với khoảng trong ngữ cảnh của cái có điểm tốt nhất.",explain:"Chính nó!",correct:!0},{text:"Mô hình tạo ra một câu trả lời và bạn chỉ cần giải mã nó.",explain:"Không, trừ khi bạn đang coi vấn đề hỏi đáp là một tác vụ chuỗi sang chuỗi."}]}}),R=new Qn({props:{source:"https://github.com/huggingface/course/blob/main/chapters/vi/chapter7/9.mdx"}}),{c(){a=Tn("meta"),s=e(),$=Tn("p"),k=e(),u(h.$$.fragment),v=e(),u(w.$$.fragment),X=e(),T=Tn("p"),T.textContent=Cn,Y=e(),u(_.$$.fragment),Z=e(),u(q.$$.fragment),nn=e(),u(C.$$.fragment),tn=e(),u(z.$$.fragment),hn=e(),u(V.$$.fragment),cn=e(),u(K.$$.fragment),en=e(),u(M.$$.fragment),gn=e(),u(P.$$.fragment),mn=e(),u(B.$$.fragment),ln=e(),u(E.$$.fragment),un=e(),u(S.$$.fragment),on=e(),u(A.$$.fragment),rn=e(),u(H.$$.fragment),pn=e(),u(D.$$.fragment),an=e(),y.c(),J=e(),u(L.$$.fragment),$n=e(),u(N.$$.fragment),sn=e(),u(j.$$.fragment),kn=e(),u(F.$$.fragment),fn=e(),u(Q.$$.fragment),xn=e(),u(G.$$.fragment),vn=e(),u(I.$$.fragment),bn=e(),u(O.$$.fragment),yn=e(),u(R.$$.fragment),dn=e(),W=Tn("p"),this.h()},l(n){const t=Hn("svelte-u9bgzb",document.head);a=_n(t,"META",{name:!0,content:!0}),t.forEach(i),s=g(n),$=_n(n,"P",{}),Mn($).forEach(i),k=g(n),o(h.$$.fragment,n),v=g(n),o(w.$$.fragment,n),X=g(n),T=_n(n,"P",{"data-svelte-h":!0}),Dn(T)!=="svelte-1adc7ku"&&(T.textContent=Cn),Y=g(n),o(_.$$.fragment,n),Z=g(n),o(q.$$.fragment,n),nn=g(n),o(C.$$.fragment,n),tn=g(n),o(z.$$.fragment,n),hn=g(n),o(V.$$.fragment,n),cn=g(n),o(K.$$.fragment,n),en=g(n),o(M.$$.fragment,n),gn=g(n),o(P.$$.fragment,n),mn=g(n),o(B.$$.fragment,n),ln=g(n),o(E.$$.fragment,n),un=g(n),o(S.$$.fragment,n),on=g(n),o(A.$$.fragment,n),rn=g(n),o(H.$$.fragment,n),pn=g(n),o(D.$$.fragment,n),an=g(n),y.l(n),J=g(n),o(L.$$.fragment,n),$n=g(n),o(N.$$.fragment,n),sn=g(n),o(j.$$.fragment,n),kn=g(n),o(F.$$.fragment,n),fn=g(n),o(Q.$$.fragment,n),xn=g(n),o(G.$$.fragment,n),vn=g(n),o(I.$$.fragment,n),bn=g(n),o(O.$$.fragment,n),yn=g(n),o(R.$$.fragment,n),dn=g(n),W=_n(n,"P",{}),Mn(W).forEach(i),this.h()},h(){Pn(a,"name","hf:doc:metadata"),Pn(a,"content",Rn)},m(n,t){Ln(document.head,a),c(n,s,t),c(n,$,t),c(n,k,t),r(h,n,t),c(n,v,t),r(w,n,t),c(n,X,t),c(n,T,t),c(n,Y,t),r(_,n,t),c(n,Z,t),r(q,n,t),c(n,nn,t),r(C,n,t),c(n,tn,t),r(z,n,t),c(n,hn,t),r(V,n,t),c(n,cn,t),r(K,n,t),c(n,en,t),r(M,n,t),c(n,gn,t),r(P,n,t),c(n,mn,t),r(B,n,t),c(n,ln,t),r(E,n,t),c(n,un,t),r(S,n,t),c(n,on,t),r(A,n,t),c(n,rn,t),r(H,n,t),c(n,pn,t),r(D,n,t),c(n,an,t),U[b].m(n,t),c(n,J,t),r(L,n,t),c(n,$n,t),r(N,n,t),c(n,sn,t),r(j,n,t),c(n,kn,t),r(F,n,t),c(n,fn,t),r(Q,n,t),c(n,xn,t),r(G,n,t),c(n,vn,t),r(I,n,t),c(n,bn,t),r(O,n,t),c(n,yn,t),r(R,n,t),c(n,dn,t),c(n,W,t),wn=!0},p(n,[t]){const Kn={};t&1&&(Kn.fw=n[0]),h.$set(Kn);let qn=b;b=Vn(n),b!==qn&&(jn(),m(U[qn],1,1,()=>{U[qn]=null}),Nn(),y=U[b],y||(y=U[b]=zn[b](n),y.c()),l(y,1),y.m(J.parentNode,J))},i(n){wn||(l(h.$$.fragment,n),l(w.$$.fragment,n),l(_.$$.fragment,n),l(q.$$.fragment,n),l(C.$$.fragment,n),l(z.$$.fragment,n),l(V.$$.fragment,n),l(K.$$.fragment,n),l(M.$$.fragment,n),l(P.$$.fragment,n),l(B.$$.fragment,n),l(E.$$.fragment,n),l(S.$$.fragment,n),l(A.$$.fragment,n),l(H.$$.fragment,n),l(D.$$.fragment,n),l(y),l(L.$$.fragment,n),l(N.$$.fragment,n),l(j.$$.fragment,n),l(F.$$.fragment,n),l(Q.$$.fragment,n),l(G.$$.fragment,n),l(I.$$.fragment,n),l(O.$$.fragment,n),l(R.$$.fragment,n),wn=!0)},o(n){m(h.$$.fragment,n),m(w.$$.fragment,n),m(_.$$.fragment,n),m(q.$$.fragment,n),m(C.$$.fragment,n),m(z.$$.fragment,n),m(V.$$.fragment,n),m(K.$$.fragment,n),m(M.$$.fragment,n),m(P.$$.fragment,n),m(B.$$.fragment,n),m(E.$$.fragment,n),m(S.$$.fragment,n),m(A.$$.fragment,n),m(H.$$.fragment,n),m(D.$$.fragment,n),m(y),m(L.$$.fragment,n),m(N.$$.fragment,n),m(j.$$.fragment,n),m(F.$$.fragment,n),m(Q.$$.fragment,n),m(G.$$.fragment,n),m(I.$$.fragment,n),m(O.$$.fragment,n),m(R.$$.fragment,n),wn=!1},d(n){n&&(i(s),i($),i(k),i(v),i(X),i(T),i(Y),i(Z),i(nn),i(tn),i(hn),i(cn),i(en),i(gn),i(mn),i(ln),i(un),i(on),i(rn),i(pn),i(an),i(J),i($n),i(sn),i(kn),i(fn),i(xn),i(vn),i(bn),i(yn),i(dn),i(W)),i(a),p(h,n),p(w,n),p(_,n),p(q,n),p(C,n),p(z,n),p(V,n),p(K,n),p(M,n),p(P,n),p(B,n),p(E,n),p(S,n),p(A,n),p(H,n),p(D,n),U[b].d(n),p(L,n),p(N,n),p(j,n),p(F,n),p(Q,n),p(G,n),p(I,n),p(O,n),p(R,n)}}}const Rn='{"title":"Đố vui cuối chương","local":"đố-vui-cuối-chương","sections":[{"title":"1. Tác vụ nào sau đây có thể được coi là vấn đề phân loại token?","local":"1-tác-vụ-nào-sau-đây-có-thể-được-coi-là-vấn-đề-phân-loại-token","sections":[],"depth":3},{"title":"2. Phần tiền xử lý để phân loại token khác với các pipeline tiền xử lý khác ở điểm nào?","local":"2-phần-tiền-xử-lý-để-phân-loại-token-khác-với-các-pipeline-tiền-xử-lý-khác-ở-điểm-nào","sections":[],"depth":3},{"title":"3. Vấn đề gì phát sinh khi ta tokenize các từ trong bài toán phân loại token và muốn đánh nhãn token?","local":"3-vấn-đề-gì-phát-sinh-khi-ta-tokenize-các-từ-trong-bài-toán-phân-loại-token-và-muốn-đánh-nhãn-token","sections":[],"depth":3},{"title":"4. “Thích ứng chuyên môn” là gì?","local":"4-thích-ứng-chuyên-môn-là-gì","sections":[],"depth":3},{"title":"5. Các nhãn trong bài toán mô hình ngôn ngữ bị ẩn đi là gì?","local":"5-các-nhãn-trong-bài-toán-mô-hình-ngôn-ngữ-bị-ẩn-đi-là-gì","sections":[],"depth":3},{"title":"6. Tác vụ nào sau đây có thể được coi là bài toán chuỗi sang chuỗi?","local":"6-tác-vụ-nào-sau-đây-có-thể-được-coi-là-bài-toán-chuỗi-sang-chuỗi","sections":[],"depth":3},{"title":"7. Đây là phuwong pháp phù hợp để tiền xử lý dữ liệu cho bài toán chuỗi sang chuỗi?","local":"7-đây-là-phuwong-pháp-phù-hợp-để-tiền-xử-lý-dữ-liệu-cho-bài-toán-chuỗi-sang-chuỗi","sections":[],"depth":3},{"title":"8. Vì sao lại có lớp con Trainer cho các bài toán chuỗi sang chuỗi?","local":"8-vì-sao-lại-có-lớp-con-trainer-cho-các-bài-toán-chuỗi-sang-chuỗi","sections":[],"depth":3},{"title":"9. Vì sao không cần thiết chỉ định hàm mất mát khi gọi compile() trong mô hình Transformer?","local":"9-vì-sao-không-cần-thiết-chỉ-định-hàm-mất-mát-khi-gọi-compile-trong-mô-hình-transformer","sections":[],"depth":3},{"title":"10. Khi nào bạn nên huấn luyện trước một mô hình mới?","local":"10-khi-nào-bạn-nên-huấn-luyện-trước-một-mô-hình-mới","sections":[],"depth":3},{"title":"11. Vì sao ta dễ huấn luyện trước một mô hình ngôn ngữ khi có khối lượng văn bản khổng lồ?","local":"11-vì-sao-ta-dễ-huấn-luyện-trước-một-mô-hình-ngôn-ngữ-khi-có-khối-lượng-văn-bản-khổng-lồ","sections":[],"depth":3},{"title":"12. Đâu là những thách thức chính khi tiền xử lí dữ liệu cho tác vụ hỏi đáp?","local":"12-đâu-là-những-thách-thức-chính-khi-tiền-xử-lí-dữ-liệu-cho-tác-vụ-hỏi-đáp","sections":[],"depth":3},{"title":"13. Làm thể nào để hậu xử lý trong bài toán hỏi đáp?","local":"13-làm-thể-nào-để-hậu-xử-lý-trong-bài-toán-hỏi-đáp","sections":[],"depth":3}],"depth":1}';function Un(d,a,s){let $="pt";return En(()=>{const k=new URLSearchParams(window.location.search);s(0,$=k.get("fw")||"pt")}),[$]}class nt extends Sn{constructor(a){super(),An(this,a,Un,On,Bn,{})}}export{nt as component}; | |
Xet Storage Details
- Size:
- 23.8 kB
- Xet hash:
- 4ec0b78ebaba11006b16c884c54a021e13bf84c4b515d364a20fc469ce139d8c
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.