from collections import namedtuple

# Genotype = namedtuple('Genotype', 'normal normal_concat reduce reduce_concat')
Genotype = namedtuple('Genotype', 'normal normal_concat reduce reduce_concat robust robust_concat')


PRIMITIVES = [
    'none',
    'max_pool_3x3',
    'avg_pool_3x3',
    'skip_connect',
    'sep_conv_3x3',
    'sep_conv_5x5',
    'dil_conv_3x3',
    'dil_conv_5x5'
]

# NASNet = Genotype(
#     normal=[
#         ('sep_conv_5x5', 1),
#         ('sep_conv_3x3', 0),
#         ('sep_conv_5x5', 0),
#         ('sep_conv_3x3', 0),
#         ('avg_pool_3x3', 1),
#         ('skip_connect', 0),
#         ('avg_pool_3x3', 0),
#         ('avg_pool_3x3', 0),
#         ('sep_conv_3x3', 1),
#         ('skip_connect', 1),
#     ],
#     normal_concat=[2, 3, 4, 5, 6],
#     reduce=[
#         ('sep_conv_5x5', 1),
#         ('sep_conv_7x7', 0),
#         ('max_pool_3x3', 1),
#         ('sep_conv_7x7', 0),
#         ('avg_pool_3x3', 1),
#         ('sep_conv_5x5', 0),
#         ('skip_connect', 3),
#         ('avg_pool_3x3', 2),
#         ('sep_conv_3x3', 2),
#         ('max_pool_3x3', 1),
#     ],
#     reduce_concat=[4, 5, 6],
# )
#
# AmoebaNet = Genotype(
#     normal=[
#         ('avg_pool_3x3', 0),
#         ('max_pool_3x3', 1),
#         ('sep_conv_3x3', 0),
#         ('sep_conv_5x5', 2),
#         ('sep_conv_3x3', 0),
#         ('avg_pool_3x3', 3),
#         ('sep_conv_3x3', 1),
#         ('skip_connect', 1),
#         ('skip_connect', 0),
#         ('avg_pool_3x3', 1),
#     ],
#     normal_concat=[4, 5, 6],
#     reduce=[
#         ('avg_pool_3x3', 0),
#         ('sep_conv_3x3', 1),
#         ('max_pool_3x3', 0),
#         ('sep_conv_7x7', 2),
#         ('sep_conv_7x7', 0),
#         ('avg_pool_3x3', 1),
#         ('max_pool_3x3', 0),
#         ('max_pool_3x3', 1),
#         ('conv_7x1_1x7', 0),
#         ('sep_conv_3x3', 5),
#     ],
#     reduce_concat=[3, 4, 6]
# )
#
#
# DARTS = Genotype(normal=[('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('sep_conv_3x3', 1), ('skip_connect', 0), ('skip_connect', 0), ('dil_conv_3x3', 2)], normal_concat=[2, 3, 4, 5], reduce=[('max_pool_3x3', 0), ('max_pool_3x3', 1), ('skip_connect', 2), ('max_pool_3x3', 1), ('max_pool_3x3', 0), ('skip_connect', 2), ('skip_connect', 2), ('max_pool_3x3', 1)], reduce_concat=[2, 3, 4, 5])
# ADVRUSH = Genotype(normal=[('sep_conv_3x3', 1), ('sep_conv_3x3', 0), ('sep_conv_5x5', 0), ('sep_conv_3x3', 1), ('sep_conv_3x3', 1), ('sep_conv_3x3', 0), ('skip_connect', 0), ('sep_conv_3x3', 1)], normal_concat=range(2, 6), reduce=[('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('skip_connect', 0), ('dil_conv_3x3', 2), ('skip_connect', 0), ('avg_pool_3x3', 1), ('skip_connect', 0), ('skip_connect', 2)], reduce_concat=range(2, 6))
# PDARTS = Genotype(normal=[('skip_connect', 0), ('dil_conv_3x3', 1), ('skip_connect', 0),('sep_conv_3x3', 1), ('sep_conv_3x3', 1), ('sep_conv_3x3', 3), ('sep_conv_3x3',0), ('dil_conv_5x5', 4)], normal_concat=range(2, 6), reduce=[('avg_pool_3x3', 0), ('sep_conv_5x5', 1), ('sep_conv_3x3', 0), ('dil_conv_5x5', 2), ('max_pool_3x3', 0), ('dil_conv_3x3', 1), ('dil_conv_3x3', 1), ('dil_conv_5x5', 3)], reduce_concat=range(2, 6))
# RACL = Genotype(normal=[('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('sep_conv_5x5', 0), ('skip_connect', 1), ('sep_conv_3x3', 0), ('skip_connect', 3), ('sep_conv_3x3', 3), ('skip_connect', 4)], normal_concat=[2, 3, 4, 5], reduce=[('sep_conv_3x3',0), ('sep_conv_5x5', 1), ('avg_pool_3x3', 0), ('dil_conv_3x3', 1), ('sep_conv_3x3', 0), ('sep_conv_5x5',1), ('sep_conv_3x3', 2), ('dil_conv_3x3', 3)], reduce_concat=[2, 3, 4, 5])
# E2RNAS = Genotype(normal=[('avg_pool_3x3', 0), ('skip_connect', 1), ('avg_pool_3x3', 0), ('sep_conv_3x3', 2), ('sep_conv_5x5', 3), ('avg_pool_3x3', 0), ('avg_pool_3x3', 0), ('sep_conv_5x5', 2)], normal_concat=range(2, 6), reduce=[('avg_pool_3x3', 0), ('avg_pool_3x3', 1), ('avg_pool_3x3', 0), ('avg_pool_3x3', 1), ('avg_pool_3x3', 0), ('skip_connect', 3), ('avg_pool_3x3', 0), ('skip_connect', 3)], reduce_concat=range(2, 6))
# RNAS = Genotype(normal=[('dil_conv_5x5', 0), ('dil_conv_5x5', 1), ('dil_conv_5x5', 0), ('dil_conv_3x3', 1), ('dil_conv_5x5', 3), ('sep_conv_5x5', 0), ('dil_conv_5x5', 0), ('dil_conv_3x3', 2)], normal_concat=range(2, 6), reduce=[('avg_pool_3x3', 1), ('dil_conv_5x5', 0), ('dil_conv_5x5', 2), ('sep_conv_5x5', 0), ('sep_conv_3x3', 3), ('skip_connect', 0), ('sep_conv_5x5', 0), ('sep_conv_5x5', 4)], reduce_concat=range(2, 6))
#
# EoiNAS = Genotype(normal=[('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('skip_connect', 0), ('sep_conv_3x3', 2), ('skip_connect', 1), ('sep_conv_5x5', 3), ('skip_connect', 1), ('dil_conv_5x5', 4)], normal_concat=range(2, 6), reduce=[('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('sep_conv_3x3', 0), ('sep_conv_5x5', 1), ('sep_conv_5x5', 0), ('dil_conv_5x5', 3), ('dil_conv_5x5', 2), ('dil_conv_5x5', 3)], reduce_concat=range(2, 6))
# iDARTS = Genotype(normal=[('skip_connect', 0), ('skip_connect', 1), ('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('sep_conv_5x5', 0), ('max_pool_3x3', 3), ('sep_conv_3x3', 0), ('sep_conv_5x5', 0)], normal_concat=range(2, 6), reduce=[('max_pool_3x3', 0), ('avg_pool_3x3', 1), ('sep_conv_3x3', 0), ('sep_conv_5x5', 1), ('sep_conv_3x3', 0), ('avg_pool_3x3', 2), ('sep_conv_3x3', 0), ('sep_conv_5x5', 1)], reduce_concat=range(2, 6))
# RelativeNAS = Genotype(normal=[('dil_conv_5x5', 0), ('sep_conv_5x5', 1), ('sep_conv_5x5', 0), ('sep_conv_5x5', 1), ('dil_conv_5x5', 0), ('sep_conv_3x3', 1), ('dil_conv_5x5', 2), ('avg_pool_3x3', 4)], normal_concat=range(2, 6), reduce=[('avg_pool_3x3', 1), ('sep_conv_5x5', 1), ('sep_conv_5x5', 0), ('max_pool_3x3', 0), ('dil_conv_5x5', 2), ('sep_conv_3x3', 3), ('max_pool_3x3', 0), ('sep_conv_3x3', 4)], reduce_concat=range(2, 6))
#
# search_cifar10 = Genotype(normal=[('max_pool_3x3', 1), ('avg_pool_3x3', 0), ('sep_conv_3x3', 1), ('skip_connect', 0), ('sep_conv_3x3', 2), ('avg_pool_3x3', 1), ('max_pool_3x3', 3), ('max_pool_3x3', 0)], normal_concat=[2, 3, 4, 5], reduce=[('none', 0), ('none', 1), ('sep_conv_5x5', 2), ('max_pool_3x3', 0), ('avg_pool_3x3', 2), ('skip_connect', 1), ('max_pool_3x3', 3), ('skip_connect', 4)], reduce_concat=[2, 3, 4, 5])
# search_cifar100 = Genotype(normal=[('avg_pool_3x3', 0), ('none', 1), ('skip_connect', 0), ('skip_connect', 2), ('sep_conv_5x5', 3), ('skip_connect', 2), ('max_pool_3x3', 4), ('sep_conv_5x5', 1)], normal_concat=[2, 3, 4, 5], reduce=[('none', 0), ('skip_connect', 1), ('none', 0), ('none', 1), ('max_pool_3x3', 1), ('none', 0), ('skip_connect', 4), ('sep_conv_3x3', 0)], reduce_concat=[2, 3, 4, 5])
#
# ablation_18 = Genotype(normal=[('avg_pool_3x3', 0), ('none', 1), ('skip_connect', 0), ('skip_connect', 2), ('dil_conv_5x5', 1), ('max_pool_3x3', 3), ('sep_conv_5x5', 1), ('skip_connect', 2)], normal_concat=[2, 3, 4, 5], reduce=[('none', 1), ('none', 1), ('skip_connect', 0), ('avg_pool_3x3', 2), ('skip_connect', 1), ('none', 2), ('skip_connect', 2), ('skip_connect', 4)], reduce_concat=[2, 3, 4, 5])
# ablation_16 = Genotype(normal=[('dil_conv_5x5', 1), ('avg_pool_3x3', 0), ('skip_connect', 2), ('none', 1), ('max_pool_3x3', 0), ('skip_connect', 2), ('avg_pool_3x3', 4), ('none', 1)], normal_concat=[2, 3, 4, 5], reduce=[('skip_connect', 0), ('none', 1), ('avg_pool_3x3', 1), ('none', 1), ('skip_connect', 1), ('max_pool_3x3', 3), ('none', 3), ('skip_connect', 4)], reduce_concat=[2, 3, 4, 5])
# ablation_14 = Genotype(normal=[('none', 0), ('none', 1), ('skip_connect', 0), ('skip_connect', 2), ('skip_connect', 1), ('none', 0), ('sep_conv_5x5', 1), ('none', 3)], normal_concat=[2, 3, 4, 5], reduce=[('max_pool_3x3', 0), ('none', 1), ('max_pool_3x3', 1), ('none', 1), ('skip_connect', 1), ('none', 1), ('avg_pool_3x3', 3), ('skip_connect', 4)], reduce_concat=[2, 3, 4, 5])
#
# no_greedy = Genotype(normal=[('dil_conv_3x3', 0), ('dil_conv_5x5', 1), ('max_pool_3x3', 0), ('dil_conv_5x5', 2), ('skip_connect', 0), ('skip_connect', 2), ('sep_conv_5x5', 2), ('dil_conv_5x5', 3)], normal_concat=[2, 3, 4, 5], reduce=[('sep_conv_5x5', 0), ('avg_pool_3x3', 1), ('sep_conv_5x5', 0), ('dil_conv_5x5', 2), ('none', 0), ('max_pool_3x3', 2), ('sep_conv_3x3', 0), ('max_pool_3x3', 2)], reduce_concat=[2, 3, 4, 5])
# no_warmup =  Genotype(normal=[('avg_pool_3x3', 0), ('none', 1), ('skip_connect', 0), ('dil_conv_3x3', 1), ('avg_pool_3x3', 1), ('skip_connect', 2), ('none', 1), ('sep_conv_5x5', 2)], normal_concat=[2, 3, 4, 5], reduce=[('none', 1), ('none', 1), ('none', 0), ('none', 1), ('dil_conv_3x3', 1), ('none', 2), ('sep_conv_3x3', 0), ('max_pool_3x3', 3)], reduce_concat=[2, 3, 4, 5])
# no_both = Genotype(normal=[('sep_conv_3x3', 0), ('sep_conv_3x3', 1), ('max_pool_3x3', 0), ('dil_conv_5x5', 2), ('sep_conv_3x3', 0), ('none', 3), ('sep_conv_3x3', 2), ('avg_pool_3x3', 4)], normal_concat=[2, 3, 4, 5], reduce=[('dil_conv_5x5', 0), ('none', 1), ('dil_conv_3x3', 0), ('dil_conv_5x5', 2), ('dil_conv_3x3', 1), ('none', 2), ('avg_pool_3x3', 2), ('avg_pool_3x3', 4)], reduce_concat=[2, 3, 4, 5])


ARNAS = Genotype(normal=[('skip_connect', 0), ('skip_connect', 1), ('sep_conv_5x5', 0), ('sep_conv_3x3', 1), ('sep_conv_5x5', 3), ('sep_conv_3x3', 1), ('sep_conv_5x5', 4), ('skip_connect', 0)], normal_concat=range(2, 6), reduce=[('avg_pool_3x3', 1), ('avg_pool_3x3', 0), ('dil_conv_5x5', 2), ('avg_pool_3x3', 0), ('dil_conv_5x5', 3), ('dil_conv_5x5', 2), ('dil_conv_5x5', 4), ('dil_conv_5x5', 3)], reduce_concat=range(2, 6), robust=[('dil_conv_5x5', 0), ('dil_conv_5x5', 1), ('dil_conv_5x5', 1), ('dil_conv_5x5', 2), ('dil_conv_3x3', 3), ('dil_conv_5x5', 2), ('dil_conv_3x3', 4), ('dil_conv_3x3', 3)], robust_concat=range(2, 6))



search_cifar10_338_0 = Genotype(normal=[['sep_conv_5x5', 1], ['sep_conv_5x5', 1], ['sep_conv_3x3', 2], ['sep_conv_3x3', 1], ['dil_conv_5x5', 3], ['avg_pool_3x3', 0], ['sep_conv_5x5', 2], ['skip_connect', 3]], normal_concat=[2, 3, 4, 5], reduce=[['sep_conv_5x5', 1], ['dil_conv_5x5', 0], ['sep_conv_5x5', 0], ['max_pool_3x3', 1], ['dil_conv_5x5', 2], ['dil_conv_5x5', 2], ['skip_connect', 3], ['max_pool_3x3', 2]], reduce_concat=[2, 3, 4, 5], robust=[['sep_conv_5x5', 1], ['dil_conv_5x5', 0], ['sep_conv_5x5', 0], ['skip_connect', 0], ['dil_conv_5x5', 2], ['dil_conv_5x5', 1], ['skip_connect', 3], ['avg_pool_3x3', 4]], robust_concat=[2, 3, 4, 5])
