MI-FGSM代码及注释

import os
from PIL import Image
import torch
from torch import nn
import torchvision.transforms as transforms

def mi_fgsm_attack(image, epsilon, data_grad, alpha, decay_factor, g):
    # 计算梯度的符号
    sign_data_grad = data_grad.sign()
    # 更新累积梯度
    g = decay_factor * g + sign_data_grad
    # 通过调整输入图像的每个像素来创建扰动图像
    perturbed_image = image + alpha * g
    # 将扰动图像剪切到[0,1]范围内
    perturbed_image = torch.clamp(perturbed_image, 0, 1)
    # 添加扰动
    perturbed_image = torch.clamp(perturbed_image, image - epsilon, image + epsilon)
    # 返回扰动图像和累积梯度
    return perturbed_image, g

# 定义模型
model = nn.Sequential(
    nn.Conv2d(1, 32, kernel_size=3),
    nn.ReLU(),
    nn.MaxPool2d(kernel_size=2),
    nn.Conv2d(32, 64, kernel_size=3),
    nn.ReLU(),
    nn.MaxPool2d(kernel_size=2),
    nn.Flatten(),
    nn.Linear(1600, 10)
)

# 加载预训练模型权重
model.load_state_dict(torch.load('model.pth'))

# 定义损失函数
criterion = nn.CrossEntropyLoss()

# 定义图像转换
transform = transforms.Compose([
    transforms.Resize((28, 28)),
    transforms.ToTensor()
])

# 定义图像文件夹路径
image_folder = 'images'

# 获取图像文件列表
image_files = os.listdir(image_folder)

# 迭代次数
num_iter = 10

# 迭代步长
alpha = 0.05

# 最大扰动值
epsilon = 0.1

# 衰减因子
decay_factor = 1.0

for image_file in image_files:
    # 获取图像文件路径
    image_path = os.path.join(image_folder, image_file)

    # 读取图像文件并转换为灰度图像
    image = Image.open(image_path).convert('L')

    # 转换图像并添加批次维度
    image = transform(image).unsqueeze(0)

    # 将模型设置为评估模式
    model.eval()

    # 定义扰动图像和累积梯度
    perturbed_image = image.clone().detach()
    g = torch.zeros_like(perturbed_image)

    for i in range(num_iter):
        # 前向传播以获取预测结果
        output = model(perturbed_image)

        # 获取预测标签
        label = output.argmax(dim=1)

        # 计算损失
        loss = criterion(output, label)

        # 反向传播以获取梯度
        model.zero_grad()
        loss.backward()
        data_grad = perturbed_image.grad.data

        # 调用 mi_fgsm_attack 函数生成对抗样本和更新累积梯度
        perturbed_image, g = mi_fgsm_attack(perturbed_image, epsilon, data_grad, alpha, decay_factor, g)

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FGSM(Fast Gradient Sign Method)是一种用于对抗样本生成的攻击方法。它通过在原始输入数据上添加一个微小的幅度扰动,以便欺骗机器学习模型。FGSM的思想是利用梯度信息来计算出对抗样本。具体来说,它计算出使损失函数最大化的输入扰动,然后将该扰动添加到原始输入中,从而生成对抗样本。 I-FGSM(Iterative Fast Gradient Sign Method)是对FGSM的改进。与FGSM只进行一次扰动不同,I-FGSM通过迭代的方式进行多次扰动来生成对抗样本。在每次迭代中,利用当前生成的对抗样本计算梯度,然后使用梯度信息来更新对抗样本。通过多次迭代,I-FGSM可以生成更强的对抗样本,提高攻击成功率。 PGD(Projected Gradient Descent)也是一种改进的对抗样本生成方法。PGD与I-FGSM类似,都是通过迭代方式生成对抗样本。不同之处在于,PGD在每次迭代中,会对生成的对抗样本进行投影,确保其在一定的距离范围内。这样做的目的是防止生成的对抗样本偏离原始输入太远,保持样本的可接受性。通过投影操作,PGD可以生成较为强鲁棒的对抗样本。 总结来说,FGSM是一种简单而快速的对抗样本生成方法,而I-FGSM和PGD则是对其的改进,通过迭代生成更强鲁棒的对抗样本。这些对抗样本生成方法的应用可以帮助我们了解和提升机器学习模型的安全性,从而更好地保护数据和系统的安全。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值