import envs
from library import *
import matplotlib.pyplot as plt
import wandb
import gym
import numpy as np
import argparse
from wrappers import *
import imageio

MASK_TYPES = ["fully_obs", "no_stack", "framestack", "masked", "all_masked", "all_history_masked"]
TYPE_LABELS = ["MDP", "NMDP", "FrameStack", "AdaptiveStack (Ours)", "AdaptiveStackAC (Ours)", "AdaptiveStackAP (Ours)"]
# TYPE_LABELS = ["MDP", "NMDP", "FS", "AS (Ours)", "ASAC (Ours)", "ASAP (Ours)"]

#####################################################################################
parser = argparse.ArgumentParser()
parser.add_argument('--path', default="./data/", help="")
parser.add_argument('--algo', default="QL", help="QL (Q-Learning), DQL (Double-Q-Learning), SQL (Soft Q-learning), MC0, MC1, MC2 (Monte Carlo))")
parser.add_argument('--exploration', default="edecay", help="Exploration type: online, offline, edecay")
parser.add_argument('--mask_type', default="fully_obs", help="fully_obs, no_stack, framestack, masked, ca_masked, ca_all_masked")
parser.add_argument('--maze_length', type=int, default=1, help="Maze length")
parser.add_argument('--maze_length_eval', type=int, default=1, help="Eval maze length")
parser.add_argument('--num_stack', type=int, default=1, help="Memory length")
parser.add_argument('--run', default=None, type=int, help="")
args = parser.parse_args()
assert args.mask_type in ["fully_obs", "no_stack", "framestack", "masked", "ca_masked", "all_masked", "ca_all_masked", "all_history_masked", "ca_all_history_masked"], 'mask_type not in ["fully_obs", "no_stack", "framestack", "masked", "ca_masked", "all_masked", "ca_all_masked", "all_history_masked", "ca_all_history_masked"]'
#####################################################################################

def get_data():
    data = {}
    runs = 10
    gamma = 0.99
    render = False
    render_mode = "rgb_array"
    for mask_type in MASK_TYPES:
        data[mask_type] = {}
        for maze_length in [2,8]:
            data[mask_type][maze_length] = {}
            for maze_length_eval in [1,2,8]:
                data[mask_type][maze_length][maze_length_eval] = {}
                if mask_type in ["fully_obs", "no_stack"]: num_stacks = [1]
                else: num_stacks = [2,4]
                for num_stack in num_stacks:
                    data[mask_type][maze_length][maze_length_eval][num_stack] = {"Successes" : [], "Timesteps" : []}

                    env = gym.make("tmaze-v0", length=maze_length_eval, max_episode_step=20, fix_start=True, fully_obs=mask_type=="fully_obs", render_mode = render_mode)
                    if mask_type=="framestack": env = FrameStack(env, num_stack)
                    if "masked" in mask_type: env = MaskedFrameStack(env, num_stack)
                    env = TupleObs(env)
                    
                    save_path = "videos/{}-maze_length_{}-maze_length_eval_{}-num_stack_{}-mask_type_{}.gif".format(args.algo,maze_length, maze_length_eval, num_stack, mask_type)
                    print(save_path)
                    for run in range(runs):
                        data_path = "data/{}-maze_length_{}-num_stack_{}-mask_type_{}-run_{}-values.npy".format(args.algo,maze_length, num_stack,mask_type,run)
                        Q = defaultdict(lambda: np.zeros(env.action_space.n))
                        Q.update(np.load(data_path, allow_pickle=True).tolist())
                        # ./data/QL-maze_length_2-num_stack_1-mask_type_fully_obs-run_0

                        images = []
                        for start_goal in range(len(env.goals)):
                            env.unwrapped.start_goal = start_goal
                            state, _ = env.reset()
                            for t in range(1000):
                                if "render": images.append(env.render())
                                action = Q[state].argmax()
                                state, reward, done, truncate, _ = env.step(action) 
                                if done or truncate: break # or state==state_: break
                                # state = state_
                            data[mask_type][maze_length][maze_length_eval][num_stack]["Successes"].append(reward>0)
                            data[mask_type][maze_length][maze_length_eval][num_stack]["Timesteps"].append(t)
                            if "render": images.append(env.render())
                        if "render": imageio.mimsave(save_path, images, duration=1000/10)
    return data


def generate_latex_table(data):
    table = []
    table.append(r'\begin{table}[ht]')
    table.append(r'\centering')
    table.append(r'\resizebox{\textwidth}{!}{%')
    table.append(r'\begin{tabular}{cclccccccc}')
    table.append(r'\toprule')
    table.append(r'\multirow{2}{*}{\textbf{Maze length}} & \multirow{2}{*}{\textbf{Stack length}} & \multirow{2}{*}{\textbf{Algorithm}} & \multicolumn{3}{c}{\textbf{Eval successes per maze length $\uparrow$}} & \multicolumn{3}{c}{\textbf{Eval timesteps per maze length $\downarrow$}} \\')
    table.append(r'\cmidrule(lr){4-6} \cmidrule(lr){7-9}')
    table.append(r' & & & \textbf{1} & \textbf{2} & \textbf{8} & \textbf{1} & \textbf{2} & \textbf{8} \\')
    
    # Loop through maze lengths
    for maze_length in [2,8]:
        table.append(r'\midrule')

        first_row_maze = True  # Track if it's the first row for maze_length

        # Process Num Stack 1 (fully_obs and no_stack)
        num_stack = 1
        mask_types = ['fully_obs', 'no_stack']
        first_row_stack = True
        for mask_type in mask_types:
            mask_data = data[mask_type][maze_length]
            type_label = TYPE_LABELS[MASK_TYPES.index(mask_type)]
            
            row = []

            # Add maze_length as a multirow
            if first_row_maze:
                row.append(rf'\multirow{{6}}{{*}}{{{maze_length}}}')
                first_row_maze = False
            else:
                row.append('')

            # Add Num Stack as a multirow for stack 1 (spanning 2 rows)
            if first_row_stack:
                row.append(rf'\multirow{{2}}{{*}}{{{num_stack}}}')
                first_row_stack = False
            else:
                row.append('')
                
            row.append(f'{type_label}')
            for maze_length_eval in sorted(mask_data.keys()):
                results = mask_data[maze_length_eval][num_stack]
                successes_mean = np.mean(results['Successes'])
                successes_std = np.std(results['Successes'])
                row.append(rf'{successes_mean:.2f} $\pm$ {successes_std:.2f}')
            for maze_length_eval in sorted(mask_data.keys()):
                results = mask_data[maze_length_eval][num_stack]
                timesteps_mean = np.mean(results['Timesteps'])
                timesteps_std = np.std(results['Timesteps'])
                row.append(rf'{timesteps_mean:.2f} $\pm$ {timesteps_std:.2f}')
            table.append(' & '.join(row) + r' \\')

        table.append(r'\cmidrule(lr){2-9}')

        num_stacks = [2,4]
        for num_stack in num_stacks:
            mask_types = ['framestack', 'masked', 'all_masked', 'all_history_masked']
            first_row_stack = True

            best_eval = {maze_length_eval:{"Successes":0,"Timesteps":float("inf")} for maze_length_eval in sorted(mask_data.keys())}
            for mask_type in mask_types:
                mask_data = data[mask_type][maze_length]
                for maze_length_eval in sorted(mask_data.keys()):
                    results = mask_data[maze_length_eval][num_stack]
                    successes_mean = np.mean(results['Successes'])
                    successes_std = np.std(results['Successes'])
                    timesteps_mean = np.mean(results['Timesteps'])
                    timesteps_std = np.std(results['Timesteps'])
                    if successes_mean > best_eval[maze_length_eval]['Successes']: best_eval[maze_length_eval]['Successes'] = successes_mean
                    if timesteps_mean < best_eval[maze_length_eval]['Timesteps']: best_eval[maze_length_eval]['Timesteps'] = timesteps_mean
                
            for mask_type in mask_types:
                mask_data = data[mask_type][maze_length]
                type_label = TYPE_LABELS[MASK_TYPES.index(mask_type)]

                # Start building the row
                row = []

                # Add maze_length as a multirow
                if first_row_maze and num_stack == 2:  # Only for Num Stack 2 do we need to add maze_length
                    row.append(rf'\multirow{{12}}{{*}}{{{maze_length}}}')
                    first_row_maze = False
                else:
                    row.append('')

                # Add Num Stack as a multirow for stack 2 and 3 (spanning 4 rows)
                if first_row_stack:
                    row.append(rf'\multirow{{4}}{{*}}{{{num_stack}}}')
                    first_row_stack = False
                else:
                    row.append('')
                    
                row.append(f'{type_label}')    
                for maze_length_eval in sorted(mask_data.keys()):
                    results = mask_data[maze_length_eval][num_stack]
                    successes_mean = np.mean(results['Successes'])
                    successes_std = np.std(results['Successes'])
                    if successes_mean == best_eval[maze_length_eval]['Successes']: row.append(rf'\textbf{{{successes_mean:.2f} $\pm$ {successes_std:.2f}}}')
                    else:                                                          row.append(rf'{successes_mean:.2f} $\pm$ {successes_std:.2f}')
                    
                for maze_length_eval in sorted(mask_data.keys()):
                    results = mask_data[maze_length_eval][num_stack]
                    timesteps_mean = np.mean(results['Timesteps'])
                    timesteps_std = np.std(results['Timesteps'])
                    if timesteps_mean == best_eval[maze_length_eval]['Timesteps']: row.append(rf'\textbf{{{timesteps_mean:.2f} $\pm$ {timesteps_std:.2f}}}')
                    else:                                                          row.append(rf'{timesteps_mean:.2f} $\pm$ {timesteps_std:.2f}')
                table.append(' & '.join(row) + r' \\')
            if num_stack != num_stacks[-1]: table.append(r'\cmidrule(lr){2-9}')

    table.append(r'\bottomrule')
    table.append(r'\end{tabular}')
    table.append(r'}')  # Close resizebox
    table.append(r'\vspace{0.2cm}')
    table.append(r'\caption{Mean Successes and Timesteps in the TMaze domain for various Maze Lengths, Mask Types, and Num Stacks}')
    table.append(r'\end{table}')

    return "\n".join(table)



data = {'fully_obs': {2: {1: {1: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}, 2: {1: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2]}}, 8: {1: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}}, 8: {1: {1: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}, 2: {1: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}, 8: {1: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8]}}}}, 'no_stack': {2: {1: {1: {'Successes': [False, False, True, False, False, False, False, True, False, False, False, False, True, False, False, True, False, True, False, False], 'Timesteps': [19, 19, 1, 1, 19, 19, 1, 1, 19, 19, 19, 19, 1, 1, 1, 1, 1, 1, 19, 19]}}, 2: {1: {'Successes': [False, False, True, False, False, False, False, True, False, False, False, False, True, False, False, True, False, True, False, False], 'Timesteps': [19, 19, 2, 2, 19, 19, 2, 2, 19, 19, 19, 19, 2, 2, 2, 2, 2, 2, 19, 19]}}, 8: {1: {'Successes': [False, False, True, False, False, False, False, True, False, False, False, False, True, False, False, True, False, True, False, False], 'Timesteps': [19, 19, 8, 8, 19, 19, 8, 8, 19, 19, 19, 19, 8, 8, 8, 8, 8, 8, 19, 19]}}}, 8: {1: {1: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}, 2: {1: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}, 8: {1: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}}}, 'framestack': {2: {1: {2: {'Successes': [False, True, True, False, False, True, True, False, True, False, False, False, True, False, False, False, False, False, False, False], 'Timesteps': [1, 1, 2, 2, 2, 2, 1, 1, 2, 2, 19, 19, 1, 1, 19, 19, 19, 19, 19, 19]}, 4: {'Successes': [True, False, False, False, True, False, True, False, True, True, True, False, True, False, True, False, True, True, True, False], 'Timesteps': [5, 5, 19, 5, 1, 1, 6, 5, 11, 9, 6, 5, 6, 5, 6, 5, 6, 6, 6, 19]}}, 2: {2: {'Successes': [False, True, True, False, False, True, True, False, True, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [2, 2, 3, 3, 3, 3, 2, 2, 3, 3, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}, 4: {'Successes': [True, True, False, True, False, False, True, True, False, False, True, True, True, True, True, True, False, False, False, False], 'Timesteps': [6, 6, 19, 6, 19, 19, 7, 6, 19, 19, 7, 6, 7, 6, 7, 6, 19, 19, 19, 19]}}, 8: {2: {'Successes': [False, True, True, False, False, True, True, False, True, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [8, 8, 9, 9, 9, 9, 8, 8, 9, 9, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}, 4: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}}, 8: {1: {2: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}, 4: {'Successes': [True, False, True, False, True, False, True, False, True, False, True, False, False, False, True, False, True, False, False, False], 'Timesteps': [1, 1, 6, 19, 1, 1, 1, 1, 1, 1, 1, 1, 19, 6, 4, 19, 2, 2, 19, 19]}}, 2: {2: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}, 4: {'Successes': [False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 3, 3, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}, 8: {2: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}, 4: {'Successes': [False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}}}, 'masked': {2: {1: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, False, True, False, True, True, True, True, True, True, True], 'Timesteps': [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 19, 3, 19, 3, 3, 3, 3, 3, 3, 3]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [6, 6, 5, 4, 5, 5, 4, 7, 6, 5, 6, 6, 4, 5, 5, 7, 6, 7, 5, 5]}}, 2: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, False, True, False, True, True, True, True, True, True, True], 'Timesteps': [4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 19, 4, 19, 4, 4, 4, 4, 4, 4, 4]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [7, 7, 6, 5, 6, 6, 5, 8, 7, 6, 7, 7, 5, 6, 6, 8, 7, 8, 6, 6]}}, 8: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, False, True, False, True, True, True, True, True, True, True], 'Timesteps': [10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 19, 10, 19, 10, 10, 10, 10, 10, 10, 10]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [13, 13, 12, 11, 12, 12, 11, 14, 13, 12, 13, 13, 11, 12, 12, 14, 13, 14, 12, 12]}}}, 8: {1: {2: {'Successes': [False, False, False, True, True, False, False, True, True, False, False, False, False, True, True, False, True, False, False, False], 'Timesteps': [19, 19, 1, 1, 3, 3, 2, 2, 2, 2, 19, 19, 2, 2, 1, 1, 2, 2, 19, 19]}, 4: {'Successes': [True, False, True, False, False, True, False, False, False, True, True, False, False, False, False, False, False, True, True, False], 'Timesteps': [1, 1, 1, 1, 3, 3, 19, 19, 3, 3, 1, 1, 19, 19, 19, 19, 2, 2, 1, 1]}}, 2: {2: {'Successes': [False, False, False, True, True, False, False, True, True, False, False, False, False, True, True, False, True, False, False, False], 'Timesteps': [19, 19, 2, 2, 4, 4, 3, 3, 3, 3, 19, 19, 3, 3, 2, 2, 3, 3, 19, 19]}, 4: {'Successes': [False, True, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, True, False, True], 'Timesteps': [4, 4, 19, 19, 19, 19, 19, 19, 19, 19, 2, 2, 19, 19, 19, 19, 5, 5, 4, 4]}}, 8: {2: {'Successes': [False, False, False, True, True, False, False, True, True, False, False, False, False, True, True, False, True, False, False, False], 'Timesteps': [19, 19, 8, 8, 10, 10, 9, 9, 9, 9, 19, 19, 9, 9, 8, 8, 9, 9, 19, 19]}, 4: {'Successes': [False, True, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, True], 'Timesteps': [10, 10, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 11, 11, 10, 10]}}}}, 'all_masked': {2: {1: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [4, 4, 4, 3, 4, 4, 3, 4, 3, 4, 4, 4, 3, 4, 3, 4, 4, 3, 4, 4]}}, 2: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [5, 5, 5, 4, 5, 5, 4, 5, 4, 5, 5, 5, 4, 5, 4, 5, 5, 4, 5, 5]}}, 8: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [11, 11, 11, 10, 11, 11, 10, 11, 10, 11, 11, 11, 10, 11, 10, 11, 11, 10, 11, 11]}}}, 8: {1: {2: {'Successes': [False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, True, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 2, 2, 19, 19, 19, 19, 19, 19, 19, 19, 2, 2, 19, 19, 19, 19]}, 4: {'Successes': [False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, True, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 1, 1, 19, 19, 19, 19, 19, 19, 3, 3, 19, 19]}}, 2: {2: {'Successes': [False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, True, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 3, 3, 19, 19, 19, 19, 19, 19, 19, 19, 3, 3, 19, 19, 19, 19]}, 4: {'Successes': [False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, True, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 2, 2, 19, 19, 19, 19, 19, 19, 5, 5, 19, 19]}}, 8: {2: {'Successes': [False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, True, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 9, 9, 19, 19, 19, 19, 19, 19, 19, 19, 9, 9, 19, 19, 19, 19]}, 4: {'Successes': [False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False, False], 'Timesteps': [19, 19, 19, 19, 19, 19, 19, 19, 8, 8, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19]}}}}, 'all_history_masked': {2: {1: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3]}}, 2: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4]}}, 8: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10]}}}, 8: {1: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3]}}, 2: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4]}}, 8: {2: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10]}, 4: {'Successes': [True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True, True], 'Timesteps': [10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10]}}}}}
# data = get_data()
# print(data)
print(generate_latex_table(data))



