2 使用自己的数据训练一个简单的二分类模型

1 下载数据

1null手把手带你实战 Huggingface Transformers 课程视频同步更新在B站与YouTube - transformers-code/01-Getting Started/04-model/ChnSentiCorp_htl_all.csv at master · zyds/transformers-codehttps://github.com/zyds/transformers-code/blob/master/01-Getting%20Started/04-model/ChnSentiCorp_htl_all.csv手把手带你实战 Huggingface Transformers 课程视频同步更新在B站与YouTube - transformers-code/01-Getting Started/04-model/ChnSentiCorp_htl_all.csv at master · zyds/transformers-codehttps://github.com/zyds/transformers-code/blob/master/01-Getting%20Started/04-model/ChnSentiCorp_htl_all.csv巧妇难为无米之炊,先准备数据吧!

1.1 简单数据分析:

2 上代码,上模型

1 整理数据。 2 加载预训练模型。 3 微调。

from transformers import AutoTokenizer, AutoModelForSequenceClassification
import pandas as pd
data = pd.read_csv("./data/ChnSentiCorp_htl_all.csv")
data = data.dropna()
# 画图
data.groupby('label').count().plot(kind='bar')



# 变化成模型能够读懂的格式
from torch.utils.data import Dataset

class MyDataset(Dataset):

    def __init__(self) -> None:
        super().__init__()
        self.data = pd.read_csv("./data/ChnSentiCorp_htl_all.csv")
        self.data = self.data.dropna()

    def __getitem__(self, index):
        return self.data.iloc[index]["review"], self.data.iloc[index]["label"]
    
    def __len__(self):
        return len(self.data)
# 划分数据集
from torch.utils.data import random_split
dataset = MyDataset()

trainset, validset = random_split(dataset, lengths=[0.9, 0.1])
len(trainset), len(validset)


import torch

tokenizer = AutoTokenizer.from_pretrained("./dianping")

# 前面提到了 需要对数据进行处理称模型能够接受的格式: input_ids, token_type_ids,attention_mask
def collate_func(batch):
    texts, labels = [], []
    for item in batch:
        texts.append(item[0])
        labels.append(item[1])
    inputs = tokenizer(texts, max_length=128, padding="max_length", truncation=True, return_tensors="pt")
    inputs["labels"] = torch.tensor(labels)
    return inputs
from torch.utils.data import DataLoader

trainloader = DataLoader(trainset, batch_size=32, shuffle=True, collate_fn=collate_func)
validloader = DataLoader(validset, batch_size=64, shuffle=False, collate_fn=collate_func)



# 加载预训练模型,然后优化
from torch.optim import Adam
model = AutoModelForSequenceClassification.from_pretrained("./dianping")

if torch.cuda.is_available():
    model = model.cuda()
# 两个参数, 1 模型参数, 2 学习速率
optimizer = Adam(model.parameters(), lr=2e-5)
def evaluate():
    model.eval()
    acc_num = 0
    with torch.inference_mode():
        for batch in validloader:
            if torch.cuda.is_available():
                batch = {k: v.cuda() for k, v in batch.items()}
            output = model(**batch)
            pred = torch.argmax(output.logits, dim=-1)
            acc_num += (pred.long() == batch["labels"].long()).float().sum()
    return acc_num / len(validset)

def train(epoch=3, log_step=100):
    global_step = 0
    for ep in range(epoch):
        # 开启训练模式
        model.train()
        for batch in trainloader:
            # 是否使用显卡
            if torch.cuda.is_available():
                batch = {k: v.cuda() for k, v in batch.items()}
            # 梯度归零
            optimizer.zero_grad()
            # 计算损失
            output = model(**batch)
            # 反向求导
            output.loss.backward()
            # 迭代
            optimizer.step()
            if global_step % log_step == 0:
                print(f"ep: {ep}, global_step: {global_step}, loss: {output.loss.item()}")
            global_step += 1
        acc = evaluate()
        print(f"ep: {ep}, acc: {acc}")

train()
sen = "真的不错,推荐你来来试试这个过程!"
id2_label = {0: "差评!", 1: "好评!"}
model.eval()
with torch.inference_mode():
    inputs = tokenizer(sen, return_tensors="pt")
    inputs = {k: v.cuda() for k, v in inputs.items()}
    logits = model(**inputs).logits
    pred = torch.argmax(logits, dim=-1)
    print(f"输入:{sen}\n模型预测结果:{id2_label.get(pred.item())}")
from transformers import pipeline

model.config.id2label = id2_label
pipe = pipeline("text-classification", model=model, tokenizer=tokenizer, device=0)
复制代码
输出:
ep: 0, global_step: 0, loss: 0.3093985319137573
ep: 0, global_step: 100, loss: 0.15114116668701172
ep: 0, global_step: 200, loss: 0.18284356594085693
ep: 0, acc: 0.9123711585998535
ep: 1, global_step: 300, loss: 0.06553637981414795
ep: 1, global_step: 400, loss: 0.12580494582653046
ep: 1, acc: 0.907216489315033
ep: 2, global_step: 500, loss: 0.1393854171037674
ep: 2, global_step: 600, loss: 0.024754131212830544
ep: 2, acc: 0.907216489315033

输入:真的不错,推荐你来来试试这个过程!
模型预测结果:好评!

cpu很慢.....

相关推荐
LZXCyrus15 分钟前
【杂记】vLLM如何指定GPU单卡/多卡离线推理
人工智能·经验分享·python·深度学习·语言模型·llm·vllm
我感觉。32 分钟前
【机器学习chp4】特征工程
人工智能·机器学习·主成分分析·特征工程
YRr YRr41 分钟前
深度学习神经网络中的优化器的使用
人工智能·深度学习·神经网络
DieYoung_Alive41 分钟前
一篇文章了解机器学习(下)
人工智能·机器学习
夏沫的梦43 分钟前
生成式AI对产业的影响与冲击
人工智能·aigc
goomind1 小时前
YOLOv8实战木材缺陷识别
人工智能·yolo·目标检测·缺陷检测·pyqt5·木材缺陷识别
只怕自己不够好1 小时前
《OpenCV 图像基础操作全解析:从读取到像素处理与 ROI 应用》
人工智能·opencv·计算机视觉
幻风_huanfeng1 小时前
人工智能之数学基础:线性代数在人工智能中的地位
人工智能·深度学习·神经网络·线性代数·机器学习·自然语言处理
嵌入式大圣1 小时前
嵌入式系统与OpenCV
人工智能·opencv·计算机视觉
请你喝好果汁6411 小时前
单细胞|M3-4. 细胞聚类与轨迹推断
机器学习·数据挖掘·聚类