数据增强----mixup

本文展示了在数据量有限的情况下,如何利用MixUp技术进行数据增强。通过Python实现,结合随机Beta分布生成权重lam,将两张图片按权重叠加,并在神经网络模型中应用CrossEntropyLoss函数计算损失。同时计算了预测的准确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在数据量较少的时候可以采用数据mixup数据增强,具体实现代码如下,将两张图叠加

alpha=1.0   
loss_fun = nn.CrossEntropyLoss()
loss_fun = loss_fun.to(device) 

for x,data in enumerate(tqdm(train_dataloader)):#加个tqdm可以显示进度条
        imgs,targets = data
        imgs = imgs.to(device)
        targets = targets.to(device)
        lam = np.random.beta(alpha, alpha)
        index = torch.randperm(imgs.size(0))
        images_a, images_b = imgs, imgs[index]
        labels_a, labels_b = targets, targets[index]
        mixed_images = lam * images_a + (1 - lam) * images_b
        outputs = model(mixed_images)
        _, preds = torch.max(outputs, 1)
        loss = lam * loss_fun(outputs, labels_a) + (1 - lam) * loss_fun(outputs, labels_b)

#计算正确率
acc = (lam * preds.eq(labels_a.data).cpu().sum().float()
                    + (1 - lam) * preds.eq(labels_b.data).cpu().sum().float())/100

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雪豹不会梦到瑞克5

妈妈生的

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值