import os
import numpy as np
import pandas as pd
import csv

def save_output(model_name, dataset, sub, bs, lr, wd, alpha, epochs, results, **kwargs):

    base_folder = './results'
    subject = f'subject_{sub}'

    dropout = kwargs['dropout']
    windows = kwargs['windows']
    processor = kwargs['pre_processor']
    encoder = kwargs['pre_encoder']
    cut = kwargs['cutfill']
    dec = kwargs['learn_decoder']
    predec = kwargs['learn_predecoder']
    lora = kwargs['learn_lora']
    llr = kwargs['lora_lr']
    hp_config = f'win{windows}_bs{bs}_lr{lr}_wd{wd}_dp{dropout}_llr{llr}_proc{processor}_enc{encoder}_cut{cut}_dec{dec}_predec{predec}_lora{lora}'
    if model_name == "mixer":
        hp_config += f"_blocks{kwargs['blocks']}_ffdim{kwargs['ff_dim']}_dropout{kwargs['dropout']}"
    elif model_name == "vit":
        hp_config += f"_depth{kwargs['depth']}_mlpdim{kwargs['mlp_dim']}_dropout{kwargs['dropout']}"

    model_folder = os.path.join(base_folder, dataset, model_name, subject, hp_config)
    os.makedirs(model_folder, exist_ok=True)

    run_id = 1
    output_file = os.path.join(model_folder, f'run_{run_id}.csv')
    while os.path.exists(output_file):
        run_id += 1
        output_file = os.path.join(model_folder, f'run_{run_id}.csv')

    outputs = ['train_losses', 'train_accs', 'val_losses', 'val_accs', 'test_losses', 'test_accs']

    # Flatten everything to 1D and convert to floats
    flat_results = [[float(x) for x in np.ravel(arr)] for arr in results]

    # Transpose so that each row is one epoch
    rows = list(zip(*flat_results))

    # Write CSV manually
    with open(output_file, 'w', newline='') as f:
        writer = csv.writer(f)
        writer.writerow(outputs)  # header
        writer.writerows(rows)