使用Bert预训练模型处理序列推荐任务

最近的工作有涉及该任务,整理一下思路以及代码细节。

流程

总体来说思路就是首先用预训练的bert模型,在训练集的序列上进行CLS任务。对序列内容(这里默认是token id的sequence)以0.3左右的概率进行随机mask,然后将相应sequence的attention mask(原来决定padding index)和label(也就是mask的ground truth)输入到bert model里面。

当然其中vocab.txt并不存在的token是需要add进去的,具体方法不再详述,网上例子很多,注意word embedding也需要初始化就行。

模型定义:
self.model = AutoModelForMaskedLM.from_pretrained('./bert')

模型的输入:
result = self.bert_model(tail_mask, attention_mask, labels)

得到模型训练的结果之后,要做一个选择:

(1)transformer的bert model可以输出要预测时间步的hidden state,可以选择取出对应的hidden state,其中需要在数据处理的时候记录下每个sequence的tail position,也就是要预测位置的idx。另外我认为既然要进行序列推荐,那么最后一个tail position的token表征一定是最重要的,所以需要对tail position的idx专门给个写死的mask,效果会好一些。然后与sequence中item的全集进行相似度的计算,再去算交叉熵loss。

py 复制代码
bert_hidden = result.hidden_states[-1]
bert_seq_hidden = torch.zeros((self.args.batch_size, 312)).to(self.device)
for i in range(self.args.batch_size):
	bert_seq_hidden[i,:] = bert_hidden[i, tail_pos[i], :]
logits = torch.matmul(bert_seq_hidden, test_item_emb.transpose(0, 1))
main_loss = self.criterion(logits, targets)

(2)同时也可以result.loss直接数据mask prediction的loss,我理解这个loss面对的任务是我要求sequence中的各个token表征都要尽可能准确,都要考虑,(1)可能更加注重最后一个位置的标准的准确性。

然后在evaluate阶段,需要注意输入到模型的不再是tail_mask,而是仅仅mask掉tail token id的sequence,因为我们需要尽可能准确的序列信息,只需要保证要预测的存在mask就够了。

由于是推荐任务,而且bert得到的hidden state表征过于隐式,所以需要一定的个性化引导它进行训练。经过个人的实验也确实如此,而且结果相差很多。

以上就是我个人的总结经验,欢迎大家指点。

相关推荐
nuise_1 分钟前
李沐 《动手学深度学习》 | 实战Kaggle比赛:预测房价
人工智能·深度学习
苏苏susuus6 分钟前
深度学习:PyTorch简介
人工智能·pytorch·深度学习
Sun_light29 分钟前
AI代替大脑:用Trae助手开发颜色记忆小游戏全流程实录
前端·人工智能·html
Lucien要变强32 分钟前
Cursor! 让我们意念合一!
人工智能·ai编程·cursor
程序员岳焱41 分钟前
深入解析Spring AI:Java生态中的AI集成利器
java·人工智能·openai
TGC达成共识43 分钟前
菌菇食用攻略:从营养解析到安全指南,解锁科学食菌
大数据·人工智能·其他·安全·百度·生活·新浪微博
汀沿河1 小时前
mac:大模型系列测试
人工智能·macos
硬核隔壁老王1 小时前
从零开始搭建RAG系统系列(十二):RAG系统评估及测评
人工智能·程序员·llm
芯盾时代1 小时前
AI中间件,构建大模型应用的标准化接入枢纽
人工智能·网络安全·中间件
机器之心1 小时前
刚刚,LeCun亲自出镜,Meta推出新世界模型!
人工智能·meta