from Base import *
import numpy as np

np.random.seed(100)

n_layers_ta = 5
n_layers_so = 5
# input_dim = 8
input_dim = 4
num = 16
output_dim = 1
# n_units = 16
n_units = 16

# generate net

total_results = []


for j in range(100):
  print(j)
  ta = task(input_dim = input_dim, output_dim = output_dim,
          n_layers = n_layers_ta, n_units = n_units)
  ta.init_param(sigma = 0.5)
  ta.set_true()
  # so = [deepcopy(ta) for i in range(n_layers)]
  so = []
  so_copy = []
  # num = int(n_units / 2)

  # diverse source tasks
  for i in range(num):
    so.append(task(input_dim = input_dim, output_dim = i+1,
                  n_layers = n_layers_so, n_units = n_units, no_output = False))
  for i in range(num):
    so[i].init_param("Diverse_prediction", sigma = 0.5)
    so[i].set_representation(ta, n_rep = n_layers_so)
    so[i].set_true()
    so[i].init_param()
    so_copy.append(deepcopy(so[i]))


  ta.init_param() # set random before training
  ta_copy = deepcopy(ta)
  results = [0]*(num) + [0]
  dat_so = []
  for i in range(num):
    dat_so.append(so[i].gen_data(int(100 * n_units / (i + 1)), sigma = 0.5))
  dat_ta = ta.gen_data(50, sigma = 0.5)
  for i in range(num):
    ta = deepcopy(ta_copy)
    #ta = deepcopy(ta_copy)i
    so[i].init_param()
    #so[i] = deepcopy(so_copy[i])
    so[i].training(dat_so[i])
    # so[i].net = so[i].net_true
    ta.set_representation(so[i], n_rep = n_layers_so)
    results[i] += ta.training(dat_ta, with_rep = True)

  ta = deepcopy(ta_copy)
  results[-1] += ta.training(dat_ta, with_rep = False)
  total_results.append(results)

print(np.mean(total_results, 0))
print(np.std(total_results, 0))
