{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collecting clip@ git+https://github.com/openai/CLIP.git@a1d071733d7111c9c014f024669f959182114e33\n",
      "  Using cached clip-1.0-py3-none-any.whl\n",
      "Collecting d4rl-atari@ git+https://github.com/takuseno/d4rl-atari@039d1a935ca932b916c544feaa63b9b6ae73e293\n",
      "  Using cached d4rl_atari-0.1-py3-none-any.whl\n",
      "Collecting eorl@ git+https://github.com/indrasweb/expert-offline-rl.git@d0e8b9dbd3bd409a8d591e63cd30b825323d3eda\n",
      "  Cloning https://github.com/indrasweb/expert-offline-rl.git (to revision d0e8b9dbd3bd409a8d591e63cd30b825323d3eda) to c:\\users\\jortv\\appdata\\local\\temp\\pip-install-mqby18_l\\eorl_1329074ff32b4d73ac87e4089394c59a\n",
      "  Resolved https://github.com/indrasweb/expert-offline-rl.git to commit d0e8b9dbd3bd409a8d591e63cd30b825323d3eda\n",
      "  Preparing metadata (setup.py): started\n",
      "  Preparing metadata (setup.py): finished with status 'done'\n",
      "Requirement already satisfied: absl-py==2.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 1)) (2.0.0)\n",
      "Collecting aiohttp==3.9.1\n",
      "  Using cached aiohttp-3.9.1-cp39-cp39-win_amd64.whl (365 kB)\n",
      "Collecting aiosignal==1.3.1\n",
      "  Using cached aiosignal-1.3.1-py3-none-any.whl (7.6 kB)\n",
      "Requirement already satisfied: ale-py==0.8.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 4)) (0.8.1)\n",
      "Requirement already satisfied: argcomplete==3.2.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 5)) (3.2.3)\n",
      "Requirement already satisfied: async-timeout==4.0.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 6)) (4.0.3)\n",
      "Requirement already satisfied: atari-py==0.2.9 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 7)) (0.2.9)\n",
      "Requirement already satisfied: attrs==23.1.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 8)) (23.1.0)\n",
      "Requirement already satisfied: AutoROM==0.4.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 9)) (0.4.2)\n",
      "Requirement already satisfied: AutoROM.accept-rom-license==0.6.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 10)) (0.6.1)\n",
      "Requirement already satisfied: bidict==0.21.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 11)) (0.21.2)\n",
      "Requirement already satisfied: boto==2.49.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 12)) (2.49.0)\n",
      "Requirement already satisfied: cachetools==5.3.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 13)) (5.3.2)\n",
      "Requirement already satisfied: certifi==2022.12.7 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 14)) (2022.12.7)\n",
      "Requirement already satisfied: cffi==1.15.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 15)) (1.15.1)\n",
      "Requirement already satisfied: chardet==4.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 16)) (4.0.0)\n",
      "Requirement already satisfied: charset-normalizer==2.1.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 17)) (2.1.1)\n",
      "Requirement already satisfied: click==8.1.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 18)) (8.1.3)\n",
      "Requirement already satisfied: cloudpickle==3.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 20)) (3.0.0)\n",
      "Requirement already satisfied: colorama==0.4.6 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 21)) (0.4.6)\n",
      "Requirement already satisfied: colour==0.1.5 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 22)) (0.1.5)\n",
      "Requirement already satisfied: contourpy==1.1.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 23)) (1.1.1)\n",
      "Requirement already satisfied: crcmod==1.7 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 24)) (1.7)\n",
      "Collecting cryptography==38.0.4\n",
      "  Using cached cryptography-38.0.4-cp36-abi3-win_amd64.whl (2.4 MB)\n",
      "Requirement already satisfied: cycler==0.12.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 26)) (0.12.1)\n",
      "Requirement already satisfied: d3rlpy==1.1.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 27)) (1.1.1)\n",
      "Collecting dataclasses-json==0.6.4\n",
      "  Using cached dataclasses_json-0.6.4-py3-none-any.whl (28 kB)\n",
      "Requirement already satisfied: distlib==0.3.6 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 30)) (0.3.6)\n",
      "Requirement already satisfied: docutils==0.16 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 31)) (0.16)\n",
      "Requirement already satisfied: Farama-Notifications==0.0.4 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 33)) (0.0.4)\n",
      "Requirement already satisfied: fasteners==0.19 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 34)) (0.19)\n",
      "Requirement already satisfied: filelock==3.9.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 35)) (3.9.0)\n",
      "Collecting Flask==2.1.3\n",
      "  Using cached Flask-2.1.3-py3-none-any.whl (95 kB)\n",
      "Collecting Flask-Cors==3.0.10\n",
      "  Using cached Flask_Cors-3.0.10-py2.py3-none-any.whl (14 kB)\n",
      "Collecting Flask-SocketIO==5.3.2\n",
      "  Using cached Flask_SocketIO-5.3.2-py3-none-any.whl (17 kB)\n",
      "Requirement already satisfied: fonttools==4.43.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 39)) (4.43.1)\n",
      "Requirement already satisfied: frozenlist==1.4.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 40)) (1.4.0)\n",
      "Requirement already satisfied: fsspec==2023.12.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 41)) (2023.12.0)\n",
      "Requirement already satisfied: ftfy==6.1.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 42)) (6.1.3)\n",
      "Requirement already satisfied: gcs-oauth2-boto-plugin==3.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 43)) (3.0)\n",
      "Requirement already satisfied: geniusweb==1.2.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 44)) (1.2.1)\n",
      "Collecting gevent==21.1.2\n",
      "  Using cached gevent-21.1.2-cp39-cp39-win_amd64.whl (1.6 MB)\n",
      "Requirement already satisfied: google-apitools==0.5.32 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 46)) (0.5.32)\n",
      "Collecting google-auth==2.24.0\n",
      "  Using cached google_auth-2.24.0-py2.py3-none-any.whl (183 kB)\n",
      "Collecting google-auth-oauthlib==1.1.0\n",
      "  Using cached google_auth_oauthlib-1.1.0-py2.py3-none-any.whl (19 kB)\n",
      "Requirement already satisfied: google-reauth==0.1.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 49)) (0.1.1)\n",
      "Requirement already satisfied: greenlet==1.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 50)) (1.0.0)\n",
      "Requirement already satisfied: grpcio==1.59.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 51)) (1.59.3)\n",
      "Requirement already satisfied: gsutil==5.27 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 52)) (5.27)\n",
      "Requirement already satisfied: gym==0.26.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 53)) (0.26.2)\n",
      "Requirement already satisfied: gym-notices==0.0.8 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 54)) (0.0.8)\n",
      "Collecting gymnasium==0.29.1\n",
      "  Using cached gymnasium-0.29.1-py3-none-any.whl (953 kB)\n",
      "Requirement already satisfied: h5py==3.10.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 56)) (3.10.0)\n",
      "Requirement already satisfied: httplib2==0.20.4 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 57)) (0.20.4)\n",
      "Requirement already satisfied: idna==3.4 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 58)) (3.4)\n",
      "Requirement already satisfied: importlib-metadata==6.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 59)) (6.0.0)\n",
      "Requirement already satisfied: importlib-resources==6.1.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 60)) (6.1.0)\n",
      "Requirement already satisfied: itsdangerous==2.1.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 61)) (2.1.2)\n",
      "Collecting Jinja2==3.1.2\n",
      "  Using cached Jinja2-3.1.2-py3-none-any.whl (133 kB)\n",
      "Requirement already satisfied: joblib==1.2.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 63)) (1.2.0)\n",
      "Requirement already satisfied: jsonpickle==1.5.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 64)) (1.5.1)\n",
      "Requirement already satisfied: kaleido==0.2.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 65)) (0.2.1)\n",
      "Requirement already satisfied: kiwisolver==1.4.5 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 66)) (1.4.5)\n",
      "Requirement already satisfied: lightgbm==3.3.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 67)) (3.3.2)\n",
      "Requirement already satisfied: lightning-utilities==0.10.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 68)) (0.10.0)\n",
      "Requirement already satisfied: logging==1.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 69)) (1.0.0)\n",
      "Collecting Markdown==3.5.1\n",
      "  Using cached Markdown-3.5.1-py3-none-any.whl (102 kB)\n",
      "Requirement already satisfied: MarkupSafe==2.1.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 71)) (2.1.3)\n",
      "Requirement already satisfied: marshmallow==3.21.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 72)) (3.21.1)\n",
      "Collecting matplotlib==3.8.0\n",
      "  Using cached matplotlib-3.8.0-cp39-cp39-win_amd64.whl (7.6 MB)\n",
      "Collecting matrx==2.2.0\n",
      "  Using cached matrx-2.2.0-py3-none-any.whl (7.4 MB)\n",
      "Requirement already satisfied: monotonic==1.6 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 75)) (1.6)\n",
      "Requirement already satisfied: mpmath==1.3.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 76)) (1.3.0)\n",
      "Requirement already satisfied: multidict==6.0.4 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 77)) (6.0.4)\n",
      "Requirement already satisfied: mypy-extensions==1.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 78)) (1.0.0)\n",
      "Requirement already satisfied: networkx==3.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 79)) (3.0)\n",
      "Collecting nltk==3.8.1\n",
      "  Using cached nltk-3.8.1-py3-none-any.whl (1.5 MB)\n",
      "Requirement already satisfied: numpy==1.23.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 81)) (1.23.1)\n",
      "Requirement already satisfied: oauth2client==4.1.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 82)) (4.1.3)\n",
      "Requirement already satisfied: oauthlib==3.2.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 83)) (3.2.2)\n",
      "Requirement already satisfied: opencv-contrib-python==4.8.1.78 in c:\\users\\jortv\\appdata\\roaming\\python\\python39\\site-packages (from -r requirements.txt (line 84)) (4.8.1.78)\n",
      "Requirement already satisfied: opencv-python==4.8.1.78 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 85)) (4.8.1.78)\n",
      "Requirement already satisfied: openssl-python==0.1.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 86)) (0.1.1)\n",
      "Requirement already satisfied: packaging==23.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 87)) (23.2)\n",
      "Requirement already satisfied: pandas==1.4.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 88)) (1.4.1)\n",
      "Requirement already satisfied: pbr==3.1.1 in c:\\users\\jortv\\appdata\\roaming\\python\\python39\\site-packages (from -r requirements.txt (line 89)) (3.1.1)\n",
      "Requirement already satisfied: Pillow==9.3.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 90)) (9.3.0)\n",
      "Requirement already satisfied: platformdirs==3.2.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 91)) (3.2.0)\n",
      "Requirement already satisfied: plotly==5.6.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 92)) (5.6.0)\n",
      "Requirement already satisfied: protobuf==4.23.4 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 93)) (4.23.4)\n",
      "Requirement already satisfied: pyasn1==0.5.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 94)) (0.5.1)\n",
      "Requirement already satisfied: pyasn1-modules==0.3.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 95)) (0.3.0)\n",
      "Requirement already satisfied: pyclustering==0.10.1.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 96)) (0.10.1.2)\n",
      "Requirement already satisfied: pycparser==2.21 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 97)) (2.21)\n",
      "Requirement already satisfied: Pygments==2.14.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 98)) (2.14.0)\n",
      "Collecting pyOpenSSL==23.1.0\n",
      "  Using cached pyOpenSSL-23.1.0-py3-none-any.whl (57 kB)\n",
      "Requirement already satisfied: pyparsing==3.1.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 100)) (3.1.1)\n",
      "Requirement already satisfied: PyQt5==5.15.6 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 101)) (5.15.6)\n",
      "Requirement already satisfied: PyQt5-Qt5==5.15.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 102)) (5.15.2)\n",
      "Requirement already satisfied: PyQt5-sip==12.11.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 103)) (12.11.1)\n",
      "Requirement already satisfied: pyson==1.1.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 104)) (1.1.3)\n",
      "Requirement already satisfied: python-dateutil==2.8.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 105)) (2.8.2)\n",
      "Requirement already satisfied: python-engineio==4.3.4 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 106)) (4.3.4)\n",
      "Collecting python-socketio==5.7.2\n",
      "  Using cached python_socketio-5.7.2-py3-none-any.whl (56 kB)\n",
      "Requirement already satisfied: pytorch-lightning==2.1.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 108)) (2.1.2)\n",
      "Requirement already satisfied: pytz==2022.7.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 109)) (2022.7.1)\n",
      "Requirement already satisfied: pyu2f==0.1.5 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 110)) (0.1.5)\n",
      "Requirement already satisfied: PyYAML==6.0.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 111)) (6.0.1)\n",
      "Requirement already satisfied: regex==2023.10.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 112)) (2023.10.3)\n",
      "Collecting requests==2.28.1\n",
      "  Using cached requests-2.28.1-py3-none-any.whl (62 kB)\n",
      "Collecting requests-oauthlib==1.3.1\n",
      "  Using cached requests_oauthlib-1.3.1-py2.py3-none-any.whl (23 kB)\n",
      "Requirement already satisfied: retry-decorator==1.1.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 115)) (1.1.1)\n",
      "Requirement already satisfied: rsa==4.7.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 116)) (4.7.2)\n",
      "Requirement already satisfied: scikit-learn==1.3.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 117)) (1.3.1)\n",
      "Requirement already satisfied: scipy==1.11.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 118)) (1.11.3)\n",
      "Collecting seaborn==0.13.2\n",
      "  Using cached seaborn-0.13.2-py3-none-any.whl (294 kB)\n",
      "Requirement already satisfied: six==1.16.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 120)) (1.16.0)\n",
      "Requirement already satisfied: structlog==24.1.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 121)) (24.1.0)\n",
      "Requirement already satisfied: sympy==1.12 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 122)) (1.12)\n",
      "Requirement already satisfied: tenacity==8.2.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 123)) (8.2.2)\n",
      "Collecting tensorboard==2.15.1\n",
      "  Using cached tensorboard-2.15.1-py3-none-any.whl (5.5 MB)\n",
      "Requirement already satisfied: tensorboard-data-server==0.7.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 125)) (0.7.2)\n",
      "Requirement already satisfied: tensorboardX==2.6.2.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 126)) (2.6.2.2)\n",
      "Requirement already satisfied: threadpoolctl==3.1.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 127)) (3.1.0)\n",
      "Collecting torch==2.1.1\n",
      "  Using cached torch-2.1.1-cp39-cp39-win_amd64.whl (192.2 MB)\n",
      "Collecting torchaudio==2.1.1\n",
      "  Using cached torchaudio-2.1.1-cp39-cp39-win_amd64.whl (2.3 MB)\n",
      "Requirement already satisfied: torchmetrics==1.2.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 130)) (1.2.1)\n",
      "Collecting torchvision==0.16.1\n",
      "  Using cached torchvision-0.16.1-cp39-cp39-win_amd64.whl (1.1 MB)\n",
      "Requirement already satisfied: tqdm==4.66.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 132)) (4.66.1)\n",
      "Requirement already satisfied: typing-inspect==0.9.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 133)) (0.9.0)\n",
      "Requirement already satisfied: typing_extensions==4.4.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 134)) (4.4.0)\n",
      "Requirement already satisfied: uri==2.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 135)) (2.0.0)\n",
      "Requirement already satisfied: urllib3==1.26.13 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 136)) (1.26.13)\n",
      "Requirement already satisfied: utilities==1.0.5 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 137)) (1.0.5)\n",
      "Requirement already satisfied: virtualenv==20.21.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 138)) (20.21.0)\n",
      "Requirement already satisfied: wcwidth==0.2.12 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 139)) (0.2.12)\n",
      "Requirement already satisfied: websocket-client==1.0.1 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 140)) (1.0.1)\n",
      "Requirement already satisfied: Werkzeug==2.0.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 141)) (2.0.0)\n",
      "Requirement already satisfied: yarl==1.9.3 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 142)) (1.9.3)\n",
      "Requirement already satisfied: zipp==3.14.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 143)) (3.14.0)\n",
      "Requirement already satisfied: zope.event==4.6 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 144)) (4.6)\n",
      "Requirement already satisfied: zope.interface==5.5.2 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from -r requirements.txt (line 145)) (5.5.2)\n",
      "Collecting utilities@ https://tracinsy.ewi.tudelft.nl/pubtrac/Utilities/export/314/utilitiespy/dist/utilities-1.0.5.tar.gz\n",
      "  Using cached utilities-1.0.5-py3-none-any.whl\n",
      "Collecting pyson@ https://tracinsy.ewi.tudelft.nl/pubtrac/Utilities/export/312/pyson/dist/pyson-1.1.3.tar.gz\n",
      "  Using cached pyson-1.1.3-py3-none-any.whl\n",
      "Collecting logging@ https://tracinsy.ewi.tudelft.nl/pubtrac/Utilities/export/226/loggingpy/dist/logging-1.0.0.tar.gz\n",
      "  Using cached logging-1.0.0-py3-none-any.whl\n",
      "Requirement already satisfied: setuptools in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from gevent==21.1.2->-r requirements.txt (line 45)) (65.6.3)\n",
      "Requirement already satisfied: google-auth[aiohttp]>=2.5.0 in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from gsutil==5.27->-r requirements.txt (line 52)) (2.29.0)\n",
      "Requirement already satisfied: wheel in c:\\users\\jortv\\anaconda3\\lib\\site-packages (from lightgbm==3.3.2->-r requirements.txt (line 67)) (0.38.4)\n",
      "Collecting uri@ https://tracinsy.ewi.tudelft.nl/pubtrac/Utilities/export/297/uri/dist/uri-2.0.0.tar.gz\n",
      "  Using cached uri-2.0.0-py3-none-any.whl\n",
      "Collecting google-auth[aiohttp]>=2.5.0\n",
      "  Using cached google_auth-2.28.2-py2.py3-none-any.whl (186 kB)\n",
      "  Using cached google_auth-2.28.1-py2.py3-none-any.whl (186 kB)\n",
      "  Using cached google_auth-2.28.0-py2.py3-none-any.whl (186 kB)\n",
      "  Using cached google_auth-2.27.0-py2.py3-none-any.whl (186 kB)\n",
      "  Using cached google_auth-2.26.2-py2.py3-none-any.whl (186 kB)\n",
      "  Using cached google_auth-2.26.1-py2.py3-none-any.whl (186 kB)\n",
      "  Using cached google_auth-2.26.0-py2.py3-none-any.whl (186 kB)\n",
      "  Using cached google_auth-2.25.2-py2.py3-none-any.whl (184 kB)\n",
      "  Using cached google_auth-2.25.1-py2.py3-none-any.whl (184 kB)\n",
      "  Using cached google_auth-2.25.0-py2.py3-none-any.whl (184 kB)\n",
      "Installing collected packages: requests, python-socketio, Jinja2, aiosignal, torch, requests-oauthlib, nltk, matplotlib, Markdown, gymnasium, google-auth, gevent, Flask, dataclasses-json, cryptography, aiohttp, torchvision, torchaudio, seaborn, pyOpenSSL, google-auth-oauthlib, Flask-SocketIO, Flask-Cors, tensorboard, matrx, clip, d4rl-atari\n",
      "  Attempting uninstall: requests\n",
      "    Found existing installation: requests 2.28.2\n",
      "    Uninstalling requests-2.28.2:\n",
      "      Successfully uninstalled requests-2.28.2\n",
      "  Attempting uninstall: Jinja2\n",
      "    Found existing installation: Jinja2 2.11.3\n",
      "    Uninstalling Jinja2-2.11.3:\n",
      "      Successfully uninstalled Jinja2-2.11.3\n",
      "  Attempting uninstall: aiosignal\n",
      "    Found existing installation: aiosignal 1.2.0\n",
      "    Uninstalling aiosignal-1.2.0:\n",
      "      Successfully uninstalled aiosignal-1.2.0\n",
      "  Attempting uninstall: torch\n",
      "    Found existing installation: torch 1.12.1\n",
      "    Uninstalling torch-1.12.1:\n",
      "      Successfully uninstalled torch-1.12.1\n",
      "Note: you may need to restart the kernel to use updated packages.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "  Running command git clone --filter=blob:none --quiet https://github.com/indrasweb/expert-offline-rl.git 'C:\\Users\\jortv\\AppData\\Local\\Temp\\pip-install-mqby18_l\\eorl_1329074ff32b4d73ac87e4089394c59a'\n",
      "  Running command git rev-parse -q --verify 'sha^d0e8b9dbd3bd409a8d591e63cd30b825323d3eda'\n",
      "  Running command git fetch -q https://github.com/indrasweb/expert-offline-rl.git d0e8b9dbd3bd409a8d591e63cd30b825323d3eda\n",
      "WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "    WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "    WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "    WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "    WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "ERROR: Could not install packages due to an OSError: [WinError 5] Access is denied: 'C:\\\\Users\\\\jortv\\\\anaconda3\\\\Lib\\\\site-packages\\\\~orch\\\\lib\\\\asmjit.dll'\n",
      "Consider using the `--user` option or check the permissions.\n",
      "\n",
      "WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "WARNING: Ignoring invalid distribution -rotobuf (c:\\users\\jortv\\anaconda3\\lib\\site-packages)\n",
      "\n",
      "[notice] A new release of pip available: 22.3.1 -> 24.0\n",
      "[notice] To update, run: python.exe -m pip install --upgrade pip\n"
     ]
    }
   ],
   "source": [
    "pip install -r requirements.txt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "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": 55,
   "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": 56,
   "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": 57,
   "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": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "decompressing data...\n",
      "Dataset loaded\n",
      "789\n",
      "Dataset extracted with 69045 samples.\n",
      "Information about the dataset:\n",
      "Observation shape:  (69045, 4, 84, 84)\n",
      "Action shape:  (69045,)\n",
      "Reward shape:  (69045,)\n",
      "Terminal shape:  (69045,)\n",
      "Action space:  4\n",
      "Observation space:  (84, 84)\n",
      "Number of terminal states is... 54\n",
      "Environment 'ALE/Breakout-ram-v5' initialized.\n"
     ]
    }
   ],
   "source": [
    "from makeSeaquestdata import load_seaquest_dataset\n",
    "\n",
    "data_size = 50\n",
    "test_size = 5\n",
    "seaquestdata, sq_env = load_seaquest_dataset(env_name='Breakout', size=data_size+test_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "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": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "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": 62,
   "metadata": {},
   "outputs": [],
   "source": [
    "from load_model import load_seaquest_model\n",
    "pre_trained_encoder_seaquest = load_seaquest_model(\"decision_transformer_atari/checkpoints/Breakout_123.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing sub'trajectories: 100%|██████████| 63030/63030 [00:01<00:00, 34796.52it/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=15\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([4228, 15, 4, 84, 84])"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "final_obs_sq.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([15, 4, 84, 84]),\n",
       " tensor([1., 0., 1., 0., 0., 0., 0., 0., 0., 0., 2., 2., 2., 1., 1.]),\n",
       " tensor([0., 0., 0., 0., 0., 0., 0., 1., 0., 0., 0., 0., 0., 0., 0.]))"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "final_obs_sq[0].shape, final_act_sq[0], final_rew_sq[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = 'cpu'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\jortv\\AppData\\Local\\Programs\\Python\\Python39\\lib\\site-packages\\torch\\cuda\\amp\\grad_scaler.py:125: UserWarning: torch.cuda.amp.GradScaler is enabled, but CUDA is not available.  Disabling.\n",
      "  warnings.warn(\n",
      "Processing trajectories:   0%|          | 0/4228 [00:00<?, ?it/s]c:\\Users\\jortv\\AppData\\Local\\Programs\\Python\\Python39\\lib\\site-packages\\torch\\amp\\autocast_mode.py:250: UserWarning: User provided device_type of 'cuda', but CUDA is not available. Disabling\n",
      "  warnings.warn(\n",
      "Processing trajectories: 100%|██████████| 4228/4228 [03:43<00:00, 18.89it/s]\n"
     ]
    }
   ],
   "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": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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glNOOYXjjz+e1atX895773HBBRf4VwY5OTk8/PDD3HnnnVRWVnLaaaf5NYHmz5/PVVddxa233oparebhhx9mzpw5HHPMMZx77rlUVFTw5ptv0qdPn4Ay//GPf/DCCy9w8cUXs3HjRpKTk3n33Xd/tdrlwXj00Uc59dRTmTBhApdddhkdHR288MILFBQUBAiSK6+8kvb2do455hjS0tKoqqri+eefZ+jQoQwYMOBXl3sov6N9qaqq4pRTTkEQBM466yw+/fTTgPjBgwcH2J4cboYOHYpSqeTxxx/HbDaj1Wo55phjArTsujn55JP54osvOP300znppJOoqKjg5ZdfZuDAgQHvordcfPHFvPPOO9x8882sW7eOSZMmYbPZWLRoEddeey2nnnpqr8eNQ9Xml156idmzZzN8+HDOO+884uPjqa6u5ttvv2XChAkhBdy+LF68mOuuu46zzz6b3NxcvF4v7777LkqlkjPPPPNX95GfQ3/M/duZO3eutH+VpkyZIuXn54dMv3LlSmns2LGSXq+XUlJSpNtvv1364YcfJED65Zdf/OkuueQSKTMzM+j5V199VRoxYoSk1+ul8PBwadCgQdLtt98u1dfXB6RbsGCBNH78eEmv10sRERHS6NGjpQ8//NAfb7VapQsuuECKioqSgICympqapMsuu0yKi4uTNBqNNGjQoCDX1xUVFRIgPfnkkwfsnxNPPFECpFWrVh0w3b7Qg/ttQJoyZYo/XU/9nJmZKZ100kkh8507d67///fff78ESEVFRdJZZ50lhYeHS9HR0dJ1110nORzB7pY///xzaeLEiZLRaJSMRqPUv39/ae7cuVJxcXFAuhdffFHKzs6WtFqtNHLkSGnZsmXSlClTAuouSZJUVVUlnXLKKZLBYJDi4uKkG264Qfr+++8P+i0cqO8B6f777w8I++ijj6T+/ftLWq1WKigokBYsWCCdeeaZUv/+/f1pPvvsM2nGjBlSQkKCpNFopIyMDGnOnDlSQ0NDUBn701N/H8rvqJue3Nh3/+3f9lDsn677O2hpaQlI9+abb0qAVFFREdDW/V3mv/baa1KfPn0kpVIZ8O72f+eiKEqPPvqolJmZKWm1WmnYsGHSN998E/K33tu22O126e6775ays7MltVotJSUlSWeddZZUVlYWkK4340ZP7zHUt9tTmyWp6x3NnDlTioyM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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "clusters_seaquest = perform_clustering_and_plot(trajectory_embedding_seaquest.detach().cpu(), 2, 5, plot=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "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": 70,
   "metadata": {},
   "outputs": [],
   "source": [
    "list_episodes_sq = make_episodes(final_obs_sq, final_act_sq, final_rew_sq, 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "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": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:05 [debug    ] RandomIterator is selected.   \n",
      "2024-04-17 18:59:05 [info     ] Directory is created at d3rlpy_logs\\DiscreteSAC_20240417185905\n",
      "2024-04-17 18:59:05 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-04-17 18:59:05 [debug    ] Building models...            \n",
      "2024-04-17 18:59:05 [debug    ] Models have been built.       \n",
      "2024-04-17 18:59:05 [info     ] Parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\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': 4}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 10/10 [00:04<00:00,  2.11it/s, temp_loss=0.027, temp=1, critic_loss=1.61, actor_loss=-1.33]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:10 [info     ] DiscreteSAC_20240417185905: epoch=1 step=10 epoch=1 metrics={'time_sample_batch': 0.005893182754516601, 'time_algorithm_update': 0.46661398410797117, 'temp_loss': 0.02735897954553366, 'temp': 0.9983568489551544, 'critic_loss': 1.370126724243164, 'actor_loss': -1.5128796696662903, 'time_step': 0.4727159023284912} step=10\n",
      "2024-04-17 18:59:10 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_10.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/10: 100%|██████████| 10/10 [00:04<00:00,  2.19it/s, temp_loss=0.0271, temp=0.997, critic_loss=0.552, actor_loss=-2]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:15 [info     ] DiscreteSAC_20240417185905: epoch=2 step=20 epoch=2 metrics={'time_sample_batch': 0.006883573532104492, 'time_algorithm_update': 0.44752538204193115, 'temp_loss': 0.026213647052645683, 'temp': 0.9953825891017913, 'critic_loss': 0.31687018275260925, 'actor_loss': -2.5674616575241087, 'time_step': 0.4545119047164917} step=20\n",
      "2024-04-17 18:59:15 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_20.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/10: 100%|██████████| 10/10 [00:04<00:00,  2.21it/s, temp_loss=0.0251, temp=0.994, critic_loss=0.159, actor_loss=-2.27]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:19 [info     ] DiscreteSAC_20240417185905: epoch=3 step=30 epoch=3 metrics={'time_sample_batch': 0.006856727600097656, 'time_algorithm_update': 0.4431561708450317, 'temp_loss': 0.025514468550682068, 'temp': 0.9924596667289733, 'critic_loss': 0.19594647586345673, 'actor_loss': -2.3638957023620604, 'time_step': 0.4501138210296631} step=30\n",
      "2024-04-17 18:59:19 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_30.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/10: 100%|██████████| 10/10 [00:04<00:00,  2.37it/s, temp_loss=0.0263, temp=0.991, critic_loss=0.205, actor_loss=-2.72]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:24 [info     ] DiscreteSAC_20240417185905: epoch=4 step=40 epoch=4 metrics={'time_sample_batch': 0.00513615608215332, 'time_algorithm_update': 0.41487300395965576, 'temp_loss': 0.026539514027535915, 'temp': 0.989545738697052, 'critic_loss': 0.1567689761519432, 'actor_loss': -2.607569622993469, 'time_step': 0.42011351585388185} step=40\n",
      "2024-04-17 18:59:24 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_40.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/10: 100%|██████████| 10/10 [00:04<00:00,  2.19it/s, temp_loss=0.0266, temp=0.988, critic_loss=0.164, actor_loss=-2.46]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:28 [info     ] DiscreteSAC_20240417185905: epoch=5 step=50 epoch=5 metrics={'time_sample_batch': 0.006542491912841797, 'time_algorithm_update': 0.4476973056793213, 'temp_loss': 0.026621984876692296, 'temp': 0.9866020619869232, 'critic_loss': 0.14960030913352967, 'actor_loss': -2.570516896247864, 'time_step': 0.4545412063598633} step=50\n",
      "2024-04-17 18:59:28 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_50.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/10: 100%|██████████| 10/10 [00:04<00:00,  2.16it/s, temp_loss=0.0266, temp=0.985, critic_loss=0.116, actor_loss=-2.59]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:33 [info     ] DiscreteSAC_20240417185905: epoch=6 step=60 epoch=6 metrics={'time_sample_batch': 0.007015371322631836, 'time_algorithm_update': 0.45332815647125246, 'temp_loss': 0.026676899939775466, 'temp': 0.9836502611637116, 'critic_loss': 0.12685430645942689, 'actor_loss': -2.581970548629761, 'time_step': 0.460736608505249} step=60\n",
      "2024-04-17 18:59:33 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_60.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/10: 100%|██████████| 10/10 [00:04<00:00,  2.30it/s, temp_loss=0.0267, temp=0.982, critic_loss=0.0994, actor_loss=-2.61]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:37 [info     ] DiscreteSAC_20240417185905: epoch=7 step=70 epoch=7 metrics={'time_sample_batch': 0.0056644916534423825, 'time_algorithm_update': 0.4271427869796753, 'temp_loss': 0.026772008277475834, 'temp': 0.9806992053985596, 'critic_loss': 0.1305367462337017, 'actor_loss': -2.5851802110671995, 'time_step': 0.4329193592071533} step=70\n",
      "2024-04-17 18:59:37 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_70.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/10: 100%|██████████| 10/10 [00:04<00:00,  2.22it/s, temp_loss=0.0268, temp=0.979, critic_loss=0.18, actor_loss=-2.55]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:42 [info     ] DiscreteSAC_20240417185905: epoch=8 step=80 epoch=8 metrics={'time_sample_batch': 0.006237602233886719, 'time_algorithm_update': 0.4422831773757935, 'temp_loss': 0.02680848687887192, 'temp': 0.9777515351772308, 'critic_loss': 0.13234855011105537, 'actor_loss': -2.5985635995864866, 'time_step': 0.44883365631103517} step=80\n",
      "2024-04-17 18:59:42 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_80.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/10: 100%|██████████| 10/10 [00:04<00:00,  2.37it/s, temp_loss=0.0268, temp=0.976, critic_loss=0.125, actor_loss=-2.58]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:46 [info     ] DiscreteSAC_20240417185905: epoch=9 step=90 epoch=9 metrics={'time_sample_batch': 0.00579683780670166, 'time_algorithm_update': 0.4152830123901367, 'temp_loss': 0.026832524873316287, 'temp': 0.974810665845871, 'critic_loss': 0.11786969229578972, 'actor_loss': -2.5790223836898805, 'time_step': 0.42119059562683103} step=90\n",
      "2024-04-17 18:59:46 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_90.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/10: 100%|██████████| 10/10 [00:04<00:00,  2.35it/s, temp_loss=0.0269, temp=0.973, critic_loss=0.119, actor_loss=-2.58]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:50 [info     ] DiscreteSAC_20240417185905: epoch=10 step=100 epoch=10 metrics={'time_sample_batch': 0.005445528030395508, 'time_algorithm_update': 0.41818344593048096, 'temp_loss': 0.02685812320560217, 'temp': 0.9718780100345612, 'critic_loss': 0.13556680753827094, 'actor_loss': -2.568425941467285, 'time_step': 0.4242130517959595} step=100\n",
      "2024-04-17 18:59:50 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185905\\model_100.pt\n"
     ]
    }
   ],
   "source": [
    "sac_sq = fit_discrete_sac(list_episodes_sq, n_steps=100, n_steps_per_epoch=10, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "action_dict = {0: 'NOOP', 1: 'FIRE', 2: 'RIGHT', 3: 'LEFT'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPQAAASmCAYAAAAZJoYRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABrZklEQVR4nO3dzY8b5+Ef8O9whhySw5cV902SJUuOpVS241hWbAc9JYELRCgCFEjQQ4ECvfXUS/6CHttL0WMPBYoCLfDrMUByKOIcDBRBYEexLNex9fLTrlby7nJJLl/n/bUH9xlzJXLJtYba3UffDyDIXs0On52d7zyvM6MkSZKAiKSQO+4CEFF2GGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEtHk3VBRlkeUgohnmWdTJGppIIgw0kUQYaCKJzN2HPu3EGEChUECpVIKqqgf+PY5jxHF8YHtFUZDLHbzmhWEI13URhiGSJEEcx1AUBbquI5/PI5fLQVVVKIqCJEnSfo/4b7Hf8c8Q+42iCFEUwfd9RFF0YF+6rqNQKDxT5vHPOIzruvA874hH7fsRxyGXyyGfz08df3n6OIj/F7+LKIrgOA6iKHoh5Z5UPl3XoaoqVFWFpmlQFAVhGCIIAsRxjCAIjq18k7wUgVYUBcViEfl8HlevXsXNmzextraW/nsYhhgMBrBt+8D3GIaBSqWSnpyKouDJkyf4+OOP0Ww2YZomhsMhdF3HT37yE1y7dg2GYeDs2bMol8vwPC89IYMgQBAEUFUVxWIRmqYhn89D13XEcYzHjx+j2Wyi2+3izp07aLVaqFarOHv2LAzDwLvvvosf/ehH6QmVJAlc14VpmjNPqCAI8Mknn+DWrVsIw3Bhxxn49oL56quvYm1tDbVaDZcvX0alUpm4rQh8LpdDsVhEuVxGkiQYDocwTRO7u7v4+OOPsb29vdAyT2MYBq5fv47z58+j0Wjg8uXLKBQK2NzcxMbGBkajEe7du4e9vb1jKd8kL0Wgc7kcdF2Hrut4/fXX8etf/xpXr15N/933fezu7qLX66VfUxQFjUYDq6ur0DQtDfXnn3+OJ0+eIAgCJEmC0WgEXdfx1ltv4ec//zkajQbeeOMNLC0tpYEPggCO48B1XeTzedRqNeTzeZRKJVSrVQRBgNu3b+Pu3bt4/PgxNjc30Wq1YBhGejJ9+OGHuHnzJnK5XForjEYjdDodBEFw6M/vui4GgwE+++yzhR1jQdM0nD17FleuXMG5c+fwwQcfYHl5eeK24uKmqipqtRrOnDmDJEnQbDaxv7+Pr776Cnfu3Dm2QJdKJVy7dg1vv/02Ll68iPfffx+GYeCTTz7BX/7yF7Tbbezt7THQx0U060QTSojjGLu7u9ja2jqw7euvv45GowFVVQ80fyc1IUXzXOxbVdW0yej7PobDISzLSptwxWIRhULhwPdMauI/vW8RaFFD93o9+L5/6M/tui4cx3mOIze/JEnSC5hpmuj1elOb3KqqolKpQNM0FIvF9GcXF89Jx+JFE8d+/Pc0XraTNp37UgV6mtFohD/+8Y/46KOP0v6opmn41a9+hfX1dVSrVRiG8Uy/+zBxHMM0TTx+/Bi2bWN3dxftdhu1Wg2vvfYa6vU6oihCvV4/UlnjOE77w7u7u/j8888xGo0O/Z4gCLC9vX1gjGBRoihCr9dDPp+HaZoAMLXJXSqVsLKyglKphDiOsba2dqRjTM9ioPFtk3trawt37txJv6ZpGt555x14npeecEcVBEFaM7fbbbRaLbiui+XlZaiqCtd15xrQAr5bVBDHcTooY1kWWq0WBoPBgW0nDeSZpjn3Zz2P8b49AHQ6nQNjEwDSY2kYRjpWYdt2OhAotuHTsY6OgT7BfN9Pw3r//n0sLy8jSRLYto0gCNBsNtP+s+jnl0olXLhw4UDN77ou9vf38fe//33hI7KqqqLRaODChQtYWVnBW2+9hXq9DsdxYFkWgiBAt9vFcDhMLzS+72NzczP9/k6ng8FggEePHr2wroIsGOgTzHVddDodmKaJW7duodvtQlGUtIYTI+e5XC4dNW80GvjpT3+KK1eupPuxbRsbGxv405/+NHMA7XlpmoZz587h6tWruHTpEn72s59hfX0drVYLOzs7ME0TX3/9NUzTTMOtKAo6nQ7u37+PJElgmiZs28b+/v4zrQ86HAMNpDVbrVZLvzY+UCOmrI5KURTk8/l0eqpQKEDXdWiaBk3TZvYXxTy3mO/0PO+ZcuTzeQBI9y9Gzif9LC+K+DxRlmq1CsdxYBgGkiRBqVR6Zk4dADzPQxzH8DwPvu+ng380PwYa3w7aiCkncQLlcjm89957qNfr6dTKUeRyOVQqFbzyyitwXReVSgXnz59HqVTC+fPnUS6XUa/X09HwSfL5PCqVCiqVCl577TW88847U0d+xUWiVquhWq0e7QAsmLhgNhoNGIYB3/extLQ0cdsoitDv92GaJra3t/HgwYMXW9hTjoEGUC6X8f777+PKlStpoBVFwcrKCqrV6jPTXEfZ79raGsIwxNLS0oF56EKhgHK5jFwud2igDcNAtVrFhQsXcO3atanlEC0JXddhGMaRy7pouq5jaWkJYRhCVVWsrKxM3C6KInQ6HfT7fcRx/EJbFjKYO9ClUmmR5VioXC6HQqEATdPgeR62trYONOWCIECn08FwOEy/pigKbNvGaDQ6MAe9vb0N13UBfFsriuajZVnY29uD67ooFAppM3M0GiGKIriuC9/3oWkaDMNIm+HlchlRFGF7ezsdLFJVFaVSKW1Ox3GMwWCAnZ2dqTW06BYUCgU4joNyuZz+m+u6GA6HKBaLC5831XUdQRCki142NzcxGo3g+z5c100XxEwb7BI19Gg0gmmaae1+HPL5fNqXz+fzePjwIUqlEnZ2dg6sLDxJ2VDmfXPG+Mqq00iMAi8tLeHVV1898EtIkgSe5z1TU4r+73gILMvCN998k440e54HTdOwtraGM2fOpIFVVTWdYhJTMGLd9/giEVVV04Egy7Lgui7a7TZc1037opqmodFooF6vzwykqKXHgy+Wlr6IuWhVVbG0tIRKpYJisYgzZ84gn88jSRJEUZT+Pa1VIhamhGEIx3HSi+Rx0DQtbaUVi8W0tTYcDjEYDBAEAXq93jPTcosyT/dj7kC/++67z10gIvr+bt++PXObuZvcv/zlL5+rMES0eHPX0OPrnInoxbt06dLMbeauoVdXV5+rMES0eMd/OwsRZYaBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpJI5g84ELcMjr8Choi+M/4KIHFbb1YyD7TjOBgOh4iiKL0XmIi+M/4yhnq9fuBhFM8r80CHYQjLstJnR5+kF3kRnQSqqqYPz8j6cVGZB7rT6eCLL76AbduwbZvPVSZ6SqlUgmEYKJVKuH79+oEntD6vTAMdxzEePXqEP/zhD+h0Otjb2zvwAjiil934SxBXV1fTt1pm1Y9eSB9ahLnZbKLT6WT9EUSnmnj+eC6Xy/x5aZy2IpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiWT+1E9VVVEsFlEsFlEqlTJ9KwCRDEqlEorFInRdh6qqme4780Druo5arYYgCBCGYabv7SGSwfLyMpaXl7G0tIRCoZDpvhdWQ4vaOevnDhOddqeqhl5ZWcE777yD0WiE4XAI0zSz/giiU61araJaraJWq2F5efnkvn0yl8thfX0d77//PnzfT/8Q0XcKhQJ0XUehUMDa2lqm+868hs7lcigWi8jlculb9ojoO5qmoVAoIJ/PZ97k5ogVkUQYaCKJLGSUWzSzFUWBoihZfwTRqSZe9p7P5zOf1s080OKt9FEUIQxDRFGEJEmy/hiiU0lRFKiqCk3T0r+ztJBBMU3T0tqZC0uIDlJVNf1z4mto4NtQJ0nCmploglwul/7JukuaeaCfrpXZhyY6SEzpnopAx3GMIAjSPnQcxxNrahF88UMt4oejxYrjOP39ir9lapWJ/u549zGLc1TsYxHne+aBHgwG2Nraguu68DwPnudN3C6Xy2FpaQn1eh2apqFarWa+UJ0Wy/d9dDodBEEAy7Jg27ZUgc7n82g0GjAMA4VCAZVKJZNBrEVWXJkH2rZt7O7uwrIsWJYFx3Em/pI1TcP58+ehKAqKxSJvszyFgiBAv9+Hbdvo9/vo9XqIoui4i5WZYrGIOI4RRREMw4BhGMddpJkyDXQcx7BtG3t7ewduzpgU6Hw+n1714jhGGIZscp8yItCj0QjtdhvNZlOqQBuGgUqlki7RjOP4xJ+jmdfQe3t7+PTTT9HpdNBut9HtdicGulgsYjQapU3vlZWVE3+w6CDLsvDw4UPs7e1hc3MTd+/eRRiGx12szDQaDcRxDN/3EQQB1tfXM+tDL2rMKPNAO46DdruNvb09NJtNdDqdidsVi0Xs7+/DNE3oui7Vlf1lEYYhBoMBer0ems0mtre3EQTBcRcrM67rotfrwbIsuK57KsYHuOqDSCIMNJFEFrJSbB5JksDzvLTJ3ev1TsW0laqqKJfLC1sYcJrk83lUq1WYpokzZ85gZWVlapN7fF2C53mH9rXF+gRVVVEqleaaKvI8D5ZlIY7j7/3zTDK+XiKL37fYx6L60ccW6DAMcf/+fQyHQxSLRfz5z38+FdMCFy9exIcffohz586lj5F5Wder/+AHP8DNmzdhWRb6/T663e7EQCVJgt3dXTx+/BjD4RBffPEFHj58OHGfYpC0Uqng/Pnz+PDDD3HhwoVDy5EkCT799FP87ne/Q7/fz+JHA/BtmAuFAorFIgzDQK1WQ61Wy2z/AE7HWu55RFGEx48f48mTJwBOzxLRGzdu4M0338SZM2dQrVZRLpczv2PmtKhUKjh37lw6WDRt0ChJEnz11Vf47LPP0Gq10Gq1sLGxMXH7XC6HSqWClZUV/PCHP8RvfvMb/PjHPz60HEmSwDAMfPTRR5kHWtM06LqehrpSqTz3fsePl1hVmZVjPxNnnQwnzdNLHE/LhWhR5rnnPUmSIzdbx5ul8zym5zR1fxRFWdj5/nK2FYkkdew19Gkm280Ip9Vp+h2Mt0gXUW4G+ohM08SDBw8QBEG6wm3SwEYul4NhGFhaWoKqqjAMA8ViceI+kySBbdvpDS39fh+O40zcVlVVFAoF5HI51Go1rK6uznyyahRFaLVa2Nvbm9lf03Udq6urqFar6Wc9b1NWzGiIxzrPWk2WJEk6Ku667tRjMb697/uZB0SUw/d9eJ4Hx3GmzsT4vg/bthEEAYbDIUaj0cRjLR4AIh5BtLKykulAGwN9RIPBALdu3cKjR49QLpdRqVSmjlReuHABV65cQblcxtmzZ9FoNCaGIwxD7O3tYX9/H4PBAPfu3UOv15u4z/E70y5fvowbN27MHKgJggB37tzBX//615lhqlQquHHjBi5dugRd11GtVp970C+O4/RGHc/zDp1aErdiittwbdue+bKGJEngum7mU1biQiEuKqZpTu3PD4dD7O7uwrZtbG1tYWNjY+rF0zCM9GH7H3zwAQN9nIIgSNeg27YN27YnhlRRFJTLZZimeWDudVqgXdeFZVkYjUbY399Hu92e+Pn5fB6u66JYLGJ5eTl9h9g8ZW61WjOXZopyeJ4HRVEyWcopajoR1HmCJwYfRU09a/9Zh/npfUdRdGhZRA1tmib6/T7a7fbEY6coCqrVajq6Pe324u+LgT4i27bx6NEj6LoOTdPS56dN4jgOarUa6vV6ekWeJAgCdDod7OzsoNVq4csvv8T29vbEbQuFAlZWVlAul6HrOt5+++2ZNajneXj8+DFu3749800my8vLePXVV9FoNNJFHc+74Ec0uYMgQBAEM/uP4t/mbXIDWFiTOwzDtKvguu7U7s1oNMLe3h4GgwEePHiAv/3tb1PD32g0sLy8jJWVFVy/fh1xHGc2H81AH5HrulPDNk68QeTy5cvwfR/r6+twXXdi+H3fx3A4RLvdxs7ODu7du4etra2J+y0Wi1hfX0elUsH6+jps2555L7njONjZ2cHXX3898+WB4lVGg8EAcRyjUqk8d1BE01XUSrP293Sze1YtJoK3qD50FEVpOaZd3CzLwv7+PrrdLh49eoS7d+9OLLeiKFhdXcX6+nraIssSA/09zHPiiHu8xYnsed6hgRaDRuLEnPYZ44/8ESfbrIEuEaJpj4N6ev/jtVEWdxmJLoeooWc1j8d/PnHcZm2/iBoawIEwH1ZDu657YNBv2rEev1hxlPuUCcMwHUjpdDoolUoTAx0EAbrdLkajESzLmtlnFCdEGIaHPuZJmLV2elwURRiNRuh2u2mYdV2f63unSZIE+/v76QMvDmv2j/ebHcdBp9NBvV6fuf/BYJD5LbjigR1ieXKr1YJlWRO3bbfb6Pf7GA6HC7u4zIOBXiBRQ4spD9M0pwZajAB7njfXySCu9PMMiokXHsxD1Hai32qa5nMPjIlpOdEKmbeGFqGeZ5R73uN2FON9aDFYOO0zxLTjPL+PRWKgFyRJEgyHQ2xsbKBUKqHX66HRaEzcNgxDtNtt9Ho9DAYD2LZ96H5FM9txHPT7/ZkDKq7rzt109jwPm5ubCMMwswfjJUmCXq+HVqsFx3EwGAwO3dbzvHSQ6fbt2+l6/8NM67M+D9/3sb29Dd/30Ww20W63p7ZWTNNEs9lMWxWLGnWfhYFeoFarhX6/ny7yP2xNsqhFRX9zmvFaYzQapQ9kPIwYdJsn0I7j4PPPP8eXX36Zrr3OgmhGixbANEmSpE8QHQwG2N3dnWstt2gFZcl1XTx48ACbm5sH3ggziWhRLOKGi6NgoBcoDMOFNL/EoJkYNJrVJPZ9f+4TTPQbj5Oo3cQqreMiWgtZ1/yLxJsziCTCQBNJhE3uU2Z8Wse2bXS73bma3LK91YImY6BPGdHH9TwPW1tbCMNw5t1WcRzjm2++ObaRV3pxGOhTZvxlgGJ55qxRYDGFxhpafgz0KTS+qMRxnJlTS2IqhYGWHwN9Commswj1Ub6H5MZAn2JigIxI4LQVkUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIItpxF4BOLkVRoGkaFEWBrusoFouI4ximacLzvOMuHk3AQNNUqqpC13VomoalpSWsrKwgDEM8efKEgT6hGGiaSlEUqKoKTdNQLBZRrVbh+z40jafNScXfDE2laRoMw0ChUMDFixfxxhtvwLZtdDod7O3tHXfxaAIOitFUqqqiVCqhUqng3Llz+Cf/5J/gypUrqNfrx100moI1NE0VxzGCIICmabBtG4PBAI7joFwuY319Hb7vYzQaIQzD4y4q/X8MNE0VBAH6/T4sy8I//uM/Iooi5PN5XLx4Ea+99hp2dnbw6aefotfrHXdR6f9joGmqKIrgeR7CMESv10OxWIRhGLh27RrOnz8PANB1/ZhLSeMYaJoqSRJEUYQkSeD7PkzTBAA2sU8wBpqmSpIEYRhCURRYlgVVVRHHMXzfP+6i0RQc5aaZRE0dBAF834frumlTPEmS4y4ejWENTXMRTe4gCPB//+//xc7ODnq9XtoMp5OBgaa5BEGAIAhg2zb6/T4URUGSJIjj+LiLRmMYaDqSJEnYzD7B2IcmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSSRuR9BFEXRzG34jKmXj6IoAIBSqYRyuZz+fxaiKILrugjDEHEcS/c8cPGqoSAI5jpu5XJ55jZzB3qeZzGL5zjHccznTr0EFEVBLpdDLpfDysoKLl68mOmrZh3HQbPZhG3bcF0XlmVJcV6Jik9csOZ9curS0tLMbeY++vPUvE8/QE6Gg0+HUxQFiqKgWCyiVquhUChktm9N09Dtdg/UYjKcU+JnGH/eeVYtm7kD7XnezG2SJEEQBOnVh+Q2/kL4s2fP4vr165m+60qEudVqAQAsy5KiSyeCHIYhLMvCcDjMbN8LCbQIswxXU5pOBDqfz+OVV17Be++9B8MwMtv/9vY22u12evJ3Op3M9n2cxmtmy7LS55xnYe5AzxNOPrP55SReZpd1H9e2bfi+jyiKpKiZhfGciP70Cw800dPEKG0cx7h37x5+//vfZ9qHHo1GePjwIYbDISzLYjduDgw0fW/jr5vd3d2F67rI5bJb2uD7PobDIXzfRxAEbP3NYe5AP3z4cOY2SZKg2WzCcRy4rssr6ktCNLlt2850HjoMQwRBIN1UaBiGcBwHg8EADx48QD6fn+v7fvGLX8zcRknmPEq//e1vZ26TJAk2NjZw584d2LYNy7LgOM48u6dTTlVVqKqa6T5F/1L0OWUJtDhWqqqiXq/PtWAEmK9SnbuG3tnZmWu7brcLz/PSvhW9HKIoYotsTuPHKusKb+5A379/f67t+v0+bNs+MH1FRC/G3E3ueUcv4zhOa2ZZmkhEJ8E8eZo70FkOdhDR0c0TVd4+SSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQyfaYYER0v1tBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEtHm3VBRlEWWg4hmSJJk5jasoYkkwkATSYSBJpLI3H3o006MARQKBZRKJaiqeuDf4zhGHMcHtlcUBbncwWteGIZwXRdhGCJJEsRxDEVRoOs68vk8crkcVFWFoihIkiTt94j/Fvsd/wyx3yiKEEURfN9HFEUH9qXrOgqFwjNlHv+Mw7iuC8/zjnjUvh9xHHK5HPL5/NTxl6ePg/h/8buIogiO4yCKohdS7knl03UdqqpCVVVomgZFURCGIYIgQBzHCILg2Mo3yUsRaEVRUCwWkc/ncfXqVdy8eRNra2vpv4dhiMFgANu2D3yPYRioVCrpyakoCp48eYKPP/4YzWYTpmliOBxC13X85Cc/wbVr12AYBs6ePYtyuQzP89ITMggCBEEAVVVRLBahaRry+Tx0XUccx3j8+DGazSa63S7u3LmDVquFarWKs2fPwjAMvPvuu/jRj36UnlBJksB1XZimOfOECoIAn3zyCW7duoUwDBd2nIFvL5ivvvoq1tbWUKvVcPnyZVQqlYnbisDncjkUi0WUy2UkSYLhcAjTNLG7u4uPP/4Y29vbCy3zNIZh4Pr16zh//jwajQYuX76MQqGAzc1NbGxsYDQa4d69e9jb2zuW8k3yUgQ6l8tB13Xouo7XX38dv/71r3H16tX0333fx+7uLnq9Xvo1RVHQaDSwuroKTdPSUH/++ed48uQJgiBAkiQYjUbQdR1vvfUWfv7zn6PRaOCNN97A0tJSGvggCOA4DlzXRT6fR61WQz6fR6lUQrVaRRAEuH37Nu7evYvHjx9jc3MTrVYLhmGkJ9OHH36ImzdvIpfLpbXCaDRCp9NBEASH/vyu62IwGOCzzz5b2DEWNE3D2bNnceXKFZw7dw4ffPABlpeXJ24rLm6qqqJWq+HMmTNIkgTNZhP7+/v46quvcOfOnWMLdKlUwrVr1/D222/j4sWLeP/992EYBj755BP85S9/Qbvdxt7eHgN9XESzTjShhDiOsbu7i62trQPbvv7662g0GlBV9UDzd1ITUjTPxb5VVU2bjL7vYzgcwrKstAlXLBZRKBQOfM+kJv7T+xaBFjV0r9eD7/uH/tyu68JxnOc4cvNLkiS9gJmmiV6vN7XJraoqKpUKNE1DsVhMf3Zx8Zx0LF40cezHf0/jZTtp07kvVaCnGY1G+OMf/4iPPvoo7Y9qmoZf/epXWF9fR7VahWEYz/S7DxPHMUzTxOPHj2HbNnZ3d9Fut1Gr1fDaa6+hXq8jiiLU6/UjlTWO47Q/vLu7i88//xyj0ejQ7wmCANvb2wfGCBYliiL0ej3k83mYpgkAU5vcpVIJKysrKJVKiOMYa2trRzrG9CwGGt82ube2tnDnzp30a5qm4Z133oHneekJd1RBEKQ1c7vdRqvVguu6WF5ehqqqcF13rgEt4LtFBXEcp4MylmWh1WphMBgc2HbSQJ5pmnN/1vMY79sDQKfTOTA2ASA9loZhpGMVtm2nA4FimxdRXtkw0CeY7/tpWO/fv4/l5WUkSQLbthEEAZrNZtp/Fv38UqmECxcuHKj5XdfF/v4+/v73vy98RFZVVTQaDVy4cAErKyt46623UK/X4TgOLMtCEATodrsYDofphcb3fWxubqbf3+l0MBgM8OjRoxfWVZAFA32Cua6LTqcD0zRx69YtdLtdKIqS1nBi5DyXy6Wj5o1GAz/96U9x5cqVdD+2bWNjYwN/+tOfZg6gPS9N03Du3DlcvXoVly5dws9+9jOsr6+j1WphZ2cHpmni66+/hmmaabgVRUGn08H9+/eRJAlM04Rt29jf33+m9UGHY6CBtGar1Wrp18YHasSU1VEpioJ8Pp9OTxUKBei6Dk3ToGnazP6imOcW852e5z1Tjnw+DwDp/sXI+aSf5UURnyfKUq1W4TgODMNAkiQolUrPzKkDgOd5iOMYnufB9/108I/mx0Dj20EbMeUkTqBcLof33nsP9Xo9nVo5ilwuh0qlgldeeQWu66JSqeD8+fMolUo4f/48yuUy6vV6Oho+ST6fR6VSQaVSwWuvvYZ33nln6sivuEjUajVUq9WjHYAFExfMRqMBwzDg+z6WlpYmbhtFEfr9PkzTxPb2Nh48ePBiC3vKMdAAyuUy3n//fVy5ciUNtKIoWFlZQbVafWaa6yj7XVtbQxiGWFpaOjAPXSgUUC6XkcvlDg20YRioVqu4cOECrl27NrUcoiWh6zoMwzhyWRdN13UsLS0hDEOoqoqVlZWJ20VRhE6ng36/jziOX2jLQgZzB7pUKi2yHAuVy+VQKBSgaRo8z8PW1taBplwQBOh0OhgOh+nXFEWBbdsYjUYH5qC3t7fhui6Ab2tF0Xy0LAt7e3twXReFQiFtZo5GI0RRBNd14fs+NE2DYRhpM7xcLiOKImxvb6eDRaqqolQqpc3pOI4xGAyws7MztYYW3YJCoQDHcVAul9N/c10Xw+EQxWJx4fOmuq4jCIJ00cvm5iZGoxF834fruumCmGmDXaKGHo1GME0zrd2PQz6fT/vy+XweDx8+RKlUws7OzoGVhScpG0oyZydlfGXVaSRGgZeWlvDqq68e+CUkSQLP856pKUX/dzwElmXhm2++SUeaPc+DpmlYW1vDmTNn0sCqqppOMYkpGLHue3yRiKqq6UCQZVlwXRftdhuu66Z9UU3T0Gg0UK/XZwZS1NLjwRdLS1/EXLSqqlhaWkKlUkGxWMSZM2eQz+eRJAmiKEr/ntYqEQtTwjCE4zjpRfI4aJqWttKKxWLaWhsOhxgMBgiCAL1e75lpuUWZp/sxd6Dffffd5y4QEX1/t2/fnrnN3E3uX/7yl89VGCJavLlr6PF1zkT04l26dGnmNnPX0Kurq89VGCJavOO/nYWIMsNAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0kk8wcciFsGx18BQ0TfGX8FkLitNyuZB9pxHAyHQ0RRlN4LTETfGX8ZQ71eP/AwiueVeaDDMIRlWemzo0/Si7yITgJVVdOHZ2T9uKjMA93pdPDFF1/Atm3Yts3nKhM9pVQqwTAMlEolXL9+/cATWp9XpoGO4xiPHj3CH/7wB3Q6Hezt7R14ARzRy278JYirq6vpWy2z6kcvpA8twtxsNtHpdLL+CKJTTTx/PJfLZf68NE5bEUmEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRDJ/6qeqqigWiygWiyiVSpm+FYBIBqVSCcViEbquQ1XVTPedeaB1XUetVkMQBAjDMNP39hDJYHl5GcvLy1haWkKhUMh03wuroUXtnPVzh4lOu1NVQ6+srOCdd97BaDTCcDiEaZpZfwTRqVatVlGtVlGr1bC8vHxy3z6Zy+Wwvr6O999/H77vp3+I6DuFQgG6rqNQKGBtbS3TfWdeQ+dyORSLReRyufQte0T0HU3TUCgUkM/nM29yc8SKSCIMNJFEFjLKLZrZiqJAUZSsP4LoVBMve8/n85lP62YeaPFW+iiKEIYhoihCkiRZfwzRqaQoClRVhaZp6d9ZWsigmKZpae3MhSVEB6mqmv458TU08G2okyRhzUw0QS6XS/9k3SXNPNBP18rsQxMdJKZ0T0Wg4zhGEARpHzqO44k1tQi++KEW8cPRYsVxnP5+xd8ytcpEf3e8+5jFOSr2sYjzPfNADwYDbG1twXVdeJ4Hz/MmbpfL5bC0tIR6vQ5N01CtVjNfqE6L5fs+Op0OgiCAZVmwbVuqQOfzeTQaDRiGgUKhgEqlkskg1iIrrswDbds2dnd3YVkWLMuC4zgTf8mapuH8+fNQFAXFYpG3WZ5CQRCg3+/Dtm30+330ej1EUXTcxcpMsVhEHMeIogiGYcAwjOMu0kyZBjqOY9i2jb29vQM3Z0wKdD6fT696cRwjDEM2uU8ZEejRaIR2u41msylVoA3DQKVSSZdoxnF84s/RzGvovb09fPrpp+h0Omi32+h2uxMDXSwWMRqN0qb3ysrKiT9YdJBlWXj48CH29vawubmJu3fvIgzD4y5WZhqNBuI4hu/7CIIA6+vrmfWhFzVmlHmgHcdBu93G3t4ems0mOp3OxO2KxSL29/dhmiZ0XZfqyv6yCMMQg8EAvV4PzWYT29vbCILguIuVGdd10ev1YFkWXNc9FeMDXPVBJBEGmkgiC1kpNo8kSeB5Xtrk7vV6p2LaSlVVlMvlhS0MOE3y+Tyq1SpM08SZM2ewsrIytck9vi7B87xD+9pifYKqqiiVSnNNFXmeB8uyEMfx9/55JhlfL5HF71vsY1H96GMLdBiGuH//PobDIYrFIv785z+fimmBixcv4sMPP8S5c+fSx8i8rOvVf/CDH+DmzZuwLAv9fh/dbndioJIkwe7uLh4/fozhcIgvvvgCDx8+nLhPMUhaqVRw/vx5fPjhh7hw4cKh5UiSBJ9++il+97vfod/vZ/GjAfg2zIVCAcViEYZhoFaroVarZbZ/AKdjLfc8oijC48eP8eTJEwCnZ4nojRs38Oabb+LMmTOoVqsol8uZ3zFzWlQqFZw7dy4dLJo2aJQkCb766it89tlnaLVaaLVa2NjYmLh9LpdDpVLBysoKfvjDH+I3v/kNfvzjHx9ajiRJYBgGPvroo8wDrWkadF1PQ12pVJ57v+PHS6yqzMqxn4mzToaT5ukljqflQrQo89zzniTJkZut483SeR7Tc5q6P4qiLOx8fznbikSSOvYa+jST7WaE0+o0/Q7GW6SLKDcDfUSmaeLBgwcIgiBd4TZpYCOXy8EwDCwtLUFVVRiGgWKxOHGfSZLAtu30hpZ+vw/HcSZuq6oqCoUCcrkcarUaVldXZz5ZNYoitFot7O3tzeyv6bqO1dVVVKvV9LOetykrZjTEY51nrSZLkiQdFXddd+qxGN/e9/3MAyLK4fs+PM+D4zhTZ2J834dt2wiCAMPhEKPRaOKxFg8AEY8gWllZyXSgjYE+osFggFu3buHRo0col8uoVCpTRyovXLiAK1euoFwu4+zZs2g0GhPDEYYh9vb2sL+/j8FggHv37qHX603c5/idaZcvX8aNGzdmDtQEQYA7d+7gr3/968wwVSoV3LhxA5cuXYKu66hWq8896BfHcXqjjud5h04tiVsxxW24tm3PfFlDkiRwXTfzKStxoRAXFdM0p/bnh8Mhdnd3Yds2tra2sLGxMfXiaRhG+rD9Dz74gIE+TkEQpGvQbduGbdsTQ6ooCsrlMkzTPDD3Oi3QruvCsiyMRiPs7++j3W5P/Px8Pg/XdVEsFrG8vJy+Q2yeMrdarZlLM0U5PM+DoiiZLOUUNZ0I6jzBE4OPoqaetf+sw/z0vqMoOrQsooY2TRP9fh/tdnvisVMUBdVqNR3dnnZ78ffFQB+Rbdt49OgRdF2Hpmnp89MmcRwHtVoN9Xo9vSJPEgQBOp0OdnZ20Gq18OWXX2J7e3vitoVCASsrKyiXy9B1HW+//fbMGtTzPDx+/Bi3b9+e+SaT5eVlvPrqq2g0Gumijudd8COa3EEQIAiCmf1H8W/zNrkBLKzJHYZh2lVwXXdq92Y0GmFvbw+DwQAPHjzA3/72t6nhbzQaWF5exsrKCq5fv444jjObj2agj8h13alhGyfeIHL58mX4vo/19XW4rjsx/L7vYzgcot1uY2dnB/fu3cPW1tbE/RaLRayvr6NSqWB9fR22bc+8l9xxHOzs7ODrr7+e+fJA8SqjwWCAOI5RqVSeOyii6SpqpVn7e7rZPasWE8FbVB86iqK0HNMubpZlYX9/H91uF48ePcLdu3cnlltRFKyurmJ9fT1tkWWJgf4e5jlxxD3e4kT2PO/QQItBI3FiTvuM8Uf+iJNt1kCXCNG0x0E9vf/x2iiLu4xEl0PU0LOax+M/nzhus7ZfRA0N4ECYD6uhXdc9MOg37ViPX6w4yn3KhGGYDqR0Oh2USqWJgQ6CAN1uF6PRCJZlzewzihMiDMNDH/MkzFo7PS6KIoxGI3S73TTMuq7P9b3TJEmC/f399IEXhzX7x/vNjuOg0+mgXq/P3P9gMMj8FlzxwA6xPLnVasGyrInbtttt9Pt9DIfDhV1c5sFAL5CoocWUh2maUwMtRoA9z5vrZBBX+nkGxcQLD+YhajvRbzVN87kHxsS0nGiFzFtDi1DPM8o973E7ivE+tBgsnPYZYtpxnt/HIjHQC5IkCYbDITY2NlAqldDr9dBoNCZuG4Yh2u02er0eBoMBbNs+dL+ime04Dvr9/swBFdd15246e56Hzc1NhGGY2YPxkiRBr9dDq9WC4zgYDAaHbut5XjrIdPv27XS9/2Gm9Vmfh+/72N7ehu/7aDabaLfbU1srpmmi2WymrYpFjbrPwkAvUKvVQr/fTxf5H7YmWdSior85zXitMRqN0gcyHkYMus0TaMdx8Pnnn+PLL79M115nQTSjRQtgmiRJ0ieIDgYD7O7uzrWWW7SCsuS6Lh48eIDNzc0Db4SZRLQoFnHDxVEw0AsUhuFCml9i0EwMGs1qEvu+P/cJJvqNx0nUbmKV1nERrYWsa/5F4s0ZRBJhoIkkwib3KTM+rWPbNrrd7lxNbtneakGTMdCnjOjjep6Hra0thGE4826rOI7xzTffHNvIK704DPQpM/4yQLE8c9YosJhCYw0tPwb6FBpfVOI4zsypJTGVwkDLj4E+hUTTWYT6KN9DcmOgTzExQEYkcNqKSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEtOMuAL14uVwOiqKkfwAgiiLEcXzMJaPnxUC/ZDRNQ71eR6lUgqZp0HUdiqJgf38fnU4HSZIcdxHpOTDQLxlVVVGtVlGv16HrOgzDQC6XQxAE6Ha7iKLouItIz4GBfskoioJCoYBisYhSqYSlpSWoqor9/X0YhoEgCOD7PoN9SjHQL5lcLodKpYJGo4GlpSVcunQJ+XweiqIgCAI4joNWqwXTNI+7qPQ9MNAvGUVRkM/n0+b20tISdF1HvV5HtVpN/51OJwb6JROGIdrtNoIggG3b0HUdpVIJSZLg3LlzsCwL3W4XvV7vuItK3wMD/ZLxfR9PnjzB9vY21tbWEEVR2gS/evUqhsMhtra2jruY9D0x0C+ZJEkQBAEAwHEcWJYFRVFQq9WOuWSUBQb6JeY4DprNJnRdR7/fx+7uLlzXZXP7FGOgX2Ke56HT6UBVVXS7Xezu7iIMQ4xGo+MuGn1PDPRLLEkSRFGUrg5LkgRxHHMO+hRjoF9icRzD8zwoipKu7xYhp9OJgX6JJUmS1s4MsRx4+ySRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgic7/wfZ4XgidJgjiOn6tAdLooigIAKJVKKJfL6f9nIYoiuK6LMAwRxzHCMMxs3ydBHMcIggBBEMx13Mrl8sxt5g607/szt0mSJD34SZLMu2s6pRRFQS6XQy6Xw8rKCi5evAhNm/uUmslxHDSbTdi2Ddd1YVmWFOeVqPjEBcs0zbm+b2lpaeY2cx/9eWreJEkOHHAZDj4dTlEUKIqCYrGIWq2GQqGQ2b41TUO32z1Qi8lwTomfIUkSRFE0dw09j7kD7XnezG2SJEEQBOnVh+SmKApUVYWmaTh79iyuX78OXdcz278Ic6vVAgBYliVFl04EOQxDWJaF4XCY2b4XEmgRZhmupjSdCHQ+n8crr7yC9957D4ZhZLb/7e1ttNvt9OTvdDqZ7fs4jdfMlmWh3++/+Bp6nnA+3eSml0OSJPB9P/M+rm3b8H0fURRJUTML4zkR/ekXHmiip4lR2jiOce/ePfz+97/PtA89Go3w8OFDDIdDWJbFbtwcGGj63kTTMUkS7O7uwnVd5HLZLW3wfR/D4RC+7yMIArb+5jB3oB8+fDhzmyRJ0Gw24TgOXNflFfUlIZrctm1nOg8dhiGCIJBuKjQMQziOg8FggAcPHiCfz8/1fb/4xS9mbqMkcx6l3/72tzO3SZIEGxsbuHPnDmzbhmVZcBxnnt3TKaeqKlRVzXSfon8p+pyyBFocK1VVUa/X51owAsxXqc5dQ+/s7My1Xbfbhed5ad+KXg5RFLFFNqfxY5V1hTd3oO/fvz/Xdv1+H7ZtH5i+IqIXY+4m97yjl3EcpzWzLE0kopNgnjzNHegsBzuI6OjmiSpvnySSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgimT5TjIiOF2toIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIokw0EQSYaCJJMJAE0mEgSaSCANNJBEGmkgiDDSRRBhoIolo826oKMoiy0FEMyRJMnMb1tBEEmGgiSTCQBNJZO4+9GknxgAKhQJKpRJUVT3w73EcI47jA9srioJc7uA1LwxDuK6LMAyRJAniOIaiKNB1Hfl8HrlcDqqqQlEUJEmS9nvEf4v9jn+G2G8URYiiCL7vI4qiA/vSdR2FQuGZMo9/xmFc14XneUc8at+POA65XA75fH7q+MvTx0H8v/hdRFEEx3EQRdELKfek8um6DlVVoaoqNE2DoigIwxBBECCOYwRBcGzlm+SlCLSiKCgWi8jn87h69Spu3ryJtbW19N/DMMRgMIBt2we+xzAMVCqV9ORUFAVPnjzBxx9/jGazCdM0MRwOoes6fvKTn+DatWswDANnz55FuVyG53npCRkEAYIggKqqKBaL0DQN+Xweuq4jjmM8fvwYzWYT3W4Xd+7cQavVQrVaxdmzZ2EYBt5991386Ec/Sk+oJEngui5M05x5QgVBgE8++QS3bt1CGIYLO87AtxfMV199FWtra6jVarh8+TIqlcrEbUXgc7kcisUiyuUykiTBcDiEaZrY3d3Fxx9/jO3t7YWWeRrDMHD9+nWcP38ejUYDly9fRqFQwObmJjY2NjAajXDv3j3s7e0dS/kmeSkCncvloOs6dF3H66+/jl//+te4evVq+u++72N3dxe9Xi/9mqIoaDQaWF1dhaZpaag///xzPHnyBEEQIEkSjEYj6LqOt956Cz//+c/RaDTwxhtvYGlpKQ18EARwHAeu6yKfz6NWqyGfz6NUKqFarSIIAty+fRt3797F48ePsbm5iVarBcMw0pPpww8/xM2bN5HL5dJaYTQaodPpIAiCQ39+13UxGAzw2WefLewYC5qm4ezZs7hy5QrOnTuHDz74AMvLyxO3FRc3VVVRq9Vw5swZJEmCZrOJ/f19fPXVV7hz586xBbpUKuHatWt4++23cfHiRbz//vswDAOffPIJ/vKXv6DdbmNvb4+BPi6iWSeaUEIcx9jd3cXW1taBbV9//XU0Gg2oqnqg+TupCSma52LfqqqmTUbf9zEcDmFZVtqEKxaLKBQKB75nUhP/6X2LQIsautfrwff9Q39u13XhOM5zHLn5JUmSXsBM00Sv15va5FZVFZVKBZqmoVgspj+7uHhOOhYvmjj247+n8bKdtOnclyrQ04xGI/zxj3/ERx99lPZHNU3Dr371K6yvr6NarcIwjGf63YeJ4ximaeLx48ewbRu7u7tot9uo1Wp47bXXUK/XEUUR6vX6kcoax3HaH97d3cXnn3+O0Wh06PcEQYDt7e0DYwSLEkURer0e8vk8TNMEgKlN7lKphJWVFZRKJcRxjLW1tSMdY3oWA41vm9xbW1u4c+dO+jVN0/DOO+/A87z0hDuqIAjSmrndbqPVasF1XSwvL0NVVbiuO9eAFvDdooI4jtNBGcuy0Gq1MBgMDmw7aSDPNM25P+t5jPftAaDT6RwYmwCQHkvDMNKxCtu204FAsc2LKK9sGOgTzPf9NKz379/H8vIykiSBbdsIggDNZjPtP4t+fqlUwoULFw7U/K7rYn9/H3//+98XPiKrqioajQYuXLiAlZUVvPXWW6jX63AcB5ZlIQgCdLtdDIfD9ELj+z42NzfT7+90OhgMBnj06NEL6yrIgoE+wVzXRafTgWmauHXrFrrdLhRFSWs4MXKey+XSUfNGo4Gf/vSnuHLlSrof27axsbGBP/3pTzMH0J6Xpmk4d+4crl69ikuXLuFnP/sZ1tfX0Wq1sLOzA9M08fXXX8M0zTTciqKg0+ng/v37SJIEpmnCtm3s7+8/0/qgwzHQQFqz1Wq19GvjAzViyuqoFEVBPp9Pp6cKhQJ0XYemadA0bWZ/Ucxzi/lOz/OeKUc+nweAdP9i5HzSz/KiiM8TZalWq3AcB4ZhIEkSlEqlZ+bUAcDzPMRxDM/z4Pt+OvhH82Og8e2gjZhyEidQLpfDe++9h3q9nk6tHEUul0OlUsErr7wC13VRqVRw/vx5lEolnD9/HuVyGfV6PR0NnySfz6NSqaBSqeC1117DO++8M3XkV1wkarUaqtXq0Q7AgokLZqPRgGEY8H0fS0tLE7eNogj9fh+maWJ7exsPHjx4sYU95RhoAOVyGe+//z6uXLmSBlpRFKysrKBarT4zzXWU/a6trSEMQywtLR2Yhy4UCiiXy8jlcocG2jAMVKtVXLhwAdeuXZtaDtGS0HUdhmEcuayLpus6lpaWEIYhVFXFysrKxO2iKEKn00G/30ccxy+0ZSGDuQNdKpUWWY6FyuVyKBQK0DQNnudha2vrQFMuCAJ0Oh0Mh8P0a4qiwLZtjEajA3PQ29vbcF0XwLe1omg+WpaFvb09uK6LQqGQNjNHoxGiKILruvB9H5qmwTCMtBleLpcRRRG2t7fTwSJVVVEqldLmdBzHGAwG2NnZmVpDi25BoVCA4zgol8vpv7mui+FwiGKxuPB5U13XEQRBuuhlc3MTo9EIvu/Ddd10Qcy0wS5RQ49GI5immdbuxyGfz6d9+Xw+j4cPH6JUKmFnZ+fAysKTlA0lmbOTMr6y6jQSo8BLS0t49dVXD/wSkiSB53nP1JSi/zseAsuy8M0336QjzZ7nQdM0rK2t4cyZM2lgVVVNp5jEFIxY9z2+SERV1XQgyLIsuK6LdrsN13XTvqimaWg0GqjX6zMDKWrp8eCLpaUvYi5aVVUsLS2hUqmgWCzizJkzyOfzSJIEURSlf09rlYiFKWEYwnGc9CJ5HDRNS1tpxWIxba0Nh0MMBgMEQYBer/fMtNyizNP9mDvQ77777nMXiIi+v9u3b8/cZu4m9y9/+cvnKgwRLd7cNfT4OmcievEuXbo0c5u5a+jV1dXnKgwRLd7x385CRJlhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkkvkDDsQtg+OvgCGi74y/Akjc1puVzAPtOA6GwyGiKErvBSai74y/jKFerx94GMXzyjzQYRjCsqz02dEn6UVeRCeBqqrpwzOyflxU5oHudDr44osvYNs2bNvmc5WJnlIqlWAYBkqlEq5fv37gCa3PK9NAx3GMR48e4Q9/+AM6nQ729vYOvACO6GU3/hLE1dXV9K2WWfWjF9KHFmFuNpvodDpZfwTRqSaeP57L5TJ/XhqnrYgkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCKZP/VTVVUUi0UUi0WUSqVM3wpAJINSqYRisQhd16Gqaqb7zjzQuq6jVqshCAKEYZjpe3uIZLC8vIzl5WUsLS2hUChkuu+F1dCids76ucNEp92pqqFXVlbwzjvvYDQaYTgcwjTNrD+C6FSrVquoVquo1WpYXl4+uW+fzOVyWF9fx/vvvw/f99M/RPSdQqEAXddRKBSwtraW6b4zr6FzuRyKxSJyuVz6lj0i+o6maSgUCsjn85k3uTliRSQRBppIIgsZ5RbNbEVRoChK1h9BdKqJl73n8/nMp3UzD7R4K30URQjDEFEUIUmSrD+G6FRSFAWqqkLTtPTvLC1kUEzTtLR25sISooNUVU3/nPgaGvg21EmSsGYmmiCXy6V/su6SZh7op2tl9qGJDhJTuqci0HEcIwiCtA8dx/HEmloEX/xQi/jhaLHiOE5/v+JvmVplor873n3M4hwV+1jE+Z55oAeDAba2tuC6LjzPg+d5E7fL5XJYWlpCvV6HpmmoVquZL1SnxfJ9H51OB0EQwLIs2LYtVaDz+TwajQYMw0ChUEClUslkEGuRFVfmgbZtG7u7u7AsC5ZlwXGcib9kTdNw/vx5KIqCYrHI2yxPoSAI0O/3Yds2+v0+er0eoig67mJlplgsIo5jRFEEwzBgGMZxF2mmTAMdxzFs28be3t6BmzMmBTqfz6dXvTiOEYYhm9ynjAj0aDRCu91Gs9mUKtCGYaBSqaRLNOM4PvHnaOY19N7eHj799FN0Oh202210u92JgS4WixiNRmnTe2Vl5cQfLDrIsiw8fPgQe3t72NzcxN27dxGG4XEXKzONRgNxHMP3fQRBgPX19cz60IsaM8o80I7joN1uY29vD81mE51OZ+J2xWIR+/v7ME0Tuq5LdWV/WYRhiMFggF6vh2azie3tbQRBcNzFyozruuj1erAsC67rnorxAa76IJIIA00kkYWsFJtHkiTwPC9tcvd6vVMxbaWqKsrl8sIWBpwm+Xwe1WoVpmnizJkzWFlZmdrkHl+X4HneoX1tsT5BVVWUSqW5poo8z4NlWYjj+Hv/PJOMr5fI4vct9rGofvSxBToMQ9y/fx/D4RDFYhF//vOfT8W0wMWLF/Hhhx/i3Llz6WNkXtb16j/4wQ9w8+ZNWJaFfr+Pbrc7MVBJkmB3dxePHz/GcDjEF198gYcPH07cpxgkrVQqOH/+PD788ENcuHDh0HIkSYJPP/0Uv/vd79Dv97P40QB8G+ZCoYBisQjDMFCr1VCr1TLbP4DTsZZ7HlEU4fHjx3jy5AmA07NE9MaNG3jzzTdx5swZVKtVlMvlzO+YOS0qlQrOnTuXDhZNGzRKkgRfffUVPvvsM7RaLbRaLWxsbEzcPpfLoVKpYGVlBT/84Q/xm9/8Bj/+8Y8PLUeSJDAMAx999FHmgdY0Dbqup6GuVCrPvd/x4yVWVWbl2M/EWSfDSfP0EsfTciFalHnueU+S5MjN1vFm6TyP6TlN3R9FURZ2vr+cbUUiSR17DX2ayXYzwml1mn4H4y3SRZSbgT4i0zTx4MEDBEGQrnCbNLCRy+VgGAaWlpagqioMw0CxWJy4zyRJYNt2ekNLv9+H4zgTt1VVFYVCAblcDrVaDaurqzOfrBpFEVqtFvb29mb213Rdx+rqKqrVavpZz9uUFTMa4rHOs1aTJUmSjoq7rjv1WIxv7/t+5gER5fB9H57nwXGcqTMxvu/Dtm0EQYDhcIjRaDTxWIsHgIhHEK2srGQ60MZAH9FgMMCtW7fw6NEjlMtlVCqVqSOVFy5cwJUrV1Aul3H27Fk0Go2J4QjDEHt7e9jf38dgMMC9e/fQ6/Um7nP8zrTLly/jxo0bMwdqgiDAnTt38Ne//nVmmCqVCm7cuIFLly5B13VUq9XnHvSL4zi9UcfzvEOnlsStmOI2XNu2Z76sIUkSuK6b+ZSVuFCIi4ppmlP788PhELu7u7BtG1tbW9jY2Jh68TQMI33Y/gcffMBAH6cgCNI16LZtw7btiSFVFAXlchmmaR6Ye50WaNd1YVkWRqMR9vf30W63J35+Pp+H67ooFotYXl5O3yE2T5lbrdbMpZmiHJ7nQVGUTJZyippOBHWe4InBR1FTz9p/1mF+et9RFB1aFlFDm6aJfr+Pdrs98dgpioJqtZqObk+7vfj7YqCPyLZtPHr0CLquQ9O09PlpkziOg1qthnq9nl6RJwmCAJ1OBzs7O2i1Wvjyyy+xvb09cdtCoYCVlRWUy2Xouo633357Zg3qeR4eP36M27dvz3yTyfLyMl599VU0Go10UcfzLvgRTe4gCBAEwcz+o/i3eZvcABbW5A7DMO0quK47tXszGo2wt7eHwWCABw8e4G9/+9vU8DcaDSwvL2NlZQXXr19HHMeZzUcz0Efkuu7UsI0TbxC5fPkyfN/H+vo6XNedGH7f9zEcDtFut7Gzs4N79+5ha2tr4n6LxSLW19dRqVSwvr4O27Zn3kvuOA52dnbw9ddfz3x5oHiV0WAwQBzHqFQqzx0U0XQVtdKs/T3d7J5Vi4ngLaoPHUVRWo5pFzfLsrC/v49ut4tHjx7h7t27E8utKApWV1exvr6etsiyxEB/D/OcOOIeb3Eie553aKDFoJE4Mad9xvgjf8TJNmugS4Ro2uOgnt7/eG2UxV1GosshauhZzePxn08ct1nbL6KGBnAgzIfV0K7rHhj0m3asxy9WHOU+ZcIwTAdSOp0OSqXSxEAHQYBut4vRaATLsmb2GcUJEYbhoY95EmatnR4XRRFGoxG63W4aZl3X5/reaZIkwf7+fvrAi8Oa/eP9Zsdx0Ol0UK/XZ+5/MBhkfguueGCHWJ7carVgWdbEbdvtNvr9PobD4cIuLvNgoBdI1NBiysM0zamBFiPAnufNdTKIK/08g2LihQfzELWd6LeapvncA2NiWk60QuatoUWo5xnlnve4HcV4H1oMFk77DDHtOM/vY5EY6AVJkgTD4RAbGxsolUro9XpoNBoTtw3DEO12G71eD4PBALZtH7pf0cx2HAf9fn/mgIrrunM3nT3Pw+bmJsIwzOzBeEmSoNfrodVqwXEcDAaDQ7f1PC8dZLp9+3a63v8w0/qsz8P3fWxvb8P3fTSbTbTb7amtFdM00Ww201bFokbdZ2GgF6jVaqHf76eL/A9bkyxqUdHfnGa81hiNRukDGQ8jBt3mCbTjOPj888/x5ZdfpmuvsyCa0aIFME2SJOkTRAeDAXZ3d+dayy1aQVlyXRcPHjzA5ubmgTfCTCJaFIu44eIoGOgFCsNwIc0vMWgmBo1mNYl935/7BBP9xuMkajexSuu4iNZC1jX/IvHmDCKJMNBEEmGT+5QZn9axbRvdbneuJrdsb7WgyRjoU0b0cT3Pw9bWFsIwnHm3VRzH+Oabb45t5JVeHAb6lBl/GaBYnjlrFFhMobGGlh8DfQqNLypxHGfm1JKYSmGg5cdAn0Ki6SxCfZTvIbkx0KeYGCAjEjhtRSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIItpxF4CyoSgKFEUBACRJkn59/L9Jfgy0JHRdR6FQAABEUYQ4jhFFEYIgYKhfIgy0BBRFgaZpKJVKSJIEYRimYQ7DkIF+iTDQElAUBdVqFaurq4jjGK7rIggC2LYN3/cRx/FxF5FeEAZaAqqq4pVXXsHbb7+NKIrQ6/Vg2zb29vZgmibCMDzuItILwkBLolwuY2lpCUmSII5jaJoG0zSRy3Ei42XCQEsgSRIMBgNsb29DVVUkSQJd11GpVLCysoJyuQzbtmFZ1nEXlRaMl28JxHGM/f19bGxs4MmTJwjDEKVSCbVaDefOncP58+dRrVbTaS2SF2toSYhBMODbGjuXy0HTNBQKhbQJrigKR7wlx0BLII5jjEYjBEGAWq2GV155Bfl8HuVyGWfOnIHneeh2u8ddTHoBGGhJ2Lad1tCiRtZ1HdVqFYVCAcVikU3ulwADLZkgCNDtdqHrOoIggOu68H0ftm2zuf0SYKAlY9s2/v73v+Mf//Ef0ymsOI7hOA4XmLwEGGjJRFGEfr9/3MWgY8JpKyKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUS0eTeMomjmNkmSII7j5yoQnS6KogAASqUSyuVy+v9ZiKIIrusiDEPEcYwwDDPb90kQxzGCIEAQBHMdt3K5PHObuQPt+/7MbZIkSQ9+kiTz7ppOKUVRkMvlkMvlsLKygosXL0LT5j6lZnIcB81mE7Ztw3VdWJYlxXklKj5xwTJNc67vW1pamrnN3Ed/npo3SZIDB1yGg0+HUxQFiqKgWCyiVquhUChktm9N09Dtdg/UYjKcU+JnSJIEURTNXUPPY+5Ae543c5skSRAEQXr1IbkpigJVVaFpGs6ePYvr169D1/XM9i/C3Gq1AACWZUnRpRNBDsMQlmVhOBxmtu+FBFqEWYarKU0nAp3P5/HKK6/gvffeg2EYme1/e3sb7XY7Pfk7nU5m+z5O4zWzZVno9/svvoaeJ5xPN7np5ZAkCXzfz7yPa9s2fN9HFEVS1MzCeE5Ef/qFB5roaWKUNo5j3Lt3D7///e8z7UOPRiM8fPgQw+EQlmWxGzcHBpq+N9F0TJIEu7u7cF0XuVx2Sxt838dwOITv+wiCgK2/Ocwd6IcPH87cJkkSNJtNOI4D13V5RX1JiCa3bduZzkOHYYggCKSbCg3DEI7jYDAY4MGDB8jn83N93y9+8YuZ2yjJnEfpt7/97cxtkiTBxsYG7ty5A9u2YVkWHMeZZ/d0yqmqClVVM92n6F+KPqcsgRbHSlVV1Ov1uRaMAPNVqnPX0Ds7O3Nt1+124Xle2reil0MURWyRzWn8WGVd4c0d6Pv378+1Xb/fh23bB6aviOjFmLvJPe/oZRzHac0sSxOJ6CSYJ09zBzrLwQ4iOrp5osrbJ4kkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpJIps8UI6LjxRqaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoE+B//7f/zsURcGtW7cm/vujR4+gKMrUP//xP/7HdNuf//znU7e7e/fuofsZ//Po0aMX9NPTUWjHXQDKzr/6V/8K//yf//Nnvv7uu+8e+P8LFy7gP/yH//DMdufOncP/+B//48DX/tN/+k/45ptv8J//838+8PXV1dUMSkxZY6AlcuPGDfzrf/2vZ25Xr9enbvf01//X//pf6PV6c+2Xjh+b3EQSYQ0tEdu20el0nvn60tISNO27X3UURc9sVywWUalUFl5GWizW0BL59//+32N1dfWZP08Ppt29e/eZbf7dv/t3x1RqyhJraIn823/7b/Ev/+W/fObrb7755oH/v3z5Mv7rf/2vB752/vz5hZaNXgwGWiJXr17FP/tn/2zmdoZhzLUdnT5schNJhIEmkggDTSQR9qFPkf/23/4b/vf//t/PfP1f/It/AQD47LPP8D//5/985t9ff/11/NN/+k8XXj46fgz0KfJf/st/mfj1n//85wCAf/iHf8A//MM/PPPv/+bf/BsG+iWhJEmSHHchiCgb7EMTSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBKZe2GJoiiLLAcRzTDPkhHW0EQSYaCJJMJAE0nkpbk5Q4wBFAoFlEolqKp64N/jOEYcxwe2VxQFudzBa14YhnBdF2EYIkkSxHEMRVGg6zry+TxyuRxUVYWiKEiSJO33iP8W+x3/DLHfKIoQRRF830cURQf2pes6CoXCM2Ue/4zDuK4Lz/OOeNS+H3Eccrkc8vn81PGXp4+D+H/xu4iiCI7jIIqiF1LuSeXTdR2qqkJVVWiaBkVREIYhgiBAHMcIguDYyjfJSxFoRVFQLBaRz+dx9epV3Lx5E2tra+m/h2GIwWAA27YPfI9hGKhUKunJqSgKnjx5go8//hjNZhOmaWI4HELXdfzkJz/BtWvXYBgGzp49i3K5DM/z0hMyCAIEQQBVVVEsFqFpGvL5PHRdRxzHePz4MZrNJrrdLu7cuYNWq4VqtYqzZ8/CMAy8++67+NGPfpSeUEmSwHVdmKY584QKggCffPIJbt26hTAMF3acgW8vmK+++irW1tZQq9Vw+fLlqU8TFYHP5XIoFosol8tIkgTD4RCmaWJ3dxcff/wxtre3F1rmaQzDwPXr13H+/Hk0Gg1cvnwZhUIBm5ub2NjYwGg0wr1797C3t3cs5ZvkpQh0LpeDruvQdR2vv/46fv3rX+Pq1avpv/u+j93dXfR6vfRriqKg0WhgdXUVmqalof7888/x5MkTBEGAJEkwGo2g6zreeust/PznP0ej0cAbb7yBpaWlNPBBEMBxHLiui3w+j1qthnw+j1KphGq1iiAIcPv2bdy9exePHz/G5uYmWq0WDMNIT6YPP/wQN2/eRC6XS2uF0WiETqeDIAgO/fld18VgMMBnn322sGMsaJqGs2fP4sqVKzh37hw++OADLC8vT9xWXNxUVUWtVsOZM2eQJAmazSb29/fx1Vdf4c6dO8cW6FKphGvXruHtt9/GxYsX8f7778MwDHzyySf4y1/+gna7jb29PQb6uIhmnWhCCXEcY3d3F1tbWwe2ff3119FoNKCq6oHm76QmpGiei32rqpo2GX3fx3A4hGVZaROuWCyiUCgc+J5JTfyn9y0CLWroXq8H3/cP/bld14XjOM9x5OaXJEl6ATNNE71eb2qTW1VVVCoVaJqGYrGY/uzi4jnpWLxo4tiP/57Gy3bSpnNfqkBPMxqN8Mc//hEfffRR2h/VNA2/+tWvsL6+jmq1CsMwnul3HyaOY5imicePH8O2bezu7qLdbqNWq+G1115DvV5HFEWo1+tHKmscx2l/eHd3F59//jlGo9Gh3xMEAba3tw+MESxKFEXo9XrI5/MwTRMApja5S6USVlZWUCqVEMcx1tbWjnSM6VkMNL5tcm9tbeHOnTvp1zRNwzvvvAPP89IT7qiCIEhr5na7jVarBdd1sby8DFVV4bruXANawHeLCuI4TgdlLMtCq9XCYDA4sO2kgTzTNOf+rOcx3rcHgE6nc2BsAkB6LA3DSMcqbNtOBwLFNnz2xtEx0CeY7/tpWO/fv4/l5WUkSQLbthEEAZrNZtp/Fv38UqmECxcuHKj5XdfF/v4+/v73vy98RFZVVTQaDVy4cAErKyt46623UK/X4TgOLMtCEATodrsYDofphcb3fWxubqbf3+l0MBgM8OjRoxfWVZAFA32Cua6LTqcD0zRx69YtdLtdKIqS1nBi5DyXy6Wj5o1GAz/96U9x5cqVdD+2bWNjYwN/+tOfZg6gPS9N03Du3DlcvXoVly5dws9+9jOsr6+j1WphZ2cHpmni66+/hmmaabgVRUGn08H9+/eRJAlM04Rt29jf33+m9UGHY6CBtGar1Wrp18YHasSU1VEpioJ8Pp9OTxUKBei6Dk3ToGnazP6imOcW852e5z1Tjnw+DwDp/sXI+aSf5UURnyfKUq1W4TgODMNAkiQolUrPzKkDgOd5iOMYnufB9/108I/mx0Dj20EbMeUkTqBcLof33nsP9Xo9nVo5ilwuh0qlgldeeQWu66JSqeD8+fMolUo4f/48yuUy6vV6Oho+ST6fR6VSQaVSwWuvvYZ33nln6sivuEjUajVUq9WjHYAFExfMRqMBwzDg+z6WlpYmbhtFEfr9PkzTxPb2Nh48ePBiC3vKMdAAyuUy3n//fVy5ciUNtKIoWFlZQbVafWaa6yj7XVtbQxiGWFpaOjAPXSgUUC6XkcvlDg20YRioVqu4cOECrl27NrUcoiWh6zoMwzhyWRdN13UsLS0hDEOoqoqVlZWJ24lX3fb7fcRx/EJbFjKYO9ClUmmR5VioXC6HQqEATdPgeR62trYONOWCIECn08FwOEy/pigKbNvGaDQ6MAe9vb0N13UBfFsriuajZVnY29uD67ooFAppM3M0GiGKIriuC9/3oWkaDMNIm+HlchlRFGF7ezsdLFJVFaVSKW1Ox3GMwWCAnZ2dqTW06BYUCgU4joNyuZz+m+u6GA6HKBaLC5831XUdQRCki142NzcxGo3g+z5c100XxEwb7BI19Gg0gmmaae1+HPL5fNqXz+fzePjwIUqlEnZ2dg6sLDxJ2Zj7udzjK6tOIzEKvLS0hFdfffXALyFJEnie90xNKfq/4yGwLAvffPNNOtLseR40TcPa2hrOnDmTBlZV1XSKSUzBiHXf44tEVFVNB4Isy4Lrumi323BdN+2LapqGRqOBer0+M5Cilh4Pvlha+iLmolVVxdLSEiqVCorFIs6cOYN8Po8kSRBFUfr3tFaJWJgShiEcx0kvksdB07S0lVYsFtPW2nA4xGAwQBAE6PV6z0zLLco83Y+5A/3uu+8+d4GI6Pu7ffv2zG3mbnL/8pe/fK7CENHizV1Dj69zJqIX79KlSzO3mbuGXl1dfa7CENHiHf/tLESUGQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCKZP+BA3DI4/goYIvrO+CuAxG29Wck80I7jYDgcIoqi9F5gIvrO+MsY6vX6gYdRPK/MAx2GISzLSp8dfZJe5EV0Eqiqmj48I+vHRWUe6E6ngy+++AK2bcO2bT5XmegppVIJhmGgVCrh+vXrB57Q+rwyDXQcx3j06BH+8Ic/oNPpYG9v78AL4IheduMvQVxdXU3faplVP3ohfWgR5maziU6nk/VHEJ1q4vnjuVwu8+elcdqKSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkkvlTP1VVRbFYRLFYRKlUyvStAEQyKJVKKBaL0HUdqqpmuu/MA63rOmq1GoIgQBiGmb63h0gGy8vLWF5extLSEgqFQqb7XlgNLWrnrJ87THTanaoaemVlBe+88w5GoxGGwyFM08z6I4hOtWq1imq1ilqthuXl5ZP79slcLof19XW8//778H0//UNE3ykUCtB1HYVCAWtra5nuO/MaOpfLoVgsIpfLpW/ZI6LvaJqGQqGAfD6feZObI1ZEEmGgiSSykFFu0cxWFAWKomT9EUSnmnjZez6fz3xaN/NAi7fSR1GEMAwRRRGSJMn6Y4hOJUVRoKoqNE1L/87SQgbFNE1La2cuLCE6SFXV9M+Jr6GBb0OdJAlrZqIJcrlc+ifrLmnmgX66VmYfmuggMaV7KgIdxzGCIEj70HEcT6ypRfDFD7WIH44WK47j9Pcr/papVSb6u+PdxyzOUbGPRZzvmQd6MBhga2sLruvC8zx4njdxu1wuh6WlJdTrdWiahmq1mvlCdVos3/fR6XQQBAEsy4Jt21IFOp/Po9FowDAMFAoFVCqVTAaxFllxZR5o27axu7sLy7JgWRYcx5n4S9Y0DefPn4eiKCgWi7zN8hQKggD9fh+2baPf76PX6yGKouMuVmaKxSLiOEYURTAMA4ZhHHeRZso00HEcw7Zt7O3tHbg5Y1Kg8/l8etWL4xhhGLLJfcqIQI9GI7TbbTSbTakCbRgGKpVKukQzjuMTf45mXkPv7e3h008/RafTQbvdRrfbnRjoYrGI0WiUNr1XVlZO/MGigyzLwsOHD7G3t4fNzU3cvXsXYRged7Ey02g0EMcxfN9HEARYX1/PrA+9qDGjzAPtOA7a7Tb29vbQbDbR6XQmblcsFrG/vw/TNKHrulRX9pdFGIYYDAbo9XpoNpvY3t5GEATHXazMuK6LXq8Hy7Lguu6pGB/gqg8iiTDQRBJZyEqxeSRJAs/z0iZ3r9c7FdNWqqqiXC4vbGHAaZLP51GtVmGaJs6cOYOVlZWpTe7xdQme5x3a1xbrE1RVRalUmmuqyPM8WJaFOI6/988zyfh6iSx+32Ifi+pHH1ugwzDE/fv3MRwOUSwW8ec///lUTAtcvHgRH374Ic6dO5c+RuZlXa/+gx/8ADdv3oRlWej3++h2uxMDlSQJdnd38fjxYwyHQ3zxxRd4+PDhxH2KQdJKpYLz58/jww8/xIULFw4tR5Ik+PTTT/G73/0O/X4/ix8NwLdhLhQKKBaLMAwDtVoNtVots/0DOB1ruecRRREeP36MJ0+eADg9S0Rv3LiBN998E2fOnEG1WkW5XM78jpnTolKp4Ny5c+lg0bRBoyRJ8NVXX+Gzzz5Dq9VCq9XCxsbGxO1zuRwqlQpWVlbwwx/+EL/5zW/w4x//+NByJEkCwzDw0UcfZR5oTdOg63oa6kql8tz7HT9eYlVlVo79TJx1Mpw0Ty9xPC0XokWZ5573JEmO3Gwdb5bO85ie09T9URRlYef7y9lWJJLUsdfQp5lsNyOcVqfpdzDeIl1EuRnoIzJNEw8ePEAQBOkKt0kDG7lcDoZhYGlpCaqqwjAMFIvFiftMkgS2bac3tPT7fTiOM3FbVVVRKBSQy+VQq9Wwuro688mqURSh1Wphb29vZn9N13Wsrq6iWq2mn/W8TVkxoyEe6zxrNVmSJOmouOu6U4/F+Pa+72ceEFEO3/fheR4cx5k6E+P7PmzbRhAEGA6HGI1GE4+1eACIeATRyspKpgNtDPQRDQYD3Lp1C48ePUK5XEalUpk6UnnhwgVcuXIF5XIZZ8+eRaPRmBiOMAyxt7eH/f19DAYD3Lt3D71eb+I+x+9Mu3z5Mm7cuDFzoCYIAty5cwd//etfZ4apUqngxo0buHTpEnRdR7Vafe5BvziO0xt1PM87dGpJ3IopbsO1bXvmyxqSJIHruplPWYkLhbiomKY5tT8/HA6xu7sL27axtbWFjY2NqRdPwzDSh+1/8MEHDPRxCoIgXYNu2zZs254YUkVRUC6XYZrmgbnXaYF2XReWZWE0GmF/fx/tdnvi5+fzebiui2KxiOXl5fQdYvOUudVqzVyaKcrheR4URclkKaeo6URQ5wmeGHwUNfWs/Wcd5qf3HUXRoWURNbRpmuj3+2i32xOPnaIoqFar6ej2tNuLvy8G+ohs28ajR4+g6zo0TUufnzaJ4zio1Wqo1+vpFXmSIAjQ6XSws7ODVquFL7/8Etvb2xO3LRQKWFlZQblchq7rePvtt2fWoJ7n4fHjx7h9+/bMN5ksLy/j1VdfRaPRSBd1PO+CH9HkDoIAQRDM7D+Kf5u3yQ1gYU3uMAzTroLrulO7N6PRCHt7exgMBnjw4AH+9re/TQ1/o9HA8vIyVlZWcP36dcRxnNl8NAN9RK7rTg3bOPEGkcuXL8P3fayvr8N13Ynh930fw+EQ7XYbOzs7uHfvHra2tibut1gsYn19HZVKBevr67Bte+a95I7jYGdnB19//fXMlweKVxkNBgPEcYxKpfLcQRFNV1Erzdrf083uWbWYCN6i+tBRFKXlmHZxsywL+/v76Ha7ePToEe7evTux3IqiYHV1Fevr62mLLEsM9Pcwz4kj7vEWJ7LneYcGWgwaiRNz2meMP/JHnGyzBrpEiKY9Durp/Y/XRlncZSS6HKKGntU8Hv/5xHGbtf0iamgAB8J8WA3tuu6BQb9px3r8YsVR7lMmDMN0IKXT6aBUKk0MdBAE6Ha7GI1GsCxrZp9RnBBhGB76mCdh1trpcVEUYTQaodvtpmHWdX2u750mSRLs7++nD7w4rNk/3m92HAedTgf1en3m/geDQea34IoHdojlya1WC5ZlTdy23W6j3+9jOBwu7OIyDwZ6gUQNLaY8TNOcGmgxAux53lwng7jSzzMoJl54MA9R24l+q2mazz0wJqblRCtk3hpahHqeUe55j9tRjPehxWDhtM8Q047z/D4WiYFekCRJMBwOsbGxgVKphF6vh0ajMXHbMAzRbrfR6/UwGAxg2/ah+xXNbMdx0O/3Zw6ouK47d9PZ8zxsbm4iDMPMHoyXJAl6vR5arRYcx8FgMDh0W8/z0kGm27dvp+v9DzOtz/o8fN/H9vY2fN9Hs9lEu92e2loxTRPNZjNtVSxq1H0WBnqBWq0W+v1+usj/sDXJohYV/c1pxmuN0WiUPpDxMGLQbZ5AO46Dzz//HF9++WW69joLohktWgDTJEmSPkF0MBhgd3d3rrXcohWUJdd18eDBA2xubh54I8wkokWxiBsujoKBXqAwDBfS/BKDZmLQaFaT2Pf9uU8w0W88TqJ2E6u0jotoLWRd8y8Sb84gkggDTSQRNrlPmfFpHdu20e1252pyy/ZWC5qMgT5lRB/X8zxsbW0hDMOZd1vFcYxvvvnm2EZe6cVhoE+Z8ZcBiuWZs0aBxRQaa2j5MdCn0PiiEsdxZk4tiakUBlp+DPQpJJrOItRH+R6SGwN9iokBMiKB01ZEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRPvXzBCsUCiiVSlAUBb7vIwgCxHGMOI75jG2aiIE+wSqVCi5cuIBcLoder4d+v48wDOG6Lh/fSxMx0CdYPp9HuVxGoVCA4zjQtG9/XblcjoGmiRjoE6xer+OHP/whisUiSqUS8vk8XNdFu92GZVl80D49g4E+wZaWlvDGG2+gUqmkL6QzTROWZcH3fURRxP40HcBAn2BRFMFxHKiqCk3TUKlUkCQJdF1HoVBAEARzv9uKXg4M9AnWbDbxf/7P/0G1WsW5c+fw5ptvYjAYwLZtaJoG0zTh+z7CMDzuotIJwUCfYP1+H/fv30elUsHq6ipeeeUVVCoVbG1twXEcxHE881Wy9HJhoE+wKIrgeR5yuRy63S52d3cxHA4xHA7hui5832f/mQ5goE8w3/fTJvaDBw/SEO/s7GA0GqW1NJHAQJ9gYlVYHMcYjUbo9XoIggCO46R9Z9bQNI6BPgWSJMFwOATwbTNcTFsx0PQ0BvoUiOMYg8EgDXWSJOkfonEM9CnBvjLNg3MeRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEQaaSCIMNJFEGGgiiTDQRBJhoIkkwkATSYSBJpIIA00kEW3eDaMomrlNkiSI4/i5CkQnh6ZpKJVKUFUVuVwOqqou7LPiOEYURYjjGK7rwvf9hX3WSRHHMYIgQBAEUBRl5vblcnnmNnMHep4DnCQJwjBEHMdIkmTeXdMJVSqVcP78eRSLRei6jmKxONeJ9314ngfXdREEAZrNJvb39xfyOSeBqPiiKILrujBNc67vW1pamrnN3IGep+ZNkuRAkBnq001VVZRKJRiGgVKphHK5vLBAu64LTdPg+z7y+fxCPuOkELlIkgRRFM1dQ89j7kB7njdzmyRJEARBevWh080wDFy+fBlnzpxBrVbD0tLSwgI9Go3Q7/dhWRYGgwH29vakrRBEkMMwhGVZGA6Hme17IYEWYZb1F/KyqFQqeO2113Du3Dmsrq5ibW1tIf3oJEnQ7XbRbDYxGAzw6NGjzD/jJBmvmS3LQr/ff/E19DzhfLrJTaeb6OM5jgPTNGEYBnK57CdGkiSBZVmwbRuu6yIMw8w/4yQZz4noT7/wQNPLp9fr4fbt26hUKiiXywsLtBjZNk0Tnudhd3eXFcP3xEDTVKZpYnNzE/l8HpqmQdO0hQQaAMIwhO/7iKIo0z7ly2buQD98+HDmNkmSoNlswnEcuK7LgbFTLo5jeJ6HKIqgqio0bXHX/yiKDvyRWRiGcBwHg8EADx48mHtU/xe/+MXMbZRkzrbNb3/725nbJEmCjY0N3LlzB7Ztw7IsOI4zz+7pBFIUBaqqpv27RY1wC6JvGcex1AuUVFVN/9Tr9bkWjADzVapzX3J3dnbm2q7b7cLzvHT6ik4vsVCIsjXeCsm6wps70Pfv359ru36/D9u2D0xfEdGLMXeTu1AozLXD8eYSRyqJsjNPnuYO9KL7T0R0uHmiytsniSTCQBNJhIEmkggDTSQRBppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkkimzxQjouPFGppIIgw0kUQYaCKJMNBEEmGgiSTCQBNJhIEmkggDTSQRBppIIv8PT2lL+reYvc0AAAAASUVORK5CYII=",
      "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": 75,
   "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": 76,
   "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=100, n_steps_per_epoch=10)\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": 77,
   "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": 78,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Original model action:  [3]\n",
      "Original model action value:  [1.1475153]\n",
      "Passing:  3 1.1475153\n",
      "Original model action:  [3]\n",
      "Original model action value:  [1.1552153]\n",
      "Passing:  3 1.1552153\n",
      "Original model action:  [3]\n",
      "Original model action value:  [1.1562788]\n",
      "Passing:  3 1.1562788\n",
      "Original model action:  [3]\n",
      "Original model action value:  [1.139393]\n",
      "Passing:  3 1.139393\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 1 has 645 trajectories out of 4228\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-04-17 18:59:51 [debug    ] RandomIterator is selected.   \n",
      "2024-04-17 18:59:51 [info     ] Directory is created at d3rlpy_logs\\DiscreteSAC_20240417185951\n",
      "2024-04-17 18:59:51 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-04-17 18:59:51 [debug    ] Building models...            \n",
      "2024-04-17 18:59:52 [debug    ] Models have been built.       \n",
      "2024-04-17 18:59:52 [info     ] Parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\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': 4}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 10/10 [00:04<00:00,  2.15it/s, temp_loss=0.0266, temp=1, critic_loss=1.71, actor_loss=-1.37]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 18:59:56 [info     ] DiscreteSAC_20240417185951: epoch=1 step=10 epoch=1 metrics={'time_sample_batch': 0.0068737506866455075, 'time_algorithm_update': 0.455118465423584, 'temp_loss': 0.027153842709958555, 'temp': 0.998356282711029, 'critic_loss': 1.3895124256610871, 'actor_loss': -1.5381006002426147, 'time_step': 0.4622126340866089} step=10\n",
      "2024-04-17 18:59:56 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_10.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/10: 100%|██████████| 10/10 [00:04<00:00,  2.19it/s, temp_loss=0.0262, temp=0.997, critic_loss=0.615, actor_loss=-2.04]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:01 [info     ] DiscreteSAC_20240417185951: epoch=2 step=20 epoch=2 metrics={'time_sample_batch': 0.007535004615783691, 'time_algorithm_update': 0.4475152254104614, 'temp_loss': 0.022137716971337797, 'temp': 0.9954183280467988, 'critic_loss': 0.33940318673849107, 'actor_loss': -2.6068787574768066, 'time_step': 0.4552532911300659} step=20\n",
      "2024-04-17 19:00:01 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_20.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/10: 100%|██████████| 10/10 [00:04<00:00,  2.28it/s, temp_loss=0.024, temp=0.994, critic_loss=0.192, actor_loss=-2.36]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:05 [info     ] DiscreteSAC_20240417185951: epoch=3 step=30 epoch=3 metrics={'time_sample_batch': 0.006152009963989258, 'time_algorithm_update': 0.430195689201355, 'temp_loss': 0.02543841265141964, 'temp': 0.9925889492034912, 'critic_loss': 0.19845907539129257, 'actor_loss': -2.4079041957855223, 'time_step': 0.43678429126739504} step=30\n",
      "2024-04-17 19:00:05 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_30.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/10: 100%|██████████| 10/10 [00:04<00:00,  2.34it/s, temp_loss=0.0261, temp=0.991, critic_loss=0.169, actor_loss=-2.74]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:10 [info     ] DiscreteSAC_20240417185951: epoch=4 step=40 epoch=4 metrics={'time_sample_batch': 0.005861806869506836, 'time_algorithm_update': 0.419066047668457, 'temp_loss': 0.02615120876580477, 'temp': 0.9896484076976776, 'critic_loss': 0.15885896384716033, 'actor_loss': -2.6833322048187256, 'time_step': 0.42514102458953856} step=40\n",
      "2024-04-17 19:00:10 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_40.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/10: 100%|██████████| 10/10 [00:04<00:00,  2.22it/s, temp_loss=0.0261, temp=0.988, critic_loss=0.159, actor_loss=-2.51]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:14 [info     ] DiscreteSAC_20240417185951: epoch=5 step=50 epoch=5 metrics={'time_sample_batch': 0.006233596801757812, 'time_algorithm_update': 0.44148013591766355, 'temp_loss': 0.02612737212330103, 'temp': 0.986651611328125, 'critic_loss': 0.14808314368128778, 'actor_loss': -2.5828553199768067, 'time_step': 0.4478156328201294} step=50\n",
      "2024-04-17 19:00:14 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_50.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/10: 100%|██████████| 10/10 [00:04<00:00,  2.27it/s, temp_loss=0.0261, temp=0.985, critic_loss=0.11, actor_loss=-2.68]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:19 [info     ] DiscreteSAC_20240417185951: epoch=6 step=60 epoch=6 metrics={'time_sample_batch': 0.006622219085693359, 'time_algorithm_update': 0.4322230100631714, 'temp_loss': 0.02615604568272829, 'temp': 0.9836513638496399, 'critic_loss': 0.12920888662338256, 'actor_loss': -2.638979768753052, 'time_step': 0.4389511585235596} step=60\n",
      "2024-04-17 19:00:19 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_60.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/10: 100%|██████████| 10/10 [00:04<00:00,  2.28it/s, temp_loss=0.0262, temp=0.982, critic_loss=0.14, actor_loss=-2.59]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:23 [info     ] DiscreteSAC_20240417185951: epoch=7 step=70 epoch=7 metrics={'time_sample_batch': 0.005805754661560058, 'time_algorithm_update': 0.43041000366210935, 'temp_loss': 0.026286484301090242, 'temp': 0.980658882856369, 'critic_loss': 0.14035867899656296, 'actor_loss': -2.6376606702804564, 'time_step': 0.4364216089248657} step=70\n",
      "2024-04-17 19:00:23 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_70.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/10: 100%|██████████| 10/10 [00:04<00:00,  2.35it/s, temp_loss=0.0264, temp=0.979, critic_loss=0.207, actor_loss=-2.65]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:27 [info     ] DiscreteSAC_20240417185951: epoch=8 step=80 epoch=8 metrics={'time_sample_batch': 0.005912232398986817, 'time_algorithm_update': 0.4176741123199463, 'temp_loss': 0.02641369141638279, 'temp': 0.9776727318763733, 'critic_loss': 0.14095460772514343, 'actor_loss': -2.608592891693115, 'time_step': 0.42382259368896485} step=80\n",
      "2024-04-17 19:00:27 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_80.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/10: 100%|██████████| 10/10 [00:04<00:00,  2.43it/s, temp_loss=0.0265, temp=0.976, critic_loss=0.156, actor_loss=-2.63]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:32 [info     ] DiscreteSAC_20240417185951: epoch=9 step=90 epoch=9 metrics={'time_sample_batch': 0.00491800308227539, 'time_algorithm_update': 0.4044216156005859, 'temp_loss': 0.026495152711868288, 'temp': 0.974692440032959, 'critic_loss': 0.15392423868179322, 'actor_loss': -2.6068325281143188, 'time_step': 0.4096713066101074} step=90\n",
      "2024-04-17 19:00:32 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_90.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/10: 100%|██████████| 10/10 [00:04<00:00,  2.35it/s, temp_loss=0.0265, temp=0.973, critic_loss=0.114, actor_loss=-2.59]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:36 [info     ] DiscreteSAC_20240417185951: epoch=10 step=100 epoch=10 metrics={'time_sample_batch': 0.005324149131774902, 'time_algorithm_update': 0.41848390102386473, 'temp_loss': 0.026611636951565744, 'temp': 0.9717194378376007, 'critic_loss': 0.12298234701156616, 'actor_loss': -2.6303174018859865, 'time_step': 0.4239093542098999} step=100\n",
      "2024-04-17 19:00:36 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417185951\\model_100.pt\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1888446]\n",
      "Passing:  3 1.1888446\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1998907]\n",
      "Passing:  3 1.1998907\n",
      "New model action:  [3]\n",
      "New model action value:  [1.2001013]\n",
      "Passing:  3 1.2001013\n",
      "New model action:  [3]\n",
      "New model action value:  [1.181586]\n",
      "Passing:  3 1.181586\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 2 has 736 trajectories out of 4228\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-04-17 19:00:36 [debug    ] RandomIterator is selected.   \n",
      "2024-04-17 19:00:36 [info     ] Directory is created at d3rlpy_logs\\DiscreteSAC_20240417190036\n",
      "2024-04-17 19:00:36 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-04-17 19:00:36 [debug    ] Building models...            \n",
      "2024-04-17 19:00:36 [debug    ] Models have been built.       \n",
      "2024-04-17 19:00:36 [info     ] Parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\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': 4}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 10/10 [00:04<00:00,  2.27it/s, temp_loss=0.0264, temp=1, critic_loss=1.56, actor_loss=-1.37]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:41 [info     ] DiscreteSAC_20240417190036: epoch=1 step=10 epoch=1 metrics={'time_sample_batch': 0.0060252189636230465, 'time_algorithm_update': 0.43235201835632325, 'temp_loss': 0.026091165468096734, 'temp': 0.9983587741851807, 'critic_loss': 1.3919852137565614, 'actor_loss': -1.5235510349273682, 'time_step': 0.43848934173583987} step=10\n",
      "2024-04-17 19:00:41 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_10.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/10: 100%|██████████| 10/10 [00:04<00:00,  2.30it/s, temp_loss=0.0259, temp=0.997, critic_loss=0.723, actor_loss=-1.97]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:45 [info     ] DiscreteSAC_20240417190036: epoch=2 step=20 epoch=2 metrics={'time_sample_batch': 0.006589078903198242, 'time_algorithm_update': 0.4261343240737915, 'temp_loss': 0.024979851208627224, 'temp': 0.9953884601593017, 'critic_loss': 0.3649374142289162, 'actor_loss': -2.5708745956420898, 'time_step': 0.43281896114349366} step=20\n",
      "2024-04-17 19:00:45 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_20.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/10: 100%|██████████| 10/10 [00:04<00:00,  2.20it/s, temp_loss=0.0224, temp=0.994, critic_loss=0.147, actor_loss=-2.47]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:50 [info     ] DiscreteSAC_20240417190036: epoch=3 step=30 epoch=3 metrics={'time_sample_batch': 0.005765533447265625, 'time_algorithm_update': 0.4465567350387573, 'temp_loss': 0.023186440765857696, 'temp': 0.9924908995628356, 'critic_loss': 0.18180751353502272, 'actor_loss': -2.5004430294036863, 'time_step': 0.4526418924331665} step=30\n",
      "2024-04-17 19:00:50 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_30.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/10: 100%|██████████| 10/10 [00:04<00:00,  2.33it/s, temp_loss=0.0251, temp=0.991, critic_loss=0.224, actor_loss=-2.73]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:54 [info     ] DiscreteSAC_20240417190036: epoch=4 step=40 epoch=4 metrics={'time_sample_batch': 0.005454015731811523, 'time_algorithm_update': 0.42238128185272217, 'temp_loss': 0.025838435254991056, 'temp': 0.9896054267883301, 'critic_loss': 0.1673162579536438, 'actor_loss': -2.6317445993423463, 'time_step': 0.42815937995910647} step=40\n",
      "2024-04-17 19:00:54 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_40.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/10: 100%|██████████| 10/10 [00:04<00:00,  2.45it/s, temp_loss=0.0264, temp=0.988, critic_loss=0.117, actor_loss=-2.5]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:00:58 [info     ] DiscreteSAC_20240417190036: epoch=5 step=50 epoch=5 metrics={'time_sample_batch': 0.0053882598876953125, 'time_algorithm_update': 0.4011422634124756, 'temp_loss': 0.026450135558843613, 'temp': 0.9866241097450257, 'critic_loss': 0.14712570011615753, 'actor_loss': -2.5983464241027834, 'time_step': 0.40664775371551515} step=50\n",
      "2024-04-17 19:00:58 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_50.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/10: 100%|██████████| 10/10 [00:04<00:00,  2.35it/s, temp_loss=0.0265, temp=0.985, critic_loss=0.173, actor_loss=-2.69]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:02 [info     ] DiscreteSAC_20240417190036: epoch=6 step=60 epoch=6 metrics={'time_sample_batch': 0.0052290201187133786, 'time_algorithm_update': 0.4185349702835083, 'temp_loss': 0.02651936374604702, 'temp': 0.9835989654064179, 'critic_loss': 0.14970612153410912, 'actor_loss': -2.601855421066284, 'time_step': 0.42386455535888673} step=60\n",
      "2024-04-17 19:01:02 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_60.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/10: 100%|██████████| 10/10 [00:04<00:00,  2.36it/s, temp_loss=0.0265, temp=0.982, critic_loss=0.114, actor_loss=-2.59]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:07 [info     ] DiscreteSAC_20240417190036: epoch=7 step=70 epoch=7 metrics={'time_sample_batch': 0.0062231779098510746, 'time_algorithm_update': 0.4164940595626831, 'temp_loss': 0.02656409628689289, 'temp': 0.9805724143981933, 'critic_loss': 0.14756250604987145, 'actor_loss': -2.6309106826782225, 'time_step': 0.4228289842605591} step=70\n",
      "2024-04-17 19:01:07 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_70.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/10: 100%|██████████| 10/10 [00:04<00:00,  2.35it/s, temp_loss=0.0266, temp=0.979, critic_loss=0.128, actor_loss=-2.59]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:11 [info     ] DiscreteSAC_20240417190036: epoch=8 step=80 epoch=8 metrics={'time_sample_batch': 0.0056297540664672855, 'time_algorithm_update': 0.41870708465576173, 'temp_loss': 0.02670511230826378, 'temp': 0.9775558471679687, 'critic_loss': 0.1356653206050396, 'actor_loss': -2.605422115325928, 'time_step': 0.4244609594345093} step=80\n",
      "2024-04-17 19:01:11 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_80.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/10: 100%|██████████| 10/10 [00:04<00:00,  2.39it/s, temp_loss=0.0268, temp=0.976, critic_loss=0.178, actor_loss=-2.65]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:15 [info     ] DiscreteSAC_20240417190036: epoch=9 step=90 epoch=9 metrics={'time_sample_batch': 0.005363869667053223, 'time_algorithm_update': 0.4111826419830322, 'temp_loss': 0.026830922439694406, 'temp': 0.9745474815368652, 'critic_loss': 0.15178677514195443, 'actor_loss': -2.602710008621216, 'time_step': 0.41686971187591554} step=90\n",
      "2024-04-17 19:01:15 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_90.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/10: 100%|██████████| 10/10 [00:04<00:00,  2.37it/s, temp_loss=0.0268, temp=0.973, critic_loss=0.103, actor_loss=-2.62]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:19 [info     ] DiscreteSAC_20240417190036: epoch=10 step=100 epoch=10 metrics={'time_sample_batch': 0.005318641662597656, 'time_algorithm_update': 0.4153627872467041, 'temp_loss': 0.026837921515107156, 'temp': 0.971549266576767, 'critic_loss': 0.1301785461604595, 'actor_loss': -2.6073734998703, 'time_step': 0.4208946466445923} step=100\n",
      "2024-04-17 19:01:20 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190036\\model_100.pt\n",
      "New model action:  [3]\n",
      "New model action value:  [1.128239]\n",
      "Passing:  3 1.128239\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1393524]\n",
      "Passing:  3 1.1393524\n",
      "New model action:  [3]\n",
      "New model action value:  [1.139132]\n",
      "Passing:  3 1.139132\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1205112]\n",
      "Passing:  3 1.1205112\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 3 has 1022 trajectories out of 4228\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-04-17 19:01:20 [debug    ] RandomIterator is selected.   \n",
      "2024-04-17 19:01:20 [info     ] Directory is created at d3rlpy_logs\\DiscreteSAC_20240417190120\n",
      "2024-04-17 19:01:20 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-04-17 19:01:20 [debug    ] Building models...            \n",
      "2024-04-17 19:01:20 [debug    ] Models have been built.       \n",
      "2024-04-17 19:01:20 [info     ] Parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\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': 4}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 10/10 [00:04<00:00,  2.33it/s, temp_loss=0.0275, temp=1, critic_loss=1.67, actor_loss=-1.4]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:24 [info     ] DiscreteSAC_20240417190120: epoch=1 step=10 epoch=1 metrics={'time_sample_batch': 0.005220103263854981, 'time_algorithm_update': 0.42194156646728515, 'temp_loss': 0.027049198001623153, 'temp': 0.9983583390712738, 'critic_loss': 1.3070890307426453, 'actor_loss': -1.5962655663490295, 'time_step': 0.4273038148880005} step=10\n",
      "2024-04-17 19:01:24 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_10.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/10: 100%|██████████| 10/10 [00:04<00:00,  2.40it/s, temp_loss=0.0229, temp=0.997, critic_loss=0.448, actor_loss=-2.16]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:28 [info     ] DiscreteSAC_20240417190120: epoch=2 step=20 epoch=2 metrics={'time_sample_batch': 0.006156802177429199, 'time_algorithm_update': 0.4091461420059204, 'temp_loss': -0.014491693815216422, 'temp': 0.9958582758903504, 'critic_loss': 0.3324222207069397, 'actor_loss': -2.4489673614501952, 'time_step': 0.41566293239593505} step=20\n",
      "2024-04-17 19:01:28 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_20.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/10: 100%|██████████| 10/10 [00:04<00:00,  2.37it/s, temp_loss=-.023, temp=0.996, critic_loss=0.211, actor_loss=-2.22]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:33 [info     ] DiscreteSAC_20240417190120: epoch=3 step=30 epoch=3 metrics={'time_sample_batch': 0.004986095428466797, 'time_algorithm_update': 0.41551148891448975, 'temp_loss': 0.010473198010004126, 'temp': 0.9960166633129119, 'critic_loss': 0.21463437974452973, 'actor_loss': -2.4094705820083617, 'time_step': 0.42072405815124514} step=30\n",
      "2024-04-17 19:01:33 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_30.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/10: 100%|██████████| 10/10 [00:04<00:00,  2.28it/s, temp_loss=0.0265, temp=0.996, critic_loss=0.163, actor_loss=-2.8]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:37 [info     ] DiscreteSAC_20240417190120: epoch=4 step=40 epoch=4 metrics={'time_sample_batch': 0.005739450454711914, 'time_algorithm_update': 0.43076965808868406, 'temp_loss': 0.02717268969863653, 'temp': 0.9951179087162018, 'critic_loss': 0.18243311047554017, 'actor_loss': -2.686958074569702, 'time_step': 0.4365983963012695} step=40\n",
      "2024-04-17 19:01:37 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_40.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/10: 100%|██████████| 10/10 [00:04<00:00,  2.27it/s, temp_loss=0.0274, temp=0.994, critic_loss=0.162, actor_loss=-2.6]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:42 [info     ] DiscreteSAC_20240417190120: epoch=5 step=50 epoch=5 metrics={'time_sample_batch': 0.005802083015441895, 'time_algorithm_update': 0.43357205390930176, 'temp_loss': 0.027269363589584827, 'temp': 0.9928025364875793, 'critic_loss': 0.149330884963274, 'actor_loss': -2.627604269981384, 'time_step': 0.4396759271621704} step=50\n",
      "2024-04-17 19:01:42 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_50.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/10: 100%|██████████| 10/10 [00:04<00:00,  2.41it/s, temp_loss=0.0272, temp=0.991, critic_loss=0.141, actor_loss=-2.7]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:46 [info     ] DiscreteSAC_20240417190120: epoch=6 step=60 epoch=6 metrics={'time_sample_batch': 0.0048321962356567385, 'time_algorithm_update': 0.4080444574356079, 'temp_loss': 0.02715562265366316, 'temp': 0.9900133013725281, 'critic_loss': 0.15290763974189758, 'actor_loss': -2.6619549036026, 'time_step': 0.4131051301956177} step=60\n",
      "2024-04-17 19:01:46 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_60.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/10: 100%|██████████| 10/10 [00:04<00:00,  2.38it/s, temp_loss=0.0272, temp=0.988, critic_loss=0.134, actor_loss=-2.62]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:50 [info     ] DiscreteSAC_20240417190120: epoch=7 step=70 epoch=7 metrics={'time_sample_batch': 0.005125784873962402, 'time_algorithm_update': 0.41357262134552003, 'temp_loss': 0.02718408927321434, 'temp': 0.9870809853076935, 'critic_loss': 0.1419624000787735, 'actor_loss': -2.636814022064209, 'time_step': 0.4189231157302856} step=70\n",
      "2024-04-17 19:01:50 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_70.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/10: 100%|██████████| 10/10 [00:04<00:00,  2.43it/s, temp_loss=0.0272, temp=0.985, critic_loss=0.14, actor_loss=-2.67]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:54 [info     ] DiscreteSAC_20240417190120: epoch=8 step=80 epoch=8 metrics={'time_sample_batch': 0.005494356155395508, 'time_algorithm_update': 0.40378196239471437, 'temp_loss': 0.02720295749604702, 'temp': 0.9841090142726898, 'critic_loss': 0.13677984923124314, 'actor_loss': -2.666862940788269, 'time_step': 0.4094935655593872} step=80\n",
      "2024-04-17 19:01:54 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_80.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/10: 100%|██████████| 10/10 [00:04<00:00,  2.43it/s, temp_loss=0.0272, temp=0.982, critic_loss=0.166, actor_loss=-2.63]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:01:58 [info     ] DiscreteSAC_20240417190120: epoch=9 step=90 epoch=9 metrics={'time_sample_batch': 0.005375528335571289, 'time_algorithm_update': 0.4049858808517456, 'temp_loss': 0.027159486524760725, 'temp': 0.9811330437660217, 'critic_loss': 0.14545433297753335, 'actor_loss': -2.6479231119155884, 'time_step': 0.410571551322937} step=90\n",
      "2024-04-17 19:01:58 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_90.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/10: 100%|██████████| 10/10 [00:04<00:00,  2.39it/s, temp_loss=0.0271, temp=0.979, critic_loss=0.171, actor_loss=-2.67]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:03 [info     ] DiscreteSAC_20240417190120: epoch=10 step=100 epoch=10 metrics={'time_sample_batch': 0.005295515060424805, 'time_algorithm_update': 0.4117622137069702, 'temp_loss': 0.027085205540060997, 'temp': 0.9781677007675171, 'critic_loss': 0.1592424303293228, 'actor_loss': -2.646222233772278, 'time_step': 0.4171647071838379} step=100\n",
      "2024-04-17 19:02:03 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190120\\model_100.pt\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1746151]\n",
      "Passing:  3 1.1746151\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1853819]\n",
      "Passing:  3 1.1853819\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1847641]\n",
      "Passing:  3 1.1847641\n",
      "New model action:  [3]\n",
      "New model action value:  [1.1626065]\n",
      "Passing:  3 1.1626065\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 4 has 1080 trajectories out of 4228\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-04-17 19:02:03 [debug    ] RandomIterator is selected.   \n",
      "2024-04-17 19:02:03 [info     ] Directory is created at d3rlpy_logs\\DiscreteSAC_20240417190203\n",
      "2024-04-17 19:02:03 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-04-17 19:02:03 [debug    ] Building models...            \n",
      "2024-04-17 19:02:03 [debug    ] Models have been built.       \n",
      "2024-04-17 19:02:03 [info     ] Parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\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': 4}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 10/10 [00:04<00:00,  2.36it/s, temp_loss=0.0265, temp=1, critic_loss=1.63, actor_loss=-1.35]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:07 [info     ] DiscreteSAC_20240417190203: epoch=1 step=10 epoch=1 metrics={'time_sample_batch': 0.005908489227294922, 'time_algorithm_update': 0.41554937362670896, 'temp_loss': 0.026715286076068878, 'temp': 0.9983570277690887, 'critic_loss': 1.437309741973877, 'actor_loss': -1.4851670026779176, 'time_step': 0.4216583013534546} step=10\n",
      "2024-04-17 19:02:07 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_10.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/10: 100%|██████████| 10/10 [00:04<00:00,  2.40it/s, temp_loss=0.0232, temp=0.997, critic_loss=0.808, actor_loss=-1.9]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:11 [info     ] DiscreteSAC_20240417190203: epoch=2 step=20 epoch=2 metrics={'time_sample_batch': 0.005339193344116211, 'time_algorithm_update': 0.4091882944107056, 'temp_loss': -0.03579779946012422, 'temp': 0.9959974408149719, 'critic_loss': 0.39538409262895585, 'actor_loss': -2.4883692264556885, 'time_step': 0.4147511005401611} step=20\n",
      "2024-04-17 19:02:11 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_20.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/10: 100%|██████████| 10/10 [00:04<00:00,  2.36it/s, temp_loss=-.0431, temp=0.996, critic_loss=0.135, actor_loss=-2.28]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:16 [info     ] DiscreteSAC_20240417190203: epoch=3 step=30 epoch=3 metrics={'time_sample_batch': 0.005377936363220215, 'time_algorithm_update': 0.41621081829071044, 'temp_loss': 0.009207385219633579, 'temp': 0.9969060122966766, 'critic_loss': 0.22182244062423706, 'actor_loss': -2.3542897939682006, 'time_step': 0.42181155681610105} step=30\n",
      "2024-04-17 19:02:16 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_30.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/10: 100%|██████████| 10/10 [00:04<00:00,  2.42it/s, temp_loss=0.0273, temp=0.997, critic_loss=0.187, actor_loss=-2.68]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:20 [info     ] DiscreteSAC_20240417190203: epoch=4 step=40 epoch=4 metrics={'time_sample_batch': 0.005815863609313965, 'time_algorithm_update': 0.4056086540222168, 'temp_loss': 0.027088827826082705, 'temp': 0.996777206659317, 'critic_loss': 0.16811463013291358, 'actor_loss': -2.6808845520019533, 'time_step': 0.4115417003631592} step=40\n",
      "2024-04-17 19:02:20 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_40.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/10: 100%|██████████| 10/10 [00:04<00:00,  2.35it/s, temp_loss=0.0267, temp=0.996, critic_loss=0.119, actor_loss=-2.56]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:24 [info     ] DiscreteSAC_20240417190203: epoch=5 step=50 epoch=5 metrics={'time_sample_batch': 0.005376839637756347, 'time_algorithm_update': 0.4188921213150024, 'temp_loss': 0.026703004352748395, 'temp': 0.9952979803085327, 'critic_loss': 0.14601199850440025, 'actor_loss': -2.563943099975586, 'time_step': 0.42437009811401366} step=50\n",
      "2024-04-17 19:02:24 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_50.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/10: 100%|██████████| 10/10 [00:04<00:00,  2.34it/s, temp_loss=0.0267, temp=0.994, critic_loss=0.103, actor_loss=-2.68]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:28 [info     ] DiscreteSAC_20240417190203: epoch=6 step=60 epoch=6 metrics={'time_sample_batch': 0.006173825263977051, 'time_algorithm_update': 0.4197744131088257, 'temp_loss': 0.026848706975579263, 'temp': 0.9932764291763305, 'critic_loss': 0.129245375841856, 'actor_loss': -2.6458601474761965, 'time_step': 0.42615666389465334} step=60\n",
      "2024-04-17 19:02:28 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_60.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/10: 100%|██████████| 10/10 [00:04<00:00,  2.48it/s, temp_loss=0.027, temp=0.992, critic_loss=0.0994, actor_loss=-2.62]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:33 [info     ] DiscreteSAC_20240417190203: epoch=7 step=70 epoch=7 metrics={'time_sample_batch': 0.005410885810852051, 'time_algorithm_update': 0.39678521156311036, 'temp_loss': 0.02701939269900322, 'temp': 0.9910099089145661, 'critic_loss': 0.14906583800911904, 'actor_loss': -2.6343767166137697, 'time_step': 0.4022996187210083} step=70\n",
      "2024-04-17 19:02:33 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_70.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/10: 100%|██████████| 10/10 [00:04<00:00,  2.36it/s, temp_loss=0.0271, temp=0.99, critic_loss=0.122, actor_loss=-2.64]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:37 [info     ] DiscreteSAC_20240417190203: epoch=8 step=80 epoch=8 metrics={'time_sample_batch': 0.005603194236755371, 'time_algorithm_update': 0.4160920143127441, 'temp_loss': 0.027100587263703346, 'temp': 0.9886157870292663, 'critic_loss': 0.14390252456068992, 'actor_loss': -2.6287978410720827, 'time_step': 0.42181365489959716} step=80\n",
      "2024-04-17 19:02:37 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_80.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/10: 100%|██████████| 10/10 [00:04<00:00,  2.38it/s, temp_loss=0.0271, temp=0.987, critic_loss=0.161, actor_loss=-2.64]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:41 [info     ] DiscreteSAC_20240417190203: epoch=9 step=90 epoch=9 metrics={'time_sample_batch': 0.0062769889831542965, 'time_algorithm_update': 0.4118372917175293, 'temp_loss': 0.02716827355325222, 'temp': 0.9861468136310577, 'critic_loss': 0.137030678242445, 'actor_loss': -2.63497998714447, 'time_step': 0.4182151794433594} step=90\n",
      "2024-04-17 19:02:41 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_90.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/10: 100%|██████████| 10/10 [00:04<00:00,  2.25it/s, temp_loss=0.0272, temp=0.985, critic_loss=0.126, actor_loss=-2.66]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:46 [info     ] DiscreteSAC_20240417190203: epoch=10 step=100 epoch=10 metrics={'time_sample_batch': 0.006732320785522461, 'time_algorithm_update': 0.43571856021881106, 'temp_loss': 0.02720014601945877, 'temp': 0.9836279928684235, 'critic_loss': 0.13745691552758216, 'actor_loss': -2.6368536233901976, 'time_step': 0.44255805015563965} step=100\n",
      "2024-04-17 19:02:46 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190203\\model_100.pt\n",
      "New model action:  [2]\n",
      "New model action value:  [1.1429275]\n",
      "Passing:  2 1.1429275\n",
      "New model action:  [2]\n",
      "New model action value:  [1.1528141]\n",
      "Passing:  2 1.1528141\n",
      "New model action:  [2]\n",
      "New model action value:  [1.1524339]\n",
      "Passing:  2 1.1524339\n",
      "New model action:  [2]\n",
      "New model action value:  [1.1383651]\n",
      "Passing:  2 1.1383651\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Cluster 5 has 745 trajectories out of 4228\n",
      "----------------------------------------------------------------------------------------------------\n",
      "2024-04-17 19:02:46 [debug    ] RandomIterator is selected.   \n",
      "2024-04-17 19:02:46 [info     ] Directory is created at d3rlpy_logs\\DiscreteSAC_20240417190246\n",
      "2024-04-17 19:02:46 [debug    ] Fitting scaler...              scaler=pixel\n",
      "2024-04-17 19:02:46 [debug    ] Building models...            \n",
      "2024-04-17 19:02:46 [debug    ] Models have been built.       \n",
      "2024-04-17 19:02:46 [info     ] Parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\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': 4}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/10: 100%|██████████| 10/10 [00:04<00:00,  2.25it/s, temp_loss=0.0264, temp=1, critic_loss=1.65, actor_loss=-1.35]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:50 [info     ] DiscreteSAC_20240417190246: epoch=1 step=10 epoch=1 metrics={'time_sample_batch': 0.006293201446533203, 'time_algorithm_update': 0.43622727394104005, 'temp_loss': 0.02561618611216545, 'temp': 0.9983591616153717, 'critic_loss': 1.385704267024994, 'actor_loss': -1.4979593276977539, 'time_step': 0.4427202224731445} step=10\n",
      "2024-04-17 19:02:50 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_10.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/10: 100%|██████████| 10/10 [00:04<00:00,  2.20it/s, temp_loss=0.0177, temp=0.997, critic_loss=0.679, actor_loss=-1.99]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:02:55 [info     ] DiscreteSAC_20240417190246: epoch=2 step=20 epoch=2 metrics={'time_sample_batch': 0.008626747131347656, 'time_algorithm_update': 0.4438409090042114, 'temp_loss': -0.004160255927126854, 'temp': 0.995909458398819, 'critic_loss': 0.360516257584095, 'actor_loss': -2.491899514198303, 'time_step': 0.4525700330734253} step=20\n",
      "2024-04-17 19:02:55 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_20.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/10: 100%|██████████| 10/10 [00:04<00:00,  2.09it/s, temp_loss=0.014, temp=0.995, critic_loss=0.195, actor_loss=-2.26]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:00 [info     ] DiscreteSAC_20240417190246: epoch=3 step=30 epoch=3 metrics={'time_sample_batch': 0.007929396629333497, 'time_algorithm_update': 0.4680398225784302, 'temp_loss': 0.023421091213822364, 'temp': 0.9948910534381866, 'critic_loss': 0.2147840827703476, 'actor_loss': -2.399477219581604, 'time_step': 0.476373553276062} step=30\n",
      "2024-04-17 19:03:00 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_30.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/10: 100%|██████████| 10/10 [00:04<00:00,  2.36it/s, temp_loss=0.0264, temp=0.994, critic_loss=0.18, actor_loss=-2.72]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:04 [info     ] DiscreteSAC_20240417190246: epoch=4 step=40 epoch=4 metrics={'time_sample_batch': 0.005730056762695312, 'time_algorithm_update': 0.4165689706802368, 'temp_loss': 0.02625423390418291, 'temp': 0.9926178634166718, 'critic_loss': 0.1589171051979065, 'actor_loss': -2.6614779949188234, 'time_step': 0.42261676788330077} step=40\n",
      "2024-04-17 19:03:04 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_40.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/10: 100%|██████████| 10/10 [00:04<00:00,  2.39it/s, temp_loss=0.0262, temp=0.991, critic_loss=0.157, actor_loss=-2.55]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:08 [info     ] DiscreteSAC_20240417190246: epoch=5 step=50 epoch=5 metrics={'time_sample_batch': 0.005388283729553222, 'time_algorithm_update': 0.4110668659210205, 'temp_loss': 0.026243098825216294, 'temp': 0.9896909952163696, 'critic_loss': 0.1458984687924385, 'actor_loss': -2.6210691213607786, 'time_step': 0.4165667533874512} step=50\n",
      "2024-04-17 19:03:08 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_50.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/10: 100%|██████████| 10/10 [00:04<00:00,  2.43it/s, temp_loss=0.0263, temp=0.988, critic_loss=0.171, actor_loss=-2.65]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:12 [info     ] DiscreteSAC_20240417190246: epoch=6 step=60 epoch=6 metrics={'time_sample_batch': 0.005727887153625488, 'time_algorithm_update': 0.40355534553527833, 'temp_loss': 0.026308276876807212, 'temp': 0.9865986347198487, 'critic_loss': 0.14650348126888274, 'actor_loss': -2.5926759243011475, 'time_step': 0.4094831943511963} step=60\n",
      "2024-04-17 19:03:12 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_60.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/10: 100%|██████████| 10/10 [00:04<00:00,  2.39it/s, temp_loss=0.0263, temp=0.985, critic_loss=0.199, actor_loss=-2.59]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:17 [info     ] DiscreteSAC_20240417190246: epoch=7 step=70 epoch=7 metrics={'time_sample_batch': 0.0055149316787719725, 'time_algorithm_update': 0.4120697259902954, 'temp_loss': 0.02634732499718666, 'temp': 0.9834786593914032, 'critic_loss': 0.1450030468404293, 'actor_loss': -2.615242028236389, 'time_step': 0.4176889657974243} step=70\n",
      "2024-04-17 19:03:17 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_70.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/10: 100%|██████████| 10/10 [00:04<00:00,  2.41it/s, temp_loss=0.0264, temp=0.982, critic_loss=0.156, actor_loss=-2.61]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:21 [info     ] DiscreteSAC_20240417190246: epoch=8 step=80 epoch=8 metrics={'time_sample_batch': 0.006180977821350098, 'time_algorithm_update': 0.4073557615280151, 'temp_loss': 0.02639289516955614, 'temp': 0.9803715407848358, 'critic_loss': 0.12369639202952384, 'actor_loss': -2.6148969888687135, 'time_step': 0.41377360820770265} step=80\n",
      "2024-04-17 19:03:21 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_80.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/10: 100%|██████████| 10/10 [00:04<00:00,  2.28it/s, temp_loss=0.0264, temp=0.979, critic_loss=0.116, actor_loss=-2.65]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:25 [info     ] DiscreteSAC_20240417190246: epoch=9 step=90 epoch=9 metrics={'time_sample_batch': 0.006247258186340332, 'time_algorithm_update': 0.4300555944442749, 'temp_loss': 0.02647211737930775, 'temp': 0.977285873889923, 'critic_loss': 0.12996798232197762, 'actor_loss': -2.60513551235199, 'time_step': 0.4364189863204956} step=90\n",
      "2024-04-17 19:03:25 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_90.pt\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/10: 100%|██████████| 10/10 [00:04<00:00,  2.31it/s, temp_loss=0.0265, temp=0.976, critic_loss=0.138, actor_loss=-2.56]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2024-04-17 19:03:30 [info     ] DiscreteSAC_20240417190246: epoch=10 step=100 epoch=10 metrics={'time_sample_batch': 0.006795072555541992, 'time_algorithm_update': 0.4250496387481689, 'temp_loss': 0.026531347073614597, 'temp': 0.9742207050323486, 'critic_loss': 0.14686010405421257, 'actor_loss': -2.6015735864639282, 'time_step': 0.4321631908416748} step=100\n",
      "2024-04-17 19:03:30 [info     ] Model parameters are saved to d3rlpy_logs\\DiscreteSAC_20240417190246\\model_100.pt\n",
      "New model action:  [0]\n",
      "New model action value:  [1.1257915]\n",
      "Passing:  0 1.1257915\n",
      "New model action:  [0]\n",
      "New model action value:  [1.1360962]\n",
      "Passing:  0 1.1360962\n",
      "New model action:  [0]\n",
      "New model action value:  [1.1346521]\n",
      "Passing:  0 1.1346521\n",
      "New model action:  [0]\n",
      "New model action value:  [1.1183755]\n",
      "Passing:  0 1.1183755\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": 85,
   "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]\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": 86,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#################################################################################################### Observation 1 ####################################################################################################\n",
      "(1, 4, 84, 84)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "1-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "2-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "3-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "4-th model predicted action: [2]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "5-th model predicted action: [0]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "DEBUG: len(sub_dist) 6\n",
      "DEBUG: sub_dist [1000000000.0, 1000000000.0, 1000000000.0, 1000000000.0, 6.277021020650864e-05, 6.277021020650864e-05]\n",
      "DEBUG: np.argsort(sub_dist) [4 5 0 1 2 3]\n",
      "Responsible data combination:  4\n",
      "#################################################################################################### Observation 2 ####################################################################################################\n",
      "(1, 4, 84, 84)\n",
      "0-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "1-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "2-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "3-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "4-th model predicted action: [2]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "5-th model predicted action: [0]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "DEBUG: len(sub_dist) 6\n",
      "DEBUG: sub_dist [1000000000.0, 1000000000.0, 1000000000.0, 1000000000.0, 6.277021020650864e-05, 6.277021020650864e-05]\n",
      "DEBUG: np.argsort(sub_dist) [4 5 0 1 2 3]\n",
      "Responsible data combination:  4\n",
      "#################################################################################################### Observation 3 ####################################################################################################\n",
      "(1, 4, 84, 84)\n",
      "0-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "1-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "2-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "3-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "4-th model predicted action: [2]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "5-th model predicted action: [0]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "DEBUG: len(sub_dist) 6\n",
      "DEBUG: sub_dist [1000000000.0, 1000000000.0, 1000000000.0, 1000000000.0, 6.277021020650864e-05, 6.277021020650864e-05]\n",
      "DEBUG: np.argsort(sub_dist) [4 5 0 1 2 3]\n",
      "Responsible data combination:  4\n",
      "#################################################################################################### Observation 4 ####################################################################################################\n",
      "(1, 4, 84, 84)\n",
      "0-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "1-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "2-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "3-th model predicted action: [3]\n",
      "Original model's action [3]\n",
      "4-th model predicted action: [2]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "5-th model predicted action: [0]\n",
      "Original model's action [3]\n",
      "Wasserstein distance:  6.277021020650864e-05\n",
      "DEBUG: len(sub_dist) 6\n",
      "DEBUG: sub_dist [1000000000.0, 1000000000.0, 1000000000.0, 1000000000.0, 6.277021020650864e-05, 6.277021020650864e-05]\n",
      "DEBUG: np.argsort(sub_dist) [4 5 0 1 2 3]\n",
      "Responsible data combination:  4\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaAAAAGgCAYAAADsNrNZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAktUlEQVR4nO3df3TUVX7/8Vd+TqIhE4kyk6wJBstukB9Fg4QxdneL2VKW42rJcdc9bBcXuhQbEMhp0VTBbhVDtS3oNsBq2cCeBanpEVzcs7BurOyBJvyIxhWtAZU26ZIZqjUzyI8km9zvHz3O108mApOZcDPh+TjnnsO9nzt33rnkzOt88vnMTJIxxggAgMss2XYBAIArEwEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALBiyAKotrZWN9xwgzIyMlRaWqpDhw4N1VMBABJQ0lB8Fty//Mu/6Lvf/a42bdqk0tJSrV+/XvX19WptbdWYMWMu+Ni+vj6dPHlSo0aNUlJSUrxLAwAMMWOMTp8+rfz8fCUnX+A8xwyB6dOnm8rKynC/t7fX5Ofnm5qamos+tr293Uii0Wg0WoK39vb2C77ex/1PcN3d3WpublZ5eXl4LDk5WeXl5WpsbIyY39XVpVAoFG6GD+cGgBFh1KhRFzwe9wD68MMP1dvbK4/H4xj3eDzy+/0R82tqauR2u8OtsLAw3iUBACy42GUU63fBVVdXKxgMhlt7e7vtkgAAl0FqvBe89tprlZKSokAg4BgPBALyer0R810ul1wuV7zLAAAMc3E/A0pPT1dJSYkaGhrCY319fWpoaJDP54v30wEAElTcz4AkqaqqSvPnz9e0adM0ffp0rV+/XmfOnNH3vve9oXg6AEACGpIA+ta3vqX/+Z//0erVq+X3+zV16lTt2bMn4sYEAMCVa0jeiBqLUCgkt9ttu4yENdB1tvfff/+Cj2lpabnouhMnTowYS0tLc/TLysouunZ9fb2j//Wvfz3iMf1vRPnoo48i5vT/Ofv3f/zjH0c8ZunSpY7+7NmzI+b867/+q6N/9uxZR//YsWMRj0lJSXH0J0+eHDGnv6uvvvqic4aT/n+9+LM/+7NBrZOdne3ojxs3ztEf6HdxoN+rRPfDH/7Q0V+wYEHEnMcff9zRr6mpGdKahkIwGIz4P/8s63fBAQCuTAQQAMAKAggAYMWQ3ISAxHIpf2Mf6DrSQNeb4uHAgQOO/v79+yPm9L92NNC1pHjof/3pn//5nyPm9L9meSnXgBLNG2+84egPtA+XYtKkSY7+4sWLB10TEh9nQAAAKwggAIAVBBAAwAoCCABgBTch4Ip19OjRiLElS5ZYqGT46/+m3UceeSRiTv+bR55//vmIOf33vP9+f/jhh4MtEQmIMyAAgBUEEADACgIIAGAF14AQ8bf7geTm5l6GSv5P/zfGFhcXR8yJx5tgB/r23bq6uqjX6V/LmjVrBl1TIuv//zSYDyx99913I8Z279496JowvHEGBACwggACAFhBAAEArBi2X0g3efLkiC/6AgAMf729vXrrrbf4QjoAwPBEAAEArCCAAABWEEAAACuG7RtRf/nLX17w4hUAYHgKhULKy8u76DzOgAAAVhBAAAArCCAAgBUEEADACgIIAGAFAQQAsIIAAgBYQQABAKwggAAAVhBAAAArCCAAgBVRB9Cvf/1r3XnnncrPz1dSUpJ27drlOG6M0erVq5WXl6fMzEyVl5fr+PHj8aoXADBCRB1AZ86c0e///u+rtrZ2wONPPvmknnnmGW3atEkHDx7U1VdfrVmzZun8+fMxFwsAGDmi/jTs2bNna/bs2QMeM8Zo/fr1euSRR3TXXXdJkn7yk5/I4/Fo165duvfee2OrFgAwYsT1GtCJEyfk9/tVXl4eHnO73SotLVVjY+OAj+nq6lIoFHI0AMDIF9cA8vv9kiSPx+MY93g84WP91dTUyO12h1tBQUE8SwIADFPW74Krrq5WMBgMt/b2dtslAQAug7gGkNfrlSQFAgHHeCAQCB/rz+VyKTs729EAACNfXAOoqKhIXq9XDQ0N4bFQKKSDBw/K5/PF86kAAAku6rvgPvnkE7333nvh/okTJ9TS0qLRo0ersLBQy5cv1+OPP67x48erqKhIq1atUn5+vu6+++541g0ASHBRB9CRI0f0h3/4h+F+VVWVJGn+/PnasmWLVq5cqTNnzmjRokXq7OzU7bffrj179igjIyN+VQMAEl6SMcbYLuKzQqGQ3G63Ojo6Yr4e9O677zr6vBkWAJz6nxwUFxfHvGYoFFJeXp6CweAFX8et3wUHALgyEUAAACsIIACAFVHfhJBIFi5c6Oi3tLTYKQQAhqmpU6c6+gcOHLhsz80ZEADACgIIAGAFAQQAsIIAAgBYQQABAKwggAAAVhBAAAArCCAAgBUEEADACgIIAGAFAQQAsIIAAgBYQQABAKwggAAAVhBAAAArCCAAgBUEEADACgIIAGAFAQQAsIIAAgBYQQABAKwggAAAVhBAAAArCCAAgBUEEADACgIIAGAFAQQAsIIAAgBYQQABAKyIKoBqamp06623atSoURozZozuvvtutba2OuacP39elZWVys3NVVZWlioqKhQIBOJaNAAg8UUVQPv27VNlZaWampr0yiuvqKenR3/0R3+kM2fOhOesWLFCu3fvVn19vfbt26eTJ09q7ty5cS8cAJDYUqOZvGfPHkd/y5YtGjNmjJqbm/XlL39ZwWBQmzdv1vbt2zVz5kxJUl1dnSZMmKCmpibNmDEjfpUDABJaTNeAgsGgJGn06NGSpObmZvX09Ki8vDw8p7i4WIWFhWpsbBxwja6uLoVCIUcDAIx8gw6gvr4+LV++XGVlZZo0aZIkye/3Kz09XTk5OY65Ho9Hfr9/wHVqamrkdrvDraCgYLAlAQASyKADqLKyUkePHtWOHTtiKqC6ulrBYDDc2tvbY1oPAJAYoroG9KklS5bo5Zdf1q9//Wtdf/314XGv16vu7m51dnY6zoICgYC8Xu+Aa7lcLrlcrsGUAQBIYFGdARljtGTJEu3cuVOvvvqqioqKHMdLSkqUlpamhoaG8Fhra6va2trk8/niUzEAYESI6gyosrJS27dv10svvaRRo0aFr+u43W5lZmbK7XZr4cKFqqqq0ujRo5Wdna2lS5fK5/NxBxwAwCGqANq4caMk6atf/apjvK6uTvfdd58kad26dUpOTlZFRYW6uro0a9YsbdiwIS7FAgBGjqgCyBhz0TkZGRmqra1VbW3toIuKl7Fjxzr6Z8+etVQJAAxP/V8nLyc+Cw4AYAUBBACwggACAFgxqPcBJYrq6mpHn2tAAOB01VVXWXtuzoAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsGNFvRPV4PI5+V1eXpUoAYHiy+YWgnAEBAKwggAAAVhBAAAArCCAAgBUj+iaE1NQR/eMBQMxsvk5yBgQAsIIAAgBYQQABAKwY0RdJ9uzZ4+ifOnUq6jVKS0sjxn7v935v0DUNR9u2bYvLOn/8x38cMZabmxuXtTF0Dh48GDH23nvvWajkytH/dWWkvaZcKs6AAABWEEAAACsIIACAFSP6GlBtba2j39LSEvUaa9eujRj74he/ONiShqWHH344LutMnTo1Yuy6666Ly9oYOrt27YoYe/755y9/IVeQ/q8rNl9TUlJSrD03Z0AAACsIIACAFQQQAMAKAggAYAUBBACwggACAFhBAAEArIgqgDZu3KgpU6YoOztb2dnZ8vl8+sUvfhE+fv78eVVWVio3N1dZWVmqqKhQIBCIe9EAgMSXZIwxlzp59+7dSklJ0fjx42WM0datW/XUU0/pjTfe0MSJE3X//ffr5z//ubZs2SK3260lS5YoOTlZBw4cuOSCQqGQ3G63Ojo6lJ2dPagf6lNlZWWO/mDeiIpLd+TIkYixkpISC5XAhmeffdbR//M///Oo1xjo92Wg36toJSUlxbxGPP3oRz9y9BctWmSpEql/BJw7dy7mNUOhkPLy8hQMBi/4Oh7VJyHceeedjv6aNWu0ceNGNTU16frrr9fmzZu1fft2zZw5U5JUV1enCRMmqKmpSTNmzBjEjwEAGKkGfQ2ot7dXO3bs0JkzZ+Tz+dTc3Kyenh6Vl5eH5xQXF6uwsFCNjY2fu05XV5dCoZCjAQBGvqgD6K233lJWVpZcLpcWL16snTt36qabbpLf71d6erpycnIc8z0ej/x+/+euV1NTI7fbHW4FBQVR/xAAgMQTdQB96UtfUktLiw4ePKj7779f8+fP1zvvvDPoAqqrqxUMBsOtvb190GsBABJH1J+GnZ6eHv72vpKSEh0+fFhPP/20vvWtb6m7u1udnZ2Os6BAICCv1/u567lcLrlcrugrBwAktJjfB9TX16euri6VlJQoLS1NDQ0N4WOtra1qa2uTz+eL9WkAACNMVGdA1dXVmj17tgoLC3X69Glt375dr732mvbu3Su3262FCxeqqqpKo0ePVnZ2tpYuXSqfz8cdcACACFEF0KlTp/Td735XHR0dcrvdmjJlivbu3auvfe1rkqR169YpOTlZFRUV6urq0qxZs7Rhw4YhKRwAkNiiCqDNmzdf8HhGRoZqa2sjvokUV4Y1a9ZEjA3mG1H7v99s2rRpUa8x0JsXd+/eHfU6+fn5jv5g3lw5kEcffTQu6/Svp3+9l1MwGIx5jZ6enoixC91Fm6j679VgfsZ4/Y73v/O4qqoq6jUGi8+CAwBYQQABAKwggAAAVkT9PiDg8+zcuTMu6/S/jnHjjTdGvUZzc3PEWP8Py7wUEydOdPS/+c1vRr3GQAZTy0A+vQHoU5mZmXFZdzDOnj0b8xq9vb0RYx9//HHM6w43/fdqMD9jvH7Hp06d6uhzDQgAMOIRQAAAKwggAIAVBBAAwApuQsCw09HR4ei//fbbMa8xWL/73e8c/eH2fVXvv/++7RLC4rHnA30b52D+/4e74fQ7bhNnQAAAKwggAIAVBBAAwIokY4yxXcRnhUIhud1udXR0KDs7O6a1ysrKHP2WlpaY1sOVp/8HNa5cuTIu6y5dujQu6wCx6v9G1AMHDsS8ZigUUl5enoLB4AVfxzkDAgBYQQABAKwggAAAVhBAAAArCCAAgBUEEADACgIIAGAFAQQAsIIPIwUuwO/3O/pPPvmkpUqAkYczIACAFQQQAMAKAggAYAXXgIAL6OnpcfTb29stVQKMPJwBAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALAipgBau3atkpKStHz58vDY+fPnVVlZqdzcXGVlZamiokKBQCDWOgEAI8ygA+jw4cP60Y9+pClTpjjGV6xYod27d6u+vl779u3TyZMnNXfu3JgLBQCMLIMKoE8++UTz5s3Tc889p2uuuSY8HgwGtXnzZv3jP/6jZs6cqZKSEtXV1enf//3f1dTUFLeiAQCJb1ABVFlZqTlz5qi8vNwx3tzcrJ6eHsd4cXGxCgsL1djYOOBaXV1dCoVCjgYAGPmi/iy4HTt26PXXX9fhw4cjjvn9fqWnpysnJ8cx7vF4Ir5X5VM1NTX6wQ9+EG0ZAIAEF9UZUHt7u5YtW6Zt27YpIyMjLgVUV1crGAyGGx/2CABXhqgCqLm5WadOndItt9yi1NRUpaamat++fXrmmWeUmpoqj8ej7u5udXZ2Oh4XCATk9XoHXNPlcik7O9vRAAAjX1R/grvjjjv01ltvOca+973vqbi4WA8++KAKCgqUlpamhoYGVVRUSJJaW1vV1tYmn88Xv6oBAAkvqgAaNWqUJk2a5Bi7+uqrlZubGx5fuHChqqqqNHr0aGVnZ2vp0qXy+XyaMWNG/KoGACS8uH8h3bp165ScnKyKigp1dXVp1qxZ2rBhQ7yfBgCQ4GIOoNdee83Rz8jIUG1trWpra2NdGgAwgvFZcAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAK6IKoL/5m79RUlKSoxUXF4ePnz9/XpWVlcrNzVVWVpYqKioUCATiXjQAIPFFfQY0ceJEdXR0hNv+/fvDx1asWKHdu3ervr5e+/bt08mTJzV37ty4FgwAGBlSo35Aaqq8Xm/EeDAY1ObNm7V9+3bNnDlTklRXV6cJEyaoqalJM2bMiL1aAMCIEfUZ0PHjx5Wfn69x48Zp3rx5amtrkyQ1Nzerp6dH5eXl4bnFxcUqLCxUY2Pj567X1dWlUCjkaACAkS+qACotLdWWLVu0Z88ebdy4USdOnNAf/MEf6PTp0/L7/UpPT1dOTo7jMR6PR36//3PXrKmpkdvtDreCgoJB/SAAgMQS1Z/gZs+eHf73lClTVFpaqrFjx+qFF15QZmbmoAqorq5WVVVVuB8KhQghALgCxHQbdk5Ojr74xS/qvffek9frVXd3tzo7Ox1zAoHAgNeMPuVyuZSdne1oAICRL6YA+uSTT/T+++8rLy9PJSUlSktLU0NDQ/h4a2ur2tra5PP5Yi4UADCyRPUnuL/8y7/UnXfeqbFjx+rkyZN69NFHlZKSom9/+9tyu91auHChqqqqNHr0aGVnZ2vp0qXy+XzcAQcAiBBVAP33f/+3vv3tb+ujjz7Sddddp9tvv11NTU267rrrJEnr1q1TcnKyKioq1NXVpVmzZmnDhg1DUjgAILFFFUA7duy44PGMjAzV1taqtrY2pqIAACMfnwUHALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALAi6gD67W9/q+985zvKzc1VZmamJk+erCNHjoSPG2O0evVq5eXlKTMzU+Xl5Tp+/HhciwYAJL6oAujjjz9WWVmZ0tLS9Itf/ELvvPOO/uEf/kHXXHNNeM6TTz6pZ555Rps2bdLBgwd19dVXa9asWTp//nzciwcAJK7UaCb/3d/9nQoKClRXVxceKyoqCv/bGKP169frkUce0V133SVJ+slPfiKPx6Ndu3bp3nvvjVPZAIBEF9UZ0M9+9jNNmzZN99xzj8aMGaObb75Zzz33XPj4iRMn5Pf7VV5eHh5zu90qLS1VY2PjgGt2dXUpFAo5GgBg5IsqgD744ANt3LhR48eP1969e3X//ffrgQce0NatWyVJfr9fkuTxeByP83g84WP91dTUyO12h1tBQcFgfg4AQIKJKoD6+vp0yy236IknntDNN9+sRYsW6fvf/742bdo06AKqq6sVDAbDrb29fdBrAQASR1QBlJeXp5tuuskxNmHCBLW1tUmSvF6vJCkQCDjmBAKB8LH+XC6XsrOzHQ0AMPJFFUBlZWVqbW11jB07dkxjx46V9H83JHi9XjU0NISPh0IhHTx4UD6fLw7lAgBGiqjugluxYoVuu+02PfHEE/rmN7+pQ4cO6dlnn9Wzzz4rSUpKStLy5cv1+OOPa/z48SoqKtKqVauUn5+vu+++eyjqBwAkqKgC6NZbb9XOnTtVXV2tv/3bv1VRUZHWr1+vefPmheesXLlSZ86c0aJFi9TZ2anbb79de/bsUUZGRtyLBwAkriRjjLFdxGeFQiG53W51dHTEfD2orKzM0W9paYlpPQAYaaZOneroHzhwIOY1Q6GQ8vLyFAwGL/g6zmfBAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCsiCqAbrjhBiUlJUW0yspKSdL58+dVWVmp3NxcZWVlqaKiQoFAYEgKBwAkttRoJh8+fFi9vb3h/tGjR/W1r31N99xzjyRpxYoV+vnPf676+nq53W4tWbJEc+fO1YEDB+JbNcLuvPNOR/+DDz6ImPP2229frnIA4JJFFUDXXXedo7927VrdeOON+spXvqJgMKjNmzdr+/btmjlzpiSprq5OEyZMUFNTk2bMmBG/qgEACW/Q14C6u7v105/+VAsWLFBSUpKam5vV09Oj8vLy8Jzi4mIVFhaqsbHxc9fp6upSKBRyNADAyDfoANq1a5c6Ozt13333SZL8fr/S09OVk5PjmOfxeOT3+z93nZqaGrnd7nArKCgYbEkAgAQy6ADavHmzZs+erfz8/JgKqK6uVjAYDLf29vaY1gMAJIaorgF96r/+67/0q1/9Si+++GJ4zOv1qru7W52dnY6zoEAgIK/X+7lruVwuuVyuwZQBSSUlJY7+TTfdFDHnzJkzjv5//ud/DmVJAHBJBnUGVFdXpzFjxmjOnDnhsZKSEqWlpamhoSE81traqra2Nvl8vtgrBQCMKFGfAfX19amurk7z589Xaur/f7jb7dbChQtVVVWl0aNHKzs7W0uXLpXP5+MOOABAhKgD6Fe/+pXa2tq0YMGCiGPr1q1TcnKyKioq1NXVpVmzZmnDhg1xKRQAMLIkGWOM7SI+KxQKye12q6OjQ9nZ2TGtVVZW5ui3tLTEtF4iePDBByPGjh075ujv3LnzcpUDYJibOnWqox+PDw4IhULKy8tTMBi84Os4nwUHALCCAAIAWEEAAQCsIIAAAFYM6o2oGL62bt0aMXbu3DkLlQDAhXEGBACwggACAFhBAAEArOAa0Ahzoa++AIDhhDMgAIAVBBAAwAoCCABgxbC9BnTu3DnH1z0MRl9fX5yquTzGjBnj6E+fPt1SJZF++ctfRox1d3dbqARAPP3ud79z9E+dOhXzmqdPn76keZwBAQCsIIAAAFYQQAAAKwggAIAVw/YmhM7OTvX29sa0RqyPv9zGjRvn6FdVVVmqJFJjY2PE2EcffWShEgDx1P9mohMnTsS85pkzZy5pHmdAAAArCCAAgBUEEADAimF7DehKdPToUUd/8eLFliqJ1NnZabsEACMMZ0AAACsIIACAFQQQAMAKAggAYEWSMcbYLuKzQqGQ3G63KioqlJaWFtNae/fudfQ//vjjmNYDAFy6YDCo7Ozszz3OGRAAwAoCCABgBQEEALBi2F4DAgAkNq4BAQCGJQIIAGBFVAHU29urVatWqaioSJmZmbrxxhv12GOP6bN/xTPGaPXq1crLy1NmZqbKy8t1/PjxuBcOAEhwJgpr1qwxubm55uWXXzYnTpww9fX1Jisryzz99NPhOWvXrjVut9vs2rXLvPnmm+Yb3/iGKSoqMufOnbuk5wgGg0YSjUaj0RK8BYPBC77eRxVAc+bMMQsWLHCMzZ0718ybN88YY0xfX5/xer3mqaeeCh/v7Ow0LpfLPP/88wQQjUajXUHtYgEU1Z/gbrvtNjU0NOjYsWOSpDfffFP79+/X7NmzJf3fV7n6/X6Vl5eHH+N2u1VaWjrgVzpLUldXl0KhkKMBAEa+qL4P6KGHHlIoFFJxcbFSUlLU29urNWvWaN68eZIkv98vSfJ4PI7HeTye8LH+ampq9IMf/GAwtQMAElhUZ0AvvPCCtm3bpu3bt+v111/X1q1b9fd///faunXroAuorq5WMBgMt/b29kGvBQBIINFcA7r++uvNP/3TPznGHnvsMfOlL33JGGPM+++/bySZN954wzHny1/+snnggQcu6Tm4BkSj0Wgjo8X1GtDZs2eVnOx8SEpKivr6+iRJRUVF8nq9amhoCB8PhUI6ePCgfD5fNE8FABjpLv38x5j58+ebL3zhC+HbsF988UVz7bXXmpUrV4bnrF271uTk5JiXXnrJ/OY3vzF33XUXt2HTaDTaFdjieht2KBQyy5YtM4WFhSYjI8OMGzfOPPzww6arqys8p6+vz6xatcp4PB7jcrnMHXfcYVpbWy/5OQggGo1GGxntYgHEh5ECAIYEH0YKABiWCCAAgBUEEADACgIIAGAFAQQAsIIAAgBYQQABAKwYdgE0zN6WBAAYpIu9ng+7ADp9+rTtEgAAcXCx1/Nh90kIfX19OnnypEaNGqXTp0+roKBA7e3tF3w3LQYnFAqxv0OI/R1a7O/QimV/jTE6ffq08vPzIz7A+rOi+kK6yyE5OVnXX3+9JCkpKUmSlJ2dzS/YEGJ/hxb7O7TY36E12P29lI9UG3Z/ggMAXBkIIACAFcM6gFwulx599FG5XC7bpYxI7O/QYn+HFvs7tC7H/g67mxAAAFeGYX0GBAAYuQggAIAVBBAAwAoCCABgBQEEALBi2AZQbW2tbrjhBmVkZKi0tFSHDh2yXVJCqqmp0a233qpRo0ZpzJgxuvvuu9Xa2uqYc/78eVVWVio3N1dZWVmqqKhQIBCwVHHiWrt2rZKSkrR8+fLwGHsbu9/+9rf6zne+o9zcXGVmZmry5Mk6cuRI+LgxRqtXr1ZeXp4yMzNVXl6u48ePW6w4cfT29mrVqlUqKipSZmambrzxRj322GOODxEd0v01w9COHTtMenq6+fGPf2zefvtt8/3vf9/k5OSYQCBgu7SEM2vWLFNXV2eOHj1qWlpazNe//nVTWFhoPvnkk/CcxYsXm4KCAtPQ0GCOHDliZsyYYW677TaLVSeeQ4cOmRtuuMFMmTLFLFu2LDzO3sbmf//3f83YsWPNfffdZw4ePGg++OADs3fvXvPee++F56xdu9a43W6za9cu8+abb5pvfOMbpqioyJw7d85i5YlhzZo1Jjc317z88svmxIkTpr6+3mRlZZmnn346PGco93dYBtD06dNNZWVluN/b22vy8/NNTU2NxapGhlOnThlJZt++fcYYYzo7O01aWpqpr68Pz/mP//gPI8k0NjbaKjOhnD592owfP9688sor5itf+Uo4gNjb2D344IPm9ttv/9zjfX19xuv1mqeeeio81tnZaVwul3n++ecvR4kJbc6cOWbBggWOsblz55p58+YZY4Z+f4fdn+C6u7vV3Nys8vLy8FhycrLKy8vV2NhosbKRIRgMSpJGjx4tSWpublZPT49jv4uLi1VYWMh+X6LKykrNmTPHsYcSexsPP/vZzzRt2jTdc889GjNmjG6++WY999xz4eMnTpyQ3+937LHb7VZpaSl7fAluu+02NTQ06NixY5KkN998U/v379fs2bMlDf3+DrtPw/7www/V29srj8fjGPd4PHr33XctVTUy9PX1afny5SorK9OkSZMkSX6/X+np6crJyXHM9Xg88vv9FqpMLDt27NDrr7+uw4cPRxxjb2P3wQcfaOPGjaqqqtJf//Vf6/Dhw3rggQeUnp6u+fPnh/dxoNcL9vjiHnroIYVCIRUXFyslJUW9vb1as2aN5s2bJ0lDvr/DLoAwdCorK3X06FHt37/fdikjQnt7u5YtW6ZXXnlFGRkZtssZkfr6+jRt2jQ98cQTkqSbb75ZR48e1aZNmzR//nzL1SW+F154Qdu2bdP27ds1ceJEtbS0aPny5crPz78s+zvs/gR37bXXKiUlJeJOoUAgIK/Xa6mqxLdkyRK9/PLL+rd/+7fw9y1JktfrVXd3tzo7Ox3z2e+La25u1qlTp3TLLbcoNTVVqamp2rdvn5555hmlpqbK4/GwtzHKy8vTTTfd5BibMGGC2traJCm8j7xeDM5f/dVf6aGHHtK9996ryZMn60//9E+1YsUK1dTUSBr6/R12AZSenq6SkhI1NDSEx/r6+tTQ0CCfz2exssRkjNGSJUu0c+dOvfrqqyoqKnIcLykpUVpammO/W1tb1dbWxn5fxB133KG33npLLS0t4TZt2jTNmzcv/G/2NjZlZWURbxs4duyYxo4dK0kqKiqS1+t17HEoFNLBgwfZ40tw9uzZiG8sTUlJUV9fn6TLsL8x38YwBHbs2GFcLpfZsmWLeeedd8yiRYtMTk6O8fv9tktLOPfff79xu93mtddeMx0dHeF29uzZ8JzFixebwsJC8+qrr5ojR44Yn89nfD6fxaoT12fvgjOGvY3VoUOHTGpqqlmzZo05fvy42bZtm7nqqqvMT3/60/CctWvXmpycHPPSSy+Z3/zmN+auu+7iNuxLNH/+fPOFL3whfBv2iy++aK699lqzcuXK8Jyh3N9hGUDGGPPDH/7QFBYWmvT0dDN9+nTT1NRku6SEJGnAVldXF55z7tw58xd/8RfmmmuuMVdddZX5kz/5E9PR0WGv6ATWP4DY29jt3r3bTJo0ybhcLlNcXGyeffZZx/G+vj6zatUq4/F4jMvlMnfccYdpbW21VG1iCYVCZtmyZaawsNBkZGSYcePGmYcffth0dXWF5wzl/vJ9QAAAK4bdNSAAwJWBAAIAWEEAAQCsIIAAAFYQQAAAKwggAIAVBBAAwAoCCABgBQEEALCCAAIAWEEAAQCs+H93WYWyZ+ogdAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "attributions_sq = trajectory_attributions(test_observations, models_sq, trajectory_embedding_seaquest, clusters_seaquest)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "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 0x0000016F9DF607F0>, 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 0x0000016FB007BBB0>, 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 0x0000016FA724DDF0>, 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 0x0000016FB0015100>, 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 0x0000016FA7208700>, 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 0x0000016FA7208340>, 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([3], dtype=int64),\n",
       "  'new_act': array([0], dtype=int64),\n",
       "  'attributed_trajs': [9,\n",
       "   10,\n",
       "   16,\n",
       "   49,\n",
       "   50,\n",
       "   53,\n",
       "   65,\n",
       "   66,\n",
       "   67,\n",
       "   71,\n",
       "   72,\n",
       "   77,\n",
       "   78,\n",
       "   81,\n",
       "   82,\n",
       "   83,\n",
       "   92,\n",
       "   98,\n",
       "   100,\n",
       "   101,\n",
       "   112,\n",
       "   113,\n",
       "   114,\n",
       "   123,\n",
       "   125,\n",
       "   129,\n",
       "   130,\n",
       "   135,\n",
       "   136,\n",
       "   137,\n",
       "   141,\n",
       "   142,\n",
       "   143,\n",
       "   145,\n",
       "   154,\n",
       "   162,\n",
       "   165,\n",
       "   166,\n",
       "   170,\n",
       "   171,\n",
       "   172,\n",
       "   175,\n",
       "   176,\n",
       "   178,\n",
       "   181,\n",
       "   182,\n",
       "   183,\n",
       "   185,\n",
       "   186,\n",
       "   187,\n",
       "   219,\n",
       "   223,\n",
       "   224,\n",
       "   225,\n",
       "   254,\n",
       "   293,\n",
       "   295,\n",
       "   302,\n",
       "   304,\n",
       "   325,\n",
       "   326,\n",
       "   327,\n",
       "   331,\n",
       "   332,\n",
       "   345,\n",
       "   346,\n",
       "   347,\n",
       "   348,\n",
       "   349,\n",
       "   353,\n",
       "   354,\n",
       "   356,\n",
       "   407,\n",
       "   409,\n",
       "   435,\n",
       "   436,\n",
       "   439,\n",
       "   450,\n",
       "   451,\n",
       "   458,\n",
       "   478,\n",
       "   479,\n",
       "   480,\n",
       "   482,\n",
       "   485,\n",
       "   499,\n",
       "   500,\n",
       "   501,\n",
       "   502,\n",
       "   507,\n",
       "   508,\n",
       "   530,\n",
       "   531,\n",
       "   532,\n",
       "   533,\n",
       "   535,\n",
       "   536,\n",
       "   564,\n",
       "   565,\n",
       "   569,\n",
       "   611,\n",
       "   612,\n",
       "   615,\n",
       "   619,\n",
       "   621,\n",
       "   625,\n",
       "   627,\n",
       "   628,\n",
       "   643,\n",
       "   645,\n",
       "   650,\n",
       "   657,\n",
       "   662,\n",
       "   672,\n",
       "   673,\n",
       "   727,\n",
       "   728,\n",
       "   740,\n",
       "   758,\n",
       "   761,\n",
       "   762,\n",
       "   767,\n",
       "   778,\n",
       "   797,\n",
       "   800,\n",
       "   801,\n",
       "   802,\n",
       "   803,\n",
       "   805,\n",
       "   806,\n",
       "   812,\n",
       "   819,\n",
       "   821,\n",
       "   822,\n",
       "   823,\n",
       "   824,\n",
       "   827,\n",
       "   830,\n",
       "   834,\n",
       "   839,\n",
       "   840,\n",
       "   844,\n",
       "   859,\n",
       "   860,\n",
       "   861,\n",
       "   862,\n",
       "   863,\n",
       "   864,\n",
       "   865,\n",
       "   867,\n",
       "   868,\n",
       "   875,\n",
       "   894,\n",
       "   895,\n",
       "   896,\n",
       "   899,\n",
       "   900,\n",
       "   901,\n",
       "   902,\n",
       "   910,\n",
       "   912,\n",
       "   932,\n",
       "   933,\n",
       "   934,\n",
       "   935,\n",
       "   936,\n",
       "   937,\n",
       "   939,\n",
       "   958,\n",
       "   959,\n",
       "   960,\n",
       "   968,\n",
       "   981,\n",
       "   998,\n",
       "   1000,\n",
       "   1002,\n",
       "   1003,\n",
       "   1004,\n",
       "   1005,\n",
       "   1006,\n",
       "   1007,\n",
       "   1031,\n",
       "   1032,\n",
       "   1033,\n",
       "   1034,\n",
       "   1035,\n",
       "   1036,\n",
       "   1037,\n",
       "   1038,\n",
       "   1039,\n",
       "   1040,\n",
       "   1041,\n",
       "   1046,\n",
       "   1050,\n",
       "   1051,\n",
       "   1063,\n",
       "   1066,\n",
       "   1067,\n",
       "   1075,\n",
       "   1085,\n",
       "   1093,\n",
       "   1096,\n",
       "   1097,\n",
       "   1107,\n",
       "   1129,\n",
       "   1134,\n",
       "   1136,\n",
       "   1141,\n",
       "   1142,\n",
       "   1143,\n",
       "   1144,\n",
       "   1145,\n",
       "   1146,\n",
       "   1147,\n",
       "   1148,\n",
       "   1149,\n",
       "   1150,\n",
       "   1151,\n",
       "   1156,\n",
       "   1168,\n",
       "   1192,\n",
       "   1202,\n",
       "   1206,\n",
       "   1212,\n",
       "   1219,\n",
       "   1220,\n",
       "   1228,\n",
       "   1229,\n",
       "   1230,\n",
       "   1231,\n",
       "   1232,\n",
       "   1233,\n",
       "   1238,\n",
       "   1239,\n",
       "   1240,\n",
       "   1243,\n",
       "   1245,\n",
       "   1258,\n",
       "   1261,\n",
       "   1269,\n",
       "   1270,\n",
       "   1271,\n",
       "   1272,\n",
       "   1274,\n",
       "   1287,\n",
       "   1288,\n",
       "   1289,\n",
       "   1292,\n",
       "   1293,\n",
       "   1320,\n",
       "   1339,\n",
       "   1340,\n",
       "   1341,\n",
       "   1344,\n",
       "   1345,\n",
       "   1347,\n",
       "   1353,\n",
       "   1355,\n",
       "   1374,\n",
       "   1376,\n",
       "   1378,\n",
       "   1379,\n",
       "   1380,\n",
       "   1382,\n",
       "   1383,\n",
       "   1390,\n",
       "   1406,\n",
       "   1408,\n",
       "   1409,\n",
       "   1410,\n",
       "   1411,\n",
       "   1412,\n",
       "   1413,\n",
       "   1416,\n",
       "   1419,\n",
       "   1421,\n",
       "   1456,\n",
       "   1463,\n",
       "   1464,\n",
       "   1470,\n",
       "   1471,\n",
       "   1472,\n",
       "   1474,\n",
       "   1479,\n",
       "   1509,\n",
       "   1529,\n",
       "   1532,\n",
       "   1578,\n",
       "   1579,\n",
       "   1582,\n",
       "   1583,\n",
       "   1584,\n",
       "   1585,\n",
       "   1586,\n",
       "   1615,\n",
       "   1617,\n",
       "   1619,\n",
       "   1621,\n",
       "   1623,\n",
       "   1632,\n",
       "   1639,\n",
       "   1661,\n",
       "   1664,\n",
       "   1667,\n",
       "   1689,\n",
       "   1690,\n",
       "   1730,\n",
       "   1733,\n",
       "   1734,\n",
       "   1758,\n",
       "   1759,\n",
       "   1771,\n",
       "   1772,\n",
       "   1775,\n",
       "   1776,\n",
       "   1807,\n",
       "   1853,\n",
       "   1890,\n",
       "   1912,\n",
       "   1915,\n",
       "   1916,\n",
       "   1918,\n",
       "   1921,\n",
       "   1943,\n",
       "   1944,\n",
       "   1945,\n",
       "   1947,\n",
       "   1951,\n",
       "   1952,\n",
       "   1984,\n",
       "   1992,\n",
       "   1993,\n",
       "   1997,\n",
       "   2002,\n",
       "   2005,\n",
       "   2006,\n",
       "   2007,\n",
       "   2008,\n",
       "   2010,\n",
       "   2018,\n",
       "   2019,\n",
       "   2020,\n",
       "   2021,\n",
       "   2028,\n",
       "   2029,\n",
       "   2033,\n",
       "   2035,\n",
       "   2041,\n",
       "   2045,\n",
       "   2050,\n",
       "   2052,\n",
       "   2061,\n",
       "   2069,\n",
       "   2074,\n",
       "   2081,\n",
       "   2082,\n",
       "   2083,\n",
       "   2084,\n",
       "   2086,\n",
       "   2094,\n",
       "   2108,\n",
       "   2109,\n",
       "   2110,\n",
       "   2111,\n",
       "   2124,\n",
       "   2138,\n",
       "   2139,\n",
       "   2141,\n",
       "   2142,\n",
       "   2143,\n",
       "   2148,\n",
       "   2155,\n",
       "   2157,\n",
       "   2158,\n",
       "   2189,\n",
       "   2190,\n",
       "   2191,\n",
       "   2192,\n",
       "   2194,\n",
       "   2217,\n",
       "   2220,\n",
       "   2225,\n",
       "   2226,\n",
       "   2227,\n",
       "   2234,\n",
       "   2237,\n",
       "   2238,\n",
       "   2240,\n",
       "   2246,\n",
       "   2258,\n",
       "   2259,\n",
       "   2260,\n",
       "   2261,\n",
       "   2265,\n",
       "   2266,\n",
       "   2267,\n",
       "   2276,\n",
       "   2279,\n",
       "   2284,\n",
       "   2296,\n",
       "   2297,\n",
       "   2298,\n",
       "   2299,\n",
       "   2300,\n",
       "   2301,\n",
       "   2302,\n",
       "   2324,\n",
       "   2327,\n",
       "   2348,\n",
       "   2351,\n",
       "   2400,\n",
       "   2403,\n",
       "   2433,\n",
       "   2442,\n",
       "   2446,\n",
       "   2450,\n",
       "   2452,\n",
       "   2453,\n",
       "   2457,\n",
       "   2459,\n",
       "   2460,\n",
       "   2463,\n",
       "   2465,\n",
       "   2466,\n",
       "   2467,\n",
       "   2469,\n",
       "   2470,\n",
       "   2471,\n",
       "   2472,\n",
       "   2473,\n",
       "   2474,\n",
       "   2479,\n",
       "   2480,\n",
       "   2483,\n",
       "   2485,\n",
       "   2488,\n",
       "   2494,\n",
       "   2506,\n",
       "   2507,\n",
       "   2508,\n",
       "   2509,\n",
       "   2510,\n",
       "   2511,\n",
       "   2512,\n",
       "   2513,\n",
       "   2514,\n",
       "   2515,\n",
       "   2516,\n",
       "   2517,\n",
       "   2518,\n",
       "   2519,\n",
       "   2520,\n",
       "   2521,\n",
       "   2522,\n",
       "   2523,\n",
       "   2524,\n",
       "   2525,\n",
       "   2526,\n",
       "   2527,\n",
       "   2581,\n",
       "   2608,\n",
       "   2614,\n",
       "   2618,\n",
       "   2636,\n",
       "   2659,\n",
       "   2662,\n",
       "   2674,\n",
       "   2675,\n",
       "   2676,\n",
       "   2677,\n",
       "   2678,\n",
       "   2679,\n",
       "   2680,\n",
       "   2682,\n",
       "   2683,\n",
       "   2685,\n",
       "   2687,\n",
       "   2688,\n",
       "   2703,\n",
       "   2717,\n",
       "   2719,\n",
       "   2720,\n",
       "   2726,\n",
       "   2727,\n",
       "   2729,\n",
       "   2730,\n",
       "   2737,\n",
       "   2738,\n",
       "   2739,\n",
       "   2740,\n",
       "   2741,\n",
       "   2742,\n",
       "   2744,\n",
       "   2745,\n",
       "   2746,\n",
       "   2791,\n",
       "   2793,\n",
       "   2797,\n",
       "   2799,\n",
       "   2810,\n",
       "   2811,\n",
       "   2812,\n",
       "   2816,\n",
       "   2817,\n",
       "   2819,\n",
       "   2820,\n",
       "   2821,\n",
       "   2823,\n",
       "   2824,\n",
       "   2826,\n",
       "   2852,\n",
       "   2854,\n",
       "   2856,\n",
       "   2929,\n",
       "   2968,\n",
       "   2982,\n",
       "   2984,\n",
       "   2986,\n",
       "   2987,\n",
       "   2988,\n",
       "   2991,\n",
       "   2992,\n",
       "   2993,\n",
       "   2996,\n",
       "   3002,\n",
       "   3008,\n",
       "   3043,\n",
       "   3044,\n",
       "   3057,\n",
       "   3060,\n",
       "   3061,\n",
       "   3062,\n",
       "   3063,\n",
       "   3066,\n",
       "   3067,\n",
       "   3083,\n",
       "   3084,\n",
       "   3086,\n",
       "   3087,\n",
       "   3088,\n",
       "   3090,\n",
       "   3092,\n",
       "   3105,\n",
       "   3108,\n",
       "   3109,\n",
       "   3110,\n",
       "   3111,\n",
       "   3114,\n",
       "   3118,\n",
       "   3127,\n",
       "   3128,\n",
       "   3132,\n",
       "   3138,\n",
       "   3147,\n",
       "   3150,\n",
       "   3151,\n",
       "   3152,\n",
       "   3154,\n",
       "   3155,\n",
       "   3194,\n",
       "   3197,\n",
       "   3198,\n",
       "   3200,\n",
       "   3206,\n",
       "   3207,\n",
       "   3208,\n",
       "   3209,\n",
       "   3210,\n",
       "   3211,\n",
       "   3231,\n",
       "   3238,\n",
       "   3239,\n",
       "   3256,\n",
       "   3259,\n",
       "   3265,\n",
       "   3343,\n",
       "   3346,\n",
       "   3357,\n",
       "   3359,\n",
       "   3362,\n",
       "   3365,\n",
       "   3366,\n",
       "   3367,\n",
       "   3392,\n",
       "   3394,\n",
       "   3397,\n",
       "   3399,\n",
       "   3424,\n",
       "   3425,\n",
       "   3426,\n",
       "   3428,\n",
       "   3430,\n",
       "   3431,\n",
       "   3435,\n",
       "   3444,\n",
       "   3445,\n",
       "   3446,\n",
       "   3461,\n",
       "   3462,\n",
       "   3463,\n",
       "   3465,\n",
       "   3466,\n",
       "   3467,\n",
       "   3468,\n",
       "   3469,\n",
       "   3476,\n",
       "   3477,\n",
       "   3478,\n",
       "   3479,\n",
       "   3491,\n",
       "   3492,\n",
       "   3493,\n",
       "   3494,\n",
       "   3495,\n",
       "   3498,\n",
       "   3500,\n",
       "   3501,\n",
       "   3514,\n",
       "   3515,\n",
       "   3517,\n",
       "   3519,\n",
       "   3524,\n",
       "   3555,\n",
       "   3556,\n",
       "   3557,\n",
       "   3558,\n",
       "   3559,\n",
       "   3560,\n",
       "   3561,\n",
       "   3562,\n",
       "   3563,\n",
       "   3564,\n",
       "   3565,\n",
       "   3567,\n",
       "   3586,\n",
       "   3591,\n",
       "   3596,\n",
       "   3625,\n",
       "   3627,\n",
       "   3628,\n",
       "   3633,\n",
       "   3634,\n",
       "   3637,\n",
       "   3638,\n",
       "   3642,\n",
       "   3651,\n",
       "   3652,\n",
       "   3653,\n",
       "   3654,\n",
       "   3655,\n",
       "   3656,\n",
       "   3658,\n",
       "   3665,\n",
       "   3666,\n",
       "   3668,\n",
       "   3669,\n",
       "   3736,\n",
       "   3757,\n",
       "   3767,\n",
       "   3791,\n",
       "   3792,\n",
       "   3794,\n",
       "   3795,\n",
       "   3796,\n",
       "   3798,\n",
       "   3800,\n",
       "   3801,\n",
       "   3802,\n",
       "   3803,\n",
       "   3804,\n",
       "   3805,\n",
       "   3806,\n",
       "   3807,\n",
       "   3821,\n",
       "   3822,\n",
       "   3823,\n",
       "   3825,\n",
       "   3826,\n",
       "   3827,\n",
       "   3828,\n",
       "   3829,\n",
       "   3831,\n",
       "   3834,\n",
       "   3852,\n",
       "   3853,\n",
       "   3854,\n",
       "   3857,\n",
       "   3858,\n",
       "   3888,\n",
       "   3891,\n",
       "   3896,\n",
       "   3900,\n",
       "   3901,\n",
       "   3902,\n",
       "   3903,\n",
       "   3904,\n",
       "   3910,\n",
       "   3915,\n",
       "   3926,\n",
       "   3950,\n",
       "   3951,\n",
       "   3955,\n",
       "   3964,\n",
       "   3967,\n",
       "   3994,\n",
       "   3995,\n",
       "   3998,\n",
       "   4007,\n",
       "   4008,\n",
       "   4013,\n",
       "   4033,\n",
       "   4038,\n",
       "   4039,\n",
       "   4040,\n",
       "   4041,\n",
       "   4046,\n",
       "   4047,\n",
       "   4048,\n",
       "   4049,\n",
       "   4075,\n",
       "   4082,\n",
       "   4088,\n",
       "   4089,\n",
       "   4090,\n",
       "   4091,\n",
       "   4092,\n",
       "   4109,\n",
       "   4113,\n",
       "   4123,\n",
       "   4124,\n",
       "   4137,\n",
       "   4138,\n",
       "   4139,\n",
       "   4142,\n",
       "   4157,\n",
       "   4158,\n",
       "   4185,\n",
       "   4186,\n",
       "   4187,\n",
       "   4215,\n",
       "   4216,\n",
       "   4219,\n",
       "   4220,\n",
       "   4222,\n",
       "   4223],\n",
       "  'responsible_cluster': 4},\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 0x0000016F9DF607F0>, 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 0x0000016FB007BBB0>, 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 0x0000016FA724DDF0>, 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 0x0000016FB0015100>, 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 0x0000016FA7208700>, 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 0x0000016FA7208340>, 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([3], dtype=int64),\n",
       "  'new_act': array([0], dtype=int64),\n",
       "  'attributed_trajs': [9,\n",
       "   10,\n",
       "   16,\n",
       "   49,\n",
       "   50,\n",
       "   53,\n",
       "   65,\n",
       "   66,\n",
       "   67,\n",
       "   71,\n",
       "   72,\n",
       "   77,\n",
       "   78,\n",
       "   81,\n",
       "   82,\n",
       "   83,\n",
       "   92,\n",
       "   98,\n",
       "   100,\n",
       "   101,\n",
       "   112,\n",
       "   113,\n",
       "   114,\n",
       "   123,\n",
       "   125,\n",
       "   129,\n",
       "   130,\n",
       "   135,\n",
       "   136,\n",
       "   137,\n",
       "   141,\n",
       "   142,\n",
       "   143,\n",
       "   145,\n",
       "   154,\n",
       "   162,\n",
       "   165,\n",
       "   166,\n",
       "   170,\n",
       "   171,\n",
       "   172,\n",
       "   175,\n",
       "   176,\n",
       "   178,\n",
       "   181,\n",
       "   182,\n",
       "   183,\n",
       "   185,\n",
       "   186,\n",
       "   187,\n",
       "   219,\n",
       "   223,\n",
       "   224,\n",
       "   225,\n",
       "   254,\n",
       "   293,\n",
       "   295,\n",
       "   302,\n",
       "   304,\n",
       "   325,\n",
       "   326,\n",
       "   327,\n",
       "   331,\n",
       "   332,\n",
       "   345,\n",
       "   346,\n",
       "   347,\n",
       "   348,\n",
       "   349,\n",
       "   353,\n",
       "   354,\n",
       "   356,\n",
       "   407,\n",
       "   409,\n",
       "   435,\n",
       "   436,\n",
       "   439,\n",
       "   450,\n",
       "   451,\n",
       "   458,\n",
       "   478,\n",
       "   479,\n",
       "   480,\n",
       "   482,\n",
       "   485,\n",
       "   499,\n",
       "   500,\n",
       "   501,\n",
       "   502,\n",
       "   507,\n",
       "   508,\n",
       "   530,\n",
       "   531,\n",
       "   532,\n",
       "   533,\n",
       "   535,\n",
       "   536,\n",
       "   564,\n",
       "   565,\n",
       "   569,\n",
       "   611,\n",
       "   612,\n",
       "   615,\n",
       "   619,\n",
       "   621,\n",
       "   625,\n",
       "   627,\n",
       "   628,\n",
       "   643,\n",
       "   645,\n",
       "   650,\n",
       "   657,\n",
       "   662,\n",
       "   672,\n",
       "   673,\n",
       "   727,\n",
       "   728,\n",
       "   740,\n",
       "   758,\n",
       "   761,\n",
       "   762,\n",
       "   767,\n",
       "   778,\n",
       "   797,\n",
       "   800,\n",
       "   801,\n",
       "   802,\n",
       "   803,\n",
       "   805,\n",
       "   806,\n",
       "   812,\n",
       "   819,\n",
       "   821,\n",
       "   822,\n",
       "   823,\n",
       "   824,\n",
       "   827,\n",
       "   830,\n",
       "   834,\n",
       "   839,\n",
       "   840,\n",
       "   844,\n",
       "   859,\n",
       "   860,\n",
       "   861,\n",
       "   862,\n",
       "   863,\n",
       "   864,\n",
       "   865,\n",
       "   867,\n",
       "   868,\n",
       "   875,\n",
       "   894,\n",
       "   895,\n",
       "   896,\n",
       "   899,\n",
       "   900,\n",
       "   901,\n",
       "   902,\n",
       "   910,\n",
       "   912,\n",
       "   932,\n",
       "   933,\n",
       "   934,\n",
       "   935,\n",
       "   936,\n",
       "   937,\n",
       "   939,\n",
       "   958,\n",
       "   959,\n",
       "   960,\n",
       "   968,\n",
       "   981,\n",
       "   998,\n",
       "   1000,\n",
       "   1002,\n",
       "   1003,\n",
       "   1004,\n",
       "   1005,\n",
       "   1006,\n",
       "   1007,\n",
       "   1031,\n",
       "   1032,\n",
       "   1033,\n",
       "   1034,\n",
       "   1035,\n",
       "   1036,\n",
       "   1037,\n",
       "   1038,\n",
       "   1039,\n",
       "   1040,\n",
       "   1041,\n",
       "   1046,\n",
       "   1050,\n",
       "   1051,\n",
       "   1063,\n",
       "   1066,\n",
       "   1067,\n",
       "   1075,\n",
       "   1085,\n",
       "   1093,\n",
       "   1096,\n",
       "   1097,\n",
       "   1107,\n",
       "   1129,\n",
       "   1134,\n",
       "   1136,\n",
       "   1141,\n",
       "   1142,\n",
       "   1143,\n",
       "   1144,\n",
       "   1145,\n",
       "   1146,\n",
       "   1147,\n",
       "   1148,\n",
       "   1149,\n",
       "   1150,\n",
       "   1151,\n",
       "   1156,\n",
       "   1168,\n",
       "   1192,\n",
       "   1202,\n",
       "   1206,\n",
       "   1212,\n",
       "   1219,\n",
       "   1220,\n",
       "   1228,\n",
       "   1229,\n",
       "   1230,\n",
       "   1231,\n",
       "   1232,\n",
       "   1233,\n",
       "   1238,\n",
       "   1239,\n",
       "   1240,\n",
       "   1243,\n",
       "   1245,\n",
       "   1258,\n",
       "   1261,\n",
       "   1269,\n",
       "   1270,\n",
       "   1271,\n",
       "   1272,\n",
       "   1274,\n",
       "   1287,\n",
       "   1288,\n",
       "   1289,\n",
       "   1292,\n",
       "   1293,\n",
       "   1320,\n",
       "   1339,\n",
       "   1340,\n",
       "   1341,\n",
       "   1344,\n",
       "   1345,\n",
       "   1347,\n",
       "   1353,\n",
       "   1355,\n",
       "   1374,\n",
       "   1376,\n",
       "   1378,\n",
       "   1379,\n",
       "   1380,\n",
       "   1382,\n",
       "   1383,\n",
       "   1390,\n",
       "   1406,\n",
       "   1408,\n",
       "   1409,\n",
       "   1410,\n",
       "   1411,\n",
       "   1412,\n",
       "   1413,\n",
       "   1416,\n",
       "   1419,\n",
       "   1421,\n",
       "   1456,\n",
       "   1463,\n",
       "   1464,\n",
       "   1470,\n",
       "   1471,\n",
       "   1472,\n",
       "   1474,\n",
       "   1479,\n",
       "   1509,\n",
       "   1529,\n",
       "   1532,\n",
       "   1578,\n",
       "   1579,\n",
       "   1582,\n",
       "   1583,\n",
       "   1584,\n",
       "   1585,\n",
       "   1586,\n",
       "   1615,\n",
       "   1617,\n",
       "   1619,\n",
       "   1621,\n",
       "   1623,\n",
       "   1632,\n",
       "   1639,\n",
       "   1661,\n",
       "   1664,\n",
       "   1667,\n",
       "   1689,\n",
       "   1690,\n",
       "   1730,\n",
       "   1733,\n",
       "   1734,\n",
       "   1758,\n",
       "   1759,\n",
       "   1771,\n",
       "   1772,\n",
       "   1775,\n",
       "   1776,\n",
       "   1807,\n",
       "   1853,\n",
       "   1890,\n",
       "   1912,\n",
       "   1915,\n",
       "   1916,\n",
       "   1918,\n",
       "   1921,\n",
       "   1943,\n",
       "   1944,\n",
       "   1945,\n",
       "   1947,\n",
       "   1951,\n",
       "   1952,\n",
       "   1984,\n",
       "   1992,\n",
       "   1993,\n",
       "   1997,\n",
       "   2002,\n",
       "   2005,\n",
       "   2006,\n",
       "   2007,\n",
       "   2008,\n",
       "   2010,\n",
       "   2018,\n",
       "   2019,\n",
       "   2020,\n",
       "   2021,\n",
       "   2028,\n",
       "   2029,\n",
       "   2033,\n",
       "   2035,\n",
       "   2041,\n",
       "   2045,\n",
       "   2050,\n",
       "   2052,\n",
       "   2061,\n",
       "   2069,\n",
       "   2074,\n",
       "   2081,\n",
       "   2082,\n",
       "   2083,\n",
       "   2084,\n",
       "   2086,\n",
       "   2094,\n",
       "   2108,\n",
       "   2109,\n",
       "   2110,\n",
       "   2111,\n",
       "   2124,\n",
       "   2138,\n",
       "   2139,\n",
       "   2141,\n",
       "   2142,\n",
       "   2143,\n",
       "   2148,\n",
       "   2155,\n",
       "   2157,\n",
       "   2158,\n",
       "   2189,\n",
       "   2190,\n",
       "   2191,\n",
       "   2192,\n",
       "   2194,\n",
       "   2217,\n",
       "   2220,\n",
       "   2225,\n",
       "   2226,\n",
       "   2227,\n",
       "   2234,\n",
       "   2237,\n",
       "   2238,\n",
       "   2240,\n",
       "   2246,\n",
       "   2258,\n",
       "   2259,\n",
       "   2260,\n",
       "   2261,\n",
       "   2265,\n",
       "   2266,\n",
       "   2267,\n",
       "   2276,\n",
       "   2279,\n",
       "   2284,\n",
       "   2296,\n",
       "   2297,\n",
       "   2298,\n",
       "   2299,\n",
       "   2300,\n",
       "   2301,\n",
       "   2302,\n",
       "   2324,\n",
       "   2327,\n",
       "   2348,\n",
       "   2351,\n",
       "   2400,\n",
       "   2403,\n",
       "   2433,\n",
       "   2442,\n",
       "   2446,\n",
       "   2450,\n",
       "   2452,\n",
       "   2453,\n",
       "   2457,\n",
       "   2459,\n",
       "   2460,\n",
       "   2463,\n",
       "   2465,\n",
       "   2466,\n",
       "   2467,\n",
       "   2469,\n",
       "   2470,\n",
       "   2471,\n",
       "   2472,\n",
       "   2473,\n",
       "   2474,\n",
       "   2479,\n",
       "   2480,\n",
       "   2483,\n",
       "   2485,\n",
       "   2488,\n",
       "   2494,\n",
       "   2506,\n",
       "   2507,\n",
       "   2508,\n",
       "   2509,\n",
       "   2510,\n",
       "   2511,\n",
       "   2512,\n",
       "   2513,\n",
       "   2514,\n",
       "   2515,\n",
       "   2516,\n",
       "   2517,\n",
       "   2518,\n",
       "   2519,\n",
       "   2520,\n",
       "   2521,\n",
       "   2522,\n",
       "   2523,\n",
       "   2524,\n",
       "   2525,\n",
       "   2526,\n",
       "   2527,\n",
       "   2581,\n",
       "   2608,\n",
       "   2614,\n",
       "   2618,\n",
       "   2636,\n",
       "   2659,\n",
       "   2662,\n",
       "   2674,\n",
       "   2675,\n",
       "   2676,\n",
       "   2677,\n",
       "   2678,\n",
       "   2679,\n",
       "   2680,\n",
       "   2682,\n",
       "   2683,\n",
       "   2685,\n",
       "   2687,\n",
       "   2688,\n",
       "   2703,\n",
       "   2717,\n",
       "   2719,\n",
       "   2720,\n",
       "   2726,\n",
       "   2727,\n",
       "   2729,\n",
       "   2730,\n",
       "   2737,\n",
       "   2738,\n",
       "   2739,\n",
       "   2740,\n",
       "   2741,\n",
       "   2742,\n",
       "   2744,\n",
       "   2745,\n",
       "   2746,\n",
       "   2791,\n",
       "   2793,\n",
       "   2797,\n",
       "   2799,\n",
       "   2810,\n",
       "   2811,\n",
       "   2812,\n",
       "   2816,\n",
       "   2817,\n",
       "   2819,\n",
       "   2820,\n",
       "   2821,\n",
       "   2823,\n",
       "   2824,\n",
       "   2826,\n",
       "   2852,\n",
       "   2854,\n",
       "   2856,\n",
       "   2929,\n",
       "   2968,\n",
       "   2982,\n",
       "   2984,\n",
       "   2986,\n",
       "   2987,\n",
       "   2988,\n",
       "   2991,\n",
       "   2992,\n",
       "   2993,\n",
       "   2996,\n",
       "   3002,\n",
       "   3008,\n",
       "   3043,\n",
       "   3044,\n",
       "   3057,\n",
       "   3060,\n",
       "   3061,\n",
       "   3062,\n",
       "   3063,\n",
       "   3066,\n",
       "   3067,\n",
       "   3083,\n",
       "   3084,\n",
       "   3086,\n",
       "   3087,\n",
       "   3088,\n",
       "   3090,\n",
       "   3092,\n",
       "   3105,\n",
       "   3108,\n",
       "   3109,\n",
       "   3110,\n",
       "   3111,\n",
       "   3114,\n",
       "   3118,\n",
       "   3127,\n",
       "   3128,\n",
       "   3132,\n",
       "   3138,\n",
       "   3147,\n",
       "   3150,\n",
       "   3151,\n",
       "   3152,\n",
       "   3154,\n",
       "   3155,\n",
       "   3194,\n",
       "   3197,\n",
       "   3198,\n",
       "   3200,\n",
       "   3206,\n",
       "   3207,\n",
       "   3208,\n",
       "   3209,\n",
       "   3210,\n",
       "   3211,\n",
       "   3231,\n",
       "   3238,\n",
       "   3239,\n",
       "   3256,\n",
       "   3259,\n",
       "   3265,\n",
       "   3343,\n",
       "   3346,\n",
       "   3357,\n",
       "   3359,\n",
       "   3362,\n",
       "   3365,\n",
       "   3366,\n",
       "   3367,\n",
       "   3392,\n",
       "   3394,\n",
       "   3397,\n",
       "   3399,\n",
       "   3424,\n",
       "   3425,\n",
       "   3426,\n",
       "   3428,\n",
       "   3430,\n",
       "   3431,\n",
       "   3435,\n",
       "   3444,\n",
       "   3445,\n",
       "   3446,\n",
       "   3461,\n",
       "   3462,\n",
       "   3463,\n",
       "   3465,\n",
       "   3466,\n",
       "   3467,\n",
       "   3468,\n",
       "   3469,\n",
       "   3476,\n",
       "   3477,\n",
       "   3478,\n",
       "   3479,\n",
       "   3491,\n",
       "   3492,\n",
       "   3493,\n",
       "   3494,\n",
       "   3495,\n",
       "   3498,\n",
       "   3500,\n",
       "   3501,\n",
       "   3514,\n",
       "   3515,\n",
       "   3517,\n",
       "   3519,\n",
       "   3524,\n",
       "   3555,\n",
       "   3556,\n",
       "   3557,\n",
       "   3558,\n",
       "   3559,\n",
       "   3560,\n",
       "   3561,\n",
       "   3562,\n",
       "   3563,\n",
       "   3564,\n",
       "   3565,\n",
       "   3567,\n",
       "   3586,\n",
       "   3591,\n",
       "   3596,\n",
       "   3625,\n",
       "   3627,\n",
       "   3628,\n",
       "   3633,\n",
       "   3634,\n",
       "   3637,\n",
       "   3638,\n",
       "   3642,\n",
       "   3651,\n",
       "   3652,\n",
       "   3653,\n",
       "   3654,\n",
       "   3655,\n",
       "   3656,\n",
       "   3658,\n",
       "   3665,\n",
       "   3666,\n",
       "   3668,\n",
       "   3669,\n",
       "   3736,\n",
       "   3757,\n",
       "   3767,\n",
       "   3791,\n",
       "   3792,\n",
       "   3794,\n",
       "   3795,\n",
       "   3796,\n",
       "   3798,\n",
       "   3800,\n",
       "   3801,\n",
       "   3802,\n",
       "   3803,\n",
       "   3804,\n",
       "   3805,\n",
       "   3806,\n",
       "   3807,\n",
       "   3821,\n",
       "   3822,\n",
       "   3823,\n",
       "   3825,\n",
       "   3826,\n",
       "   3827,\n",
       "   3828,\n",
       "   3829,\n",
       "   3831,\n",
       "   3834,\n",
       "   3852,\n",
       "   3853,\n",
       "   3854,\n",
       "   3857,\n",
       "   3858,\n",
       "   3888,\n",
       "   3891,\n",
       "   3896,\n",
       "   3900,\n",
       "   3901,\n",
       "   3902,\n",
       "   3903,\n",
       "   3904,\n",
       "   3910,\n",
       "   3915,\n",
       "   3926,\n",
       "   3950,\n",
       "   3951,\n",
       "   3955,\n",
       "   3964,\n",
       "   3967,\n",
       "   3994,\n",
       "   3995,\n",
       "   3998,\n",
       "   4007,\n",
       "   4008,\n",
       "   4013,\n",
       "   4033,\n",
       "   4038,\n",
       "   4039,\n",
       "   4040,\n",
       "   4041,\n",
       "   4046,\n",
       "   4047,\n",
       "   4048,\n",
       "   4049,\n",
       "   4075,\n",
       "   4082,\n",
       "   4088,\n",
       "   4089,\n",
       "   4090,\n",
       "   4091,\n",
       "   4092,\n",
       "   4109,\n",
       "   4113,\n",
       "   4123,\n",
       "   4124,\n",
       "   4137,\n",
       "   4138,\n",
       "   4139,\n",
       "   4142,\n",
       "   4157,\n",
       "   4158,\n",
       "   4185,\n",
       "   4186,\n",
       "   4187,\n",
       "   4215,\n",
       "   4216,\n",
       "   4219,\n",
       "   4220,\n",
       "   4222,\n",
       "   4223],\n",
       "  'responsible_cluster': 4},\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 0x0000016F9DF607F0>, 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 0x0000016FB007BBB0>, 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 0x0000016FA724DDF0>, 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 0x0000016FB0015100>, 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 0x0000016FA7208700>, 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 0x0000016FA7208340>, 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([3], dtype=int64),\n",
       "  'new_act': array([0], dtype=int64),\n",
       "  'attributed_trajs': [9,\n",
       "   10,\n",
       "   16,\n",
       "   49,\n",
       "   50,\n",
       "   53,\n",
       "   65,\n",
       "   66,\n",
       "   67,\n",
       "   71,\n",
       "   72,\n",
       "   77,\n",
       "   78,\n",
       "   81,\n",
       "   82,\n",
       "   83,\n",
       "   92,\n",
       "   98,\n",
       "   100,\n",
       "   101,\n",
       "   112,\n",
       "   113,\n",
       "   114,\n",
       "   123,\n",
       "   125,\n",
       "   129,\n",
       "   130,\n",
       "   135,\n",
       "   136,\n",
       "   137,\n",
       "   141,\n",
       "   142,\n",
       "   143,\n",
       "   145,\n",
       "   154,\n",
       "   162,\n",
       "   165,\n",
       "   166,\n",
       "   170,\n",
       "   171,\n",
       "   172,\n",
       "   175,\n",
       "   176,\n",
       "   178,\n",
       "   181,\n",
       "   182,\n",
       "   183,\n",
       "   185,\n",
       "   186,\n",
       "   187,\n",
       "   219,\n",
       "   223,\n",
       "   224,\n",
       "   225,\n",
       "   254,\n",
       "   293,\n",
       "   295,\n",
       "   302,\n",
       "   304,\n",
       "   325,\n",
       "   326,\n",
       "   327,\n",
       "   331,\n",
       "   332,\n",
       "   345,\n",
       "   346,\n",
       "   347,\n",
       "   348,\n",
       "   349,\n",
       "   353,\n",
       "   354,\n",
       "   356,\n",
       "   407,\n",
       "   409,\n",
       "   435,\n",
       "   436,\n",
       "   439,\n",
       "   450,\n",
       "   451,\n",
       "   458,\n",
       "   478,\n",
       "   479,\n",
       "   480,\n",
       "   482,\n",
       "   485,\n",
       "   499,\n",
       "   500,\n",
       "   501,\n",
       "   502,\n",
       "   507,\n",
       "   508,\n",
       "   530,\n",
       "   531,\n",
       "   532,\n",
       "   533,\n",
       "   535,\n",
       "   536,\n",
       "   564,\n",
       "   565,\n",
       "   569,\n",
       "   611,\n",
       "   612,\n",
       "   615,\n",
       "   619,\n",
       "   621,\n",
       "   625,\n",
       "   627,\n",
       "   628,\n",
       "   643,\n",
       "   645,\n",
       "   650,\n",
       "   657,\n",
       "   662,\n",
       "   672,\n",
       "   673,\n",
       "   727,\n",
       "   728,\n",
       "   740,\n",
       "   758,\n",
       "   761,\n",
       "   762,\n",
       "   767,\n",
       "   778,\n",
       "   797,\n",
       "   800,\n",
       "   801,\n",
       "   802,\n",
       "   803,\n",
       "   805,\n",
       "   806,\n",
       "   812,\n",
       "   819,\n",
       "   821,\n",
       "   822,\n",
       "   823,\n",
       "   824,\n",
       "   827,\n",
       "   830,\n",
       "   834,\n",
       "   839,\n",
       "   840,\n",
       "   844,\n",
       "   859,\n",
       "   860,\n",
       "   861,\n",
       "   862,\n",
       "   863,\n",
       "   864,\n",
       "   865,\n",
       "   867,\n",
       "   868,\n",
       "   875,\n",
       "   894,\n",
       "   895,\n",
       "   896,\n",
       "   899,\n",
       "   900,\n",
       "   901,\n",
       "   902,\n",
       "   910,\n",
       "   912,\n",
       "   932,\n",
       "   933,\n",
       "   934,\n",
       "   935,\n",
       "   936,\n",
       "   937,\n",
       "   939,\n",
       "   958,\n",
       "   959,\n",
       "   960,\n",
       "   968,\n",
       "   981,\n",
       "   998,\n",
       "   1000,\n",
       "   1002,\n",
       "   1003,\n",
       "   1004,\n",
       "   1005,\n",
       "   1006,\n",
       "   1007,\n",
       "   1031,\n",
       "   1032,\n",
       "   1033,\n",
       "   1034,\n",
       "   1035,\n",
       "   1036,\n",
       "   1037,\n",
       "   1038,\n",
       "   1039,\n",
       "   1040,\n",
       "   1041,\n",
       "   1046,\n",
       "   1050,\n",
       "   1051,\n",
       "   1063,\n",
       "   1066,\n",
       "   1067,\n",
       "   1075,\n",
       "   1085,\n",
       "   1093,\n",
       "   1096,\n",
       "   1097,\n",
       "   1107,\n",
       "   1129,\n",
       "   1134,\n",
       "   1136,\n",
       "   1141,\n",
       "   1142,\n",
       "   1143,\n",
       "   1144,\n",
       "   1145,\n",
       "   1146,\n",
       "   1147,\n",
       "   1148,\n",
       "   1149,\n",
       "   1150,\n",
       "   1151,\n",
       "   1156,\n",
       "   1168,\n",
       "   1192,\n",
       "   1202,\n",
       "   1206,\n",
       "   1212,\n",
       "   1219,\n",
       "   1220,\n",
       "   1228,\n",
       "   1229,\n",
       "   1230,\n",
       "   1231,\n",
       "   1232,\n",
       "   1233,\n",
       "   1238,\n",
       "   1239,\n",
       "   1240,\n",
       "   1243,\n",
       "   1245,\n",
       "   1258,\n",
       "   1261,\n",
       "   1269,\n",
       "   1270,\n",
       "   1271,\n",
       "   1272,\n",
       "   1274,\n",
       "   1287,\n",
       "   1288,\n",
       "   1289,\n",
       "   1292,\n",
       "   1293,\n",
       "   1320,\n",
       "   1339,\n",
       "   1340,\n",
       "   1341,\n",
       "   1344,\n",
       "   1345,\n",
       "   1347,\n",
       "   1353,\n",
       "   1355,\n",
       "   1374,\n",
       "   1376,\n",
       "   1378,\n",
       "   1379,\n",
       "   1380,\n",
       "   1382,\n",
       "   1383,\n",
       "   1390,\n",
       "   1406,\n",
       "   1408,\n",
       "   1409,\n",
       "   1410,\n",
       "   1411,\n",
       "   1412,\n",
       "   1413,\n",
       "   1416,\n",
       "   1419,\n",
       "   1421,\n",
       "   1456,\n",
       "   1463,\n",
       "   1464,\n",
       "   1470,\n",
       "   1471,\n",
       "   1472,\n",
       "   1474,\n",
       "   1479,\n",
       "   1509,\n",
       "   1529,\n",
       "   1532,\n",
       "   1578,\n",
       "   1579,\n",
       "   1582,\n",
       "   1583,\n",
       "   1584,\n",
       "   1585,\n",
       "   1586,\n",
       "   1615,\n",
       "   1617,\n",
       "   1619,\n",
       "   1621,\n",
       "   1623,\n",
       "   1632,\n",
       "   1639,\n",
       "   1661,\n",
       "   1664,\n",
       "   1667,\n",
       "   1689,\n",
       "   1690,\n",
       "   1730,\n",
       "   1733,\n",
       "   1734,\n",
       "   1758,\n",
       "   1759,\n",
       "   1771,\n",
       "   1772,\n",
       "   1775,\n",
       "   1776,\n",
       "   1807,\n",
       "   1853,\n",
       "   1890,\n",
       "   1912,\n",
       "   1915,\n",
       "   1916,\n",
       "   1918,\n",
       "   1921,\n",
       "   1943,\n",
       "   1944,\n",
       "   1945,\n",
       "   1947,\n",
       "   1951,\n",
       "   1952,\n",
       "   1984,\n",
       "   1992,\n",
       "   1993,\n",
       "   1997,\n",
       "   2002,\n",
       "   2005,\n",
       "   2006,\n",
       "   2007,\n",
       "   2008,\n",
       "   2010,\n",
       "   2018,\n",
       "   2019,\n",
       "   2020,\n",
       "   2021,\n",
       "   2028,\n",
       "   2029,\n",
       "   2033,\n",
       "   2035,\n",
       "   2041,\n",
       "   2045,\n",
       "   2050,\n",
       "   2052,\n",
       "   2061,\n",
       "   2069,\n",
       "   2074,\n",
       "   2081,\n",
       "   2082,\n",
       "   2083,\n",
       "   2084,\n",
       "   2086,\n",
       "   2094,\n",
       "   2108,\n",
       "   2109,\n",
       "   2110,\n",
       "   2111,\n",
       "   2124,\n",
       "   2138,\n",
       "   2139,\n",
       "   2141,\n",
       "   2142,\n",
       "   2143,\n",
       "   2148,\n",
       "   2155,\n",
       "   2157,\n",
       "   2158,\n",
       "   2189,\n",
       "   2190,\n",
       "   2191,\n",
       "   2192,\n",
       "   2194,\n",
       "   2217,\n",
       "   2220,\n",
       "   2225,\n",
       "   2226,\n",
       "   2227,\n",
       "   2234,\n",
       "   2237,\n",
       "   2238,\n",
       "   2240,\n",
       "   2246,\n",
       "   2258,\n",
       "   2259,\n",
       "   2260,\n",
       "   2261,\n",
       "   2265,\n",
       "   2266,\n",
       "   2267,\n",
       "   2276,\n",
       "   2279,\n",
       "   2284,\n",
       "   2296,\n",
       "   2297,\n",
       "   2298,\n",
       "   2299,\n",
       "   2300,\n",
       "   2301,\n",
       "   2302,\n",
       "   2324,\n",
       "   2327,\n",
       "   2348,\n",
       "   2351,\n",
       "   2400,\n",
       "   2403,\n",
       "   2433,\n",
       "   2442,\n",
       "   2446,\n",
       "   2450,\n",
       "   2452,\n",
       "   2453,\n",
       "   2457,\n",
       "   2459,\n",
       "   2460,\n",
       "   2463,\n",
       "   2465,\n",
       "   2466,\n",
       "   2467,\n",
       "   2469,\n",
       "   2470,\n",
       "   2471,\n",
       "   2472,\n",
       "   2473,\n",
       "   2474,\n",
       "   2479,\n",
       "   2480,\n",
       "   2483,\n",
       "   2485,\n",
       "   2488,\n",
       "   2494,\n",
       "   2506,\n",
       "   2507,\n",
       "   2508,\n",
       "   2509,\n",
       "   2510,\n",
       "   2511,\n",
       "   2512,\n",
       "   2513,\n",
       "   2514,\n",
       "   2515,\n",
       "   2516,\n",
       "   2517,\n",
       "   2518,\n",
       "   2519,\n",
       "   2520,\n",
       "   2521,\n",
       "   2522,\n",
       "   2523,\n",
       "   2524,\n",
       "   2525,\n",
       "   2526,\n",
       "   2527,\n",
       "   2581,\n",
       "   2608,\n",
       "   2614,\n",
       "   2618,\n",
       "   2636,\n",
       "   2659,\n",
       "   2662,\n",
       "   2674,\n",
       "   2675,\n",
       "   2676,\n",
       "   2677,\n",
       "   2678,\n",
       "   2679,\n",
       "   2680,\n",
       "   2682,\n",
       "   2683,\n",
       "   2685,\n",
       "   2687,\n",
       "   2688,\n",
       "   2703,\n",
       "   2717,\n",
       "   2719,\n",
       "   2720,\n",
       "   2726,\n",
       "   2727,\n",
       "   2729,\n",
       "   2730,\n",
       "   2737,\n",
       "   2738,\n",
       "   2739,\n",
       "   2740,\n",
       "   2741,\n",
       "   2742,\n",
       "   2744,\n",
       "   2745,\n",
       "   2746,\n",
       "   2791,\n",
       "   2793,\n",
       "   2797,\n",
       "   2799,\n",
       "   2810,\n",
       "   2811,\n",
       "   2812,\n",
       "   2816,\n",
       "   2817,\n",
       "   2819,\n",
       "   2820,\n",
       "   2821,\n",
       "   2823,\n",
       "   2824,\n",
       "   2826,\n",
       "   2852,\n",
       "   2854,\n",
       "   2856,\n",
       "   2929,\n",
       "   2968,\n",
       "   2982,\n",
       "   2984,\n",
       "   2986,\n",
       "   2987,\n",
       "   2988,\n",
       "   2991,\n",
       "   2992,\n",
       "   2993,\n",
       "   2996,\n",
       "   3002,\n",
       "   3008,\n",
       "   3043,\n",
       "   3044,\n",
       "   3057,\n",
       "   3060,\n",
       "   3061,\n",
       "   3062,\n",
       "   3063,\n",
       "   3066,\n",
       "   3067,\n",
       "   3083,\n",
       "   3084,\n",
       "   3086,\n",
       "   3087,\n",
       "   3088,\n",
       "   3090,\n",
       "   3092,\n",
       "   3105,\n",
       "   3108,\n",
       "   3109,\n",
       "   3110,\n",
       "   3111,\n",
       "   3114,\n",
       "   3118,\n",
       "   3127,\n",
       "   3128,\n",
       "   3132,\n",
       "   3138,\n",
       "   3147,\n",
       "   3150,\n",
       "   3151,\n",
       "   3152,\n",
       "   3154,\n",
       "   3155,\n",
       "   3194,\n",
       "   3197,\n",
       "   3198,\n",
       "   3200,\n",
       "   3206,\n",
       "   3207,\n",
       "   3208,\n",
       "   3209,\n",
       "   3210,\n",
       "   3211,\n",
       "   3231,\n",
       "   3238,\n",
       "   3239,\n",
       "   3256,\n",
       "   3259,\n",
       "   3265,\n",
       "   3343,\n",
       "   3346,\n",
       "   3357,\n",
       "   3359,\n",
       "   3362,\n",
       "   3365,\n",
       "   3366,\n",
       "   3367,\n",
       "   3392,\n",
       "   3394,\n",
       "   3397,\n",
       "   3399,\n",
       "   3424,\n",
       "   3425,\n",
       "   3426,\n",
       "   3428,\n",
       "   3430,\n",
       "   3431,\n",
       "   3435,\n",
       "   3444,\n",
       "   3445,\n",
       "   3446,\n",
       "   3461,\n",
       "   3462,\n",
       "   3463,\n",
       "   3465,\n",
       "   3466,\n",
       "   3467,\n",
       "   3468,\n",
       "   3469,\n",
       "   3476,\n",
       "   3477,\n",
       "   3478,\n",
       "   3479,\n",
       "   3491,\n",
       "   3492,\n",
       "   3493,\n",
       "   3494,\n",
       "   3495,\n",
       "   3498,\n",
       "   3500,\n",
       "   3501,\n",
       "   3514,\n",
       "   3515,\n",
       "   3517,\n",
       "   3519,\n",
       "   3524,\n",
       "   3555,\n",
       "   3556,\n",
       "   3557,\n",
       "   3558,\n",
       "   3559,\n",
       "   3560,\n",
       "   3561,\n",
       "   3562,\n",
       "   3563,\n",
       "   3564,\n",
       "   3565,\n",
       "   3567,\n",
       "   3586,\n",
       "   3591,\n",
       "   3596,\n",
       "   3625,\n",
       "   3627,\n",
       "   3628,\n",
       "   3633,\n",
       "   3634,\n",
       "   3637,\n",
       "   3638,\n",
       "   3642,\n",
       "   3651,\n",
       "   3652,\n",
       "   3653,\n",
       "   3654,\n",
       "   3655,\n",
       "   3656,\n",
       "   3658,\n",
       "   3665,\n",
       "   3666,\n",
       "   3668,\n",
       "   3669,\n",
       "   3736,\n",
       "   3757,\n",
       "   3767,\n",
       "   3791,\n",
       "   3792,\n",
       "   3794,\n",
       "   3795,\n",
       "   3796,\n",
       "   3798,\n",
       "   3800,\n",
       "   3801,\n",
       "   3802,\n",
       "   3803,\n",
       "   3804,\n",
       "   3805,\n",
       "   3806,\n",
       "   3807,\n",
       "   3821,\n",
       "   3822,\n",
       "   3823,\n",
       "   3825,\n",
       "   3826,\n",
       "   3827,\n",
       "   3828,\n",
       "   3829,\n",
       "   3831,\n",
       "   3834,\n",
       "   3852,\n",
       "   3853,\n",
       "   3854,\n",
       "   3857,\n",
       "   3858,\n",
       "   3888,\n",
       "   3891,\n",
       "   3896,\n",
       "   3900,\n",
       "   3901,\n",
       "   3902,\n",
       "   3903,\n",
       "   3904,\n",
       "   3910,\n",
       "   3915,\n",
       "   3926,\n",
       "   3950,\n",
       "   3951,\n",
       "   3955,\n",
       "   3964,\n",
       "   3967,\n",
       "   3994,\n",
       "   3995,\n",
       "   3998,\n",
       "   4007,\n",
       "   4008,\n",
       "   4013,\n",
       "   4033,\n",
       "   4038,\n",
       "   4039,\n",
       "   4040,\n",
       "   4041,\n",
       "   4046,\n",
       "   4047,\n",
       "   4048,\n",
       "   4049,\n",
       "   4075,\n",
       "   4082,\n",
       "   4088,\n",
       "   4089,\n",
       "   4090,\n",
       "   4091,\n",
       "   4092,\n",
       "   4109,\n",
       "   4113,\n",
       "   4123,\n",
       "   4124,\n",
       "   4137,\n",
       "   4138,\n",
       "   4139,\n",
       "   4142,\n",
       "   4157,\n",
       "   4158,\n",
       "   4185,\n",
       "   4186,\n",
       "   4187,\n",
       "   4215,\n",
       "   4216,\n",
       "   4219,\n",
       "   4220,\n",
       "   4222,\n",
       "   4223],\n",
       "  'responsible_cluster': 4},\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 0x0000016F9DF607F0>, 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 0x0000016FB007BBB0>, 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 0x0000016FA724DDF0>, 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 0x0000016FB0015100>, 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 0x0000016FA7208700>, 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 0x0000016FA7208340>, 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([3], dtype=int64),\n",
       "  'new_act': array([0], dtype=int64),\n",
       "  'attributed_trajs': [9,\n",
       "   10,\n",
       "   16,\n",
       "   49,\n",
       "   50,\n",
       "   53,\n",
       "   65,\n",
       "   66,\n",
       "   67,\n",
       "   71,\n",
       "   72,\n",
       "   77,\n",
       "   78,\n",
       "   81,\n",
       "   82,\n",
       "   83,\n",
       "   92,\n",
       "   98,\n",
       "   100,\n",
       "   101,\n",
       "   112,\n",
       "   113,\n",
       "   114,\n",
       "   123,\n",
       "   125,\n",
       "   129,\n",
       "   130,\n",
       "   135,\n",
       "   136,\n",
       "   137,\n",
       "   141,\n",
       "   142,\n",
       "   143,\n",
       "   145,\n",
       "   154,\n",
       "   162,\n",
       "   165,\n",
       "   166,\n",
       "   170,\n",
       "   171,\n",
       "   172,\n",
       "   175,\n",
       "   176,\n",
       "   178,\n",
       "   181,\n",
       "   182,\n",
       "   183,\n",
       "   185,\n",
       "   186,\n",
       "   187,\n",
       "   219,\n",
       "   223,\n",
       "   224,\n",
       "   225,\n",
       "   254,\n",
       "   293,\n",
       "   295,\n",
       "   302,\n",
       "   304,\n",
       "   325,\n",
       "   326,\n",
       "   327,\n",
       "   331,\n",
       "   332,\n",
       "   345,\n",
       "   346,\n",
       "   347,\n",
       "   348,\n",
       "   349,\n",
       "   353,\n",
       "   354,\n",
       "   356,\n",
       "   407,\n",
       "   409,\n",
       "   435,\n",
       "   436,\n",
       "   439,\n",
       "   450,\n",
       "   451,\n",
       "   458,\n",
       "   478,\n",
       "   479,\n",
       "   480,\n",
       "   482,\n",
       "   485,\n",
       "   499,\n",
       "   500,\n",
       "   501,\n",
       "   502,\n",
       "   507,\n",
       "   508,\n",
       "   530,\n",
       "   531,\n",
       "   532,\n",
       "   533,\n",
       "   535,\n",
       "   536,\n",
       "   564,\n",
       "   565,\n",
       "   569,\n",
       "   611,\n",
       "   612,\n",
       "   615,\n",
       "   619,\n",
       "   621,\n",
       "   625,\n",
       "   627,\n",
       "   628,\n",
       "   643,\n",
       "   645,\n",
       "   650,\n",
       "   657,\n",
       "   662,\n",
       "   672,\n",
       "   673,\n",
       "   727,\n",
       "   728,\n",
       "   740,\n",
       "   758,\n",
       "   761,\n",
       "   762,\n",
       "   767,\n",
       "   778,\n",
       "   797,\n",
       "   800,\n",
       "   801,\n",
       "   802,\n",
       "   803,\n",
       "   805,\n",
       "   806,\n",
       "   812,\n",
       "   819,\n",
       "   821,\n",
       "   822,\n",
       "   823,\n",
       "   824,\n",
       "   827,\n",
       "   830,\n",
       "   834,\n",
       "   839,\n",
       "   840,\n",
       "   844,\n",
       "   859,\n",
       "   860,\n",
       "   861,\n",
       "   862,\n",
       "   863,\n",
       "   864,\n",
       "   865,\n",
       "   867,\n",
       "   868,\n",
       "   875,\n",
       "   894,\n",
       "   895,\n",
       "   896,\n",
       "   899,\n",
       "   900,\n",
       "   901,\n",
       "   902,\n",
       "   910,\n",
       "   912,\n",
       "   932,\n",
       "   933,\n",
       "   934,\n",
       "   935,\n",
       "   936,\n",
       "   937,\n",
       "   939,\n",
       "   958,\n",
       "   959,\n",
       "   960,\n",
       "   968,\n",
       "   981,\n",
       "   998,\n",
       "   1000,\n",
       "   1002,\n",
       "   1003,\n",
       "   1004,\n",
       "   1005,\n",
       "   1006,\n",
       "   1007,\n",
       "   1031,\n",
       "   1032,\n",
       "   1033,\n",
       "   1034,\n",
       "   1035,\n",
       "   1036,\n",
       "   1037,\n",
       "   1038,\n",
       "   1039,\n",
       "   1040,\n",
       "   1041,\n",
       "   1046,\n",
       "   1050,\n",
       "   1051,\n",
       "   1063,\n",
       "   1066,\n",
       "   1067,\n",
       "   1075,\n",
       "   1085,\n",
       "   1093,\n",
       "   1096,\n",
       "   1097,\n",
       "   1107,\n",
       "   1129,\n",
       "   1134,\n",
       "   1136,\n",
       "   1141,\n",
       "   1142,\n",
       "   1143,\n",
       "   1144,\n",
       "   1145,\n",
       "   1146,\n",
       "   1147,\n",
       "   1148,\n",
       "   1149,\n",
       "   1150,\n",
       "   1151,\n",
       "   1156,\n",
       "   1168,\n",
       "   1192,\n",
       "   1202,\n",
       "   1206,\n",
       "   1212,\n",
       "   1219,\n",
       "   1220,\n",
       "   1228,\n",
       "   1229,\n",
       "   1230,\n",
       "   1231,\n",
       "   1232,\n",
       "   1233,\n",
       "   1238,\n",
       "   1239,\n",
       "   1240,\n",
       "   1243,\n",
       "   1245,\n",
       "   1258,\n",
       "   1261,\n",
       "   1269,\n",
       "   1270,\n",
       "   1271,\n",
       "   1272,\n",
       "   1274,\n",
       "   1287,\n",
       "   1288,\n",
       "   1289,\n",
       "   1292,\n",
       "   1293,\n",
       "   1320,\n",
       "   1339,\n",
       "   1340,\n",
       "   1341,\n",
       "   1344,\n",
       "   1345,\n",
       "   1347,\n",
       "   1353,\n",
       "   1355,\n",
       "   1374,\n",
       "   1376,\n",
       "   1378,\n",
       "   1379,\n",
       "   1380,\n",
       "   1382,\n",
       "   1383,\n",
       "   1390,\n",
       "   1406,\n",
       "   1408,\n",
       "   1409,\n",
       "   1410,\n",
       "   1411,\n",
       "   1412,\n",
       "   1413,\n",
       "   1416,\n",
       "   1419,\n",
       "   1421,\n",
       "   1456,\n",
       "   1463,\n",
       "   1464,\n",
       "   1470,\n",
       "   1471,\n",
       "   1472,\n",
       "   1474,\n",
       "   1479,\n",
       "   1509,\n",
       "   1529,\n",
       "   1532,\n",
       "   1578,\n",
       "   1579,\n",
       "   1582,\n",
       "   1583,\n",
       "   1584,\n",
       "   1585,\n",
       "   1586,\n",
       "   1615,\n",
       "   1617,\n",
       "   1619,\n",
       "   1621,\n",
       "   1623,\n",
       "   1632,\n",
       "   1639,\n",
       "   1661,\n",
       "   1664,\n",
       "   1667,\n",
       "   1689,\n",
       "   1690,\n",
       "   1730,\n",
       "   1733,\n",
       "   1734,\n",
       "   1758,\n",
       "   1759,\n",
       "   1771,\n",
       "   1772,\n",
       "   1775,\n",
       "   1776,\n",
       "   1807,\n",
       "   1853,\n",
       "   1890,\n",
       "   1912,\n",
       "   1915,\n",
       "   1916,\n",
       "   1918,\n",
       "   1921,\n",
       "   1943,\n",
       "   1944,\n",
       "   1945,\n",
       "   1947,\n",
       "   1951,\n",
       "   1952,\n",
       "   1984,\n",
       "   1992,\n",
       "   1993,\n",
       "   1997,\n",
       "   2002,\n",
       "   2005,\n",
       "   2006,\n",
       "   2007,\n",
       "   2008,\n",
       "   2010,\n",
       "   2018,\n",
       "   2019,\n",
       "   2020,\n",
       "   2021,\n",
       "   2028,\n",
       "   2029,\n",
       "   2033,\n",
       "   2035,\n",
       "   2041,\n",
       "   2045,\n",
       "   2050,\n",
       "   2052,\n",
       "   2061,\n",
       "   2069,\n",
       "   2074,\n",
       "   2081,\n",
       "   2082,\n",
       "   2083,\n",
       "   2084,\n",
       "   2086,\n",
       "   2094,\n",
       "   2108,\n",
       "   2109,\n",
       "   2110,\n",
       "   2111,\n",
       "   2124,\n",
       "   2138,\n",
       "   2139,\n",
       "   2141,\n",
       "   2142,\n",
       "   2143,\n",
       "   2148,\n",
       "   2155,\n",
       "   2157,\n",
       "   2158,\n",
       "   2189,\n",
       "   2190,\n",
       "   2191,\n",
       "   2192,\n",
       "   2194,\n",
       "   2217,\n",
       "   2220,\n",
       "   2225,\n",
       "   2226,\n",
       "   2227,\n",
       "   2234,\n",
       "   2237,\n",
       "   2238,\n",
       "   2240,\n",
       "   2246,\n",
       "   2258,\n",
       "   2259,\n",
       "   2260,\n",
       "   2261,\n",
       "   2265,\n",
       "   2266,\n",
       "   2267,\n",
       "   2276,\n",
       "   2279,\n",
       "   2284,\n",
       "   2296,\n",
       "   2297,\n",
       "   2298,\n",
       "   2299,\n",
       "   2300,\n",
       "   2301,\n",
       "   2302,\n",
       "   2324,\n",
       "   2327,\n",
       "   2348,\n",
       "   2351,\n",
       "   2400,\n",
       "   2403,\n",
       "   2433,\n",
       "   2442,\n",
       "   2446,\n",
       "   2450,\n",
       "   2452,\n",
       "   2453,\n",
       "   2457,\n",
       "   2459,\n",
       "   2460,\n",
       "   2463,\n",
       "   2465,\n",
       "   2466,\n",
       "   2467,\n",
       "   2469,\n",
       "   2470,\n",
       "   2471,\n",
       "   2472,\n",
       "   2473,\n",
       "   2474,\n",
       "   2479,\n",
       "   2480,\n",
       "   2483,\n",
       "   2485,\n",
       "   2488,\n",
       "   2494,\n",
       "   2506,\n",
       "   2507,\n",
       "   2508,\n",
       "   2509,\n",
       "   2510,\n",
       "   2511,\n",
       "   2512,\n",
       "   2513,\n",
       "   2514,\n",
       "   2515,\n",
       "   2516,\n",
       "   2517,\n",
       "   2518,\n",
       "   2519,\n",
       "   2520,\n",
       "   2521,\n",
       "   2522,\n",
       "   2523,\n",
       "   2524,\n",
       "   2525,\n",
       "   2526,\n",
       "   2527,\n",
       "   2581,\n",
       "   2608,\n",
       "   2614,\n",
       "   2618,\n",
       "   2636,\n",
       "   2659,\n",
       "   2662,\n",
       "   2674,\n",
       "   2675,\n",
       "   2676,\n",
       "   2677,\n",
       "   2678,\n",
       "   2679,\n",
       "   2680,\n",
       "   2682,\n",
       "   2683,\n",
       "   2685,\n",
       "   2687,\n",
       "   2688,\n",
       "   2703,\n",
       "   2717,\n",
       "   2719,\n",
       "   2720,\n",
       "   2726,\n",
       "   2727,\n",
       "   2729,\n",
       "   2730,\n",
       "   2737,\n",
       "   2738,\n",
       "   2739,\n",
       "   2740,\n",
       "   2741,\n",
       "   2742,\n",
       "   2744,\n",
       "   2745,\n",
       "   2746,\n",
       "   2791,\n",
       "   2793,\n",
       "   2797,\n",
       "   2799,\n",
       "   2810,\n",
       "   2811,\n",
       "   2812,\n",
       "   2816,\n",
       "   2817,\n",
       "   2819,\n",
       "   2820,\n",
       "   2821,\n",
       "   2823,\n",
       "   2824,\n",
       "   2826,\n",
       "   2852,\n",
       "   2854,\n",
       "   2856,\n",
       "   2929,\n",
       "   2968,\n",
       "   2982,\n",
       "   2984,\n",
       "   2986,\n",
       "   2987,\n",
       "   2988,\n",
       "   2991,\n",
       "   2992,\n",
       "   2993,\n",
       "   2996,\n",
       "   3002,\n",
       "   3008,\n",
       "   3043,\n",
       "   3044,\n",
       "   3057,\n",
       "   3060,\n",
       "   3061,\n",
       "   3062,\n",
       "   3063,\n",
       "   3066,\n",
       "   3067,\n",
       "   3083,\n",
       "   3084,\n",
       "   3086,\n",
       "   3087,\n",
       "   3088,\n",
       "   3090,\n",
       "   3092,\n",
       "   3105,\n",
       "   3108,\n",
       "   3109,\n",
       "   3110,\n",
       "   3111,\n",
       "   3114,\n",
       "   3118,\n",
       "   3127,\n",
       "   3128,\n",
       "   3132,\n",
       "   3138,\n",
       "   3147,\n",
       "   3150,\n",
       "   3151,\n",
       "   3152,\n",
       "   3154,\n",
       "   3155,\n",
       "   3194,\n",
       "   3197,\n",
       "   3198,\n",
       "   3200,\n",
       "   3206,\n",
       "   3207,\n",
       "   3208,\n",
       "   3209,\n",
       "   3210,\n",
       "   3211,\n",
       "   3231,\n",
       "   3238,\n",
       "   3239,\n",
       "   3256,\n",
       "   3259,\n",
       "   3265,\n",
       "   3343,\n",
       "   3346,\n",
       "   3357,\n",
       "   3359,\n",
       "   3362,\n",
       "   3365,\n",
       "   3366,\n",
       "   3367,\n",
       "   3392,\n",
       "   3394,\n",
       "   3397,\n",
       "   3399,\n",
       "   3424,\n",
       "   3425,\n",
       "   3426,\n",
       "   3428,\n",
       "   3430,\n",
       "   3431,\n",
       "   3435,\n",
       "   3444,\n",
       "   3445,\n",
       "   3446,\n",
       "   3461,\n",
       "   3462,\n",
       "   3463,\n",
       "   3465,\n",
       "   3466,\n",
       "   3467,\n",
       "   3468,\n",
       "   3469,\n",
       "   3476,\n",
       "   3477,\n",
       "   3478,\n",
       "   3479,\n",
       "   3491,\n",
       "   3492,\n",
       "   3493,\n",
       "   3494,\n",
       "   3495,\n",
       "   3498,\n",
       "   3500,\n",
       "   3501,\n",
       "   3514,\n",
       "   3515,\n",
       "   3517,\n",
       "   3519,\n",
       "   3524,\n",
       "   3555,\n",
       "   3556,\n",
       "   3557,\n",
       "   3558,\n",
       "   3559,\n",
       "   3560,\n",
       "   3561,\n",
       "   3562,\n",
       "   3563,\n",
       "   3564,\n",
       "   3565,\n",
       "   3567,\n",
       "   3586,\n",
       "   3591,\n",
       "   3596,\n",
       "   3625,\n",
       "   3627,\n",
       "   3628,\n",
       "   3633,\n",
       "   3634,\n",
       "   3637,\n",
       "   3638,\n",
       "   3642,\n",
       "   3651,\n",
       "   3652,\n",
       "   3653,\n",
       "   3654,\n",
       "   3655,\n",
       "   3656,\n",
       "   3658,\n",
       "   3665,\n",
       "   3666,\n",
       "   3668,\n",
       "   3669,\n",
       "   3736,\n",
       "   3757,\n",
       "   3767,\n",
       "   3791,\n",
       "   3792,\n",
       "   3794,\n",
       "   3795,\n",
       "   3796,\n",
       "   3798,\n",
       "   3800,\n",
       "   3801,\n",
       "   3802,\n",
       "   3803,\n",
       "   3804,\n",
       "   3805,\n",
       "   3806,\n",
       "   3807,\n",
       "   3821,\n",
       "   3822,\n",
       "   3823,\n",
       "   3825,\n",
       "   3826,\n",
       "   3827,\n",
       "   3828,\n",
       "   3829,\n",
       "   3831,\n",
       "   3834,\n",
       "   3852,\n",
       "   3853,\n",
       "   3854,\n",
       "   3857,\n",
       "   3858,\n",
       "   3888,\n",
       "   3891,\n",
       "   3896,\n",
       "   3900,\n",
       "   3901,\n",
       "   3902,\n",
       "   3903,\n",
       "   3904,\n",
       "   3910,\n",
       "   3915,\n",
       "   3926,\n",
       "   3950,\n",
       "   3951,\n",
       "   3955,\n",
       "   3964,\n",
       "   3967,\n",
       "   3994,\n",
       "   3995,\n",
       "   3998,\n",
       "   4007,\n",
       "   4008,\n",
       "   4013,\n",
       "   4033,\n",
       "   4038,\n",
       "   4039,\n",
       "   4040,\n",
       "   4041,\n",
       "   4046,\n",
       "   4047,\n",
       "   4048,\n",
       "   4049,\n",
       "   4075,\n",
       "   4082,\n",
       "   4088,\n",
       "   4089,\n",
       "   4090,\n",
       "   4091,\n",
       "   4092,\n",
       "   4109,\n",
       "   4113,\n",
       "   4123,\n",
       "   4124,\n",
       "   4137,\n",
       "   4138,\n",
       "   4139,\n",
       "   4142,\n",
       "   4157,\n",
       "   4158,\n",
       "   4185,\n",
       "   4186,\n",
       "   4187,\n",
       "   4215,\n",
       "   4216,\n",
       "   4219,\n",
       "   4220,\n",
       "   4222,\n",
       "   4223],\n",
       "  'responsible_cluster': 4}]"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "attributions_sq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "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"
     ]
    }
   ],
   "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": 89,
   "metadata": {},
   "outputs": [],
   "source": [
    "trajectories = attributions_sq[0]['attributed_trajs']\n",
    "observation = test_observations[0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.         1.         0.01975948 0.00925719 0.00925842 0.00925842]\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": 91,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[9,\n",
       " 10,\n",
       " 16,\n",
       " 49,\n",
       " 50,\n",
       " 53,\n",
       " 65,\n",
       " 66,\n",
       " 67,\n",
       " 71,\n",
       " 72,\n",
       " 77,\n",
       " 78,\n",
       " 81,\n",
       " 82,\n",
       " 83,\n",
       " 92,\n",
       " 98,\n",
       " 100,\n",
       " 101,\n",
       " 112,\n",
       " 113,\n",
       " 114,\n",
       " 123,\n",
       " 125,\n",
       " 129,\n",
       " 130,\n",
       " 135,\n",
       " 136,\n",
       " 137,\n",
       " 141,\n",
       " 142,\n",
       " 143,\n",
       " 145,\n",
       " 154,\n",
       " 162,\n",
       " 165,\n",
       " 166,\n",
       " 170,\n",
       " 171,\n",
       " 172,\n",
       " 175,\n",
       " 176,\n",
       " 178,\n",
       " 181,\n",
       " 182,\n",
       " 183,\n",
       " 185,\n",
       " 186,\n",
       " 187,\n",
       " 219,\n",
       " 223,\n",
       " 224,\n",
       " 225,\n",
       " 254,\n",
       " 293,\n",
       " 295,\n",
       " 302,\n",
       " 304,\n",
       " 325,\n",
       " 326,\n",
       " 327,\n",
       " 331,\n",
       " 332,\n",
       " 345,\n",
       " 346,\n",
       " 347,\n",
       " 348,\n",
       " 349,\n",
       " 353,\n",
       " 354,\n",
       " 356,\n",
       " 407,\n",
       " 409,\n",
       " 435,\n",
       " 436,\n",
       " 439,\n",
       " 450,\n",
       " 451,\n",
       " 458,\n",
       " 478,\n",
       " 479,\n",
       " 480,\n",
       " 482,\n",
       " 485,\n",
       " 499,\n",
       " 500,\n",
       " 501,\n",
       " 502,\n",
       " 507,\n",
       " 508,\n",
       " 530,\n",
       " 531,\n",
       " 532,\n",
       " 533,\n",
       " 535,\n",
       " 536,\n",
       " 564,\n",
       " 565,\n",
       " 569,\n",
       " 611,\n",
       " 612,\n",
       " 615,\n",
       " 619,\n",
       " 621,\n",
       " 625,\n",
       " 627,\n",
       " 628,\n",
       " 643,\n",
       " 645,\n",
       " 650,\n",
       " 657,\n",
       " 662,\n",
       " 672,\n",
       " 673,\n",
       " 727,\n",
       " 728,\n",
       " 740,\n",
       " 758,\n",
       " 761,\n",
       " 762,\n",
       " 767,\n",
       " 778,\n",
       " 797,\n",
       " 800,\n",
       " 801,\n",
       " 802,\n",
       " 803,\n",
       " 805,\n",
       " 806,\n",
       " 812,\n",
       " 819,\n",
       " 821,\n",
       " 822,\n",
       " 823,\n",
       " 824,\n",
       " 827,\n",
       " 830,\n",
       " 834,\n",
       " 839,\n",
       " 840,\n",
       " 844,\n",
       " 859,\n",
       " 860,\n",
       " 861,\n",
       " 862,\n",
       " 863,\n",
       " 864,\n",
       " 865,\n",
       " 867,\n",
       " 868,\n",
       " 875,\n",
       " 894,\n",
       " 895,\n",
       " 896,\n",
       " 899,\n",
       " 900,\n",
       " 901,\n",
       " 902,\n",
       " 910,\n",
       " 912,\n",
       " 932,\n",
       " 933,\n",
       " 934,\n",
       " 935,\n",
       " 936,\n",
       " 937,\n",
       " 939,\n",
       " 958,\n",
       " 959,\n",
       " 960,\n",
       " 968,\n",
       " 981,\n",
       " 998,\n",
       " 1000,\n",
       " 1002,\n",
       " 1003,\n",
       " 1004,\n",
       " 1005,\n",
       " 1006,\n",
       " 1007,\n",
       " 1031,\n",
       " 1032,\n",
       " 1033,\n",
       " 1034,\n",
       " 1035,\n",
       " 1036,\n",
       " 1037,\n",
       " 1038,\n",
       " 1039,\n",
       " 1040,\n",
       " 1041,\n",
       " 1046,\n",
       " 1050,\n",
       " 1051,\n",
       " 1063,\n",
       " 1066,\n",
       " 1067,\n",
       " 1075,\n",
       " 1085,\n",
       " 1093,\n",
       " 1096,\n",
       " 1097,\n",
       " 1107,\n",
       " 1129,\n",
       " 1134,\n",
       " 1136,\n",
       " 1141,\n",
       " 1142,\n",
       " 1143,\n",
       " 1144,\n",
       " 1145,\n",
       " 1146,\n",
       " 1147,\n",
       " 1148,\n",
       " 1149,\n",
       " 1150,\n",
       " 1151,\n",
       " 1156,\n",
       " 1168,\n",
       " 1192,\n",
       " 1202,\n",
       " 1206,\n",
       " 1212,\n",
       " 1219,\n",
       " 1220,\n",
       " 1228,\n",
       " 1229,\n",
       " 1230,\n",
       " 1231,\n",
       " 1232,\n",
       " 1233,\n",
       " 1238,\n",
       " 1239,\n",
       " 1240,\n",
       " 1243,\n",
       " 1245,\n",
       " 1258,\n",
       " 1261,\n",
       " 1269,\n",
       " 1270,\n",
       " 1271,\n",
       " 1272,\n",
       " 1274,\n",
       " 1287,\n",
       " 1288,\n",
       " 1289,\n",
       " 1292,\n",
       " 1293,\n",
       " 1320,\n",
       " 1339,\n",
       " 1340,\n",
       " 1341,\n",
       " 1344,\n",
       " 1345,\n",
       " 1347,\n",
       " 1353,\n",
       " 1355,\n",
       " 1374,\n",
       " 1376,\n",
       " 1378,\n",
       " 1379,\n",
       " 1380,\n",
       " 1382,\n",
       " 1383,\n",
       " 1390,\n",
       " 1406,\n",
       " 1408,\n",
       " 1409,\n",
       " 1410,\n",
       " 1411,\n",
       " 1412,\n",
       " 1413,\n",
       " 1416,\n",
       " 1419,\n",
       " 1421,\n",
       " 1456,\n",
       " 1463,\n",
       " 1464,\n",
       " 1470,\n",
       " 1471,\n",
       " 1472,\n",
       " 1474,\n",
       " 1479,\n",
       " 1509,\n",
       " 1529,\n",
       " 1532,\n",
       " 1578,\n",
       " 1579,\n",
       " 1582,\n",
       " 1583,\n",
       " 1584,\n",
       " 1585,\n",
       " 1586,\n",
       " 1615,\n",
       " 1617,\n",
       " 1619,\n",
       " 1621,\n",
       " 1623,\n",
       " 1632,\n",
       " 1639,\n",
       " 1661,\n",
       " 1664,\n",
       " 1667,\n",
       " 1689,\n",
       " 1690,\n",
       " 1730,\n",
       " 1733,\n",
       " 1734,\n",
       " 1758,\n",
       " 1759,\n",
       " 1771,\n",
       " 1772,\n",
       " 1775,\n",
       " 1776,\n",
       " 1807,\n",
       " 1853,\n",
       " 1890,\n",
       " 1912,\n",
       " 1915,\n",
       " 1916,\n",
       " 1918,\n",
       " 1921,\n",
       " 1943,\n",
       " 1944,\n",
       " 1945,\n",
       " 1947,\n",
       " 1951,\n",
       " 1952,\n",
       " 1984,\n",
       " 1992,\n",
       " 1993,\n",
       " 1997,\n",
       " 2002,\n",
       " 2005,\n",
       " 2006,\n",
       " 2007,\n",
       " 2008,\n",
       " 2010,\n",
       " 2018,\n",
       " 2019,\n",
       " 2020,\n",
       " 2021,\n",
       " 2028,\n",
       " 2029,\n",
       " 2033,\n",
       " 2035,\n",
       " 2041,\n",
       " 2045,\n",
       " 2050,\n",
       " 2052,\n",
       " 2061,\n",
       " 2069,\n",
       " 2074,\n",
       " 2081,\n",
       " 2082,\n",
       " 2083,\n",
       " 2084,\n",
       " 2086,\n",
       " 2094,\n",
       " 2108,\n",
       " 2109,\n",
       " 2110,\n",
       " 2111,\n",
       " 2124,\n",
       " 2138,\n",
       " 2139,\n",
       " 2141,\n",
       " 2142,\n",
       " 2143,\n",
       " 2148,\n",
       " 2155,\n",
       " 2157,\n",
       " 2158,\n",
       " 2189,\n",
       " 2190,\n",
       " 2191,\n",
       " 2192,\n",
       " 2194,\n",
       " 2217,\n",
       " 2220,\n",
       " 2225,\n",
       " 2226,\n",
       " 2227,\n",
       " 2234,\n",
       " 2237,\n",
       " 2238,\n",
       " 2240,\n",
       " 2246,\n",
       " 2258,\n",
       " 2259,\n",
       " 2260,\n",
       " 2261,\n",
       " 2265,\n",
       " 2266,\n",
       " 2267,\n",
       " 2276,\n",
       " 2279,\n",
       " 2284,\n",
       " 2296,\n",
       " 2297,\n",
       " 2298,\n",
       " 2299,\n",
       " 2300,\n",
       " 2301,\n",
       " 2302,\n",
       " 2324,\n",
       " 2327,\n",
       " 2348,\n",
       " 2351,\n",
       " 2400,\n",
       " 2403,\n",
       " 2433,\n",
       " 2442,\n",
       " 2446,\n",
       " 2450,\n",
       " 2452,\n",
       " 2453,\n",
       " 2457,\n",
       " 2459,\n",
       " 2460,\n",
       " 2463,\n",
       " 2465,\n",
       " 2466,\n",
       " 2467,\n",
       " 2469,\n",
       " 2470,\n",
       " 2471,\n",
       " 2472,\n",
       " 2473,\n",
       " 2474,\n",
       " 2479,\n",
       " 2480,\n",
       " 2483,\n",
       " 2485,\n",
       " 2488,\n",
       " 2494,\n",
       " 2506,\n",
       " 2507,\n",
       " 2508,\n",
       " 2509,\n",
       " 2510,\n",
       " 2511,\n",
       " 2512,\n",
       " 2513,\n",
       " 2514,\n",
       " 2515,\n",
       " 2516,\n",
       " 2517,\n",
       " 2518,\n",
       " 2519,\n",
       " 2520,\n",
       " 2521,\n",
       " 2522,\n",
       " 2523,\n",
       " 2524,\n",
       " 2525,\n",
       " 2526,\n",
       " 2527,\n",
       " 2581,\n",
       " 2608,\n",
       " 2614,\n",
       " 2618,\n",
       " 2636,\n",
       " 2659,\n",
       " 2662,\n",
       " 2674,\n",
       " 2675,\n",
       " 2676,\n",
       " 2677,\n",
       " 2678,\n",
       " 2679,\n",
       " 2680,\n",
       " 2682,\n",
       " 2683,\n",
       " 2685,\n",
       " 2687,\n",
       " 2688,\n",
       " 2703,\n",
       " 2717,\n",
       " 2719,\n",
       " 2720,\n",
       " 2726,\n",
       " 2727,\n",
       " 2729,\n",
       " 2730,\n",
       " 2737,\n",
       " 2738,\n",
       " 2739,\n",
       " 2740,\n",
       " 2741,\n",
       " 2742,\n",
       " 2744,\n",
       " 2745,\n",
       " 2746,\n",
       " 2791,\n",
       " 2793,\n",
       " 2797,\n",
       " 2799,\n",
       " 2810,\n",
       " 2811,\n",
       " 2812,\n",
       " 2816,\n",
       " 2817,\n",
       " 2819,\n",
       " 2820,\n",
       " 2821,\n",
       " 2823,\n",
       " 2824,\n",
       " 2826,\n",
       " 2852,\n",
       " 2854,\n",
       " 2856,\n",
       " 2929,\n",
       " 2968,\n",
       " 2982,\n",
       " 2984,\n",
       " 2986,\n",
       " 2987,\n",
       " 2988,\n",
       " 2991,\n",
       " 2992,\n",
       " 2993,\n",
       " 2996,\n",
       " 3002,\n",
       " 3008,\n",
       " 3043,\n",
       " 3044,\n",
       " 3057,\n",
       " 3060,\n",
       " 3061,\n",
       " 3062,\n",
       " 3063,\n",
       " 3066,\n",
       " 3067,\n",
       " 3083,\n",
       " 3084,\n",
       " 3086,\n",
       " 3087,\n",
       " 3088,\n",
       " 3090,\n",
       " 3092,\n",
       " 3105,\n",
       " 3108,\n",
       " 3109,\n",
       " 3110,\n",
       " 3111,\n",
       " 3114,\n",
       " 3118,\n",
       " 3127,\n",
       " 3128,\n",
       " 3132,\n",
       " 3138,\n",
       " 3147,\n",
       " 3150,\n",
       " 3151,\n",
       " 3152,\n",
       " 3154,\n",
       " 3155,\n",
       " 3194,\n",
       " 3197,\n",
       " 3198,\n",
       " 3200,\n",
       " 3206,\n",
       " 3207,\n",
       " 3208,\n",
       " 3209,\n",
       " 3210,\n",
       " 3211,\n",
       " 3231,\n",
       " 3238,\n",
       " 3239,\n",
       " 3256,\n",
       " 3259,\n",
       " 3265,\n",
       " 3343,\n",
       " 3346,\n",
       " 3357,\n",
       " 3359,\n",
       " 3362,\n",
       " 3365,\n",
       " 3366,\n",
       " 3367,\n",
       " 3392,\n",
       " 3394,\n",
       " 3397,\n",
       " 3399,\n",
       " 3424,\n",
       " 3425,\n",
       " 3426,\n",
       " 3428,\n",
       " 3430,\n",
       " 3431,\n",
       " 3435,\n",
       " 3444,\n",
       " 3445,\n",
       " 3446,\n",
       " 3461,\n",
       " 3462,\n",
       " 3463,\n",
       " 3465,\n",
       " 3466,\n",
       " 3467,\n",
       " 3468,\n",
       " 3469,\n",
       " 3476,\n",
       " 3477,\n",
       " 3478,\n",
       " 3479,\n",
       " 3491,\n",
       " 3492,\n",
       " 3493,\n",
       " 3494,\n",
       " 3495,\n",
       " 3498,\n",
       " 3500,\n",
       " 3501,\n",
       " 3514,\n",
       " 3515,\n",
       " 3517,\n",
       " 3519,\n",
       " 3524,\n",
       " 3555,\n",
       " 3556,\n",
       " 3557,\n",
       " 3558,\n",
       " 3559,\n",
       " 3560,\n",
       " 3561,\n",
       " 3562,\n",
       " 3563,\n",
       " 3564,\n",
       " 3565,\n",
       " 3567,\n",
       " 3586,\n",
       " 3591,\n",
       " 3596,\n",
       " 3625,\n",
       " 3627,\n",
       " 3628,\n",
       " 3633,\n",
       " 3634,\n",
       " 3637,\n",
       " 3638,\n",
       " 3642,\n",
       " 3651,\n",
       " 3652,\n",
       " 3653,\n",
       " 3654,\n",
       " 3655,\n",
       " 3656,\n",
       " 3658,\n",
       " 3665,\n",
       " 3666,\n",
       " 3668,\n",
       " 3669,\n",
       " 3736,\n",
       " 3757,\n",
       " 3767,\n",
       " 3791,\n",
       " 3792,\n",
       " 3794,\n",
       " 3795,\n",
       " 3796,\n",
       " 3798,\n",
       " 3800,\n",
       " 3801,\n",
       " 3802,\n",
       " 3803,\n",
       " 3804,\n",
       " 3805,\n",
       " 3806,\n",
       " 3807,\n",
       " 3821,\n",
       " 3822,\n",
       " 3823,\n",
       " 3825,\n",
       " 3826,\n",
       " 3827,\n",
       " 3828,\n",
       " 3829,\n",
       " 3831,\n",
       " 3834,\n",
       " 3852,\n",
       " 3853,\n",
       " 3854,\n",
       " 3857,\n",
       " 3858,\n",
       " 3888,\n",
       " 3891,\n",
       " 3896,\n",
       " 3900,\n",
       " 3901,\n",
       " 3902,\n",
       " 3903,\n",
       " 3904,\n",
       " 3910,\n",
       " 3915,\n",
       " 3926,\n",
       " 3950,\n",
       " 3951,\n",
       " 3955,\n",
       " 3964,\n",
       " 3967,\n",
       " 3994,\n",
       " 3995,\n",
       " 3998,\n",
       " 4007,\n",
       " 4008,\n",
       " 4013,\n",
       " 4033,\n",
       " 4038,\n",
       " 4039,\n",
       " 4040,\n",
       " 4041,\n",
       " 4046,\n",
       " 4047,\n",
       " 4048,\n",
       " 4049,\n",
       " 4075,\n",
       " 4082,\n",
       " 4088,\n",
       " 4089,\n",
       " 4090,\n",
       " 4091,\n",
       " 4092,\n",
       " 4109,\n",
       " 4113,\n",
       " 4123,\n",
       " 4124,\n",
       " 4137,\n",
       " 4138,\n",
       " 4139,\n",
       " 4142,\n",
       " 4157,\n",
       " 4158,\n",
       " 4185,\n",
       " 4186,\n",
       " 4187,\n",
       " 4215,\n",
       " 4216,\n",
       " 4219,\n",
       " 4220,\n",
       " 4222,\n",
       " 4223]"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trajectories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trajectory Shape: torch.Size([15, 4, 84, 84])\n"
     ]
    },
    {
     "ename": "IndexError",
     "evalue": "index 16 is out of bounds for dimension 0 with size 15",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[92], line 13\u001b[0m\n\u001b[0;32m     10\u001b[0m plt\u001b[38;5;241m.\u001b[39msubplot(\u001b[38;5;241m3\u001b[39m, (\u001b[38;5;241m30\u001b[39m \u001b[38;5;241m/\u001b[39m\u001b[38;5;241m/\u001b[39m \u001b[38;5;241m5\u001b[39m), subplot_index)  \n\u001b[0;32m     12\u001b[0m \u001b[38;5;66;03m# Plot the first frame from the current stack\u001b[39;00m\n\u001b[1;32m---> 13\u001b[0m plt\u001b[38;5;241m.\u001b[39mimshow(\u001b[43mfinal_obs_sq\u001b[49m\u001b[43m[\u001b[49m\u001b[43mtraj\u001b[49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[43mj\u001b[49m\u001b[43m]\u001b[49m[\u001b[38;5;241m0\u001b[39m], cmap\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mgray\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[0;32m     15\u001b[0m \u001b[38;5;66;03m# Get tensor value as an integer and use it as a key to the action dictionary\u001b[39;00m\n\u001b[0;32m     16\u001b[0m corr_action \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mint\u001b[39m(final_act_sq[traj][j]\u001b[38;5;241m.\u001b[39mitem())\n",
      "\u001b[1;31mIndexError\u001b[0m: index 16 is out of bounds for dimension 0 with size 15"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1500x1000 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(15, 10))\n",
    "\n",
    "for i, traj in enumerate([31, 151, 192]):\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()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1. 1. 1. 1. 0. 0.]\n",
      "Avg Delta Q\n",
      "0.0\n",
      "0.05734006563822428\n",
      "0.02372256914774577\n",
      "0.03632175922393799\n",
      "0.003953893979390462\n",
      "0.02782897154490153\n",
      "Data distances\n",
      "[0.         1.         0.01975948 0.00925719 0.00925842 0.00925842]\n",
      "[0. 0. 0. 0. 1. 0.]\n"
     ]
    }
   ],
   "source": [
    "from utils import print_results_sq\n",
    "print_results_sq(result_data_combinations_sq, test_observations, models_sq, attributions_sq)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "factAtari",
   "language": "python",
   "name": "factenv"
  },
  "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
