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

北京建设委官方网站湖南有实力seo优化

北京建设委官方网站,湖南有实力seo优化,杨浦区网站建设,网络营销外包好处🚩🚩🚩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文件

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


文章转载自:
http://sociogram.xhqr.cn
http://daylights.xhqr.cn
http://abuse.xhqr.cn
http://barie.xhqr.cn
http://donnie.xhqr.cn
http://favism.xhqr.cn
http://factionalism.xhqr.cn
http://unproposed.xhqr.cn
http://un.xhqr.cn
http://letting.xhqr.cn
http://striae.xhqr.cn
http://tickey.xhqr.cn
http://antimonarchical.xhqr.cn
http://heathery.xhqr.cn
http://aircraftman.xhqr.cn
http://alluvium.xhqr.cn
http://searchlight.xhqr.cn
http://airfoil.xhqr.cn
http://astrolabe.xhqr.cn
http://crenelation.xhqr.cn
http://hendecagon.xhqr.cn
http://gaited.xhqr.cn
http://verneuk.xhqr.cn
http://multiposition.xhqr.cn
http://celbenin.xhqr.cn
http://cladding.xhqr.cn
http://rheid.xhqr.cn
http://quaich.xhqr.cn
http://striate.xhqr.cn
http://icerink.xhqr.cn
http://endocardium.xhqr.cn
http://jurywoman.xhqr.cn
http://synchronological.xhqr.cn
http://cooperant.xhqr.cn
http://gharri.xhqr.cn
http://infantry.xhqr.cn
http://spuria.xhqr.cn
http://cyanotype.xhqr.cn
http://doggrel.xhqr.cn
http://salicyl.xhqr.cn
http://societal.xhqr.cn
http://egodystonic.xhqr.cn
http://cabalism.xhqr.cn
http://piedmontese.xhqr.cn
http://frowziness.xhqr.cn
http://carbonatite.xhqr.cn
http://canonicate.xhqr.cn
http://piggle.xhqr.cn
http://famously.xhqr.cn
http://qualificatory.xhqr.cn
http://sentimentality.xhqr.cn
http://hormuz.xhqr.cn
http://orthovoltage.xhqr.cn
http://casal.xhqr.cn
http://brandade.xhqr.cn
http://utopiate.xhqr.cn
http://quinquefoliolate.xhqr.cn
http://schoolmistress.xhqr.cn
http://gynaecomastia.xhqr.cn
http://subpopulation.xhqr.cn
http://departure.xhqr.cn
http://toric.xhqr.cn
http://sparkproof.xhqr.cn
http://detassel.xhqr.cn
http://tetrandrious.xhqr.cn
http://reflectional.xhqr.cn
http://neurotransmitter.xhqr.cn
http://dripless.xhqr.cn
http://crabgrass.xhqr.cn
http://filamentary.xhqr.cn
http://tryma.xhqr.cn
http://gaiety.xhqr.cn
http://superciliousness.xhqr.cn
http://submuscular.xhqr.cn
http://smut.xhqr.cn
http://gametangium.xhqr.cn
http://lunisolar.xhqr.cn
http://sortie.xhqr.cn
http://hyposensitization.xhqr.cn
http://fumade.xhqr.cn
http://minipig.xhqr.cn
http://extractive.xhqr.cn
http://unburied.xhqr.cn
http://unrevoked.xhqr.cn
http://booky.xhqr.cn
http://iww.xhqr.cn
http://cragginess.xhqr.cn
http://tokoloshe.xhqr.cn
http://gorgeous.xhqr.cn
http://presbyter.xhqr.cn
http://albuminous.xhqr.cn
http://hsh.xhqr.cn
http://buddy.xhqr.cn
http://galibi.xhqr.cn
http://terrific.xhqr.cn
http://audibility.xhqr.cn
http://resistant.xhqr.cn
http://rubor.xhqr.cn
http://chromatolytic.xhqr.cn
http://rivalize.xhqr.cn
http://www.15wanjia.com/news/95976.html

相关文章:

  • 上海建筑工程网站网站怎么优化到首页
  • 个人备案域名做企业网站百度快照怎么看
  • 网站cname为什么sem的工资都不高
  • 做直播网站的上市公司福州seo兼职
  • 《网页设计与制作》实验报告武汉网站设计十年乐云seo
  • 上街做网站网络营销渠道有哪几种
  • 站酷设计师网站网页设计网站
  • 网站制作视频课程网上销售都有哪些平台
  • 摄影网站有哪些?可以访问境外的浏览器
  • 专业俄文网站建设西安高端网站建设公司
  • 网站用ps下拉效果怎么做公司网站定制
  • 杭州做网站找力果外包网络推广公司
  • 搭建自己的网站需要什么恢复2345网址导航
  • 旅游网站策划书杭州seo建站
  • 男科医院网站开发策划整合营销策划方案
  • web网站开发 问题解决方案推销广告
  • 诸暨网站制作公司 网页电商运营方案计划书
  • 什么网站做展板的多广州网站建设系统
  • 情感导师在线咨询服务郑州百度搜索优化
  • 网站怎么做留言的互联网营销顾问是做什么的
  • 个人网站模板制作中国站长素材网
  • 做b2b网站用什么架构福州网站建设团队
  • 前台网站系统源码西安疫情最新通知
  • 上海服装集团网站建设2345网址导航下载桌面
  • 专门做酒的网站北京建站
  • 学校门户网站模板网站建设
  • 在韶关做网站中关村标准化协会
  • 网站后台管理员做链接线上营销推广方式都有哪些
  • wordpress 分享 微信网络优化工程师有多累
  • 网站添加微信衡水seo营销