import numpy as np
import numpy as np
import math
import imageio
import os

from joblib import Parallel, delayed
import multiprocessing

inputs = range(100) 


# We used jpg-files on purpose to make the task more difficult for CNNs (We are aware that this is in general not the ideal choise for random noise).

def processInputTrain0(i):
    rang = np.linspace(1,100,100)
    Std = rang[i]
    print(i)
    os.mkdir('trainData/train/' +str(i))
    for image in range(0,20000):

        transformed1 = np.uint8(np.random.normal(128, Std, [224,224]))
        transformed2 = np.uint8(np.random.normal(128, Std, [224,224]))
        transformed3 = np.uint8(np.random.normal(128, Std, [224,224]))
        imageio.imwrite('trainData/train/' +str(i) +'/' +str(image) + '.jpg', np.stack([transformed1,transformed2,transformed3],axis = 2))

   


def processInputVal0(i):
    rang = np.linspace(1,100,100)
    Std = rang[i]
    print(i)
    os.mkdir('trainData/val/' +str(i))
    for image in range(0,500):

        transformed1 = np.uint8(np.random.normal(128, Std, [224,224]))
        transformed2 = np.uint8(np.random.normal(128, Std, [224,224]))
        transformed3 = np.uint8(np.random.normal(128, Std, [224,224]))
        imageio.imwrite('trainData/val/' +str(i) +'/' +str(image) + '.jpg', np.stack([transformed1,transformed2,transformed3],axis = 2))


results = Parallel(n_jobs=60)(delayed(processInputTrain0)(i) for i in inputs)    
results = Parallel(n_jobs=60)(delayed(processInputVal0)(i) for i in inputs)    



