import numpy as np
import time
import json
import os
from tqdm import tqdm

# Loading the model
import numpy as np
import time
import sys
import json
import tensorflow as tf
import tensorflow_addons as tfa
from tensorflow import keras
import tensorflow.keras.backend as K
from tensorflow.keras.models import model_from_json

from BesselConv2d import BesselConv2d
from GroupConv2d import GroupConv2d

model = keras.models.Sequential(name='AllGConv_7_layers')
model.add(keras.layers.experimental.preprocessing.RandomRotation(factor=1,fill_mode="constant", input_shape=(28, 28, 1)))
model.add(GroupConv2d(k=3, n_out=16, h_input='Z2', h_output='C4', activation='relu', name='GConv1'))
model.add(GroupConv2d(k=3, n_out=16, h_input='C4', h_output='C4', activation='relu', name='GConv2'))
model.add(keras.layers.MaxPooling2D((2, 2), name='Maxpool1'))
model.add(GroupConv2d(k=3, n_out=16, h_input='C4', h_output='C4', activation='relu', name='GConv3'))
model.add(GroupConv2d(k=3, n_out=32, h_input='C4', h_output='C4', activation='relu', name='GConv4'))
model.add(GroupConv2d(k=3, n_out=32, h_input='C4', h_output='C4', activation='relu', name='GConv5'))
model.add(GroupConv2d(k=3, n_out=32, h_input='C4', h_output='C4', activation='relu', name='GConv6'))
model.add(GroupConv2d(k=4, n_out=32, h_input='C4', h_output='C4', activation='relu', name='GConv7'))
model.add(keras.layers.Reshape((1,1,32,4)))
model.add(keras.layers.Lambda(lambda x: K.sum(x, axis=4), input_shape=(1,1,32,4)))
model.add(keras.layers.Flatten(name='Flatten'))
model.add(keras.layers.Dense(10, name='Output'))
model.summary()

model_json = model.to_json()

# Saving
with open('./models/AllGConv_7_layers.json', 'w') as json_file:
    json_file.write(model_json)
    
model = keras.models.Sequential(name='AllConv_7_layers')
model.add(keras.layers.experimental.preprocessing.RandomRotation(factor=1,fill_mode="constant", input_shape=(28, 28, 1)))
model.add(keras.layers.Conv2D(32, (3, 3), activation='relu', name='Conv1'))
model.add(keras.layers.Conv2D(32, (3, 3), activation='relu', name='Conv2'))
model.add(keras.layers.MaxPooling2D((2, 2), name='Maxpool1'))
model.add(keras.layers.Conv2D(64, (3, 3), activation='relu', name='Conv3'))
model.add(keras.layers.Conv2D(64, (3, 3), activation='relu', name='Conv4'))
model.add(keras.layers.Conv2D(64, (3, 3), activation='relu', name='Conv5'))
model.add(keras.layers.Conv2D(64, (3, 3), activation='relu', name='Conv6'))
model.add(keras.layers.Conv2D(64, (3, 3), activation='relu', name='Conv7'))
model.add(keras.layers.MaxPooling2D((2, 2), name='Maxpool2'))
model.add(keras.layers.Flatten(name='Flatten'))
model.add(keras.layers.Dense(10, name='Output'))
model.summary()

model_json = model.to_json()

# Saving
with open('./models/AllConv_7_layers.json', 'w') as json_file:
    json_file.write(model_json)
    
model = keras.models.Sequential(name='AllBConv_5_layers_2')
model.add(keras.layers.experimental.preprocessing.RandomRotation(factor=1,fill_mode="constant", input_shape=(28, 28, 1)))
m_max = 11 ; j_max = 9 ; k = 3 ; n_out = 16
model.add(BesselConv2d(m_max,j_max,k,n_out,padding='VALID', activation='tanh', name='BConv1'))
m_max = 9 ; j_max = 7 ; k = 5 ; n_out = 16
model.add(BesselConv2d(m_max,j_max,k,n_out,padding='VALID', activation='tanh', name='BConv2'))
m_max = 9 ; j_max = 7 ; k = 5 ; n_out = 16
model.add(BesselConv2d(m_max,j_max,k,n_out,padding='VALID', activation='tanh', name='BConv3'))
m_max = 9 ; j_max = 7 ; k = 5 ; n_out = 16
model.add(BesselConv2d(m_max,j_max,k,n_out,padding='VALID', activation='tanh', name='BConv4'))
model.add(keras.layers.MaxPooling2D((2, 2), name='Maxpool1'))
m_max = 7 ; j_max = 5 ; k = 7 ; n_out = 32
model.add(BesselConv2d(m_max,j_max,k,n_out,padding='VALID', activation='tanh', name='BConv5'))
model.add(keras.layers.Flatten(name='Flatten'))
model.add(keras.layers.Dense(10, name='output'))
model.summary()

model_json = model.to_json()

# Saving
with open('./models/AllBConv_5_layers_2.json', 'w') as json_file:
    json_file.write(model_json)