使用 fgsm 的对抗性攻击中的错误:- ValueError:尝试将类型不受支持的类型 (<class 'NoneType'>) 的值 (None) 转换为张量

Error in Adversarial attack using fgsm :- ValueError: Attempt to convert a value (None) with an unsupported type (<class 'NoneType'>) to a Tensor

提问人:Bhanu Teja Pogiri 提问时间:10/25/2023 最后编辑:Bhanu Teja Pogiri 更新时间:10/26/2023 访问量:28

问:

我正在MNIST数据集上使用FGSM生成对抗性攻击示例。

这是我的fgsm_attack_generation代码:


def fgsm_attack(model, data, epsilon):
    # Retrieve the inputs and labels from the data
    inputs, labels = data

    # Create a TensorFlow session
    sess = tf.compat.v1.Session()

    # Convert the inputs and labels to TensorFlow tensors
    inputs_tf = tf.convert_to_tensor(inputs)
    labels_tf = tf.convert_to_tensor(labels)

    # Calculate the gradients of the loss with respect to the inputs
    with tf.GradientTape() as tape:
        tape.watch(inputs_tf)
        logits = model(inputs_tf, training=False)
        loss = tf.keras.losses.sparse_categorical_crossentropy(labels_tf, logits)

    gradient = tape.gradient(loss, inputs_tf)

    # Compute the sign of the gradients
    gradient_signs = tf.sign(gradient)

    # Generate the perturbed inputs by adding epsilon times the sign of the gradients
    perturbed_inputs = tf.add(inputs_tf, epsilon * gradient_signs)

    # Clip the perturbed inputs to ensure they stay within the valid range (0 to 1)
    perturbed_inputs = tf.clip_by_value(perturbed_inputs, 0, 1)

    # Run the TensorFlow session to obtain the perturbed inputs
    perturbed_inputs_np = sess.run(perturbed_inputs)

    # Close the TensorFlow session
    sess.close()

    return perturbed_inputs_np

epsilon = 0.1  # Adjust the value as needed

perturbed_inputs = fgsm_attack(model, (test_images, test_labels), epsilon)


我收到这个错误:


WARNING:tensorflow:The dtype of the watched tensor must be floating (e.g. tf.float32), got tf.uint8
---------------------------------------------------------------------------
ValueError                                Traceback (most recent call last)
<ipython-input-15-f634fa398776> in <cell line: 38>()
     36 
     37 epsilon = 0.1  # Adjust the value as needed
---> 38 perturbed_inputs = fgsm_attack(model, (test_images, test_labels), epsilon)

2 frames
/usr/local/lib/python3.10/dist-packages/tensorflow/python/framework/constant_op.py in convert_to_eager_tensor(value, ctx, dtype)
    100       dtype = dtypes.as_dtype(dtype).as_datatype_enum
    101   ctx.ensure_initialized()
--> 102   return ops.EagerTensor(value, ctx.device_name, dtype)
    103 
    104 

ValueError: Attempt to convert a value (None) with an unsupported type (<class 'NoneType'>) to a Tensor.

我的 CNN 模型的架构如下:

Model: "sequential_15"
_________________________________________________________________
 Layer (type)                Output Shape              Param #   
=================================================================
 conv2d_45 (Conv2D)          (None, 28, 28, 32)        320       
                                                                 
 max_pooling2d_45 (MaxPooli  (None, 14, 14, 32)        0         
 ng2D)                                                           
                                                                 
 batch_normalization_45 (Ba  (None, 14, 14, 32)        128       
 tchNormalization)                                               
                                                                 
 conv2d_46 (Conv2D)          (None, 14, 14, 64)        18496     
                                                                 
 max_pooling2d_46 (MaxPooli  (None, 7, 7, 64)          0         
 ng2D)                                                           
                                                                 
 batch_normalization_46 (Ba  (None, 7, 7, 64)          256       
 tchNormalization)                                               
                                                                 
 conv2d_47 (Conv2D)          (None, 7, 7, 64)          36928     
                                                                 
 max_pooling2d_47 (MaxPooli  (None, 3, 3, 64)          0         
 ng2D)                                                           
                                                                 
 batch_normalization_47 (Ba  (None, 3, 3, 64)          256       
 tchNormalization)                                               
                                                                 
 flatten_15 (Flatten)        (None, 576)               0         
                                                                 
 dense_30 (Dense)            (None, 64)                36928     
                                                                 
 dropout_15 (Dropout)        (None, 64)                0         
                                                                 
 dense_31 (Dense)            (None, 10)                650      

================================================================= 参数总数: 93962 (367.04 KB) 可训练参数: 93642 (365.79 KB) 不可训练的参数: 320 (1.25 KB)


为什么会弹出这个错误?我能做些什么?是模型架构问题还是库版本问题?

Python TensorFlow 神经网络 MNIST 对抗攻击

评论


答: 暂无答案