from training_exp_comb import train_model
import torch
import os
from datetime import datetime
import warnings
import numpy as np
warnings.filterwarnings("ignore")
import sys

# System parameters
num_inverters_true = 10
if_reduce_verification = True
if_scalability = True

if if_scalability:
    num_inverters = 3  # Number of inverters in the microgrid
else:
    num_inverters = num_inverters_true  # Number of inverters in the microgrid
controlled_indices = list(range(1, num_inverters))  # Control all inverters except the first one
state_dims = [3] * num_inverters  # Each inverter has (delta, omega, xi)
control_dims = [1] * num_inverters  # Each inverter has one control input
device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
mode = 0  # 0 for sISS, 1 for ISS
delay_time_step = 0.1

# Dynamics parameters
dynamics_params = {
    'dt': 0.01,  # Time step (s)
    'n': num_inverters,  # Number of inverters
    'omega_star': 2 * np.pi * 50,  # Nominal frequency (50 Hz)
    'tau': [1.4895] * num_inverters,  # Time constants
    'eta': [6.3509e-4] * num_inverters,  # Droop gains
    'k': [4.9481] * num_inverters,  # Secondary control gains
    'V': [325.3] * num_inverters,  # Voltage magnitudes
    'B': np.array([[0.1 if abs(i - j) == 1 else 0 for j in range(num_inverters)] for i in range(num_inverters)]),  # Line susceptances (chain topology)
    'P_L': [1260.0] * num_inverters,  # Load powers
    'P_star': [1260.0] * num_inverters  # Desired power injections
}

# Training parameters
learning_rate = 1e-3
batch_size = 32
num_epochs = 100

# File paths
index = 0

# Train the model
st_train_time = datetime.now()
controller, system, V_net = train_model(
    num_inverters=num_inverters,
    controlled_indices=controlled_indices,
    state_dims=state_dims,
    control_dims=control_dims,
    learning_rate=learning_rate,
    batch_size=batch_size,
    num_epochs=num_epochs,
    dynamics_params=dynamics_params,
    device=device,
    mode=mode,
    delay_time_step=delay_time_step
)
end_train_time = datetime.now()
diff = end_train_time - st_train_time
print("Total training time for model index", str(index), ":", str(diff.seconds))

