-
Notifications
You must be signed in to change notification settings - Fork 5
/
obtain_distances.py
58 lines (44 loc) · 2.78 KB
/
obtain_distances.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import argparse
import os
from attacks.distance_to_boundary import distance_to_boundary
from attacks.distance_to_boundary_imagenet import distance_to_boundary_imagenet
parser = argparse.ArgumentParser(description='This script obtain and save the distance to the decision boundary of samples.')
parser.add_argument('-d', '--dataset', type=str, default='cifar_10', choices=['mnist', 'cifar10', 'cifar100', 'imagenet'], help='Indicate dataset and target model. If you trained your own target model, the model choice will be overwritten')
parser.add_argument('-m', '--model_path', type=str, default='keras_models/cifar10/alexnet.h5', help='Indicate the path to the target model. If you used the train_target_model.py to train the model, leave this field to the default value.')
parser.add_argument('-p', '--save_path', type=str, default='saved_distances/cifar10/alexnet', help='Indicate the directory that the computed distances are saved into.')
parser.add_argument('-n', '--number_of_target_classes', type=int, default=0, help='Limit the MI attack to limited a number of classes for efficiency!')
parser.add_argument('-s', '--num_of_samples_per_class', type=int, default=400, help='Due to the high computational complexity, you can specify how many samples per class to be analyzed.')
parser.add_argument('-i', '--imagenet_path', type=str, default='../imagenet/', help='path to the imagenet dataset.')
args = parser.parse_args()
if __name__ == '__main__':
dataset = args.dataset
model_name = args.model_path
num_of_samples_per_class = args.num_of_samples_per_class
if num_of_samples_per_class <= 0:
print('Error: num_of_samples_per_class should be a positive integer!')
exit()
# distance_save_dir = os.path.join(os.getcwd(), args.save_path)
distance_save_dir = args.save_path
if not os.path.isdir(distance_save_dir):
os.makedirs(distance_save_dir)
model_save_dir = os.path.join(os.getcwd(), 'saved_models')
if dataset == "mnist" or dataset == "cifar10":
num_classes = 10
num_targeted_classes = 10
elif dataset == "cifar100":
num_classes = 100
num_targeted_classes = 100
elif dataset == "imagenet":
num_classes = 1000
num_targeted_classes = 100
else:
print("Unknown dataset!")
exit()
if args.model_path != 'none':
model_name = args.model_path
if num_classes > args.number_of_target_classes > 0:
num_targeted_classes = args.number_of_target_classes
if dataset == "imagenet":
distance_to_boundary_imagenet(dataset, num_classes, num_targeted_classes, num_of_samples_per_class, model_name, distance_save_dir, args.imagenet_path)
else:
distance_to_boundary(dataset, num_classes, num_targeted_classes, num_of_samples_per_class, model_name, distance_save_dir)