
import torch
from experiments.Networks import CA_CNN_Convolutional
from experiments.Automaton import CoarseWrapper, LifeLikeAutomaton2D, CellularAutomaton2D, create_init_only_center, init_512_rule
from experiments.Trainer import Trainer, DataLogger, SGDTrainer

from experiments.AlternativeNetworks import PixelTransformerClassifier, LinearClassifier
from tqdm import tqdm

if __name__=="__main__":
    automaton = LifeLikeAutomaton2D(110, 32)

    for i in tqdm(range(512)):
        import random
        num = init_512_rule(uniform_lambda=True)
        for iters in [2,3,4,5,6,7]:
            for spatial_factor in [1]:
                grid_size=16
                CA = CellularAutomaton2D(num,grid_size)
                spatial_factor=spatial_factor
                coarse = CoarseWrapper(CA, iters, spatial_factor, only_output_coarse=True, init_function=None)
                
                for residual in [False]:
                    for extra_width in [1]:
                        for train_length in [3]:

                            net_iters = iters + spatial_factor//2

                            net  = LinearClassifier(num_layers_hidden=3*iters, k=iters, hidden_dim=128, num_classes=2)
                            net = net.cuda()
                            data_logger = DataLogger(use_wandb=True, use_local=True, localPath='results/', 
                                                    localName='Rule'+str(i), console=False, 
                                                    wandbProject="CA_MLP_AllAuto",wandbRunName="Rule"+str(i)+"_"+str(iters))
                            trainer = Trainer(net, coarse, data_logger)
                            
                            trainer.train(512*(2**train_length), 4, 1e-4, early_stopping=None, nat_its=0)
                                
                            del net
                            del data_logger
                            del trainer

        print("Finished rule", num)
        print("Iteration ", i)
  