from model import NEURAL
import torch
import time
import torch.nn.functional as F
import numpy as np
import argparse
import os



def pgd_attack_random(model, images, labels, eps=1, alpha=1, iters=40, randomize=True, gpu_id=0):
    """ Construct L_inf adversarial examples on the examples X """
    model.eval()
    device = torch.device('cuda:%d' % gpu_id)
    labels = labels.to(device)
    if randomize:
        delta = torch.rand_like(images, requires_grad=True).to(device)
        delta.data = delta.data * 2 * eps - eps
        delta.data = (delta.data + images ).clamp(-0.5,0.5)-(images)
    else:
        delta = torch.zeros_like(images, requires_grad=True).to(device)
    
    for t in range(iters):
        loss = torch.nn.CrossEntropyLoss()(model(images + delta ), labels)
        loss.backward()
        
        delta.data = (delta + alpha*delta.grad.detach().sign()).clamp(-eps,eps)
        delta.data = (delta.data + images ).clamp(-0.5,0.5)-(images)
        delta.grad.zero_()
    
    return delta+images

