{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from matplotlib import pyplot as plt\n",
    "from sklearn.decomposition import PCA\n",
    "from pyclustering.cluster.xmeans import xmeans\n",
    "from pyclustering.cluster.center_initializer import kmeans_plusplus_initializer\n",
    "from tqdm import tqdm\n",
    "from scipy.stats import wasserstein_distance\n",
    "from model import get_data_embedding\n",
    "from torch.cuda.amp import autocast, GradScaler  # For mixed precision\n",
    "import logging\n",
    "import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_trajectory_embedding(model, observations, actions, rewards, is_seaquest=False, device='cpu'):\n",
    "    \"\"\"\n",
    "    Calculates the trajectory embedding for a given model, observations, actions, and rewards.\n",
    "\n",
    "    Args:\n",
    "        model (torch.nn.Module): The model used to calculate the embedding.\n",
    "        observations (list): List of observations.\n",
    "        actions (list): List of actions.\n",
    "        rewards (list): List of rewards.\n",
    "        stack_frames_fn (function, optional): Function to stack frames for Seaquest environment. Defaults to None.\n",
    "        is_seaquest (bool, optional): Flag indicating if the environment is Seaquest. Defaults to False.\n",
    "\n",
    "    Returns:\n",
    "        list: List of trajectory embeddings.\n",
    "    \"\"\"\n",
    "    def reshape_input(observations, actions, rewards, device='cpu'):\n",
    "        input_obs = observations.view(1, -1, 4*84*84).to(device)\n",
    "        input_act = actions.view(1, -1, 1).to(device)\n",
    "        input_rew = rewards.view(1, -1, 1).to(device)\n",
    "        timesteps = torch.as_tensor([[[1]]], dtype=torch.long).to(device)  # Adjust as needed\n",
    "        return input_obs, input_act, input_rew, timesteps\n",
    "\n",
    "    model = model.to(device)\n",
    "    scaler = GradScaler()\n",
    "    if is_seaquest:\n",
    "        input_obs, input_act, input_rew, timesteps = reshape_input(observations[0], actions[0], rewards[0], device=device)\n",
    "        embedding = model(input_obs, input_act, rtgs=input_rew, timesteps=timesteps).detach()\n",
    "        MAX_SIZE = torch.mean(embedding, dim=1).flatten().shape[0]\n",
    "    else:\n",
    "        combined_input = torch.cat([observations[0], actions[0], rewards[0].unsqueeze(1)], dim=1).type(torch.long)\n",
    "        combined_input = combined_input.to(device)\n",
    "        MAX_SIZE = model(combined_input).detach().flatten().shape[0]\n",
    "\n",
    "    filename = 'seaquest_trajectory_embedding.dat' if is_seaquest else 'halfcheetah_trajectory_embedding.dat'\n",
    "\n",
    "    trajectory_embedding = torch.zeros((len(observations), MAX_SIZE), dtype=torch.float16, device=device)\n",
    "\n",
    "    for ind, (obs, act, rew) in enumerate(tqdm(zip(observations, actions, rewards), total=len(observations), desc=\"Processing trajectories\")):\n",
    "        with autocast():\n",
    "            if is_seaquest:\n",
    "                input_obs, input_act, input_rew, timesteps = reshape_input(obs, act, rew, device=device)\n",
    "                embedding = model(input_obs, input_act, rtgs=input_rew, timesteps=timesteps).detach()\n",
    "                embedding = torch.mean(embedding, dim=1).flatten()\n",
    "            else:\n",
    "                combined_input = torch.cat([obs, act, rew.unsqueeze(1)], dim=1).type(torch.long)\n",
    "                combined_input = combined_input.to(device)\n",
    "                embedding = model(combined_input).detach()\n",
    "                embedding = torch.mean(embedding, dim=1).flatten()\n",
    "            \n",
    "\n",
    "        embedding_size = min(len(embedding), MAX_SIZE)\n",
    "        trajectory_embedding[ind, :embedding_size] = embedding[:embedding_size].cpu()\n",
    "\n",
    "    return trajectory_embedding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def perform_clustering_and_plot(traj_embeddings, amount_initial_centers, max_clusters, plot=True):\n",
    "    \"\"\"\n",
    "    Performs clustering on prepared trajectory embeddings using X-Means and plots the results.\n",
    "\n",
    "    :param traj_embeddings: Prepared trajectory embeddings.\n",
    "    :param amount_initial_centers: Initial number of centers for clustering.\n",
    "    :param max_clusters: Maximum number of clusters.\n",
    "    :return: None\n",
    "    \"\"\"\n",
    "    # Create a basic logger\n",
    "    logger = logging.getLogger(__name__)\n",
    "    logging.basicConfig(level=logging.INFO)\n",
    "\n",
    "    logger.info('Starting clustering process.')\n",
    "\n",
    "    # Initialize centers using kmeans_plusplus_initializer\n",
    "    initial_centers = kmeans_plusplus_initializer(traj_embeddings, amount_initial_centers).initialize()\n",
    "\n",
    "    logger.info('Initial centers initialized.')\n",
    "\n",
    "    # Create and process X-Means instance\n",
    "    xmeans_instance = xmeans(traj_embeddings, initial_centers, max_clusters)\n",
    "    xmeans_instance.process()\n",
    "\n",
    "    logger.info('X-Means instance processed.')\n",
    "    \n",
    "    # Extract clustering results: clusters and their centers\n",
    "    clusters = xmeans_instance.get_clusters()\n",
    "\n",
    "    logger.info('Clustering results extracted.')\n",
    "    \n",
    "    # Assign cluster labels to each trajectory\n",
    "    traj_cluster_labels = np.zeros(len(traj_embeddings), dtype=int)\n",
    "    for cluster_id, cluster in enumerate(clusters):\n",
    "        for traj_id in cluster:\n",
    "            traj_cluster_labels[traj_id] = cluster_id\n",
    "\n",
    "    logger.info('Cluster labels assigned to each trajectory.')\n",
    "\n",
    "    # Perform PCA for visualization\n",
    "    pca_traj = PCA(n_components=2)\n",
    "    pca_traj_embeds = pca_traj.fit_transform(traj_embeddings)\n",
    "    plotting_data = {\n",
    "        'feature 1': pca_traj_embeds[:, 0],\n",
    "        'feature 2': pca_traj_embeds[:, 1],\n",
    "        'cluster id': traj_cluster_labels\n",
    "    }\n",
    "    df = pd.DataFrame(plotting_data)\n",
    "\n",
    "    logger.info('PCA performed for visualization.')\n",
    "\n",
    "    if plot:\n",
    "        # Plotting\n",
    "        plt.figure(figsize=(4,3))\n",
    "        palette = sns.color_palette('husl', len(clusters) + 1)\n",
    "        sns.scatterplot(\n",
    "            x='feature 1',\n",
    "            y='feature 2',\n",
    "            hue='cluster id',\n",
    "            palette=palette[:len(clusters)],\n",
    "            data=df,\n",
    "            legend=True\n",
    "        )\n",
    "        plt.title('Trajectory Embeddings for ' + str(amount_initial_centers) + ' initial centers')\n",
    "        plt.legend(title = '$c_{j}$', loc='lower center', bbox_to_anchor=(0.5, 1.05), ncol=5)\n",
    "        plt.tight_layout()\n",
    "        plt.show()\n",
    "\n",
    "        logger.info('Plot created.')\n",
    "\n",
    "    return clusters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from tqdm import tqdm\n",
    "\n",
    "def create_trajectories(observations, actions, rewards, terminals, trajectory_length):\n",
    "    \"\"\"\n",
    "    Create trajectories from the given observations, actions, rewards, and terminals.\n",
    "    Parameters:\n",
    "        observations (torch.Tensor): Tensor of shape [num_frames, height, width].\n",
    "        stack_size (int): Number of frames to stack for each observation.\n",
    "    Returns:\n",
    "        torch.Tensor: Stacked observations of shape [(num_frames-stack_size+1), stack_size, height, width].\n",
    "    \"\"\"\n",
    "    # Efficiently compute the number of trajectories\n",
    "    terminal_indices = [i for i, x in enumerate(terminals) if x]\n",
    "    #print(\"DEBUG: terminal_indices\", terminal_indices)\n",
    "    padded_length = sum(trajectory_length - (i % trajectory_length) for i in terminal_indices)\n",
    "    total_length = len(observations) + padded_length\n",
    "    num_trajectories = total_length // trajectory_length\n",
    "\n",
    "    # Tensor shapes\n",
    "    obs_shape = observations[0].shape\n",
    "    act_shape = actions[0].shape\n",
    "    rew_shape = rewards[0].shape\n",
    "    term_shape = terminals[0].shape\n",
    "\n",
    "    # Pre-allocate tensors\n",
    "    final_obs = torch.zeros((num_trajectories, trajectory_length, *obs_shape), dtype=torch.uint8)\n",
    "    final_act = torch.zeros((num_trajectories, trajectory_length, *act_shape))\n",
    "    final_rew = torch.zeros((num_trajectories, trajectory_length, *rew_shape))\n",
    "    final_ter = torch.zeros((num_trajectories, trajectory_length, *term_shape))\n",
    "\n",
    "    # Populate tensors\n",
    "    trajectory_idx = 0\n",
    "    step_idx = 0\n",
    "    for i in tqdm(range(len(observations)), desc=\"Processing sub'trajectories\"):\n",
    "        final_obs[trajectory_idx, step_idx] = torch.from_numpy(observations[i])\n",
    "        final_act[trajectory_idx, step_idx] = torch.as_tensor(actions[i])\n",
    "        final_rew[trajectory_idx, step_idx] = torch.as_tensor(rewards[i])\n",
    "        final_ter[trajectory_idx, step_idx] = torch.as_tensor(terminals[i])\n",
    "        step_idx += 1\n",
    "\n",
    "        if terminals[i] or step_idx == trajectory_length:\n",
    "            trajectory_idx += 1\n",
    "            step_idx = 0\n",
    "            if trajectory_idx >= num_trajectories:\n",
    "                break\n",
    "\n",
    "\n",
    "    return final_obs, final_act, final_rew, final_ter\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'decision_transformer_atari'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mModuleNotFoundError\u001b[0m                       Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[5], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mdecision_transformer_atari\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01matari\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mmingpt\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mmodel_atari\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m GPTConfig, GPT\n\u001b[1;32m      2\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01msys\u001b[39;00m\n\u001b[1;32m      3\u001b[0m sys\u001b[38;5;241m.\u001b[39mpath\u001b[38;5;241m.\u001b[39minsert(\u001b[38;5;241m0\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtrajectory_transformer\u001b[39m\u001b[38;5;124m'\u001b[39m)\n",
      "\u001b[0;31mModuleNotFoundError\u001b[0m: No module named 'decision_transformer_atari'"
     ]
    }
   ],
   "source": [
    "from decision_transformer_atari.atari.mingpt.model_atari import GPTConfig, GPT\n",
    "import sys\n",
    "sys.path.insert(0, 'trajectory_transformer')\n",
    "from trajectory_transformer.trajectory.models.transformers import GPT as TrajectoryGPT\n",
    "import torch\n",
    "import pickle\n",
    "\n",
    "\n",
    "def load_seaquest_model(checkpoint_path=\"decision_transformer_atari\\checkpoints\\Seaquest_123.pth\"):\n",
    "    \"\"\"\n",
    "    Load the Seaquest model from a checkpoint file.\n",
    "\n",
    "    Args:\n",
    "        checkpoint_path (str): Path to the checkpoint file. Default is \"decision_transformer_atari\\checkpoints\\Seaquest_123.pth\".\n",
    "\n",
    "    Returns:\n",
    "        model (GPT): Loaded Seaquest model.\n",
    "    \"\"\"\n",
    "    vocab_size = 18\n",
    "    block_size = 90\n",
    "    model_type = \"reward_conditioned\"\n",
    "    timesteps = 2719\n",
    "\n",
    "    mconf = GPTConfig(\n",
    "        vocab_size,\n",
    "        block_size,\n",
    "        n_layer=6,\n",
    "        n_head=8,\n",
    "        n_embd=128,\n",
    "        model_type=model_type,\n",
    "        max_timestep=timesteps,\n",
    "    )\n",
    "    model = GPT(mconf)\n",
    "\n",
    "    if torch.cuda.is_available():\n",
    "        checkpoint = torch.load(checkpoint_path)\n",
    "    else:\n",
    "        checkpoint = torch.load(checkpoint_path, map_location=torch.device('cpu'))\n",
    "    model.load_state_dict(checkpoint)\n",
    "\n",
    "    return model\n",
    "\n",
    "def load_halfcheetah_model(model_path):\n",
    "    \"\"\"\n",
    "    Loads a pre-trained transformer model from the given path.\n",
    "\n",
    "    Args:\n",
    "        model_path (str): The path to the directory containing the model files.\n",
    "\n",
    "    Returns:\n",
    "        The loaded transformer model.\n",
    "    \"\"\"\n",
    "    model_config_path = model_path + '/model_config.pkl'\n",
    "    with open(model_config_path, 'rb') as config_file:\n",
    "        model_config = pickle.load(config_file)\n",
    "    model = TrajectoryGPT(model_config)\n",
    "\n",
    "    # Load the pre-trained weights\n",
    "    # Choose the specific state file you want to load, e.g., state_0.pt, state_16.pt, etc.\n",
    "    state_dict_path = model_path + '/state_48.pt'\n",
    "    model.load_state_dict(torch.load(state_dict_path, map_location=torch.device('cpu')))\n",
    "\n",
    "    # If you're using a GPU, you can move the model to GPU\n",
    "    # model = model.to('cuda')\n",
    "    return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import gym\n",
    "import numpy as np\n",
    "import gzip\n",
    "from gym import wrappers\n",
    "from eorl import OfflineDataset\n",
    "\n",
    "def stack_frames(dataset, stack_size=4):\n",
    "    \"\"\"\n",
    "    Stack consecutive frames in the dataset with padding for initial frames.\n",
    "    \n",
    "    :param dataset: A numpy array of shape [num_frames, width, height]\n",
    "    :param stack_size: Number of frames to stack\n",
    "    :return: A numpy array of shape [num_frames, stack_size, width, height]\n",
    "    \"\"\"\n",
    "    \n",
    "    # Padding the dataset with zeros at the beginning\n",
    "    padded_dataset = np.pad(dataset, ((stack_size-1, 0), (0, 0), (0, 0)), mode='constant')\n",
    "\n",
    "    # Stacking frames\n",
    "    num_frames = len(dataset)\n",
    "    indices = np.arange(stack_size) + np.arange(num_frames)[:, None]\n",
    "    stacked_dataset = padded_dataset[indices]\n",
    "\n",
    "    return stacked_dataset\n",
    "\n",
    "def load_seaquest_dataset(env_name, size = 717):\n",
    "\n",
    "\n",
    "    # Load the dataset\n",
    "    ds = OfflineDataset(\n",
    "    env = env_name,            # pass name in supported environments below\n",
    "    dataset_size = 1e6,   # [0, 1e6) frames of atari\n",
    "    train_split = 0.9,       # 90% training, 10% held out for testing\n",
    "    obs_only = False,        # only get observations (no actions, rewards, dones)\n",
    "    framestack = 1,          # number of frames per sample\n",
    "    shuffle = False,         # chronological samples if False, randomly sampled if true\n",
    "    stride = 1,               # return every stride`th chunk (where chunk size == `framestack)\n",
    "    verbose = 1,              # 0 = silent, >0 for reporting\n",
    "    )\n",
    "\n",
    "    # Extract the dataset\n",
    "    datasets = {\n",
    "        'observations': ds.dataset['observation'],\n",
    "        'actions': ds.dataset['action'],\n",
    "        'rewards': ds.dataset['reward'],\n",
    "        'terminals': ds.dataset['terminal']\n",
    "    }\n",
    "\n",
    "    \n",
    "    \n",
    "    print(\"Dataset loaded\")\n",
    "    seaquest_length = np.where(np.cumsum(datasets[\"terminals\"]) == size)[0][0]  # Note if terminals are not binary this will not work.\n",
    "    datasets['observations'] = stack_frames(datasets['observations'][:seaquest_length])\n",
    "\n",
    "    datasets['observations'] = datasets['observations'][:seaquest_length]\n",
    "    datasets['actions'] = datasets['actions'][:seaquest_length]\n",
    "    datasets['rewards'] = datasets['rewards'][:seaquest_length]\n",
    "    datasets['terminals'] = datasets['terminals'][:seaquest_length]\n",
    "\n",
    "    # Initialize the Gym environment\n",
    "    env_name = 'ALE/' + env_name + '-ram-v5'\n",
    "    env = gym.make(env_name)\n",
    "\n",
    "    env = gym.wrappers.ResizeObservation(env, (84, 84))\n",
    "\n",
    "    # Print logging information\n",
    "    print(f\"Dataset extracted with {len(datasets['observations'])} samples.\")\n",
    "    print(\"Information about the dataset:\")\n",
    "    print(\"Observation shape: \",datasets['observations'].shape)\n",
    "    print(\"Action shape: \",datasets['actions'].shape)\n",
    "    print(\"Reward shape: \",datasets['rewards'].shape)\n",
    "    print(\"Terminal shape: \",datasets['terminals'].shape)\n",
    "    # Action space is discrete, so we can just print the number of actions\n",
    "    print(\"Action space: \",env.action_space.n)\n",
    "    print(\"Observation space: \",env.observation_space.shape)\n",
    "    print(\"Number of terminal states is...\", datasets['terminals'].sum())\n",
    "    print(f\"Environment '{env_name}' initialized.\")\n",
    "\n",
    "    return datasets, env"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'trajectory_transformer'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mModuleNotFoundError\u001b[0m                       Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[14], line 4\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mmk_patch_decision_transformer_atari\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m GPTConfig, GPT\n\u001b[1;32m      2\u001b[0m \u001b[38;5;66;03m#import sys\u001b[39;00m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;66;03m#sys.path.insert(0, 'trajectory_transformer')\u001b[39;00m\n\u001b[0;32m----> 4\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mmk_patch_trajectory_transformer\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m GPT \u001b[38;5;28;01mas\u001b[39;00m TrajectoryGPT\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mtorch\u001b[39;00m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mpickle\u001b[39;00m\n",
      "File \u001b[0;32m~/Documents/GitHub/FACT/Seaquest_HalfCheetah/mk_patch_trajectory_transformer.py:9\u001b[0m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mtorch\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mnn\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mnn\u001b[39;00m\n\u001b[1;32m      7\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mtorch\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mnn\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m functional \u001b[38;5;28;01mas\u001b[39;00m F\n\u001b[0;32m----> 9\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mtrajectory_transformer\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mtrajectory\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mmodels\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mein\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m EinLinear\n\u001b[1;32m     11\u001b[0m \u001b[38;5;28;01mclass\u001b[39;00m \u001b[38;5;21;01mCausalSelfAttention\u001b[39;00m(nn\u001b[38;5;241m.\u001b[39mModule):\n\u001b[1;32m     13\u001b[0m     \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, config):\n",
      "\u001b[0;31mModuleNotFoundError\u001b[0m: No module named 'trajectory_transformer'"
     ]
    }
   ],
   "source": [
    "from mk_patch_decision_transformer_atari import GPTConfig, GPT\n",
    "#import sys\n",
    "#sys.path.insert(0, 'trajectory_transformer')\n",
    "from mk_patch_trajectory_transformer import GPT as TrajectoryGPT\n",
    "import torch\n",
    "import pickle\n",
    "\n",
    "def load_seaquest_model(checkpoint_path=\"decision_transformer_atari\\checkpoints\\Seaquest_123.pth\"):\n",
    "    \"\"\"\n",
    "    Load the Seaquest model from a checkpoint file.\n",
    "\n",
    "    Args:\n",
    "        checkpoint_path (str): Path to the checkpoint file. Default is \"decision_transformer_atari\\checkpoints\\Seaquest_123.pth\".\n",
    "\n",
    "    Returns:\n",
    "        model (GPT): Loaded Seaquest model.\n",
    "    \"\"\"\n",
    "    vocab_size = 18 # 18 for Seaquest\n",
    "    block_size = 90\n",
    "    model_type = \"reward_conditioned\"\n",
    "    timesteps = 2719 # 2719 for Seaquest\n",
    "\n",
    "    mconf = GPTConfig(\n",
    "        vocab_size,\n",
    "        block_size,\n",
    "        n_layer=6,\n",
    "        n_head=8,\n",
    "        n_embd=128,\n",
    "        model_type=model_type,\n",
    "        max_timestep=timesteps,\n",
    "    )\n",
    "    model = GPT(mconf)\n",
    "\n",
    "    if torch.cuda.is_available():\n",
    "        checkpoint = torch.load(checkpoint_path)\n",
    "    else:\n",
    "        checkpoint = torch.load(checkpoint_path, map_location=torch.device('cpu'))\n",
    "    model.load_state_dict(checkpoint)\n",
    "\n",
    "    return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "decompressing data...\n",
      "Dataset loaded\n",
      "Dataset extracted with 96636 samples.\n",
      "Information about the dataset:\n",
      "Observation shape:  (96636, 4, 84, 84)\n",
      "Action shape:  (96636,)\n",
      "Reward shape:  (96636,)\n",
      "Terminal shape:  (96636,)\n",
      "Action space:  18\n",
      "Observation space:  (84, 84)\n",
      "Number of terminal states is... 54\n",
      "Environment 'ALE/Seaquest-ram-v5' initialized.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "A.L.E: Arcade Learning Environment (version 0.8.1+53f58b7)\n",
      "[Powered by Stella]\n"
     ]
    }
   ],
   "source": [
    "data_size = 50\n",
    "test_size = 5\n",
    "seaquestdata, sq_env = load_seaquest_dataset(env_name='Seaquest', size=data_size+test_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "terminal_indexes = np.where(seaquestdata['terminals'] == True)[0]\n",
    "trunc = terminal_indexes[-test_size]\n",
    "terminal_indexes = terminal_indexes[data_size:] # Get index of first trajectory that we want to draw\n",
    "\n",
    "test_observations = []\n",
    "test_actions = []\n",
    "for i in range(len(terminal_indexes)):\n",
    "    ind = [i + np.random.randint(200, 300)]\n",
    "    test_observations.append(seaquestdata['observations'][ind])\n",
    "    test_actions.append(seaquestdata['actions'][ind][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Observation Shape: (4, 84, 84)\n",
      "Test observation shape:  (1, 4, 84, 84)\n"
     ]
    }
   ],
   "source": [
    "observation = copy.deepcopy(test_observations[0])\n",
    "\n",
    "# Observation has shape (1, 4, 84, 84)\n",
    "# We need to remove the first dimension\n",
    "# and plot each channel separately\n",
    "observation = observation.squeeze()\n",
    "print(\"Observation Shape:\", observation.shape)\n",
    "print('Test observation shape: ', test_observations[0].shape)\n",
    "\n",
    "# assert test_observations[0].shape == (1, 4, 84, 84)\n",
    "# if not, drop the first dimension\n",
    "if test_observations[0].shape != (1, 4, 84, 84):\n",
    "    test_observations[0] = test_observations[0].squeeze()\n",
    "    print('Test observation shape after squeezing: ', test_observations[0].shape)\n",
    "\n",
    "\n",
    "# Remove all the previous observations, actions, rewards and terminals\n",
    "seaquestdata[\"observations\"] = seaquestdata[\"observations\"][:trunc]\n",
    "seaquestdata[\"actions\"] = seaquestdata[\"actions\"][:trunc]\n",
    "seaquestdata[\"rewards\"] = seaquestdata[\"rewards\"][:trunc]\n",
    "seaquestdata[\"terminals\"] = seaquestdata[\"terminals\"][:trunc]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'GPTConfig' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[13], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m pre_trained_encoder_seaquest \u001b[38;5;241m=\u001b[39m \u001b[43mload_seaquest_model\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mdecision_transformer_atari/checkpoints/Seaquest_123.pth\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "Cell \u001b[0;32mIn[8], line 23\u001b[0m, in \u001b[0;36mload_seaquest_model\u001b[0;34m(checkpoint_path)\u001b[0m\n\u001b[1;32m     20\u001b[0m model_type \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mreward_conditioned\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m     21\u001b[0m timesteps \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m2719\u001b[39m \u001b[38;5;66;03m# 2719 for Seaquest\u001b[39;00m\n\u001b[0;32m---> 23\u001b[0m mconf \u001b[38;5;241m=\u001b[39m \u001b[43mGPTConfig\u001b[49m(\n\u001b[1;32m     24\u001b[0m     vocab_size,\n\u001b[1;32m     25\u001b[0m     block_size,\n\u001b[1;32m     26\u001b[0m     n_layer\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m6\u001b[39m,\n\u001b[1;32m     27\u001b[0m     n_head\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m8\u001b[39m,\n\u001b[1;32m     28\u001b[0m     n_embd\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m128\u001b[39m,\n\u001b[1;32m     29\u001b[0m     model_type\u001b[38;5;241m=\u001b[39mmodel_type,\n\u001b[1;32m     30\u001b[0m     max_timestep\u001b[38;5;241m=\u001b[39mtimesteps,\n\u001b[1;32m     31\u001b[0m )\n\u001b[1;32m     32\u001b[0m model \u001b[38;5;241m=\u001b[39m GPT(mconf)\n\u001b[1;32m     34\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mcuda\u001b[38;5;241m.\u001b[39mis_available():\n",
      "\u001b[0;31mNameError\u001b[0m: name 'GPTConfig' is not defined"
     ]
    }
   ],
   "source": [
    "pre_trained_encoder_seaquest = load_seaquest_model(\"decision_transformer_atari/checkpoints/Seaquest_123.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing sub'trajectories: 100%|██████████| 49614/49614 [00:01<00:00, 41952.86it/s]\n"
     ]
    }
   ],
   "source": [
    "final_obs_sq, final_act_sq, final_rew_sq, _ = create_trajectories(\n",
    "        seaquestdata[\"observations\"], seaquestdata[\"actions\"], \n",
    "        seaquestdata[\"rewards\"], seaquestdata[\"terminals\"], trajectory_length=30\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1677, 30, 4, 84, 84])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "final_obs_sq.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([30, 4, 84, 84]),\n",
       " tensor([15.,  7., 15.,  7., 15., 15., 15., 15., 15., 15., 15.,  3.,  7.,  3.,\n",
       "          3., 15., 15.,  7.,  7.,  7.,  7.,  7.,  3., 15., 15., 15.,  3., 15.,\n",
       "         15., 15.]),\n",
       " tensor([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "         0., 0., 0., 0., 0., 0.]))"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "final_obs_sq[0].shape, final_act_sq[0], final_rew_sq[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = 'cpu'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "trajectory_embedding_seaquest = get_trajectory_embedding(\n",
    "        pre_trained_encoder_seaquest, final_obs_sq, final_act_sq, final_rew_sq, \n",
    "        is_seaquest=True, device= device\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "clusters_seaquest = perform_clustering_and_plot(trajectory_embedding_seaquest.detach().cpu(), 2, 8, plot=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "from d3rlpy.dataset import Episode \n",
    "import d3rlpy\n",
    "from encoder import CustomCNNFactory\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "def make_episodes(final_obs, final_act, final_rew, max_action_values):\n",
    "    list_episodes = []\n",
    "    for i in range(len(final_obs)):\n",
    "        list_episodes.append(Episode(final_obs[i].numpy().shape[1:], max_action_values, final_obs[i].numpy(), final_act[i].numpy(), final_rew[i].numpy()))\n",
    "    return list_episodes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "list_episodes_sq = make_episodes(final_obs_sq, final_act_sq, final_rew_sq, 18)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "def fit_discrete_sac(list_episodes, n_steps=1000, n_steps_per_epoch=100, device='cpu'):\n",
    "    cuda_check = True if device == 'cuda' else False\n",
    "    feature_size = 128\n",
    "    custom_encoder_actor = CustomCNNFactory(feature_size)\n",
    "    custom_encoder_critic = CustomCNNFactory(feature_size)\n",
    "\n",
    "    # Train an agent on the new data\n",
    "    sac_sq = d3rlpy.algos.DiscreteSAC(\n",
    "            actor_learning_rate=3e-4,\n",
    "            critic_learning_rate=3e-4,\n",
    "            temp_learning_rate=3e-4,\n",
    "            batch_size=256,\n",
    "            actor_encoder_factory= custom_encoder_actor,\n",
    "            critic_encoder_factory= custom_encoder_critic,\n",
    "            scaler='pixel',\n",
    "            target_update_interval=2500,\n",
    "            use_gpu=cuda_check)\n",
    "    \n",
    "    sac_sq.fit(list_episodes, n_steps=n_steps, n_steps_per_epoch=n_steps_per_epoch)\n",
    "\n",
    "    return sac_sq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:12.51 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:12.51 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211251\n",
      "2024-02-01 21:12.51 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:12.51 [debug    ] Building models...\n",
      "2024-02-01 21:12.51 [debug    ] Models have been built.\n",
      "2024-02-01 21:12.51 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 2500, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0569, temp=1, critic_loss=4.52, actor_loss=-2.86]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:12.53 [info     ] DiscreteSAC_20240201211251: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.002602100372314453, 'time_algorithm_update': 2.027575969696045, 'temp_loss': 0.056895941495895386, 'temp': 0.9997005462646484, 'critic_loss': 4.521823883056641, 'actor_loss': -2.863555908203125, 'time_step': 2.0307559967041016} step=1\n",
      "2024-02-01 21:12.53 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:01<00:00,  1.97s/it, temp_loss=0.0569, temp=0.999, critic_loss=4.46, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:12.55 [info     ] DiscreteSAC_20240201211251: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.002863168716430664, 'time_algorithm_update': 1.9616129398345947, 'temp_loss': 0.0569131076335907, 'temp': 0.9994012117385864, 'critic_loss': 4.455878734588623, 'actor_loss': -2.8722164630889893, 'time_step': 1.965097188949585} step=2\n",
      "2024-02-01 21:12.55 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:01<00:00,  1.96s/it, temp_loss=0.0569, temp=0.999, critic_loss=4.59, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:12.57 [info     ] DiscreteSAC_20240201211251: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.002264738082885742, 'time_algorithm_update': 1.9589459896087646, 'temp_loss': 0.05692661181092262, 'temp': 0.999101996421814, 'critic_loss': 4.586240291595459, 'actor_loss': -2.8832783699035645, 'time_step': 1.961709976196289} step=3\n",
      "2024-02-01 21:12.57 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0569, temp=0.999, critic_loss=4.51, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:12.59 [info     ] DiscreteSAC_20240201211251: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.00234222412109375, 'time_algorithm_update': 1.9823486804962158, 'temp_loss': 0.05693720653653145, 'temp': 0.9988027811050415, 'critic_loss': 4.51205587387085, 'actor_loss': -2.8992857933044434, 'time_step': 1.985243797302246} step=4\n",
      "2024-02-01 21:12.59 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0569, temp=0.999, critic_loss=4.43, actor_loss=-2.92]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.01 [info     ] DiscreteSAC_20240201211251: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.0020639896392822266, 'time_algorithm_update': 1.9855680465698242, 'temp_loss': 0.05694347992539406, 'temp': 0.9985037446022034, 'critic_loss': 4.434284210205078, 'actor_loss': -2.9180233478546143, 'time_step': 1.9881951808929443} step=5\n",
      "2024-02-01 21:13.01 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.29, actor_loss=-2.94]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.03 [info     ] DiscreteSAC_20240201211251: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.0020780563354492188, 'time_algorithm_update': 1.9866900444030762, 'temp_loss': 0.056949228048324585, 'temp': 0.9982047080993652, 'critic_loss': 4.289266586303711, 'actor_loss': -2.9423670768737793, 'time_step': 1.9892737865447998} step=6\n",
      "2024-02-01 21:13.03 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.057, temp=0.998, critic_loss=4.25, actor_loss=-2.97]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.05 [info     ] DiscreteSAC_20240201211251: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.0024099349975585938, 'time_algorithm_update': 1.9738390445709229, 'temp_loss': 0.056953947991132736, 'temp': 0.9979057908058167, 'critic_loss': 4.252654552459717, 'actor_loss': -2.9749579429626465, 'time_step': 1.9769108295440674} step=7\n",
      "2024-02-01 21:13.05 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.057, temp=0.998, critic_loss=4.2, actor_loss=-3.02]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.07 [info     ] DiscreteSAC_20240201211251: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.002330780029296875, 'time_algorithm_update': 1.9868278503417969, 'temp_loss': 0.056957535445690155, 'temp': 0.9976069927215576, 'critic_loss': 4.203243732452393, 'actor_loss': -3.016062021255493, 'time_step': 1.9896800518035889} step=8\n",
      "2024-02-01 21:13.07 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.057, temp=0.997, critic_loss=4, actor_loss=-3.07]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.09 [info     ] DiscreteSAC_20240201211251: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.0021491050720214844, 'time_algorithm_update': 1.9741220474243164, 'temp_loss': 0.056959401816129684, 'temp': 0.9973082542419434, 'critic_loss': 3.999593734741211, 'actor_loss': -3.071657180786133, 'time_step': 1.9768297672271729} step=9\n",
      "2024-02-01 21:13.09 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.057, temp=0.997, critic_loss=3.99, actor_loss=-3.14]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.11 [info     ] DiscreteSAC_20240201211251: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.0022840499877929688, 'time_algorithm_update': 2.006650924682617, 'temp_loss': 0.05695614963769913, 'temp': 0.9970095753669739, 'critic_loss': 3.985459804534912, 'actor_loss': -3.1388988494873047, 'time_step': 2.00954008102417} step=10\n",
      "2024-02-01 21:13.11 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211251/model_10.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "sac_sq = fit_discrete_sac(list_episodes_sq, n_steps=10, n_steps_per_epoch=1, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "action_dict = {0: 'NOOP', 1: 'FIRE', 2: 'UP', 3: 'RIGHT', 4: 'LEFT', 5: 'DOWN', 6: 'UPRIGHT', 7: 'UPLEFT', 8: 'DOWNRIGHT', 9: 'DOWNLEFT', 10: 'UPFIRE', 11: 'RIGHTFIRE', 12: 'LEFTFIRE', 13: 'DOWNFIRE', 14: 'UPRIGHTFIRE', 15: 'UPLEFTFIRE', 16: 'DOWNRIGHTFIRE', 17: 'DOWNLEFTFIRE'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x1200 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 12))  # Adjust the figure size\n",
    "for i in range(4):\n",
    "    plt.subplot(4, 1, i + 1)\n",
    "    plt.imshow(observation[i], cmap='gray')\n",
    "    plt.axis('off')\n",
    "    plt.tight_layout()\n",
    "\n",
    "    if i == 3:\n",
    "        action = sac_sq.predict(np.expand_dims(observation, axis=0))\n",
    "        plt.title(action_dict[action[0]])\n",
    "\n",
    "plt.subplots_adjust(hspace=0.4)  # Adjust the vertical spacing\n",
    "plt.savefig('test_observation_stack.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "feature_size = 128\n",
    "custom_encoder_actor = CustomCNNFactory(feature_size)\n",
    "custom_encoder_critic = CustomCNNFactory(feature_size)\n",
    "\n",
    "model_params_sq = {\n",
    "'actor_learning_rate': 3e-4,\n",
    "'critic_learning_rate': 3e-4,\n",
    "'temp_learning_rate': 3e-4,\n",
    "'batch_size': 256,\n",
    "'actor_encoder_factory': custom_encoder_actor,\n",
    "'critic_encoder_factory': custom_encoder_critic,\n",
    "'scaler': 'pixel',\n",
    "'use_gpu': True if device == 'cuda' else False\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "def fit_per_cluster(model, \n",
    "                    model_class, \n",
    "                    model_params, \n",
    "                    data_embedding, \n",
    "                    list_episodes, \n",
    "                    clusters, \n",
    "                    trajectory_embedding, \n",
    "                    test_observations):\n",
    "    \n",
    "    original_actions = []\n",
    "    original_action_values = []\n",
    "    for t in test_observations:\n",
    "        action = model.predict(t)\n",
    "        print(\"Original model action: \", action)\n",
    "        action_value = model.predict_value(t, action = action)\n",
    "        print(\"Original model action value: \", action_value)\n",
    "        print(\"Passing: \", action[0], action_value[0])\n",
    "        original_actions.append(action[0])\n",
    "        original_action_values.append(action_value[0])\n",
    "\n",
    "    result_data_combinations = {0:(original_actions, original_action_values, get_data_embedding(data_embedding))} # Original dataset policy\n",
    "    models = {0:(model, get_data_embedding(data_embedding))}\n",
    "    \n",
    "    for cluster_id, cluster in enumerate(clusters):\n",
    "        model = model_class(**model_params)\n",
    "        count_in_clusters = 0\n",
    "        count_not_in_clusters = 0\n",
    "        temp_data = []\n",
    "        temp_traj_embeds = []\n",
    "        temp_cluster_traj_embeds = []\n",
    "        for traj_id, traj in enumerate(list_episodes):\n",
    "            if traj_id not in cluster:\n",
    "                temp_data.append(list_episodes[traj_id])\n",
    "                temp_traj_embeds.append(trajectory_embedding[traj_id])\n",
    "                count_not_in_clusters += 1\n",
    "            else:\n",
    "                temp_cluster_traj_embeds.append(trajectory_embedding[traj_id])\n",
    "                count_in_clusters += 1\n",
    "        print('-'*100)\n",
    "        print(f'Cluster {cluster_id + 1} has {count_in_clusters} trajectories out of {count_not_in_clusters + count_in_clusters}')\n",
    "        print('-'*100)\n",
    "        \n",
    "        # Generate the data embedding\n",
    "        data_embedding_new = get_data_embedding(temp_traj_embeds)\n",
    "        # Train an agent on the new data\n",
    "        model.fit(temp_data, n_steps=10, n_steps_per_epoch=1)\n",
    "\n",
    "        models[cluster_id + 1] = (model, data_embedding_new)\n",
    "\n",
    "        new_actions = []\n",
    "        new_action_values = []\n",
    "        for t in test_observations:\n",
    "            action = model.predict(t)\n",
    "            print(\"New model action: \", action)\n",
    "            action_value = model.predict_value(t, action = action)\n",
    "            print(\"New model action value: \", action_value)\n",
    "            print(\"Passing: \", action[0], action_value[0])\n",
    "\n",
    "            new_actions.append(action[0])\n",
    "            new_action_values.append(action_value[0])\n",
    "        \n",
    "        result_data_combinations[cluster_id + 1] = (new_actions, new_action_values, data_embedding_new) # Clustered dataset policy (cluster_id + 1 because 0 is the original dataset)\n",
    "                                                                                    # so each value is the model trained on original data - cluster 1, original data - cluster 2, etc.\n",
    "        \n",
    "    return models, result_data_combinations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_data_embedding(traj_embeddings):\n",
    "    # Convert to numpy arrays if the embeddings are PyTorch tensors\n",
    "    if isinstance(traj_embeddings[0], torch.Tensor):\n",
    "        #traj_embeddings = traj_embeddings\n",
    "        traj_embeddings = [te.cpu().numpy() for te in traj_embeddings]\n",
    "\n",
    "    # Compute the sum of the embeddings, dividing by 10\n",
    "    summed_embeddings = np.array(traj_embeddings).sum(axis=0) / 10.0\n",
    "\n",
    "    # Apply softmax to the summed embeddings\n",
    "    max_embeddings = np.max(summed_embeddings)\n",
    "    exp_embeddings = np.exp(summed_embeddings - max_embeddings)\n",
    "    softmax_embeddings = exp_embeddings / np.sum(exp_embeddings, axis=0)\n",
    "\n",
    "    return softmax_embeddings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Original model action:  [1]\n",
      "Original model action value:  [0.32215434]\n",
      "Passing:  1 0.32215434\n",
      "Original model action:  [1]\n",
      "Original model action value:  [0.3204304]\n",
      "Passing:  1 0.3204304\n",
      "Original model action:  [1]\n",
      "Original model action value:  [0.31940165]\n",
      "Passing:  1 0.31940165\n",
      "Original model action:  [1]\n",
      "Original model action value:  [0.322946]\n",
      "Passing:  1 0.322946\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 1 has 21 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:13.12 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:13.12 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211312\n",
      "2024-02-01 21:13.12 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:13.12 [debug    ] Building models...\n",
      "2024-02-01 21:13.12 [debug    ] Models have been built.\n",
      "2024-02-01 21:13.12 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 1/1 [00:02<00:00,  2.04s/it, temp_loss=0.0566, temp=1, critic_loss=4.52, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.14 [info     ] DiscreteSAC_20240201211312: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.002476930618286133, 'time_algorithm_update': 2.0375912189483643, 'temp_loss': 0.056597039103507996, 'temp': 0.9997005462646484, 'critic_loss': 4.5199737548828125, 'actor_loss': -2.8688533306121826, 'time_step': 2.0407092571258545} step=1\n",
      "2024-02-01 21:13.14 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:02<00:00,  2.07s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.65, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.16 [info     ] DiscreteSAC_20240201211312: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.002113819122314453, 'time_algorithm_update': 2.0703392028808594, 'temp_loss': 0.05667811632156372, 'temp': 0.9994012117385864, 'critic_loss': 4.648149490356445, 'actor_loss': -2.876819133758545, 'time_step': 2.0731570720672607} step=2\n",
      "2024-02-01 21:13.16 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:02<00:00,  2.06s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.46, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.18 [info     ] DiscreteSAC_20240201211312: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.002660989761352539, 'time_algorithm_update': 2.059028148651123, 'temp_loss': 0.05673956125974655, 'temp': 0.9991019368171692, 'critic_loss': 4.46121883392334, 'actor_loss': -2.8865702152252197, 'time_step': 2.0622169971466064} step=3\n",
      "2024-02-01 21:13.18 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:02<00:00,  2.06s/it, temp_loss=0.0568, temp=0.999, critic_loss=4.4, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.20 [info     ] DiscreteSAC_20240201211312: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.002850055694580078, 'time_algorithm_update': 2.0593979358673096, 'temp_loss': 0.05678727477788925, 'temp': 0.9988027811050415, 'critic_loss': 4.4044904708862305, 'actor_loss': -2.8984386920928955, 'time_step': 2.0627689361572266} step=4\n",
      "2024-02-01 21:13.20 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:02<00:00,  2.06s/it, temp_loss=0.0568, temp=0.999, critic_loss=4.25, actor_loss=-2.91]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.22 [info     ] DiscreteSAC_20240201211312: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.0026459693908691406, 'time_algorithm_update': 2.0585782527923584, 'temp_loss': 0.056827761232852936, 'temp': 0.9985036253929138, 'critic_loss': 4.248154163360596, 'actor_loss': -2.913200616836548, 'time_step': 2.061828136444092} step=5\n",
      "2024-02-01 21:13.22 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:02<00:00,  2.13s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.37, actor_loss=-2.93]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.24 [info     ] DiscreteSAC_20240201211312: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.0030210018157958984, 'time_algorithm_update': 2.1280550956726074, 'temp_loss': 0.056858502328395844, 'temp': 0.9982045888900757, 'critic_loss': 4.368603706359863, 'actor_loss': -2.9327635765075684, 'time_step': 2.1316442489624023} step=6\n",
      "2024-02-01 21:13.24 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:02<00:00,  2.08s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.38, actor_loss=-2.96]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.27 [info     ] DiscreteSAC_20240201211312: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.0034189224243164062, 'time_algorithm_update': 2.0779640674591064, 'temp_loss': 0.05688966065645218, 'temp': 0.9979055523872375, 'critic_loss': 4.383411407470703, 'actor_loss': -2.9603395462036133, 'time_step': 2.081925868988037} step=7\n",
      "2024-02-01 21:13.27 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:02<00:00,  2.04s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.31, actor_loss=-3]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.29 [info     ] DiscreteSAC_20240201211312: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.003058910369873047, 'time_algorithm_update': 2.040431022644043, 'temp_loss': 0.05691774934530258, 'temp': 0.997606635093689, 'critic_loss': 4.313006401062012, 'actor_loss': -2.9975247383117676, 'time_step': 2.044036865234375} step=8\n",
      "2024-02-01 21:13.29 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.0569, temp=0.997, critic_loss=4.17, actor_loss=-3.05]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.31 [info     ] DiscreteSAC_20240201211312: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.003401041030883789, 'time_algorithm_update': 2.0105879306793213, 'temp_loss': 0.05694097280502319, 'temp': 0.9973077774047852, 'critic_loss': 4.167320251464844, 'actor_loss': -3.047321081161499, 'time_step': 2.01452898979187} step=9\n",
      "2024-02-01 21:13.31 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.057, temp=0.997, critic_loss=4, actor_loss=-3.11]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.33 [info     ] DiscreteSAC_20240201211312: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.003434896469116211, 'time_algorithm_update': 1.9810740947723389, 'temp_loss': 0.05695587396621704, 'temp': 0.9970089793205261, 'critic_loss': 3.9961748123168945, 'actor_loss': -3.1145598888397217, 'time_step': 1.9850099086761475} step=10\n",
      "2024-02-01 21:13.33 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211312/model_10.pt\n",
      "New model action:  [6]\n",
      "New model action value:  [0.3419367]\n",
      "Passing:  6 0.3419367\n",
      "New model action:  [6]\n",
      "New model action value:  [0.33837727]\n",
      "Passing:  6 0.33837727\n",
      "New model action:  [6]\n",
      "New model action value:  [0.33721173]\n",
      "Passing:  6 0.33721173\n",
      "New model action:  [6]\n",
      "New model action value:  [0.3399622]\n",
      "Passing:  6 0.3399622\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 2 has 67 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:13.33 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:13.33 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211333\n",
      "2024-02-01 21:13.33 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:13.33 [debug    ] Building models...\n",
      "2024-02-01 21:13.33 [debug    ] Models have been built.\n",
      "2024-02-01 21:13.33 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 1/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0564, temp=1, critic_loss=4.52, actor_loss=-2.86]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.35 [info     ] DiscreteSAC_20240201211333: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.0032279491424560547, 'time_algorithm_update': 1.9837491512298584, 'temp_loss': 0.056367333978414536, 'temp': 0.9997006058692932, 'critic_loss': 4.519977569580078, 'actor_loss': -2.863523006439209, 'time_step': 1.987490177154541} step=1\n",
      "2024-02-01 21:13.35 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:02<00:00,  2.02s/it, temp_loss=0.0565, temp=0.999, critic_loss=4.52, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.37 [info     ] DiscreteSAC_20240201211333: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.0031731128692626953, 'time_algorithm_update': 2.0162858963012695, 'temp_loss': 0.05650261789560318, 'temp': 0.9994012117385864, 'critic_loss': 4.5190958976745605, 'actor_loss': -2.8685567378997803, 'time_step': 2.0202107429504395} step=2\n",
      "2024-02-01 21:13.37 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:02<00:00,  2.04s/it, temp_loss=0.0566, temp=0.999, critic_loss=4.45, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.39 [info     ] DiscreteSAC_20240201211333: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.003668069839477539, 'time_algorithm_update': 2.0307366847991943, 'temp_loss': 0.05659816786646843, 'temp': 0.9991019368171692, 'critic_loss': 4.448627471923828, 'actor_loss': -2.874162435531616, 'time_step': 2.0349161624908447} step=3\n",
      "2024-02-01 21:13.39 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:02<00:00,  2.04s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.45, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.41 [info     ] DiscreteSAC_20240201211333: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.005146980285644531, 'time_algorithm_update': 2.029859781265259, 'temp_loss': 0.05667264014482498, 'temp': 0.9988027215003967, 'critic_loss': 4.454352378845215, 'actor_loss': -2.8810675144195557, 'time_step': 2.0355913639068604} step=4\n",
      "2024-02-01 21:13.41 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:02<00:00,  2.08s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.44, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.43 [info     ] DiscreteSAC_20240201211333: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.003244161605834961, 'time_algorithm_update': 2.071505069732666, 'temp_loss': 0.05672910064458847, 'temp': 0.998503565788269, 'critic_loss': 4.4425740242004395, 'actor_loss': -2.890504837036133, 'time_step': 2.0754339694976807} step=5\n",
      "2024-02-01 21:13.43 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0568, temp=0.998, critic_loss=4.45, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.45 [info     ] DiscreteSAC_20240201211333: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.0030090808868408203, 'time_algorithm_update': 1.9902737140655518, 'temp_loss': 0.05677219107747078, 'temp': 0.9982044696807861, 'critic_loss': 4.445353031158447, 'actor_loss': -2.9020562171936035, 'time_step': 1.993861198425293} step=6\n",
      "2024-02-01 21:13.45 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0568, temp=0.998, critic_loss=4.43, actor_loss=-2.92]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.47 [info     ] DiscreteSAC_20240201211333: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.003492116928100586, 'time_algorithm_update': 1.9844138622283936, 'temp_loss': 0.05680602788925171, 'temp': 0.997905433177948, 'critic_loss': 4.425166130065918, 'actor_loss': -2.9182016849517822, 'time_step': 1.9884488582611084} step=7\n",
      "2024-02-01 21:13.47 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:02<00:00,  2.00s/it, temp_loss=0.0568, temp=0.998, critic_loss=4.35, actor_loss=-2.94]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.49 [info     ] DiscreteSAC_20240201211333: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.0037088394165039062, 'time_algorithm_update': 1.9967408180236816, 'temp_loss': 0.05683453753590584, 'temp': 0.9976064562797546, 'critic_loss': 4.34909725189209, 'actor_loss': -2.941591262817383, 'time_step': 2.000966787338257} step=8\n",
      "2024-02-01 21:13.49 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:02<00:00,  2.00s/it, temp_loss=0.0569, temp=0.997, critic_loss=4.24, actor_loss=-2.97]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.51 [info     ] DiscreteSAC_20240201211333: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.003173828125, 'time_algorithm_update': 2.0005319118499756, 'temp_loss': 0.056862518191337585, 'temp': 0.997307538986206, 'critic_loss': 4.241878509521484, 'actor_loss': -2.973501443862915, 'time_step': 2.0042192935943604} step=9\n",
      "2024-02-01 21:13.51 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:02<00:00,  2.06s/it, temp_loss=0.0569, temp=0.997, critic_loss=4.15, actor_loss=-3.01]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.53 [info     ] DiscreteSAC_20240201211333: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.003072977066040039, 'time_algorithm_update': 2.059161901473999, 'temp_loss': 0.05688212811946869, 'temp': 0.9970086812973022, 'critic_loss': 4.148664951324463, 'actor_loss': -3.0129520893096924, 'time_step': 2.062775135040283} step=10\n",
      "2024-02-01 21:13.53 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211333/model_10.pt\n",
      "New model action:  [15]\n",
      "New model action value:  [0.38293064]\n",
      "Passing:  15 0.38293064\n",
      "New model action:  [15]\n",
      "New model action value:  [0.38008213]\n",
      "Passing:  15 0.38008213\n",
      "New model action:  [15]\n",
      "New model action value:  [0.37989616]\n",
      "Passing:  15 0.37989616\n",
      "New model action:  [15]\n",
      "New model action value:  [0.38358974]\n",
      "Passing:  15 0.38358974\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 3 has 333 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:13.53 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:13.53 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211353\n",
      "2024-02-01 21:13.53 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:13.53 [debug    ] Building models...\n",
      "2024-02-01 21:13.53 [debug    ] Models have been built.\n",
      "2024-02-01 21:13.53 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 1/10: 100%|██████████| 1/1 [00:02<00:00,  2.13s/it, temp_loss=0.0563, temp=1, critic_loss=4.63, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.56 [info     ] DiscreteSAC_20240201211353: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.008391857147216797, 'time_algorithm_update': 2.1213738918304443, 'temp_loss': 0.05631740018725395, 'temp': 0.9997006058692932, 'critic_loss': 4.633253574371338, 'actor_loss': -2.8719890117645264, 'time_step': 2.1303412914276123} step=1\n",
      "2024-02-01 21:13.56 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0564, temp=0.999, critic_loss=4.53, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:13.58 [info     ] DiscreteSAC_20240201211353: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.003117084503173828, 'time_algorithm_update': 2.022458076477051, 'temp_loss': 0.056427061557769775, 'temp': 0.9994012117385864, 'critic_loss': 4.528501987457275, 'actor_loss': -2.878662586212158, 'time_step': 2.02608323097229} step=2\n",
      "2024-02-01 21:13.58 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0565, temp=0.999, critic_loss=4.53, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.00 [info     ] DiscreteSAC_20240201211353: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.0034482479095458984, 'time_algorithm_update': 1.9904320240020752, 'temp_loss': 0.05648644268512726, 'temp': 0.9991019368171692, 'critic_loss': 4.533123016357422, 'actor_loss': -2.8857154846191406, 'time_step': 1.9944639205932617} step=3\n",
      "2024-02-01 21:14.00 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0565, temp=0.999, critic_loss=4.49, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.02 [info     ] DiscreteSAC_20240201211353: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.003582000732421875, 'time_algorithm_update': 1.9809107780456543, 'temp_loss': 0.056516170501708984, 'temp': 0.9988027811050415, 'critic_loss': 4.493155479431152, 'actor_loss': -2.8925344944000244, 'time_step': 1.9850432872772217} step=4\n",
      "2024-02-01 21:14.02 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0565, temp=0.999, critic_loss=4.48, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.04 [info     ] DiscreteSAC_20240201211353: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.0034079551696777344, 'time_algorithm_update': 2.0243990421295166, 'temp_loss': 0.05653713643550873, 'temp': 0.9985036253929138, 'critic_loss': 4.4813079833984375, 'actor_loss': -2.900700569152832, 'time_step': 2.028386116027832} step=5\n",
      "2024-02-01 21:14.04 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:02<00:00,  2.11s/it, temp_loss=0.0565, temp=0.998, critic_loss=4.45, actor_loss=-2.91]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.06 [info     ] DiscreteSAC_20240201211353: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.003940105438232422, 'time_algorithm_update': 2.1052019596099854, 'temp_loss': 0.05654934048652649, 'temp': 0.9982045888900757, 'critic_loss': 4.448138236999512, 'actor_loss': -2.9106597900390625, 'time_step': 2.109769821166992} step=6\n",
      "2024-02-01 21:14.06 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:02<00:00,  2.00s/it, temp_loss=0.0566, temp=0.998, critic_loss=4.43, actor_loss=-2.92]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.08 [info     ] DiscreteSAC_20240201211353: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.003267049789428711, 'time_algorithm_update': 1.999140739440918, 'temp_loss': 0.05655278265476227, 'temp': 0.9979056119918823, 'critic_loss': 4.432936191558838, 'actor_loss': -2.921802043914795, 'time_step': 2.0029349327087402} step=7\n",
      "2024-02-01 21:14.08 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:02<00:00,  2.02s/it, temp_loss=0.0565, temp=0.998, critic_loss=4.33, actor_loss=-2.94]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.10 [info     ] DiscreteSAC_20240201211353: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.003657817840576172, 'time_algorithm_update': 2.0148119926452637, 'temp_loss': 0.05654650554060936, 'temp': 0.9976067543029785, 'critic_loss': 4.325827598571777, 'actor_loss': -2.936957359313965, 'time_step': 2.0189828872680664} step=8\n",
      "2024-02-01 21:14.10 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:01<00:00,  1.97s/it, temp_loss=0.0565, temp=0.997, critic_loss=4.26, actor_loss=-2.96]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.12 [info     ] DiscreteSAC_20240201211353: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.0038068294525146484, 'time_algorithm_update': 1.9684500694274902, 'temp_loss': 0.056521326303482056, 'temp': 0.9973079562187195, 'critic_loss': 4.2636942863464355, 'actor_loss': -2.9570937156677246, 'time_step': 1.9728047847747803} step=9\n",
      "2024-02-01 21:14.12 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0565, temp=0.997, critic_loss=4.13, actor_loss=-2.99]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.14 [info     ] DiscreteSAC_20240201211353: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.0036568641662597656, 'time_algorithm_update': 1.9895639419555664, 'temp_loss': 0.05647263303399086, 'temp': 0.99700927734375, 'critic_loss': 4.131525993347168, 'actor_loss': -2.985175609588623, 'time_step': 1.9937341213226318} step=10\n",
      "2024-02-01 21:14.14 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211353/model_10.pt\n",
      "New model action:  [16]\n",
      "New model action value:  [0.5381601]\n",
      "Passing:  16 0.5381601\n",
      "New model action:  [16]\n",
      "New model action value:  [0.5331303]\n",
      "Passing:  16 0.5331303\n",
      "New model action:  [16]\n",
      "New model action value:  [0.5320007]\n",
      "Passing:  16 0.5320007\n",
      "New model action:  [16]\n",
      "New model action value:  [0.5362641]\n",
      "Passing:  16 0.5362641\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 4 has 116 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:14.14 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:14.14 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211414\n",
      "2024-02-01 21:14.14 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:14.14 [debug    ] Building models...\n",
      "2024-02-01 21:14.14 [debug    ] Models have been built.\n",
      "2024-02-01 21:14.14 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 1/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0563, temp=1, critic_loss=4.63, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.16 [info     ] DiscreteSAC_20240201211414: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.003286123275756836, 'time_algorithm_update': 1.97324800491333, 'temp_loss': 0.05632904917001724, 'temp': 0.9997006058692932, 'critic_loss': 4.633204460144043, 'actor_loss': -2.8675575256347656, 'time_step': 1.9770941734313965} step=1\n",
      "2024-02-01 21:14.16 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0565, temp=0.999, critic_loss=4.51, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.18 [info     ] DiscreteSAC_20240201211414: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.00403904914855957, 'time_algorithm_update': 1.980565071105957, 'temp_loss': 0.05647134780883789, 'temp': 0.9994012117385864, 'critic_loss': 4.505704402923584, 'actor_loss': -2.8714101314544678, 'time_step': 1.985158920288086} step=2\n",
      "2024-02-01 21:14.18 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0566, temp=0.999, critic_loss=4.54, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.20 [info     ] DiscreteSAC_20240201211414: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.0031239986419677734, 'time_algorithm_update': 1.9735357761383057, 'temp_loss': 0.056586503982543945, 'temp': 0.9991019368171692, 'critic_loss': 4.542080879211426, 'actor_loss': -2.8756003379821777, 'time_step': 1.9771912097930908} step=3\n",
      "2024-02-01 21:14.20 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.5, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.22 [info     ] DiscreteSAC_20240201211414: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.0030558109283447266, 'time_algorithm_update': 1.9798977375030518, 'temp_loss': 0.05668055638670921, 'temp': 0.9988027215003967, 'critic_loss': 4.499575614929199, 'actor_loss': -2.8824245929718018, 'time_step': 1.9834859371185303} step=4\n",
      "2024-02-01 21:14.22 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0568, temp=0.999, critic_loss=4.45, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.24 [info     ] DiscreteSAC_20240201211414: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.0030760765075683594, 'time_algorithm_update': 2.0249898433685303, 'temp_loss': 0.056751083582639694, 'temp': 0.9985035061836243, 'critic_loss': 4.451028347015381, 'actor_loss': -2.8917953968048096, 'time_step': 2.028815984725952} step=5\n",
      "2024-02-01 21:14.24 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0568, temp=0.998, critic_loss=4.47, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.26 [info     ] DiscreteSAC_20240201211414: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.003368854522705078, 'time_algorithm_update': 2.0259900093078613, 'temp_loss': 0.056810807436704636, 'temp': 0.9982044100761414, 'critic_loss': 4.469383716583252, 'actor_loss': -2.9044220447540283, 'time_step': 2.0299270153045654} step=6\n",
      "2024-02-01 21:14.27 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:02<00:00,  2.07s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.39, actor_loss=-2.92]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.29 [info     ] DiscreteSAC_20240201211414: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.0047149658203125, 'time_algorithm_update': 2.0606918334960938, 'temp_loss': 0.05686502158641815, 'temp': 0.9979053139686584, 'critic_loss': 4.3900322914123535, 'actor_loss': -2.921980142593384, 'time_step': 2.0660510063171387} step=7\n",
      "2024-02-01 21:14.29 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:02<00:00,  2.04s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.32, actor_loss=-2.95]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.31 [info     ] DiscreteSAC_20240201211414: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.002975940704345703, 'time_algorithm_update': 2.034745216369629, 'temp_loss': 0.05691186338663101, 'temp': 0.9976062774658203, 'critic_loss': 4.322895526885986, 'actor_loss': -2.9468212127685547, 'time_step': 2.038311243057251} step=8\n",
      "2024-02-01 21:14.31 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:01<00:00,  2.00s/it, temp_loss=0.057, temp=0.997, critic_loss=4.21, actor_loss=-2.98]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.33 [info     ] DiscreteSAC_20240201211414: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.003297090530395508, 'time_algorithm_update': 1.993189811706543, 'temp_loss': 0.05695047229528427, 'temp': 0.997307300567627, 'critic_loss': 4.2052106857299805, 'actor_loss': -2.9796156883239746, 'time_step': 1.9970028400421143} step=9\n",
      "2024-02-01 21:14.33 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.057, temp=0.997, critic_loss=4.15, actor_loss=-3.02]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.35 [info     ] DiscreteSAC_20240201211414: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.003255128860473633, 'time_algorithm_update': 1.97110915184021, 'temp_loss': 0.056975796818733215, 'temp': 0.9970083832740784, 'critic_loss': 4.15339994430542, 'actor_loss': -3.021998167037964, 'time_step': 1.9748690128326416} step=10\n",
      "2024-02-01 21:14.35 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211414/model_10.pt\n",
      "New model action:  [6]\n",
      "New model action value:  [0.16324976]\n",
      "Passing:  6 0.16324976\n",
      "New model action:  [6]\n",
      "New model action value:  [0.16362911]\n",
      "Passing:  6 0.16362911\n",
      "New model action:  [6]\n",
      "New model action value:  [0.16285233]\n",
      "Passing:  6 0.16285233\n",
      "New model action:  [6]\n",
      "New model action value:  [0.16257349]\n",
      "Passing:  6 0.16257349\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 5 has 387 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:14.35 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:14.35 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211435\n",
      "2024-02-01 21:14.35 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:14.35 [debug    ] Building models...\n",
      "2024-02-01 21:14.35 [debug    ] Models have been built.\n",
      "2024-02-01 21:14.35 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 1/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.057, temp=1, critic_loss=4.62, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.37 [info     ] DiscreteSAC_20240201211435: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.003245115280151367, 'time_algorithm_update': 1.975560188293457, 'temp_loss': 0.05699755996465683, 'temp': 0.9997005462646484, 'critic_loss': 4.623102188110352, 'actor_loss': -2.8667361736297607, 'time_step': 1.9793379306793213} step=1\n",
      "2024-02-01 21:14.37 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0571, temp=0.999, critic_loss=4.56, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.39 [info     ] DiscreteSAC_20240201211435: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.003535032272338867, 'time_algorithm_update': 1.9763379096984863, 'temp_loss': 0.05707007646560669, 'temp': 0.9994012117385864, 'critic_loss': 4.5598578453063965, 'actor_loss': -2.872403383255005, 'time_step': 1.9803969860076904} step=2\n",
      "2024-02-01 21:14.39 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0571, temp=0.999, critic_loss=4.55, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.41 [info     ] DiscreteSAC_20240201211435: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.0035169124603271484, 'time_algorithm_update': 2.022475004196167, 'temp_loss': 0.057116489857435226, 'temp': 0.9991019368171692, 'critic_loss': 4.5486555099487305, 'actor_loss': -2.87970232963562, 'time_step': 2.026543140411377} step=3\n",
      "2024-02-01 21:14.41 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.0571, temp=0.999, critic_loss=4.51, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.43 [info     ] DiscreteSAC_20240201211435: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.0027790069580078125, 'time_algorithm_update': 2.0013608932495117, 'temp_loss': 0.057149920612573624, 'temp': 0.9988027811050415, 'critic_loss': 4.505099296569824, 'actor_loss': -2.888707160949707, 'time_step': 2.0047709941864014} step=4\n",
      "2024-02-01 21:14.43 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.0572, temp=0.999, critic_loss=4.35, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.45 [info     ] DiscreteSAC_20240201211435: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.003131866455078125, 'time_algorithm_update': 2.0085160732269287, 'temp_loss': 0.057170748710632324, 'temp': 0.9985036253929138, 'critic_loss': 4.348759651184082, 'actor_loss': -2.899404525756836, 'time_step': 2.0122971534729004} step=5\n",
      "2024-02-01 21:14.45 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:01<00:00,  1.97s/it, temp_loss=0.0572, temp=0.998, critic_loss=4.5, actor_loss=-2.91]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.47 [info     ] DiscreteSAC_20240201211435: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.0036461353302001953, 'time_algorithm_update': 1.9694299697875977, 'temp_loss': 0.05718354880809784, 'temp': 0.9982045888900757, 'critic_loss': 4.5016374588012695, 'actor_loss': -2.912444591522217, 'time_step': 1.9736378192901611} step=6\n",
      "2024-02-01 21:14.47 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:01<00:00,  1.96s/it, temp_loss=0.0572, temp=0.998, critic_loss=4.41, actor_loss=-2.93]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.49 [info     ] DiscreteSAC_20240201211435: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.003490924835205078, 'time_algorithm_update': 1.9588899612426758, 'temp_loss': 0.05718472599983215, 'temp': 0.9979056119918823, 'critic_loss': 4.407726287841797, 'actor_loss': -2.927964448928833, 'time_step': 1.962942123413086} step=7\n",
      "2024-02-01 21:14.49 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0572, temp=0.998, critic_loss=4.3, actor_loss=-2.95]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.51 [info     ] DiscreteSAC_20240201211435: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.0037517547607421875, 'time_algorithm_update': 1.9782519340515137, 'temp_loss': 0.05717314034700394, 'temp': 0.9976067543029785, 'critic_loss': 4.301102638244629, 'actor_loss': -2.9510421752929688, 'time_step': 1.9825291633605957} step=8\n",
      "2024-02-01 21:14.51 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0571, temp=0.997, critic_loss=4.2, actor_loss=-2.98]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.53 [info     ] DiscreteSAC_20240201211435: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.003076791763305664, 'time_algorithm_update': 1.9774739742279053, 'temp_loss': 0.057141296565532684, 'temp': 0.9973080158233643, 'critic_loss': 4.20357608795166, 'actor_loss': -2.9831244945526123, 'time_step': 1.981092929840088} step=9\n",
      "2024-02-01 21:14.53 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0571, temp=0.997, critic_loss=4.06, actor_loss=-3.03]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.55 [info     ] DiscreteSAC_20240201211435: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.002753019332885742, 'time_algorithm_update': 1.987152099609375, 'temp_loss': 0.05707784369587898, 'temp': 0.9970093369483948, 'critic_loss': 4.055904388427734, 'actor_loss': -3.0276341438293457, 'time_step': 1.9904470443725586} step=10\n",
      "2024-02-01 21:14.55 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211435/model_10.pt\n",
      "New model action:  [14]\n",
      "New model action value:  [0.5588027]\n",
      "Passing:  14 0.5588027\n",
      "New model action:  [14]\n",
      "New model action value:  [0.5513799]\n",
      "Passing:  14 0.5513799\n",
      "New model action:  [14]\n",
      "New model action value:  [0.5494319]\n",
      "Passing:  14 0.5494319\n",
      "New model action:  [14]\n",
      "New model action value:  [0.55736095]\n",
      "Passing:  14 0.55736095\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 6 has 207 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:14.55 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:14.55 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211455\n",
      "2024-02-01 21:14.55 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:14.55 [debug    ] Building models...\n",
      "2024-02-01 21:14.55 [debug    ] Models have been built.\n",
      "2024-02-01 21:14.55 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 1/10: 100%|██████████| 1/1 [00:01<00:00,  2.00s/it, temp_loss=0.0564, temp=1, critic_loss=4.58, actor_loss=-2.85]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.57 [info     ] DiscreteSAC_20240201211455: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.002552032470703125, 'time_algorithm_update': 1.9944109916687012, 'temp_loss': 0.056416500359773636, 'temp': 0.9997005462646484, 'critic_loss': 4.578276634216309, 'actor_loss': -2.8536455631256104, 'time_step': 1.9974958896636963} step=1\n",
      "2024-02-01 21:14.57 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.0566, temp=0.999, critic_loss=4.54, actor_loss=-2.86]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:14.59 [info     ] DiscreteSAC_20240201211455: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.0037419795989990234, 'time_algorithm_update': 2.000420093536377, 'temp_loss': 0.05657003074884415, 'temp': 0.9994012117385864, 'critic_loss': 4.536737442016602, 'actor_loss': -2.86214542388916, 'time_step': 2.0047249794006348} step=2\n",
      "2024-02-01 21:14.59 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:02<00:00,  2.04s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.53, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.01 [info     ] DiscreteSAC_20240201211455: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.003276824951171875, 'time_algorithm_update': 2.0324881076812744, 'temp_loss': 0.05669310316443443, 'temp': 0.9991019368171692, 'critic_loss': 4.533144474029541, 'actor_loss': -2.8728232383728027, 'time_step': 2.0364882946014404} step=3\n",
      "2024-02-01 21:15.02 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:02<00:00,  2.02s/it, temp_loss=0.0568, temp=0.999, critic_loss=4.4, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.04 [info     ] DiscreteSAC_20240201211455: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.003985166549682617, 'time_algorithm_update': 2.0109810829162598, 'temp_loss': 0.05678773671388626, 'temp': 0.998802661895752, 'critic_loss': 4.3972344398498535, 'actor_loss': -2.886784315109253, 'time_step': 2.015483856201172} step=4\n",
      "2024-02-01 21:15.04 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0569, temp=0.999, critic_loss=4.46, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.06 [info     ] DiscreteSAC_20240201211455: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.0030968189239501953, 'time_algorithm_update': 1.9796957969665527, 'temp_loss': 0.05685241520404816, 'temp': 0.9985035061836243, 'critic_loss': 4.458629608154297, 'actor_loss': -2.90478253364563, 'time_step': 1.983341932296753} step=5\n",
      "2024-02-01 21:15.06 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.26, actor_loss=-2.92]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.08 [info     ] DiscreteSAC_20240201211455: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.0029020309448242188, 'time_algorithm_update': 1.9863450527191162, 'temp_loss': 0.05690537020564079, 'temp': 0.9982043504714966, 'critic_loss': 4.255867004394531, 'actor_loss': -2.9244513511657715, 'time_step': 1.9898149967193604} step=6\n",
      "2024-02-01 21:15.08 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:01<00:00,  1.97s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.39, actor_loss=-2.95]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.10 [info     ] DiscreteSAC_20240201211455: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.0030367374420166016, 'time_algorithm_update': 1.9689741134643555, 'temp_loss': 0.05694590508937836, 'temp': 0.9979053139686584, 'critic_loss': 4.390008449554443, 'actor_loss': -2.9463069438934326, 'time_step': 1.9725539684295654} step=7\n",
      "2024-02-01 21:15.10 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:02<00:00,  2.00s/it, temp_loss=0.057, temp=0.998, critic_loss=4.32, actor_loss=-2.98]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.12 [info     ] DiscreteSAC_20240201211455: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.0032579898834228516, 'time_algorithm_update': 2.0005199909210205, 'temp_loss': 0.05697782337665558, 'temp': 0.9976062774658203, 'critic_loss': 4.323641777038574, 'actor_loss': -2.9767112731933594, 'time_step': 2.0045299530029297} step=8\n",
      "2024-02-01 21:15.12 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.057, temp=0.997, critic_loss=4.09, actor_loss=-3.02]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.14 [info     ] DiscreteSAC_20240201211455: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.002457141876220703, 'time_algorithm_update': 1.991227149963379, 'temp_loss': 0.056999027729034424, 'temp': 0.997307300567627, 'critic_loss': 4.09193229675293, 'actor_loss': -3.0184264183044434, 'time_step': 1.9943480491638184} step=9\n",
      "2024-02-01 21:15.14 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:02<00:00,  2.05s/it, temp_loss=0.057, temp=0.997, critic_loss=4.08, actor_loss=-3.07]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.16 [info     ] DiscreteSAC_20240201211455: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.002803325653076172, 'time_algorithm_update': 2.044977903366089, 'temp_loss': 0.05699126794934273, 'temp': 0.9970084428787231, 'critic_loss': 4.0755615234375, 'actor_loss': -3.0672428607940674, 'time_step': 2.048443078994751} step=10\n",
      "2024-02-01 21:15.16 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211455/model_10.pt\n",
      "New model action:  [17]\n",
      "New model action value:  [0.42683256]\n",
      "Passing:  17 0.42683256\n",
      "New model action:  [17]\n",
      "New model action value:  [0.4240774]\n",
      "Passing:  17 0.4240774\n",
      "New model action:  [17]\n",
      "New model action value:  [0.42313105]\n",
      "Passing:  17 0.42313105\n",
      "New model action:  [17]\n",
      "New model action value:  [0.4299667]\n",
      "Passing:  17 0.4299667\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 7 has 355 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:15.16 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:15.16 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211516\n",
      "2024-02-01 21:15.16 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:15.16 [debug    ] Building models...\n",
      "2024-02-01 21:15.16 [debug    ] Models have been built.\n",
      "2024-02-01 21:15.16 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 1/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0564, temp=1, critic_loss=4.6, actor_loss=-2.85]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.18 [info     ] DiscreteSAC_20240201211516: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.0030257701873779297, 'time_algorithm_update': 1.984184741973877, 'temp_loss': 0.05637064576148987, 'temp': 0.9997006058692932, 'critic_loss': 4.600635051727295, 'actor_loss': -2.847942352294922, 'time_step': 1.9877979755401611} step=1\n",
      "2024-02-01 21:15.18 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.0565, temp=0.999, critic_loss=4.47, actor_loss=-2.85]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.20 [info     ] DiscreteSAC_20240201211516: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.003190755844116211, 'time_algorithm_update': 2.0016660690307617, 'temp_loss': 0.056528929620981216, 'temp': 0.9994012117385864, 'critic_loss': 4.471138954162598, 'actor_loss': -2.853292942047119, 'time_step': 2.005466938018799} step=2\n",
      "2024-02-01 21:15.20 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0566, temp=0.999, critic_loss=4.54, actor_loss=-2.86]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.22 [info     ] DiscreteSAC_20240201211516: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.003283977508544922, 'time_algorithm_update': 1.9837710857391357, 'temp_loss': 0.05664918199181557, 'temp': 0.9991019368171692, 'critic_loss': 4.544235706329346, 'actor_loss': -2.859880208969116, 'time_step': 1.9875750541687012} step=3\n",
      "2024-02-01 21:15.22 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:01<00:00,  1.98s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.51, actor_loss=-2.87]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.24 [info     ] DiscreteSAC_20240201211516: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.003206968307495117, 'time_algorithm_update': 1.9739279747009277, 'temp_loss': 0.056745726615190506, 'temp': 0.998802661895752, 'critic_loss': 4.513242721557617, 'actor_loss': -2.868495464324951, 'time_step': 1.9776759147644043} step=4\n",
      "2024-02-01 21:15.24 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:01<00:00,  2.00s/it, temp_loss=0.0568, temp=0.999, critic_loss=4.41, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.26 [info     ] DiscreteSAC_20240201211516: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.0029611587524414062, 'time_algorithm_update': 1.9924430847167969, 'temp_loss': 0.05683133006095886, 'temp': 0.9985035061836243, 'critic_loss': 4.409127235412598, 'actor_loss': -2.8798909187316895, 'time_step': 1.9959301948547363} step=5\n",
      "2024-02-01 21:15.26 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:02<00:00,  2.05s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.42, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.28 [info     ] DiscreteSAC_20240201211516: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.003248929977416992, 'time_algorithm_update': 2.0500099658966064, 'temp_loss': 0.056908413767814636, 'temp': 0.9982043504714966, 'critic_loss': 4.41892147064209, 'actor_loss': -2.893791675567627, 'time_step': 2.053936004638672} step=6\n",
      "2024-02-01 21:15.28 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:02<00:00,  2.11s/it, temp_loss=0.057, temp=0.998, critic_loss=4.48, actor_loss=-2.91]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.30 [info     ] DiscreteSAC_20240201211516: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.003246307373046875, 'time_algorithm_update': 2.101945161819458, 'temp_loss': 0.05697086080908775, 'temp': 0.9979052543640137, 'critic_loss': 4.483152866363525, 'actor_loss': -2.9095304012298584, 'time_step': 2.1057240962982178} step=7\n",
      "2024-02-01 21:15.31 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.057, temp=0.998, critic_loss=4.22, actor_loss=-2.93]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.33 [info     ] DiscreteSAC_20240201211516: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.0031728744506835938, 'time_algorithm_update': 2.006937026977539, 'temp_loss': 0.05700985714793205, 'temp': 0.9976062178611755, 'critic_loss': 4.222870826721191, 'actor_loss': -2.928131103515625, 'time_step': 2.0106208324432373} step=8\n",
      "2024-02-01 21:15.33 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:02<00:00,  2.02s/it, temp_loss=0.057, temp=0.997, critic_loss=4.26, actor_loss=-2.96]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.35 [info     ] DiscreteSAC_20240201211516: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.0033600330352783203, 'time_algorithm_update': 2.017241954803467, 'temp_loss': 0.05702492594718933, 'temp': 0.9973071813583374, 'critic_loss': 4.260093688964844, 'actor_loss': -2.95615291595459, 'time_step': 2.0211870670318604} step=9\n",
      "2024-02-01 21:15.35 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:02<00:00,  2.05s/it, temp_loss=0.057, temp=0.997, critic_loss=4.15, actor_loss=-2.99]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.37 [info     ] DiscreteSAC_20240201211516: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.0025777816772460938, 'time_algorithm_update': 2.0492870807647705, 'temp_loss': 0.05697012320160866, 'temp': 0.9970083236694336, 'critic_loss': 4.1494646072387695, 'actor_loss': -2.992384195327759, 'time_step': 2.052562952041626} step=10\n",
      "2024-02-01 21:15.37 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211516/model_10.pt\n",
      "New model action:  [11]\n",
      "New model action value:  [0.37452382]\n",
      "Passing:  11 0.37452382\n",
      "New model action:  [11]\n",
      "New model action value:  [0.37423462]\n",
      "Passing:  11 0.37423462\n",
      "New model action:  [11]\n",
      "New model action value:  [0.3712205]\n",
      "Passing:  11 0.3712205\n",
      "New model action:  [11]\n",
      "New model action value:  [0.3745811]\n",
      "Passing:  11 0.3745811\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 8 has 191 trajectories out of 1677\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-02-01 21:15.37 [debug    ] RandomIterator is selected.\n",
      "2024-02-01 21:15.37 [info     ] Directory is created at d3rlpy_logs/DiscreteSAC_20240201211537\n",
      "2024-02-01 21:15.37 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-02-01 21:15.37 [debug    ] Building models...\n",
      "2024-02-01 21:15.37 [debug    ] Models have been built.\n",
      "2024-02-01 21:15.37 [info     ] Parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/params.json params={'action_scaler': None, 'actor_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'actor_learning_rate': 0.0003, 'actor_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'batch_size': 256, 'critic_encoder_factory': {'type': 'custom', 'params': {'feature_size': 128}}, 'critic_learning_rate': 0.0003, 'critic_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'gamma': 0.99, 'generated_maxlen': 100000, 'initial_temperature': 1.0, 'n_critics': 2, 'n_frames': 1, 'n_steps': 1, 'q_func_factory': {'type': 'mean', 'params': {'share_encoder': False}}, 'real_ratio': 1.0, 'reward_scaler': None, 'scaler': {'type': 'pixel', 'params': {}}, 'target_update_interval': 8000, 'temp_learning_rate': 0.0003, 'temp_optim_factory': {'optim_cls': 'Adam', 'betas': (0.9, 0.999), 'eps': 0.0001, 'weight_decay': 0, 'amsgrad': False}, 'use_gpu': None, 'algorithm': 'DiscreteSAC', 'observation_shape': (4, 84, 84), 'action_size': 18}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 1/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0566, temp=1, critic_loss=4.52, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.39 [info     ] DiscreteSAC_20240201211537: epoch=1 step=1 epoch=1 metrics={'time_sample_batch': 0.0028429031372070312, 'time_algorithm_update': 1.9825680255889893, 'temp_loss': 0.056649282574653625, 'temp': 0.9997005462646484, 'critic_loss': 4.518222808837891, 'actor_loss': -2.8789267539978027, 'time_step': 1.9860060214996338} step=1\n",
      "2024-02-01 21:15.39 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_1.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 2/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0567, temp=0.999, critic_loss=4.59, actor_loss=-2.88]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.41 [info     ] DiscreteSAC_20240201211537: epoch=2 step=2 epoch=2 metrics={'time_sample_batch': 0.0028710365295410156, 'time_algorithm_update': 1.9837710857391357, 'temp_loss': 0.05671852082014084, 'temp': 0.9994012117385864, 'critic_loss': 4.587435722351074, 'actor_loss': -2.8830347061157227, 'time_step': 1.9871740341186523} step=2\n",
      "2024-02-01 21:15.41 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_2.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 3/10: 100%|██████████| 1/1 [00:02<00:00,  2.06s/it, temp_loss=0.0568, temp=0.999, critic_loss=4.58, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.43 [info     ] DiscreteSAC_20240201211537: epoch=3 step=3 epoch=3 metrics={'time_sample_batch': 0.0025742053985595703, 'time_algorithm_update': 2.0546653270721436, 'temp_loss': 0.056778937578201294, 'temp': 0.9991019368171692, 'critic_loss': 4.581206321716309, 'actor_loss': -2.8879127502441406, 'time_step': 2.057828903198242} step=3\n",
      "2024-02-01 21:15.43 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_3.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 4/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.0568, temp=0.999, critic_loss=4.52, actor_loss=-2.89]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.45 [info     ] DiscreteSAC_20240201211537: epoch=4 step=4 epoch=4 metrics={'time_sample_batch': 0.0033228397369384766, 'time_algorithm_update': 2.0029549598693848, 'temp_loss': 0.05682545155286789, 'temp': 0.9988027811050415, 'critic_loss': 4.5166730880737305, 'actor_loss': -2.894308090209961, 'time_step': 2.006824016571045} step=4\n",
      "2024-02-01 21:15.45 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_4.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 5/10: 100%|██████████| 1/1 [00:02<00:00,  2.01s/it, temp_loss=0.0569, temp=0.999, critic_loss=4.43, actor_loss=-2.9]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.47 [info     ] DiscreteSAC_20240201211537: epoch=5 step=5 epoch=5 metrics={'time_sample_batch': 0.004012107849121094, 'time_algorithm_update': 2.004570722579956, 'temp_loss': 0.05686303600668907, 'temp': 0.9985036253929138, 'critic_loss': 4.425753593444824, 'actor_loss': -2.90315842628479, 'time_step': 2.0092849731445312} step=5\n",
      "2024-02-01 21:15.47 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_5.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 6/10: 100%|██████████| 1/1 [00:01<00:00,  1.99s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.46, actor_loss=-2.91]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.49 [info     ] DiscreteSAC_20240201211537: epoch=6 step=6 epoch=6 metrics={'time_sample_batch': 0.0030918121337890625, 'time_algorithm_update': 1.9877328872680664, 'temp_loss': 0.05688629671931267, 'temp': 0.9982045888900757, 'critic_loss': 4.45601749420166, 'actor_loss': -2.914369583129883, 'time_step': 1.9913930892944336} step=6\n",
      "2024-02-01 21:15.49 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_6.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 7/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.46, actor_loss=-2.93]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.51 [info     ] DiscreteSAC_20240201211537: epoch=7 step=7 epoch=7 metrics={'time_sample_batch': 0.0032341480255126953, 'time_algorithm_update': 2.0213098526000977, 'temp_loss': 0.056892894208431244, 'temp': 0.9979056119918823, 'critic_loss': 4.458274841308594, 'actor_loss': -2.9293410778045654, 'time_step': 2.025301218032837} step=7\n",
      "2024-02-01 21:15.51 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_7.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 8/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0569, temp=0.998, critic_loss=4.31, actor_loss=-2.95]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.53 [info     ] DiscreteSAC_20240201211537: epoch=8 step=8 epoch=8 metrics={'time_sample_batch': 0.0025396347045898438, 'time_algorithm_update': 2.0220580101013184, 'temp_loss': 0.05688066408038139, 'temp': 0.9976066946983337, 'critic_loss': 4.308380126953125, 'actor_loss': -2.9480531215667725, 'time_step': 2.02531099319458} step=8\n",
      "2024-02-01 21:15.53 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_8.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 9/10: 100%|██████████| 1/1 [00:01<00:00,  1.97s/it, temp_loss=0.0568, temp=0.997, critic_loss=4.29, actor_loss=-2.97]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.55 [info     ] DiscreteSAC_20240201211537: epoch=9 step=9 epoch=9 metrics={'time_sample_batch': 0.0027751922607421875, 'time_algorithm_update': 1.967560052871704, 'temp_loss': 0.05684971809387207, 'temp': 0.9973078966140747, 'critic_loss': 4.287954330444336, 'actor_loss': -2.9738714694976807, 'time_step': 1.9708850383758545} step=9\n",
      "2024-02-01 21:15.55 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_9.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "Epoch 10/10: 100%|██████████| 1/1 [00:02<00:00,  2.03s/it, temp_loss=0.0568, temp=0.997, critic_loss=4.26, actor_loss=-3]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-02-01 21:15.57 [info     ] DiscreteSAC_20240201211537: epoch=10 step=10 epoch=10 metrics={'time_sample_batch': 0.0029478073120117188, 'time_algorithm_update': 2.028027057647705, 'temp_loss': 0.056795939803123474, 'temp': 0.9970092177391052, 'critic_loss': 4.258206367492676, 'actor_loss': -3.0024547576904297, 'time_step': 2.0314888954162598} step=10\n",
      "2024-02-01 21:15.58 [info     ] Model parameters are saved to d3rlpy_logs/DiscreteSAC_20240201211537/model_10.pt\n",
      "New model action:  [16]\n",
      "New model action value:  [0.34367856]\n",
      "Passing:  16 0.34367856\n",
      "New model action:  [16]\n",
      "New model action value:  [0.34149146]\n",
      "Passing:  16 0.34149146\n",
      "New model action:  [16]\n",
      "New model action value:  [0.3400364]\n",
      "Passing:  16 0.3400364\n",
      "New model action:  [16]\n",
      "New model action value:  [0.3437826]\n",
      "Passing:  16 0.3437826\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "models_sq, result_data_combinations_sq = fit_per_cluster(\n",
    "        model= sac_sq, \n",
    "        model_class = d3rlpy.algos.DiscreteSAC,\n",
    "        model_params=model_params_sq,\n",
    "        data_embedding=trajectory_embedding_seaquest,\n",
    "        list_episodes=list_episodes_sq,\n",
    "        clusters=clusters_seaquest,\n",
    "        trajectory_embedding=trajectory_embedding_seaquest,\n",
    "        test_observations=test_observations)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "def trajectory_attributions(test_observations, models, traj_embeddings, clusters):\n",
    "    attributions = []\n",
    "    data_embedding = get_data_embedding(traj_embeddings)\n",
    "    # First model is trained on full dataset\n",
    "    # Second model is trained on cluster 1\n",
    "    # Third model is trained on cluster 2 ...\n",
    "    original_model = models[0][0]\n",
    "    original_data_embedding = models[0][1]\n",
    "    for i in range (len(test_observations)):\n",
    "        print('#' * 100, f'Observation {i + 1}', '#' * 100)\n",
    "        print\n",
    "        t = test_observations[i]\n",
    "        print(t.shape)\n",
    "        plt.imshow(t[0][0], cmap='gray')\n",
    "        plt.savefig(f'test_observation_{i + 1}.png')\n",
    "        original_action = original_model.predict(t)\n",
    "        sub_dist = []\n",
    "        for k in models:\n",
    "            #v[0] # model\n",
    "            #v[1] # data_embedding\n",
    "            model = models[k][0]\n",
    "            data_embedding = models[k][1]\n",
    "\n",
    "            action = model.predict(t)\n",
    "            print(f\"{k}-th model predicted action:\", action)\n",
    "            print(\"Original model's action\", original_action)\n",
    "\n",
    "            if action != original_action:\n",
    "                w_d = wasserstein_distance(original_data_embedding, data_embedding)\n",
    "                print(\"Wasserstein distance: \", w_d)\n",
    "            else:\n",
    "                w_d = 1e9\n",
    "            \n",
    "            sub_dist.append(w_d)\n",
    "        \n",
    "        print(\"DEBUG: len(sub_dist)\", len(sub_dist))\n",
    "        print(\"DEBUG: sub_dist\", sub_dist)\n",
    "        print(\"DEBUG: np.argsort(sub_dist)\", np.argsort(sub_dist))\n",
    "        responsible_data_combination = np.argsort(sub_dist)[0] - 1\n",
    "        print(\"Responsible data combination: \", responsible_data_combination)\n",
    "\n",
    "        if sub_dist[responsible_data_combination] == 1e9 or sub_dist[responsible_data_combination] == 0:\n",
    "            print(\"No attribution found\")\n",
    "            continue\n",
    "    \n",
    "        attributions.append({\n",
    "                    'models': [v[0] for v in models.values()],\n",
    "                    'orig_act': original_action,\n",
    "                    'new_act': action,\n",
    "                    'attributed_trajs': clusters[responsible_data_combination],\n",
    "                    'responsible_cluster': responsible_data_combination\n",
    "                })\n",
    "    \n",
    "    return attributions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#################################################################################################### Observation 1 ####################################################################################################\n",
      "0-th model predicted action: [1]\n",
      "Original model's action [1]\n",
      "1-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  9.313225746154785e-10\n",
      "2-th model predicted action: [15]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  4.656612873077393e-10\n",
      "3-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  0.0025711171329021454\n",
      "4-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  6.05359673500061e-09\n",
      "5-th model predicted action: [14]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  2.8542708605527878e-05\n",
      "6-th model predicted action: [17]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  3.632158041000366e-08\n",
      "7-th model predicted action: [11]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.0710209608078003e-08\n",
      "8-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.3969838619232178e-09\n",
      "DEBUG: len(sub_dist) 9\n",
      "DEBUG: sub_dist [1000000000.0, 9.313225746154785e-10, 4.656612873077393e-10, 0.0025711171329021454, 6.05359673500061e-09, 2.8542708605527878e-05, 3.632158041000366e-08, 1.0710209608078003e-08, 1.3969838619232178e-09]\n",
      "DEBUG: np.argsort(sub_dist) [2 1 8 4 7 6 5 3 0]\n",
      "Responsible data combination:  1\n",
      "#################################################################################################### Observation 2 ####################################################################################################\n",
      "0-th model predicted action: [1]\n",
      "Original model's action [1]\n",
      "1-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  9.313225746154785e-10\n",
      "2-th model predicted action: [15]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  4.656612873077393e-10\n",
      "3-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  0.0025711171329021454\n",
      "4-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  6.05359673500061e-09\n",
      "5-th model predicted action: [14]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  2.8542708605527878e-05\n",
      "6-th model predicted action: [17]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  3.632158041000366e-08\n",
      "7-th model predicted action: [11]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.0710209608078003e-08\n",
      "8-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.3969838619232178e-09\n",
      "DEBUG: len(sub_dist) 9\n",
      "DEBUG: sub_dist [1000000000.0, 9.313225746154785e-10, 4.656612873077393e-10, 0.0025711171329021454, 6.05359673500061e-09, 2.8542708605527878e-05, 3.632158041000366e-08, 1.0710209608078003e-08, 1.3969838619232178e-09]\n",
      "DEBUG: np.argsort(sub_dist) [2 1 8 4 7 6 5 3 0]\n",
      "Responsible data combination:  1\n",
      "#################################################################################################### Observation 3 ####################################################################################################\n",
      "0-th model predicted action: [1]\n",
      "Original model's action [1]\n",
      "1-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  9.313225746154785e-10\n",
      "2-th model predicted action: [15]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  4.656612873077393e-10\n",
      "3-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  0.0025711171329021454\n",
      "4-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  6.05359673500061e-09\n",
      "5-th model predicted action: [14]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  2.8542708605527878e-05\n",
      "6-th model predicted action: [17]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  3.632158041000366e-08\n",
      "7-th model predicted action: [11]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.0710209608078003e-08\n",
      "8-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.3969838619232178e-09\n",
      "DEBUG: len(sub_dist) 9\n",
      "DEBUG: sub_dist [1000000000.0, 9.313225746154785e-10, 4.656612873077393e-10, 0.0025711171329021454, 6.05359673500061e-09, 2.8542708605527878e-05, 3.632158041000366e-08, 1.0710209608078003e-08, 1.3969838619232178e-09]\n",
      "DEBUG: np.argsort(sub_dist) [2 1 8 4 7 6 5 3 0]\n",
      "Responsible data combination:  1\n",
      "#################################################################################################### Observation 4 ####################################################################################################\n",
      "0-th model predicted action: [1]\n",
      "Original model's action [1]\n",
      "1-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  9.313225746154785e-10\n",
      "2-th model predicted action: [15]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  4.656612873077393e-10\n",
      "3-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  0.0025711171329021454\n",
      "4-th model predicted action: [6]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  6.05359673500061e-09\n",
      "5-th model predicted action: [14]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  2.8542708605527878e-05\n",
      "6-th model predicted action: [17]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  3.632158041000366e-08\n",
      "7-th model predicted action: [11]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.0710209608078003e-08\n",
      "8-th model predicted action: [16]\n",
      "Original model's action [1]\n",
      "Wasserstein distance:  1.3969838619232178e-09\n",
      "DEBUG: len(sub_dist) 9\n",
      "DEBUG: sub_dist [1000000000.0, 9.313225746154785e-10, 4.656612873077393e-10, 0.0025711171329021454, 6.05359673500061e-09, 2.8542708605527878e-05, 3.632158041000366e-08, 1.0710209608078003e-08, 1.3969838619232178e-09]\n",
      "DEBUG: np.argsort(sub_dist) [2 1 8 4 7 6 5 3 0]\n",
      "Responsible data combination:  1\n"
     ]
    }
   ],
   "source": [
    "attributions_sq = trajectory_attributions(test_observations, models_sq, trajectory_embedding_seaquest, clusters_seaquest)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'models': [d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310c10>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=2500, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c429af0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310ca0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c430ac0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c39f8e0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fba6b80>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fb640a0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31032aee0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31031e880>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None)],\n",
       "  'orig_act': array([1]),\n",
       "  'new_act': array([16]),\n",
       "  'attributed_trajs': [31,\n",
       "   151,\n",
       "   192,\n",
       "   202,\n",
       "   235,\n",
       "   241,\n",
       "   255,\n",
       "   257,\n",
       "   262,\n",
       "   263,\n",
       "   285,\n",
       "   316,\n",
       "   326,\n",
       "   327,\n",
       "   398,\n",
       "   461,\n",
       "   516,\n",
       "   551,\n",
       "   558,\n",
       "   559,\n",
       "   634,\n",
       "   671,\n",
       "   672,\n",
       "   675,\n",
       "   699,\n",
       "   700,\n",
       "   717,\n",
       "   751,\n",
       "   763,\n",
       "   764,\n",
       "   783,\n",
       "   795,\n",
       "   797,\n",
       "   800,\n",
       "   816,\n",
       "   859,\n",
       "   893,\n",
       "   894,\n",
       "   904,\n",
       "   934,\n",
       "   980,\n",
       "   981,\n",
       "   1034,\n",
       "   1056,\n",
       "   1063,\n",
       "   1106,\n",
       "   1154,\n",
       "   1155,\n",
       "   1156,\n",
       "   1175,\n",
       "   1204,\n",
       "   1207,\n",
       "   1220,\n",
       "   1243,\n",
       "   1288,\n",
       "   1326,\n",
       "   1333,\n",
       "   1376,\n",
       "   1506,\n",
       "   1566,\n",
       "   1567,\n",
       "   1568,\n",
       "   1582,\n",
       "   1583,\n",
       "   1589,\n",
       "   1640,\n",
       "   1675],\n",
       "  'responsible_cluster': 1},\n",
       " {'models': [d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310c10>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=2500, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c429af0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310ca0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c430ac0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c39f8e0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fba6b80>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fb640a0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31032aee0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31031e880>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None)],\n",
       "  'orig_act': array([1]),\n",
       "  'new_act': array([16]),\n",
       "  'attributed_trajs': [31,\n",
       "   151,\n",
       "   192,\n",
       "   202,\n",
       "   235,\n",
       "   241,\n",
       "   255,\n",
       "   257,\n",
       "   262,\n",
       "   263,\n",
       "   285,\n",
       "   316,\n",
       "   326,\n",
       "   327,\n",
       "   398,\n",
       "   461,\n",
       "   516,\n",
       "   551,\n",
       "   558,\n",
       "   559,\n",
       "   634,\n",
       "   671,\n",
       "   672,\n",
       "   675,\n",
       "   699,\n",
       "   700,\n",
       "   717,\n",
       "   751,\n",
       "   763,\n",
       "   764,\n",
       "   783,\n",
       "   795,\n",
       "   797,\n",
       "   800,\n",
       "   816,\n",
       "   859,\n",
       "   893,\n",
       "   894,\n",
       "   904,\n",
       "   934,\n",
       "   980,\n",
       "   981,\n",
       "   1034,\n",
       "   1056,\n",
       "   1063,\n",
       "   1106,\n",
       "   1154,\n",
       "   1155,\n",
       "   1156,\n",
       "   1175,\n",
       "   1204,\n",
       "   1207,\n",
       "   1220,\n",
       "   1243,\n",
       "   1288,\n",
       "   1326,\n",
       "   1333,\n",
       "   1376,\n",
       "   1506,\n",
       "   1566,\n",
       "   1567,\n",
       "   1568,\n",
       "   1582,\n",
       "   1583,\n",
       "   1589,\n",
       "   1640,\n",
       "   1675],\n",
       "  'responsible_cluster': 1},\n",
       " {'models': [d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310c10>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=2500, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c429af0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310ca0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c430ac0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c39f8e0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fba6b80>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fb640a0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31032aee0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31031e880>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None)],\n",
       "  'orig_act': array([1]),\n",
       "  'new_act': array([16]),\n",
       "  'attributed_trajs': [31,\n",
       "   151,\n",
       "   192,\n",
       "   202,\n",
       "   235,\n",
       "   241,\n",
       "   255,\n",
       "   257,\n",
       "   262,\n",
       "   263,\n",
       "   285,\n",
       "   316,\n",
       "   326,\n",
       "   327,\n",
       "   398,\n",
       "   461,\n",
       "   516,\n",
       "   551,\n",
       "   558,\n",
       "   559,\n",
       "   634,\n",
       "   671,\n",
       "   672,\n",
       "   675,\n",
       "   699,\n",
       "   700,\n",
       "   717,\n",
       "   751,\n",
       "   763,\n",
       "   764,\n",
       "   783,\n",
       "   795,\n",
       "   797,\n",
       "   800,\n",
       "   816,\n",
       "   859,\n",
       "   893,\n",
       "   894,\n",
       "   904,\n",
       "   934,\n",
       "   980,\n",
       "   981,\n",
       "   1034,\n",
       "   1056,\n",
       "   1063,\n",
       "   1106,\n",
       "   1154,\n",
       "   1155,\n",
       "   1156,\n",
       "   1175,\n",
       "   1204,\n",
       "   1207,\n",
       "   1220,\n",
       "   1243,\n",
       "   1288,\n",
       "   1326,\n",
       "   1333,\n",
       "   1376,\n",
       "   1506,\n",
       "   1566,\n",
       "   1567,\n",
       "   1568,\n",
       "   1582,\n",
       "   1583,\n",
       "   1589,\n",
       "   1640,\n",
       "   1675],\n",
       "  'responsible_cluster': 1},\n",
       " {'models': [d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310c10>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=2500, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c429af0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x2ad310ca0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c430ac0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30c39f8e0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fba6b80>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x30fb640a0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31032aee0>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None),\n",
       "   d3rlpy.algos.sac.DiscreteSAC(action_scaler=None, actor_encoder_factory=encoder.CustomCNNFactory(feature_size=128), actor_learning_rate=0.0003, actor_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), batch_size=256, critic_encoder_factory=encoder.CustomCNNFactory(feature_size=128), critic_learning_rate=0.0003, critic_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), gamma=0.99, generated_maxlen=100000, impl=<d3rlpy.algos.torch.sac_impl.DiscreteSACImpl object at 0x31031e880>, initial_temperature=1.0, n_critics=2, n_frames=1, n_steps=1, q_func_factory=d3rlpy.models.q_functions.MeanQFunctionFactory(share_encoder=False), real_ratio=1.0, reward_scaler=None, scaler=d3rlpy.preprocessing.scalers.PixelScaler(), target_update_interval=8000, temp_learning_rate=0.0003, temp_optim_factory=d3rlpy.models.optimizers.AdamFactory(optim_cls='Adam', betas=(0.9, 0.999), eps=0.0001, weight_decay=0, amsgrad=False), use_gpu=None)],\n",
       "  'orig_act': array([1]),\n",
       "  'new_act': array([16]),\n",
       "  'attributed_trajs': [31,\n",
       "   151,\n",
       "   192,\n",
       "   202,\n",
       "   235,\n",
       "   241,\n",
       "   255,\n",
       "   257,\n",
       "   262,\n",
       "   263,\n",
       "   285,\n",
       "   316,\n",
       "   326,\n",
       "   327,\n",
       "   398,\n",
       "   461,\n",
       "   516,\n",
       "   551,\n",
       "   558,\n",
       "   559,\n",
       "   634,\n",
       "   671,\n",
       "   672,\n",
       "   675,\n",
       "   699,\n",
       "   700,\n",
       "   717,\n",
       "   751,\n",
       "   763,\n",
       "   764,\n",
       "   783,\n",
       "   795,\n",
       "   797,\n",
       "   800,\n",
       "   816,\n",
       "   859,\n",
       "   893,\n",
       "   894,\n",
       "   904,\n",
       "   934,\n",
       "   980,\n",
       "   981,\n",
       "   1034,\n",
       "   1056,\n",
       "   1063,\n",
       "   1106,\n",
       "   1154,\n",
       "   1155,\n",
       "   1156,\n",
       "   1175,\n",
       "   1204,\n",
       "   1207,\n",
       "   1220,\n",
       "   1243,\n",
       "   1288,\n",
       "   1326,\n",
       "   1333,\n",
       "   1376,\n",
       "   1506,\n",
       "   1566,\n",
       "   1567,\n",
       "   1568,\n",
       "   1582,\n",
       "   1583,\n",
       "   1589,\n",
       "   1640,\n",
       "   1675],\n",
       "  'responsible_cluster': 1}]"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "attributions_sq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data combination 0 has 4 actions\n",
      "Data combination 1 has 4 actions\n",
      "Data combination 2 has 4 actions\n",
      "Data combination 3 has 4 actions\n",
      "Data combination 4 has 4 actions\n",
      "Data combination 5 has 4 actions\n",
      "Data combination 6 has 4 actions\n",
      "Data combination 7 has 4 actions\n",
      "Data combination 8 has 4 actions\n"
     ]
    }
   ],
   "source": [
    "for data_combination_id in result_data_combinations_sq:\n",
    "    print(f\"Data combination {data_combination_id} has {len(result_data_combinations_sq[data_combination_id][0])} actions\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "trajectories = attributions_sq[0]['attributed_trajs']\n",
    "observation = test_observations[0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.         0.00000036 0.00000018 1.         0.00000235 0.01110129\n",
      " 0.00001413 0.00000417 0.00000054]\n"
     ]
    }
   ],
   "source": [
    "data_embedding_original = models_sq[0][1]\n",
    "data_distances = np.zeros(len(result_data_combinations_sq))\n",
    "for data_combination_id, (_, action_values_new, data_embedding_new) in result_data_combinations_sq.items(): \n",
    "    data_distances[data_combination_id] = wasserstein_distance(data_embedding_original, data_embedding_new)\n",
    "\n",
    "with np.printoptions(precision=8, suppress=True):\n",
    "    print((data_distances - data_distances.min()) / (data_distances.max() - data_distances.min()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[31,\n",
       " 151,\n",
       " 192,\n",
       " 202,\n",
       " 235,\n",
       " 241,\n",
       " 255,\n",
       " 257,\n",
       " 262,\n",
       " 263,\n",
       " 285,\n",
       " 316,\n",
       " 326,\n",
       " 327,\n",
       " 398,\n",
       " 461,\n",
       " 516,\n",
       " 551,\n",
       " 558,\n",
       " 559,\n",
       " 634,\n",
       " 671,\n",
       " 672,\n",
       " 675,\n",
       " 699,\n",
       " 700,\n",
       " 717,\n",
       " 751,\n",
       " 763,\n",
       " 764,\n",
       " 783,\n",
       " 795,\n",
       " 797,\n",
       " 800,\n",
       " 816,\n",
       " 859,\n",
       " 893,\n",
       " 894,\n",
       " 904,\n",
       " 934,\n",
       " 980,\n",
       " 981,\n",
       " 1034,\n",
       " 1056,\n",
       " 1063,\n",
       " 1106,\n",
       " 1154,\n",
       " 1155,\n",
       " 1156,\n",
       " 1175,\n",
       " 1204,\n",
       " 1207,\n",
       " 1220,\n",
       " 1243,\n",
       " 1288,\n",
       " 1326,\n",
       " 1333,\n",
       " 1376,\n",
       " 1506,\n",
       " 1566,\n",
       " 1567,\n",
       " 1568,\n",
       " 1582,\n",
       " 1583,\n",
       " 1589,\n",
       " 1640,\n",
       " 1675]"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trajectories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trajectory Shape: torch.Size([30, 4, 84, 84])\n",
      "Trajectory Shape: torch.Size([30, 4, 84, 84])\n",
      "Trajectory Shape: torch.Size([30, 4, 84, 84])\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAOKCAYAAAB0zBkEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOz9eZild13n/7/u/T5Lbb131s4iJiYiLugQlgCGYXVjdFwIGRxngBFGZuTSiy9EwqiXwyKooBMWuVDByxm91AtnEFQWcQBlIqPDjBAuhSSkk+5OV3fXcpb73Ovvj/59Pjmnqk53dXVV1zl3Px/XVVcndbZPnarXfZ/7/dmcqqoqAQAAAAAAAACAddzdbgAAAAAAAAAAAJOKIjoAAAAAAAAAAGNQRAcAAAAAAAAAYAyK6AAAAAAAAAAAjEERHQAAAAAAAACAMSiiAwAAAAAAAAAwBkV0AAAAAAAAAADGoIgOAAAAAAAAAMAYFNEBAAAAAAAAABiDIjoAAAAAAAAAAGNQRJ9wv/VbvyXHcRTHsR555JF1tz/zmc/UrbfeOvK9LMv0zne+U09+8pM1MzOjdrutJz/5yXrnO9+pLMs2fJ0LfcyRI0fkOI79OnDggJ7+9Kfrj//4j7fnBwd20Zve9CY5jqPFxcUNb7/11lv1zGc+U5L04IMPjmTB8zxdc801+oEf+AH9/d///cjjHMfRq1/96nO+9jOf+cyR5xv+uummm+z9zLFho6/Xve5153ye4a83velNktZnevgrSZKR1/zbv/3bde+V+QqCQEeOHNFP/dRPaWlpad3Pd67Xed7znnee3wxwYdbmJI5jXXHFFXruc5+rd77znVpdXd3wcZ/97Gf1Az/wAzp48KCiKNKRI0f0ile8Ql//+tdH7vfWt75VjuPo7/7u70a+X1WVFhYW5DiOHnjggZHbkiRRFEX6sR/7Mfs90763v/3tY3+Gi83di170onXfHwwGete73qWnPe1pWlhYUBiGuuKKK/S93/u9+r3f+z0VRWHva451v/zLv7zhezZ83PzLv/zLTR1/HMfZ8LmAzSDfZ5Fv1A3ZPotsYxrUPa/j6gGSzpuZ//pf/6u977mugT/2sY9dUPbOVwcYfs21x5C195+dndXtt9+uj3zkI2Pfl3Fff/M3fzP2vakzf7cbgM0ZDAZ685vfrHe9613nvF+329ULX/hCffrTn9aLXvQivexlL5PruvrYxz6m17zmNfqjP/ojfeQjH1Gr1bqox0jSk570JL32ta+VJD366KN6z3veoxe/+MW699579cpXvnL73wRggv3oj/6oXvCCF6goCn35y1/Wvffeq49+9KP6m7/5Gz3pSU+6oOe66qqr9J//839e9/25ubl13/v5n/95XXfddSPfu/XWW/Xd3/3d+jf/5t/Y791333165zvfqde//vW6+eab7fef+MQn2v8ezvSwMAzP2+Z7771X7XZb3W5Xn/jEJ/Sud71L//t//2995jOfWXffca9zxRVXnPd1gK0wOcmyTMePH9df/uVf6j/8h/+gd7zjHfqTP/mTkRy8613v0mte8xpdf/31+vf//t/r8OHD+vKXv6zf/M3f1H/7b/9Nf/qnf6rbbrtNkvS0pz1NkvSZz3xG3/qt32qf4x/+4R+0tLQk3/f12c9+diSj9913n9I0tY8d9ra3vU3/7t/9OzWbzU39XBeSu7VOnjyp5z//+frCF76g5z73ubr77ru1Z88eHT9+XB//+Mf1Yz/2Y/qnf/on/dzP/dym2jLs5ptv1gc/+MGR7/1//9//p3a7rTe84Q0X/HzAuZDv9cg36oBsr0e2ManqmtfN+Kmf+ik9+clPXvf9pzzlKSP/P+4a+Fu/9Vu3lL1xdYDzec5znqO77rpLVVXpoYce0r333qvv+Z7v0Uc/+lE997nP3dTrSNKNN9543teqpQoT7QMf+EAlqXrSk55URVFUPfLIIyO333777dUtt9xi///lL395Jal617vete65fv3Xf72SVL3yla8c+f5WHnPttddWL3zhC0e+d+zYsarValVPeMITLvjnBCbJPffcU0mqTp48ueHtt9xyS3X77bdXVVVVDzzwQCWpetvb3jZynz/5kz+pJFUvf/nL7fckVa961avO+dprMz2OOTbcd999571vVVXVH/zBH1SSqk996lMb3r5RpjfzmuPeqx/+4R+uJFWf//znL/h1gO1yrpx84hOfqBqNRnXttddWvV6vqqqq+sxnPlO5rls9/elPr7rd7sj9/+mf/qk6ePBgdfjw4er06dNVVVXVYDCo4jiu/uW//Jcj9333u99d7d27t3ruc59bveIVrxi57Zd+6ZcqSdX/+T//x37PnOclVW9/+9vP+zNsR+6e+9znVq7rVn/4h3+4/o2rquq+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xjp69KiWl5d144036sYbb5Tv++c8Hw4GA33lK19Zdz582tOeZtdjNGs0Grfddpv+1//6X8qyTJ/5zGf07d/+7euOH2vdc889On78uN1UaZyt5u6mm26SpHUj1a6++mrdcccduuOOO867Nisw6cg3+UY9kW2yjekx7Xmto6uuukp33HGHXvCCF+iee+7RO97xDv36r/+6/uiP/mi3mzYVKKJPobvvvnvDtdGf//zny/O8c07J+p3f+R35vq/nPe95W34MUHfXXnutJOkrX/nKutt6vZ4efvhhex+s1263dc899+jv//7v9fu///u73RxgLHPue+5zn6tWq6VnPetZ+qu/+is99NBDG97/93//9zUYDPSiF71o5PtPe9rTVFWVPv7xj+vv/u7v9NSnPtXedtttt6nf7+sjH/mIvva1r51zeqlx++2365nPfKbe8pa3bHq9xgvJnWn/7/7u727quYFpRL7JN+qJbJNtTI865bWuXvGKV+iGG27Q3XffvW4zVKxHEX0K3XDDDbrzzjv1nve8R8ePH7ffv/rqq/XjP/7j+vjHP77hbsPvfve79clPflI/8RM/YddW3spjgLr77u/+boVhqHvvvXfdqJD3vve9yvNcz3/+83epddPhJS95ia666ir2SMDE+uQnP6lf+IVf0HXXXaeXvOQlkmQ/PL7sZS9b94H6gQce0M/+7M/q8OHDesUrXjFym/mw/o53vENZlo2Mjjly5IgOHz5sNw7azAd76ex6jcePH9d73/veTf9Mm83dU5/6VD3nOc/Re9/7Xn34wx/e8D58iMY0I9/kG/VEtsk2pkcd81pHvu/rta99rb785S+PPbbgcayJPqXe8IY36IMf/KC+8pWv6JZbbrHf/5Vf+RXdf//9+smf/El97GMfs6PH/+zP/kwf/vCHdfvtt+vtb3/7yHNt5TFAnR04cEBvfOMbdffdd+sZz3iGvvd7v1fNZlOf+9zn9Hu/93v65//8n+t7vud7tvTcf/u3f7vhpprPfOYz7Ql/eXlZH/rQhzZ8/J133rml173UgiDQa17zGv3Mz/zMyHFFkh555JENf752u63v//7vv4StxOXiox/9qO6//37lea4TJ07ok5/8pP7iL/5C1157rf7kT/7ETvl8xjOeoV/+5V/WT//0T+uJT3yiXvayl+nw4cO6//779b73vU9lWepP//RP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r9vt6oUvfKE+/elP60UvepFe9rKXyXVdfexjH9NrXvMa/dEf/ZE+8pGPqNVqXdRjJOlJT3qSXvva10qSHn30Ub3nPe/Ri1/8Yt1777165Stfuf1vAlBDZBuoL/IN1BPZxraoMJU+8IEPVJKq++67b+x9rr322uqFL3zhyPckVa961atGvvelL32pklQ9//nPv+DXALC9yDYw/UzGnvSkJ1VRFFWPPPLIyO233357dcstt9j/f/nLX15Jqt71rnete65f//VfryRVr3zlK0e+v5XHbHTsOHbsWNVqtaonPOEJF/xzApcbsg3UF/kG6olsYzuxnAt08803a9++ffrqV7+6200BsI3INrC7Xv/616soCr35zW8ee5+jR4/q/e9/v5797Gfr1a9+9brbX/WqV+lZz3qWfvM3f1NHjx7d8mPGOXTokG6++WY98MADF/jTAZcvsg3UF/kG6olsYztQRJ9yy8vLWlxcHPnaynOcOXNGCwsLm36NU6dOXWzTAZwD2Qam33XXXae77rpL73vf+/Too49ueJ+PfvSjKopCd91119jnueuuu5TnuT72sY9t+THjZFmmhx9+WHv37t3ETwRAIttAnZFvoJ7INrYDRfQpd8cdd2j//v0jX+eTJIkWFxd18uRJfeELX9CP/MiPqCgK/eAP/uCmX+PKK6/c7h8FwBCyDdTDG97wBuV5rre85S0b3v6lL31JkvQt3/ItY5/D3PblL395y48xsiyznWZf/OIXddddd+nEiRP6oR/6oU3+RAAksg3UGfkG6ols42KxseiU+43f+A094QlPuKDHvP/979f73/9++/9BEOhnf/Zn9dM//dObfg3P8y68sQA2jWwD9XD99dfrpS99qd773vfqda97nQ4fPjxy++rqqiRpZmZm7HOY21ZWVrb8GOPP//zPRzrlPM/TS1/60rEXEwA2RraB+iLfQD2RbVwsiuhT7ju/8zv1Hd/xHRf0mO/7vu/Tq1/9aqVpqvvuu0+/9Eu/pF6vJ9fdeGLCVl4DwMUh20B93H333frgBz+oN7/5zfq1X/u1kdvMh2rzAXwjaz+cb+Uxxnd913fpF3/xF+U4jprNpm6++WbNz89f2A8EQBLZBuqMfAP1RLZxMSiiX4auuuoq3XHHHZKkF7zgBdq3b59e/epX61nPepZe/OIX73LrAGwV2QYm0/XXX68777zT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",
      "text/plain": [
       "<Figure size 1500x1000 with 18 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(15, 10))\n",
    "\n",
    "for i, traj in enumerate([0,\n",
    " 3,\n",
    " 4,]):\n",
    "    print(\"Trajectory Shape:\", final_obs_sq[traj].shape)\n",
    "    # We will plot only the first frame from each stack to avoid consecutive identical frames\n",
    "    # Assuming every 4th frame is the start of a new stack\n",
    "    for j in range(0, 30, 4):  # Skip every 4 frames to get to the start of the next stack\n",
    "        # Calculate the subplot index, but normalize j to reflect that we're skipping frames\n",
    "        subplot_index = i * (30 // 5) + (j // 5) + 1\n",
    "        plt.subplot(3, (30 // 5), subplot_index)  \n",
    "        \n",
    "        # Plot the first frame from the current stack\n",
    "        plt.imshow(final_obs_sq[traj][j][0], cmap='gray')\n",
    "\n",
    "        # Get tensor value as an integer and use it as a key to the action dictionary\n",
    "        corr_action = int(final_act_sq[traj][j].item())\n",
    "        # Print the action name on top of each sub-image\n",
    "        plt.title(action_dict[corr_action])\n",
    "        plt.axis('off')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mujoco_env",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
