{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "approx_uniform.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "id": "LjyosnIRAubk",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "import numpy as np\n",
        "from matplotlib import pyplot as plt"
      ],
      "execution_count": 1,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "NsvymQAaA3iM",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "def softmax(x):\n",
        "    return np.exp(x)/np.sum(np.exp(x))\n",
        "\n",
        "def kld(x, y):\n",
        "    return np.sum(x*np.log(x/y))\n",
        "\n",
        "def cc(x, y):\n",
        "    return -np.sum(x*np.log(y))\n",
        "\n",
        "def entr(x):\n",
        "    return -np.sum(x*np.log(x))"
      ],
      "execution_count": 2,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "n9u5To2oBPRj",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "C = 20\n",
        "kl = []\n",
        "for i in range(100):\n",
        "    x = np.random.rand(C)\n",
        "    x[0] = np.log(0.7/0.3*np.sum(np.exp(x[1:])))\n",
        "    y = softmax(x)\n",
        "    y_max = np.max(y)\n",
        "    y_ = np.array([y_max] + [(1-y_max)/(C-1) for _ in range(C-1)])\n",
        "    kl.append(kld(y, y_))"
      ],
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "cFUTDrEgGjxp",
        "colab_type": "code",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 34
        },
        "outputId": "f1af1209-4ba2-4a75-b662-c4a962a170dc"
      },
      "source": [
        "print(np.mean(kl))"
      ],
      "execution_count": 4,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "0.011826110145218676\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "f14ZdTnmeuqu",
        "colab_type": "code",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 51
        },
        "outputId": "320e4295-5e73-48f3-c4ac-81ad1a9fb346"
      },
      "source": [
        "y[:10]"
      ],
      "execution_count": 5,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "array([0.7       , 0.01094519, 0.01015246, 0.02071817, 0.02451532,\n",
              "       0.0127278 , 0.01000028, 0.01583421, 0.01715736, 0.02443451])"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 5
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "G3MES-TAi2Qc",
        "colab_type": "code",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 85
        },
        "outputId": "94d1449f-7d14-4dd2-ef73-afd1aeb5093a"
      },
      "source": [
        "y_"
      ],
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "array([0.7       , 0.01578947, 0.01578947, 0.01578947, 0.01578947,\n",
              "       0.01578947, 0.01578947, 0.01578947, 0.01578947, 0.01578947,\n",
              "       0.01578947, 0.01578947, 0.01578947, 0.01578947, 0.01578947,\n",
              "       0.01578947, 0.01578947, 0.01578947, 0.01578947, 0.01578947])"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 6
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "EEiOqyr-jLHq",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "def kld2(x, y):\n",
        "    return np.sum(x*np.log(x))-np.log((0.5)/(C-1))*0.5"
      ],
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "UsfDOVxTrGwA",
        "colab_type": "code",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 34
        },
        "outputId": "b6a814c4-ceea-4ff3-9d7b-8f2975062322"
      },
      "source": [
        "kld2(y[1:], y_[1:])"
      ],
      "execution_count": 8,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.5906392684851185"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 8
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "5Y9niJvCwuOM",
        "colab_type": "code",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 34
        },
        "outputId": "10d23c9b-4f23-4431-c4bb-e98ab6f031d5"
      },
      "source": [
        "kld(y, y_)"
      ],
      "execution_count": 9,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.016369723669638705"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 9
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "glQjiYIsxrLq",
        "colab_type": "code",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 34
        },
        "outputId": "1b1bd876-8a57-4f03-a619-2caa06976fa8"
      },
      "source": [
        "-entr(y[1:]) - np.log((1-0.5)/(C-1))*(1-0.5)"
      ],
      "execution_count": 10,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.5906392684851185"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 10
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "_M2GeRCS9zN3",
        "colab_type": "code",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 51
        },
        "outputId": "0c4ecc84-7fbc-4f06-d063-4071b269c3aa"
      },
      "source": [
        "C = 1000\n",
        "x = np.random.rand(C)\n",
        "x = softmax(x)\n",
        "print(x[0])\n",
        "print(1/C)"
      ],
      "execution_count": 12,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "0.0005839275783671072\n",
            "0.001\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "JBg9YUO9JHIL",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        ""
      ],
      "execution_count": null,
      "outputs": []
    }
  ]
}