{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "unsupervised_rl_iclr_submission.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "id": "vXqSoeNAu1uy"
      },
      "source": [
        "import tensorflow as tf\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import scipy.spatial\n",
        "import scipy.optimize\n",
        "import tqdm\n",
        "import cvxpy\n",
        "import itertools\n",
        "from mpl_toolkits import mplot3d\n",
        "import matplotlib.image\n",
        "import imageio\n",
        "\n",
        "A = np.array([[1, 1, 1],\n",
        "              [0, 1, 0.5],\n",
        "              [0, 0, 0.5 * np.sqrt(3)]])\n",
        "\n",
        "def p_to_xy(p):\n",
        "  assert p.shape[0] == 3\n",
        "  _xy = A @ p\n",
        "  xy = _xy[1:]\n",
        "  return xy\n",
        "\n",
        "def xy_to_p(xy):\n",
        "  assert xy.shape[0] == 2\n",
        "  _xy = np.concatenate([np.ones_like(xy[:1]), xy])\n",
        "  return np.linalg.solve(A, _xy)\n",
        "\n",
        "print(xy_to_p(np.array([0, 0])))\n",
        "print(xy_to_p(np.array([1, 0])))\n",
        "print(xy_to_p(np.array([1./2, np.sqrt(3) / 2])))\n",
        "\n",
        "c_vec = plt.rcParams['axes.prop_cycle'].by_key()['color']"
      ],
      "execution_count": 1,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 349
        },
        "id": "VNd-DJAhDbJY",
        "outputId": "5b685ca7-0fa9-48e8-e3d9-331f477c479d"
      },
      "source": [
        "num_states = 3\n",
        "num_skills = 6\n",
        "\n",
        "p_s_given_z = np.random.dirichlet(2 * np.ones(num_states), size=num_skills)\n",
        "p_z = cvxpy.Variable(shape=num_skills)\n",
        "p_s = p_s_given_z.T * p_z\n",
        "\n",
        "h_s_given_z = -np.sum(p_s_given_z * np.log(p_s_given_z), axis=1)\n",
        "h_s = cvxpy.sum(cvxpy.entr(p_s))\n",
        "mi = h_s - h_s_given_z * p_z\n",
        "\n",
        "obj = cvxpy.Maximize(mi)\n",
        "constraints = [cvxpy.sum(p_z) == 1, p_z >= 0]\n",
        "prob = cvxpy.Problem(obj, constraints)\n",
        "prob.solve()\n",
        "\n",
        "xy_vec = p_to_xy(p_s_given_z.T).T\n",
        "hull = scipy.spatial.ConvexHull(xy_vec)\n",
        "p_vertices = p_s_given_z[hull.vertices]\n",
        "xy_vertices = xy_vec[hull.vertices]\n",
        "xy_vertices_wrapped = np.concatenate([xy_vertices, [xy_vertices[0]]])\n",
        "\n",
        "p_s_x, p_s_y = p_to_xy(p_s.value)\n",
        "xy_support = xy_vec[p_z.value > 0.01]\n",
        "\n",
        "plt.figure(figsize=(4, 4 * np.sqrt(3)))\n",
        "plt.plot(xy_vec[:, 0], xy_vec[:, 1], 'o', c=c_vec[1], ms=10, alpha=0.3)\n",
        "plt.plot(xy_vertices_wrapped[:, 0], xy_vertices_wrapped[:, 1], '-', c=c_vec[1])\n",
        "\n",
        "plt.plot(xy_support[:, 0], xy_support[:, 1], 'o', ms=10, c=c_vec[1])\n",
        "plt.plot([p_s_x], [p_s_y], 's', c=c_vec[2], ms=10)\n",
        "for (x, y) in xy_support:\n",
        "  plt.plot([x, p_s_x], [y, p_s_y], '-', c='k', linewidth=1)\n",
        "\n",
        "plt.plot([0, 1, 0.5, 0], [0, 0, 0.5 * np.sqrt(3), 0], c=c_vec[0])\n",
        "\n",
        "kl = np.sum(p_s_given_z[p_z.value > 0.01] * np.log(p_s_given_z[p_z.value > 0.01] / p_s.value[None]), axis=1)\n",
        "assert kl.max() - kl.min() < 1e-6\n",
        "d = kl.mean()\n",
        "size = 100\n",
        "x = np.linspace(0, 1, size)\n",
        "y = np.linspace(0, 1, size)\n",
        "xy = np.stack(np.meshgrid(x, y), axis=-1).reshape((-1, 2))\n",
        "p = xy_to_p(xy.T).T\n",
        "kl = np.sum(p * np.log(p / p_s.value[None]), axis=1)\n",
        "kl = kl.reshape((size, size))\n",
        "plt.contour(x, y, kl, levels=[d], colors='k', linestyles='--')\n",
        "\n",
        "plt.axis('off')\n",
        "plt.tight_layout()\n",
        "plt.gca().set_aspect('equal')\n",
        "plt.savefig('skill.png', dpi=300, bbox_inches='tight')\n",
        "plt.show()"
      ],
      "execution_count": 9,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:45: RuntimeWarning: divide by zero encountered in log\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:45: RuntimeWarning: invalid value encountered in log\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:45: RuntimeWarning: invalid value encountered in multiply\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 288x498.831 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "qreIetS6seS7"
      },
      "source": [
        ""
      ],
      "execution_count": null,
      "outputs": []
    }
  ]
}