import os
import sys

import numpy as np
import random

import jax

jax.config.update("jax_enable_x64", True)

from experiments.base.sac import train
from experiments.base.utils import prepare_logs
from issac.environments.dmc import DMC
from issac.algorithms.issimbav2 import iSSimbaV2
from issac.sample_collection.replay_buffer import ReplayBuffer
from issac.sample_collection.samplers import UniformSamplingDistribution


def run(argvs=sys.argv[1:]):
    env_name, algo_name = os.path.abspath(__file__).split("/")[-2], os.path.abspath(__file__).split("/")[-1][:-3]
    p = prepare_logs(env_name, algo_name, argvs)

    random.seed(p["seed"])
    np.random.seed(p["seed"])

    q_key, train_key = jax.random.split(jax.random.PRNGKey(p["seed"]))

    env = DMC(p["experiment_name"].split("_")[-1], p["seed"])
    eval_env = DMC(p["experiment_name"].split("_")[-1], p["seed"])

    rb = ReplayBuffer(
        sampling_distribution=UniformSamplingDistribution(p["seed"]),
        batch_size=p["batch_size"],
        max_capacity=p["replay_buffer_capacity"],
        stack_size=1,
        update_horizon=p["update_horizon"],
        gamma=p["gamma"],
        compress=False,
    )
    agent = iSSimbaV2(
        q_key,
        env.observation_dim,
        env.action_dim,
        learning_rate_init=p["learning_rate_init"],
        learning_rate_end=p["learning_rate_end"],
        learning_rate_decay_steps=p["learning_rate_decay_steps"],
        gamma=p["gamma"],
        update_horizon=p["update_horizon"],
        tau=p["tau"],
        batch_norm=p["batch_norm"],
        n_bellman_iterations=p["n_bellman_iterations"],
        loss_discount=p["loss_discount"],
    )
    train(train_key, p, agent, env, eval_env, rb)


if __name__ == "__main__":
    run()
