"""
Optimizer configurations with optimal learning rates from LR range tests
Auto-generated from LR test results
"""
import torch.optim as optim
import itertools
from HomOpt import HomM

def get_optimizer_configurations():
    """Define all HomM configurations with their optimal learning rates"""
    
    configs = {
        'HomM_a-0.75_b0.1_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.004597],
                'alpha': [-0.75],
                'beta': [0.1],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.75_b0.3_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.002261],
                'alpha': [-0.75],
                'beta': [0.3],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.75_b0.5_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.002192],
                'alpha': [-0.75],
                'beta': [0.5],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.75_b0.7_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.002405],
                'alpha': [-0.75],
                'beta': [0.7],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.75_b0.9_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.003940],
                'alpha': [-0.75],
                'beta': [0.9],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.50_b0.1_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.010905],
                'alpha': [-0.5],
                'beta': [0.1],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.50_b0.3_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.011962],
                'alpha': [-0.5],
                'beta': [0.3],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.50_b0.5_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.010252],
                'alpha': [-0.5],
                'beta': [0.5],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.50_b0.7_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.011962],
                'alpha': [-0.5],
                'beta': [0.7],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.50_b0.9_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.015791],
                'alpha': [-0.5],
                'beta': [0.9],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.25_b0.1_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.030183],
                'alpha': [-0.25],
                'beta': [0.1],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.25_b0.3_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.045074],
                'alpha': [-0.25],
                'beta': [0.3],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.25_b0.5_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.047943],
                'alpha': [-0.25],
                'beta': [0.5],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.25_b0.7_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.045074],
                'alpha': [-0.25],
                'beta': [0.7],
                'gamma': [0.9]
            }
        },
        'HomM_a-0.25_b0.9_g0.9': {
            'class': HomM,
            'params': {
                'lr': [0.045074],
                'alpha': [-0.25],
                'beta': [0.9],
                'gamma': [0.9]
            }
        }
    }
    
    print(f"Loaded {len(configs)} HomM configurations with optimal learning rates:")
    for opt_name, config in configs.items():
        params = config['params']
        lr = params['lr'][0]
        alpha = params['alpha'][0]
        beta = params['beta'][0]
        gamma = params['gamma'][0]
        print(f"  {opt_name}: LR={lr:.4f}, a={alpha}, b={beta}, c={gamma}")
    print()
    
    return configs

def generate_param_combinations(config):
    """Generate all combinations of parameters for a given optimizer config"""
    param_names = list(config['params'].keys())
    param_values = list(config['params'].values())
    
    combinations = []
    for combo in itertools.product(*param_values):
        param_dict = dict(zip(param_names, combo))
        combinations.append(param_dict)
    
    return combinations

def get_best_configs(top_n=5):
    """Get the top N configurations by learning rate (higher LR often indicates better optimization)"""
    configs = get_optimizer_configurations()
    
    # Sort by learning rate (descending)
    sorted_configs = sorted(configs.items(), 
                          key=lambda x: x[1]['params']['lr'][0], 
                          reverse=True)
    
    top_configs = dict(sorted_configs[:top_n])
    
    print(f"Top {top_n} configurations by learning rate:")
    for name, config in top_configs.items():
        lr = config['params']['lr'][0]
        print(f"  {name}: LR={lr:.4f}")
    
    return top_configs
