news 2026/6/10 18:11:18

HuggingFace项目实战之填空任务实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HuggingFace项目实战之填空任务实战

目录:

    • 一、使用场景
    • 二、代码分析

一、使用场景

大模型在填空任务中的应用主要涉及自动补全、内容生成和知识推理等场景,其核心能力在于基于上下文预测缺失信息。

二、代码分析

importtorchfromtransformersimportAutoTokenizer#加载tokenizertokenizer=AutoTokenizer.from_pretrained('google-bert/bert-base-chinese')tokenizer

fromdatasetsimportload_dataset#加载数据集dataset=load_dataset(path='lansinuote/ChnSentiCorp')#编码f=lambdax:tokenizer(x['text'],truncation=True,max_length=30,return_token_type_ids=False)dataset=dataset.map(f,remove_columns=['text','label'])#过滤句子长度f=lambdax:len(x['input_ids'])>=30dataset=dataset.filter(f)#重置label字段deff(data):#定义第15个字为labeldata['label']=data['input_ids'][15]#替换句子中的第15个字为maskdata['input_ids'][15]=tokenizer.mask_token_idreturndata dataset=dataset.map(f)#设置数据类型dataset.set_format('pt')dataset,dataset['train'][0]

loader=torch.utils.data.DataLoader(dataset['train'],batch_size=8,shuffle=True,drop_last=True)data=next(iter(loader))fork,vindata.items():print(k,v.shape)len(loader)

#查看数据样例forq,ainzip(data['input_ids'],data['label']):print(tokenizer.decode(q))print(tokenizer.decode(a))print('==============')

#定义模型classModel(torch.nn.Module):def__init__(self):super().__init__()#加载预训练模型fromtransformersimportAutoModel self.pretrained=AutoModel.from_pretrained('google-bert/bert-base-chinese')self.fc=torch.nn.Linear(in_features=768,out_features=tokenizer.vocab_size)defforward(self,input_ids,attention_mask,label=None):#使用预训练模型抽取数据特征withtorch.no_grad():last_hidden_state=self.pretrained(input_ids=input_ids,attention_mask=attention_mask).last_hidden_state#取第15个词的特征向量last_hidden_state=last_hidden_state[:,15]#对抽取的特征只取第一个字的结果做分类即可out=self.fc(last_hidden_state).softmax(dim=1)#计算lossloss=NoneiflabelisnotNone:loss=torch.nn.functional.cross_entropy(out,label)returnloss,out model=Model()model(**data)

#执行训练deftrain():optimizer=torch.optim.Adam(model.parameters(),lr=1e-4)forepochinrange(5):fori,datainenumerate(loader):loss,out=model(**data)loss.backward()optimizer.step()optimizer.zero_grad()ifi%200==0:out=out.argmax(dim=1)acc=(out==data['label']).sum().item()/len(data['label'])print(epoch,i,len(loader),loss.item(),acc)train()

#执行测试deftest():loader_test=torch.utils.data.DataLoader(dataset['test'],batch_size=8,shuffle=True,drop_last=True)correct=0total=0fori,datainenumerate(loader_test):withtorch.no_grad():_,out=model(**data)out=out.argmax(dim=1)correct+=(out==data['label']).sum().item()total+=len(data['label'])print(i,len(loader_test),correct/total)ifi==5:breakreturncorrect/total test()

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 14:27:25

EDCA Admission Protocols 发布:AI 系统进入“可拒绝接入”时代

在现有 AI 系统中,一个长期被忽视却至关重要的问题正在逐渐显现:当人类表达进入 AI 系统时, 是否存在一个明确、可裁决、可拒绝的接入阶段?现实情况是,大多数系统默认“表达即执行”。 一旦输入被接收,就会…

作者头像 李华
网站建设 2026/6/10 14:20:18

格雷厄姆特价股票策略在不同数字监管沙盒环境中的表现

格雷厄姆特价股票策略在不同数字监管沙盒环境中的表现 关键词:格雷厄姆特价股票策略、数字监管沙盒、股票投资、策略表现、监管环境 摘要:本文深入探讨了格雷厄姆特价股票策略在不同数字监管沙盒环境中的表现。首先介绍了研究的背景、目的、预期读者等内容,阐述了核心概念及…

作者头像 李华
网站建设 2026/5/30 3:47:43

【性能测试】4_性能测试基础 _流程(重点)

文章目录一、如何开展工作二、性能测试流程2.1 性能测试需求分析2.2 性能测试计划及方案2.3 性能测试用例2.4 建立测试环境2.5 测试脚本编写/录制2.6 执行测试脚本2.7 性能测试监控2.8 性能分析和调优2.9 性能测试报告总结一、如何开展工作 思考:为什么要掌握性能测…

作者头像 李华
网站建设 2026/6/10 14:19:58

A.每日一题——85. 最大矩形

题目链接:85. 最大矩形(困难) 算法原理: 博主声明:这84题和85题感谢灵神🌹🌹🌹的启发,我在灵神的思路上产生自己的想法,因此自己纯手敲了一遍,写博…

作者头像 李华