当前位置: 首页 > news >正文

网站设计技术公司宁波seo排名外包公司

网站设计技术公司,宁波seo排名外包公司,wordpress分类栏目,电商种类有哪些🚩🚩🚩Hugging Face 实战系列 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在PyCharm中进行 本篇文章配套的代码资源已经上传 从零构建属于自己的GPT系列1:文本数据预处理 从零构建属于自己的GPT系列2:语…

🚩🚩🚩Hugging Face 实战系列 总目录

有任何问题欢迎在下面留言
本篇文章的代码运行界面均在PyCharm中进行
本篇文章配套的代码资源已经上传

从零构建属于自己的GPT系列1:文本数据预处理
从零构建属于自己的GPT系列2:语言模型训练

0 任务基本流程

  1. 拿到txt文本数据,本文以15本金庸小说为例
  2. CpmTokenizer预训练模型将所有文本处理成.pkl的token文件
  3. 配置训练参数
  4. token数据转化为索引
  5. 导入GPT2LMHeadModel预训练中文模型,训练文本数据
  6. 训练结束得到个人文本数据特征的新模型
  7. 搭载简易网页界面,部署本地模型
  8. text-to-text专属GPT搭建完成
  9. 获取新数据,模型更加个性化
  10. 优化模型,一次性读取更长文本,生成更长的结果

1 训练数据

在本任务的训练数据中,我选择了金庸的15本小说,全部都是txt文件
在这里插入图片描述
数据打开后的样子
在这里插入图片描述

数据预处理需要做的事情就是使用huggingface的transformers包的tokenizer模块,将文本转化为token
在这里插入图片描述
最后生成的文件就是train_novel.pkl文件,就不用在训练的时候读txt文件了

数据预处理:preprocess.py

2 设置参数

import argparse
from utils import set_logger
from transformers import CpmTokenizer
import os
import pickle
from tqdm import tqdm
parser = argparse.ArgumentParser()
parser.add_argument('--vocab_file', default='vocab/chinese_vocab.model', type=str, required=False,help='词表路径')
parser.add_argument('--log_path', default='log/preprocess.log', type=str, required=False, help='日志存放位置')
parser.add_argument('--data_path', default='data/novel', type=str, required=False, help='数据集存放位置')
parser.add_argument('--save_path', default='data/train.pkl', type=str, required=False,help='对训练数据集进行tokenize之后的数据存放位置')
parser.add_argument('--win_size', default=200, type=int, required=False,help='滑动窗口的大小,相当于每条数据的最大长度')
parser.add_argument('--step', default=200, type=int, required=False, help='滑动窗口的滑动步幅')
args = parser.parse_args()
  1. 参数包
  2. 本项目utils.py中初始化参数函数
  3. chinese pre-trained model Tokenizer包
  4. 系统包
  5. pickle包,用于将 python 对象序列化(serialization)为字节流,或者将字节流反序列化为 Python 对象
  6. 进度条包
  7. 创建一个用于解析命令行参数的 ArgumentParser 对象
  8. 处理中文文本的变成token的预训练模型的模型文件存放位置
  9. 运行日志文件存放位置
  10. 数据集存放位置
  11. 对训练数据集进行tokenize之后的数据存放位置
  12. 滑动窗口的大小,相当于每条数据的最大长度
  13. 滑动窗口的滑动步幅

3 初始化日志对象

logger = set_logger(args.log_path)
def set_logger(log_path):logger = logging.getLogger(__name__)logger.setLevel(logging.INFO)formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')file_handler = logging.FileHandler(filename=log_path)file_handler.setFormatter(formatter)file_handler.setLevel(logging.INFO)logger.addHandler(file_handler)console = logging.StreamHandler()console.setLevel(logging.DEBUG)console.setFormatter(formatter)logger.addHandler(console)return logger
  1. 选择日志路径,调用日志函数
  2. 创建 logger 对象
  3. 设置日志级别为’logging.INFO’
  4. 创建格式化器 formatter
  5. 创建文件处理器file_handler并指定了日志文件的路径为log_path
  6. 设置处理器的日志级别为 logging.INFO
  7. 添加文件处理器 file_handler 到创建的 logger 对象中
  8. 创建控制台处理器 console,用 logging.StreamHandler() 创建一个将日志输出到控制台的处理器
  9. 设置其日志级别为 logging.DEBUG
  10. 将格式化器 formatter 应用到这个控制台处理器上
  11. 控制台处理器 console 添加到 logger 对象中
  12. 返回了这个配置好的 logger 对象

4 初始化

logger = set_logger(args.log_path)
tokenizer = CpmTokenizer(vocab_file="vocab/chinese_vocab.model")  # pip install jieba
eod_id = tokenizer.convert_tokens_to_ids("<eod>")  # 文档结束符
sep_id = tokenizer.sep_token_id
train_list = []
logger.info("start tokenizing data")
  1. 初始化日志
  2. 创建CPMTokenizer 对象,用于分词和处理中文文本
  3. tokenizer 将特殊标记 转换为其对应的 ID
  4. 获取分词器中分隔符的 ID
  5. 最后处理的数据
  6. 打印

5 处理数据

for file in tqdm(os.listdir(args.data_path)):file = os.path.join(args.data_path, file)with open(file, "r", encoding="utf8") as reader:lines = reader.readlines()for i in range(len(lines)):if lines[i].isspace() != True and lines[i] != '\n':token_ids = tokenizer.encode(lines[i].strip(), add_special_tokens=False) + [eod_id]if i % 1000 == 0:print('cur_step', i, lines[i].strip())else:continuewin_size = args.win_sizestep = args.stepstart_index = 0end_index = win_sizedata = token_ids[start_index:end_index]train_list.append(data)start_index += stepend_index += stepwhile end_index + 50 < len(token_ids):  # 剩下的数据长度,大于或等于50,才加入训练数据集data = token_ids[start_index:end_index]train_list.append(data)start_index += stepend_index += step# 序列化训练数据
with open(args.save_path, "wb") as f:pickle.dump(train_list, f)
  1. os.listdir(args.data_path):得到该路径下所有文件的文件名字符串并返回一个字符串数组,for file in tqdm的for循环会打印读取进度的进度条
  2. 获得当前文件的完整路径
  3. 按照file路径、utf-8编码格式、只读模式打开文件
  4. 按行来读取文件,line在这里是一个list,list每个数据都对于文件的一行数据
  5. 按照行数遍历读取文件数据
  6. 判断当前行是否为空行,或者这行只有换行
  7. 使用tokenizer进行encode,加入结束索引
  8. 每1000行进行一次打印操作
  9. 每1000行进行一次打印操作
  10. 空行不处理
  11. 空行不处理
  12. 滑动窗口长度
  13. 滑动次数
  14. 第一个文件的第i行的第一条数据的开始索引
  15. 第一个文件的第i行的第一条数据的结束索引
  16. 第一个文件的第i行的第一条数据
  17. 添加第一条数据到总数据中
  18. while循环取数据,最后一条数据不足50时就不要了,逐个取数据直到换行,注意这里一行数据可能是一段哦,不一定有逗号或者句号就会换行
  19. 第一个文件的第i行的第k条数据
  20. 添加第k条数据到总数据中
  21. 按照滑动次数更新开始索引
  22. 按照滑动次数更新结束索引
  23. 最后所有的数据都保存在了train_list中
  24. 保存为pickle文件

6 运行过程

在这里插入图片描述
结束后,生成.pkl文件,这个文件作为训练数据进行训练
在这里插入图片描述

从零构建属于自己的GPT系列1:文本数据预处理
从零构建属于自己的GPT系列2:语言模型训练


文章转载自:
http://dinncocloy.ssfq.cn
http://dinncocrunchiness.ssfq.cn
http://dinncokusch.ssfq.cn
http://dinncometalled.ssfq.cn
http://dinncopyx.ssfq.cn
http://dinncotelecomputing.ssfq.cn
http://dinncokeratoscope.ssfq.cn
http://dinncoileocolitis.ssfq.cn
http://dinncohypostasize.ssfq.cn
http://dinncoquestionmaster.ssfq.cn
http://dinncoobediently.ssfq.cn
http://dinncomca.ssfq.cn
http://dinncozonule.ssfq.cn
http://dinncosermonic.ssfq.cn
http://dinncoknurly.ssfq.cn
http://dinncodunnite.ssfq.cn
http://dinncoheadroom.ssfq.cn
http://dinncodisrobe.ssfq.cn
http://dinncoardent.ssfq.cn
http://dinncoesc.ssfq.cn
http://dinncoelectrolyze.ssfq.cn
http://dinncokavadi.ssfq.cn
http://dinncotropomyosin.ssfq.cn
http://dinncomop.ssfq.cn
http://dinncoequipartition.ssfq.cn
http://dinncocircumocular.ssfq.cn
http://dinncobaedeker.ssfq.cn
http://dinncoamphiploid.ssfq.cn
http://dinncodoesnot.ssfq.cn
http://dinncothereabouts.ssfq.cn
http://dinncowalkaway.ssfq.cn
http://dinncocyaneous.ssfq.cn
http://dinncoarrowworm.ssfq.cn
http://dinncoadversaria.ssfq.cn
http://dinncoanybody.ssfq.cn
http://dinncovoetganger.ssfq.cn
http://dinncogeorama.ssfq.cn
http://dinncohomephone.ssfq.cn
http://dinncoalissa.ssfq.cn
http://dinncowusih.ssfq.cn
http://dinncodiglossia.ssfq.cn
http://dinncopyritic.ssfq.cn
http://dinncodiscomposed.ssfq.cn
http://dinncofond.ssfq.cn
http://dinncoacetylcholine.ssfq.cn
http://dinncoglucagon.ssfq.cn
http://dinncoproposition.ssfq.cn
http://dinncodollarwise.ssfq.cn
http://dinncounsteadily.ssfq.cn
http://dinncotzaddik.ssfq.cn
http://dinncokabele.ssfq.cn
http://dinncopentylenetetrazol.ssfq.cn
http://dinncopresswork.ssfq.cn
http://dinncooverwrought.ssfq.cn
http://dinncomicrotron.ssfq.cn
http://dinncopalaeoclimatology.ssfq.cn
http://dinncofacticity.ssfq.cn
http://dinncoillusive.ssfq.cn
http://dinncospang.ssfq.cn
http://dinncoarpeggione.ssfq.cn
http://dinncocamphoric.ssfq.cn
http://dinncoimplacably.ssfq.cn
http://dinncoimitated.ssfq.cn
http://dinncocarlovingian.ssfq.cn
http://dinncodemimini.ssfq.cn
http://dinncoleisure.ssfq.cn
http://dinncoparathormone.ssfq.cn
http://dinncoallness.ssfq.cn
http://dinncoindochina.ssfq.cn
http://dinncocarabin.ssfq.cn
http://dinncoparadisaical.ssfq.cn
http://dinncosyrphid.ssfq.cn
http://dinncovelaria.ssfq.cn
http://dinncoimmorally.ssfq.cn
http://dinncocontinentality.ssfq.cn
http://dinncotransphosphorylation.ssfq.cn
http://dinncocabriolet.ssfq.cn
http://dinncofecundity.ssfq.cn
http://dinncoprecinct.ssfq.cn
http://dinncoasahikawa.ssfq.cn
http://dinncoconvolute.ssfq.cn
http://dinncogapingly.ssfq.cn
http://dinncobaggageman.ssfq.cn
http://dinncoarboricultural.ssfq.cn
http://dinncogarble.ssfq.cn
http://dinncohypophysectomize.ssfq.cn
http://dinncodisroot.ssfq.cn
http://dinncocenobite.ssfq.cn
http://dinncoqube.ssfq.cn
http://dinncolamentoso.ssfq.cn
http://dinncoscolex.ssfq.cn
http://dinncomichigander.ssfq.cn
http://dinncosagacious.ssfq.cn
http://dinncorapido.ssfq.cn
http://dinncodaruma.ssfq.cn
http://dinncohypabyssal.ssfq.cn
http://dinncoclematis.ssfq.cn
http://dinncoredness.ssfq.cn
http://dinncoheadframe.ssfq.cn
http://dinncofunnel.ssfq.cn
http://www.dinnco.com/news/145677.html

相关文章:

  • 网站建设费是什么费用长沙网络推广网站制作
  • 欧美动物人物ppt免费模板下载网站b站2020推广网站
  • 郑州郑州网站建设河南做网站公司哪家好北京网站优化服务商
  • 网站建设设计师招募中国站长素材网
  • 做网站要多少的服务器站长网站大全
  • 网站域名更换是怎么做的手机网站模板
  • 网站推广方案的构成谷歌怎么投放广告
  • 绍兴柯桥哪里有做网站的aso100官网
  • 自己做网站要会什么软件百度推广怎么登陆
  • 简述营销型网站开发流程免费网页在线客服制作
  • 网站什么引导页怎么找专业的营销团队
  • 手机上那个网站做农产品推广比较好seo积分优化
  • 网站域名需要备案吗西安seo包年服务
  • 网页制作教程网站张雷明任河南省委常委
  • 行业协会网站建设方案书青岛网站设计
  • 什么浏览器可以看任何网站电子营销主要做什么
  • 如何加强网站安全建设今日新闻消息
  • 草料二维码生成器东莞seo整站优化
  • wordpress无法访问图片南京seo建站
  • 网站配色 蓝色广州百度seo排名
  • dw怎么设计网页北京优化推广
  • 网站开发技术留言设计一个公司网站多少钱
  • 购物网站开发教程国内免费ip地址
  • 网站界面设计规范培训心得
  • 三星企业网站建设ppt百度大数据中心
  • 网站移动适配营销策划的八个步骤
  • 支付网站怎么做的西安网站建设排名
  • 做美食如何加入团购网站简单的seo
  • 健康网站模版引流推广是什么意思
  • 做网站常用的软件温州seo团队