一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

用PaddleNLP為GPT-2模型制作FineWeb二進制預(yù)訓(xùn)練數(shù)據(jù)集

jf_23871869 ? 來源:jf_23871869 ? 作者:jf_23871869 ? 2025-03-21 18:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

作者:算力魔方創(chuàng)始人/英特爾創(chuàng)新大使劉力

《用PaddleNLP在4060單卡上實踐大模型預(yù)訓(xùn)練技術(shù)》發(fā)布后收到讀者熱烈反響,很多讀者要求進一步講解更多的技術(shù)細節(jié)。本文主要針對大語言模型的預(yù)訓(xùn)練流程,使用PaddleNLP將FineWeb數(shù)據(jù)集中文本形式的數(shù)據(jù),經(jīng)過分詞化(Tokenize),轉(zhuǎn)換為大語言模型能直接使用的二進制數(shù)據(jù),以便提升訓(xùn)練效果。

ChatGPT發(fā)布后,當(dāng)代大語言模型(LLM)的訓(xùn)練流程基本遵循OpenAI提出的”預(yù)訓(xùn)練+后訓(xùn)練”的訓(xùn)練范式。

預(yù)訓(xùn)練:將海量知識通過無監(jiān)督學(xué)習(xí)的方式壓縮到大語言模型的權(quán)重中,使其具備基本的通用能力,能預(yù)測下一個分詞。預(yù)訓(xùn)練得到的模型叫基礎(chǔ)大模型。

后訓(xùn)練:通過監(jiān)督微調(diào)(SFT)和強化學(xué)習(xí)(RL)等方式,讓大模型按人類專家的方式輸出知識,使其具備專業(yè)能力。

一,PaddleNLP簡介


PaddleNLP是一款基于飛槳深度學(xué)習(xí)框架的大語言模型(LLM)開發(fā)套件,支持在多種硬件上進行高效的大模型訓(xùn)練、無損壓縮以及高性能推理。PaddleNLP 具備簡單易用和性能極致的特點,致力于助力開發(fā)者實現(xiàn)高效的大模型產(chǎn)業(yè)級應(yīng)用。

wKgZPGfcAnGAZJZbAAB0V6tIGJQ893.png

Github: https://github.com/PaddlePaddle/PaddleNLP


使用PaddleNLP實現(xiàn)訓(xùn)練文本分詞化僅需三行代碼,如下所示:

# 導(dǎo)入PaddleNLP庫中的GPTTokenizer類
from paddlenlp.transformers import GPTTokenizer
# 使用預(yù)訓(xùn)練的"gpt2-en"模型初始化GPTTokenizer,并設(shè)置bos_token為空字符串
tokenizer = GPTTokenizer.from_pretrained("gpt2-en", bos_token="")
# 打印使用tokenizer對字符串"Hello, world!"進行編碼后的結(jié)果
print(tokenizer.encode("Hello, world!"))

進入:

https://tiktokenizer.vercel.app/?model=gpt2


可以對比PaddleNLP的GPTTokenzier對“Hello,World!”的分詞結(jié)果。

二,F(xiàn)ineWeb簡介


FineWeb是由Hugging Face團隊于2024年推出的超大規(guī)模語言模型預(yù)訓(xùn)練數(shù)據(jù)集。作為目前最大的開源預(yù)訓(xùn)練數(shù)據(jù)集之一,F(xiàn)ineWeb數(shù)據(jù)集包含來自 CommonCrawl 的超過 15T 經(jīng)過清理和重復(fù)數(shù)據(jù)刪除的英文網(wǎng)絡(luò)數(shù)據(jù)。其高質(zhì)量的數(shù)據(jù),有助于大語言模型穩(wěn)定平穩(wěn)的完成預(yù)訓(xùn)練,而不會發(fā)生由重復(fù)低質(zhì)數(shù)據(jù)引發(fā)的Loss Spike。

Link: https://huggingface.co/datasets/HuggingFaceFW/fineweb

本文使用FineWeb數(shù)據(jù)集的sample-10BT子集作為GPT-2的預(yù)訓(xùn)練數(shù)據(jù)集。

三,開發(fā)環(huán)境準備


本文的開發(fā)環(huán)境依賴PaddlePaddle、PaddleNLP、datasets和tqdm。

首先,請安裝PaddlePaddle框架:

pip install paddlepaddle


然后,安裝其它依賴項:

pip install paddlenlp datasets tqdm


四,代碼實現(xiàn)


用PaddleNLP將FineWeb數(shù)據(jù)集進行分詞化處理,然后轉(zhuǎn)換為大語言模型能直接使用的二進制數(shù)據(jù)的關(guān)鍵步驟有:

1.從HuggingFace Hub加載fineweb數(shù)據(jù)集的10B樣本子集;

2.使用train_test_split按比例分割訓(xùn)練集和驗證集;

3.對每個文本進行編碼,添加結(jié)束符eot_token,返回ids和len;

4.為訓(xùn)練集和驗證集分別創(chuàng)建.bin文件,使用np.memmap高效寫入。

關(guān)鍵代碼如下所示:

wKgZPGfcAsWAHLv_AACNkvpFFuo041.png

完整范例代碼請參見:

https://aistudio.baidu.com/projectdetail/8798975


運行成功后,可以得到如下兩個文件:

wKgZPGfcAtCALsZgAAA-5MiqMvw838.png

五,總結(jié)


PaddleNLP好學(xué)易用,借助PaddleNLP的GPTTokenizer很容易實現(xiàn)FineWeb數(shù)據(jù)集的分詞化,并轉(zhuǎn)換為方便大模型預(yù)訓(xùn)練的二進制數(shù)據(jù)!

如果你有更好的文章,歡迎投稿!

稿件接收郵箱:nami.liu@pasuntech.com

更多精彩內(nèi)容請關(guān)注“算力魔方?”!

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 二進制
    +關(guān)注

    關(guān)注

    2

    文章

    807

    瀏覽量

    42337
  • 數(shù)據(jù)集
    +關(guān)注

    關(guān)注

    4

    文章

    1224

    瀏覽量

    25457
  • GPT
    GPT
    +關(guān)注

    關(guān)注

    0

    文章

    368

    瀏覽量

    16098
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    PaddleNLP在4060單卡上實踐大模型預(yù)訓(xùn)練技術(shù)

    手把手教您如何在單張消費級顯卡上,利用PaddleNLP實踐OpenAI的GPT-2模型預(yù)訓(xùn)練GPT
    的頭像 發(fā)表于 02-19 16:10 ?999次閱讀
    <b class='flag-5'>用</b><b class='flag-5'>PaddleNLP</b>在4060單卡上實踐大<b class='flag-5'>模型</b><b class='flag-5'>預(yù)</b><b class='flag-5'>訓(xùn)練</b>技術(shù)

    偏移二進制二進制補碼如何和實際數(shù)據(jù)對應(yīng),如何轉(zhuǎn)換?

    偏移二進制二進制補碼如何和實際數(shù)據(jù)對應(yīng),如何轉(zhuǎn)換,請哪位高手解惑
    發(fā)表于 01-16 06:01

    TLC2543的輸出結(jié)果應(yīng)為帶符號二進制格式的數(shù)據(jù),現(xiàn)在輸出的結(jié)果不帶符號的二進制數(shù),這是因為什么原因?

    DSP采用模擬SPI總線的方式和TLC2543進行通信,采用AIN0,AIN1,AIN2,TLC2543的輸出數(shù)據(jù)格式16位,高位在前,帶符號二進制數(shù)。
    發(fā)表于 12-27 07:46

    bcd編碼的應(yīng)用 bcd與二進制的區(qū)別

    BCD(Binary-Coded Decimal)編碼是一種二進制編碼形式,用于表示十進制數(shù)字。它將每個十進制數(shù)字(0-9)直接編碼一個四位二進制
    的頭像 發(fā)表于 12-20 17:11 ?3227次閱讀

    hex格式和二進制的區(qū)別

    HEX格式和二進制在多個方面存在顯著的區(qū)別。以下是對這兩者的對比: 一、定義與表示方式 HEX格式 : HEX,全稱為Intel HEX,是一種用于存儲和傳輸數(shù)據(jù)到嵌入式系統(tǒng)(如單片機)的文件格式
    的頭像 發(fā)表于 11-18 15:24 ?1744次閱讀

    在線二進制編碼器:數(shù)據(jù)轉(zhuǎn)換的快捷通道

    在數(shù)字時代,數(shù)據(jù)的快速轉(zhuǎn)換與處理至關(guān)重要。二進制編碼,作為計算機內(nèi)部數(shù)據(jù)表示的基礎(chǔ),將信息轉(zhuǎn)化為0和1的序列,數(shù)字世界構(gòu)建了溝通的橋梁。然而,對于非專業(yè)用戶來說,手動進行
    的頭像 發(fā)表于 11-15 09:01 ?1815次閱讀

    base64字符串轉(zhuǎn)換為二進制文件

    一些編程知識。以下是將Base64字符串轉(zhuǎn)換為二進制文件的一般步驟,以及一個簡單的Python示例代碼。 步驟: 獲取Base64字符串 :首先,你需要有一個Base64編碼的字符串。 解碼Base64字符串 :使用編程語言提供的庫函數(shù)將Base64字符串解碼
    的頭像 發(fā)表于 11-10 10:55 ?2842次閱讀

    ASCII碼和二進制的轉(zhuǎn)換關(guān)系

    。ASCII碼使用7位二進制數(shù)來表示128個不同的字符,包括大小寫英文字母、數(shù)字0-9以及一些控制字符和標點符號。后來,ASCII碼被擴展到了8位,即ASCII-8BIT,可以表示256個不同的字符。 二進制
    的頭像 發(fā)表于 11-10 09:50 ?4026次閱讀

    二進制編碼器的精度與分辨率

    在數(shù)字電子系統(tǒng)中,二進制編碼器扮演著至關(guān)重要的角色。它負責(zé)將外部世界的模擬信號轉(zhuǎn)換為計算機可以理解的數(shù)字信號。精度和分辨率是衡量二進制編碼器性能的兩個關(guān)鍵指標。 1. 二進制編碼器的基本原理
    的頭像 發(fā)表于 11-06 09:56 ?1241次閱讀

    二進制編碼器在自動化領(lǐng)域的作用

    二進制編碼器是一種將二進制信號轉(zhuǎn)換為數(shù)字信號的電子設(shè)備,廣泛應(yīng)用于自動化領(lǐng)域。 一、二進制編碼器的工作原理 二進制編碼器是一種將二進制信號轉(zhuǎn)
    的頭像 發(fā)表于 11-06 09:53 ?954次閱讀

    二進制編碼器的種類及特點

    處理多個輸入信號,并根據(jù)輸入信號的優(yōu)先級輸出一個二進制編碼。如果多個輸入同時高電平,它將輸出最高優(yōu)先級的輸入對應(yīng)的編碼。 應(yīng)用 :常用于鍵盤掃描、中斷優(yōu)先級處理等場景。 二進制到十進制
    的頭像 發(fā)表于 11-06 09:47 ?1468次閱讀

    二進制編碼器應(yīng)用場景 二進制編碼器與模擬編碼器比較

    編碼器是將信息從一種形式或格式轉(zhuǎn)換為另一種形式的設(shè)備。在數(shù)字和模擬系統(tǒng)中,編碼器扮演著至關(guān)重要的角色。二進制編碼器和模擬編碼器是兩種常見的編碼器類型,它們在不同的應(yīng)用場景中有著各自的優(yōu)勢和局
    的頭像 發(fā)表于 11-06 09:45 ?1266次閱讀

    二進制編碼器工作原理 如何選擇二進制編碼器

    編碼器通常有多個輸入端(通常2的n次方個,其中n是編碼器的位數(shù)),和一個或多個輸出端。每個輸入端對應(yīng)一個二進制位,而輸出端則表示輸入的二進制值。 優(yōu)先編碼器 : 優(yōu)先編碼器是一種特殊
    的頭像 發(fā)表于 11-06 09:44 ?2543次閱讀

    二進制補碼及與原碼的互相轉(zhuǎn)換方法

    大沙把一些基礎(chǔ)的知識說清楚,本文介紹二進制補碼及與原碼的轉(zhuǎn)換方法。 先說原碼,原碼?是一種計算機中對數(shù)字的二進制定點表示方法。在原碼表示法中,數(shù)值前面增加了一位符號位,最高位符號位,0表示正數(shù),1
    的頭像 發(fā)表于 09-19 22:25 ?1495次閱讀

    計算機采用二進制的原因不包括什么

    ,我們先簡要回顧一下為什么計算機會采用二進制。 物理實現(xiàn)的簡便性 :計算機的硬件,如晶體管,可以兩種穩(wěn)定狀態(tài)來表示信息,通常是0和1,這對應(yīng)于二進制的兩個數(shù)字。這種二進制系統(tǒng)非常適合
    的頭像 發(fā)表于 09-04 17:03 ?1279次閱讀