1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- import numpy as np
- import os
- import sys
- import random
- import torch
- import torchvision
- import torchvision.transforms as transforms
- from utils.dataset_utils import check, separate_data, split_data, save_file
- random.seed(1)
- np.random.seed(1)
- num_clients = 25
- num_classes = 10
- dir_path = "cifar10/"
- # Allocate data to users
- def generate_cifar10(dir_path, num_clients, num_classes, niid, balance, partition):
- if not os.path.exists(dir_path):
- os.makedirs(dir_path)
-
- # Setup directory for train/test data
- config_path = dir_path + "config.json"
- train_path = dir_path + "train/"
- test_path = dir_path + "test/"
- if check(config_path, train_path, test_path, num_clients, num_classes, niid, balance, partition):
- return
-
- # Get Cifar10 data
- transform = transforms.Compose(
- [transforms.ToTensor(), transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))])
- trainset = torchvision.datasets.CIFAR10(
- root=dir_path+"rawdata", train=True, download=True, transform=transform)
- testset = torchvision.datasets.CIFAR10(
- root=dir_path+"rawdata", train=False, download=True, transform=transform)
- trainloader = torch.utils.data.DataLoader(
- trainset, batch_size=len(trainset.data), shuffle=False)
- testloader = torch.utils.data.DataLoader(
- testset, batch_size=len(testset.data), shuffle=False)
- for _, train_data in enumerate(trainloader, 0):
- trainset.data, trainset.targets = train_data
- for _, test_data in enumerate(testloader, 0):
- testset.data, testset.targets = test_data
- dataset_image = []
- dataset_label = []
- dataset_image.extend(trainset.data.cpu().detach().numpy())
- dataset_image.extend(testset.data.cpu().detach().numpy())
- dataset_label.extend(trainset.targets.cpu().detach().numpy())
- dataset_label.extend(testset.targets.cpu().detach().numpy())
- dataset_image = np.array(dataset_image)
- dataset_label = np.array(dataset_label)
- X, y, statistic = separate_data((dataset_image, dataset_label), num_clients, num_classes,
- niid, balance, partition)
- train_data, test_data = split_data(X, y)
- save_file(config_path, train_path, test_path, train_data, test_data, num_clients, num_classes,
- statistic, niid, balance, partition)
- if __name__ == "__main__":
- niid = True if sys.argv[1] == "noniid" else False
- balance = True if sys.argv[2] == "balance" else False
- partition = sys.argv[3] if sys.argv[3] != "-" else None
- generate_cifar10(dir_path, num_clients, num_classes, niid, balance, partition)
|