{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ZHlkC1uiCyOD"
      },
      "outputs": [],
      "source": [
        "from riskfolio import RiskFunctions"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "tnHtTSrwkvcN",
        "outputId": "8025fb3c-b69c-48dc-a114-24a11ca2ac0a"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "tensor([0.6074], grad_fn=<MulBackward0>)\n",
            "Maximized EVaR: 0.45568573474884033\n",
            "Maximized beta: 0.4548013508319855\n",
            "Risk folio evar, beta 0.46791316703635705 2.183972287746039\n"
          ]
        }
      ],
      "source": [
        "import torch\n",
        "import torch.optim as optim\n",
        "\n",
        "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
        "\n",
        "# Define the function to maximize\n",
        "def evar(x, alpha, beta):\n",
        "  return (beta**-1)*((torch.log(torch.mean(torch.exp(-beta * x)))) - (torch.log(1-alpha)))\n",
        "\n",
        "# Define the variable (parameter) of the function\n",
        "x = torch.tensor(np.random.normal(0,1,size=10000), requires_grad=False)\n",
        "alpha = torch.tensor([0.1], requires_grad=False)\n",
        "beta = torch.tensor([1.0], requires_grad=True)\n",
        "\n",
        "# Initialize the optimizer (we'll use stochastic gradient descent)\n",
        "optimizer = optim.SGD([beta], lr=0.01, )\n",
        "\n",
        "\n",
        "print(evar(x,alpha,beta))\n",
        "\n",
        "# Number of optimization steps\n",
        "num_steps = 10000\n",
        "\n",
        "# Optimization loop\n",
        "for _ in range(num_steps):\n",
        "  optimizer.zero_grad()\n",
        "  output = evar(x, alpha, beta)\n",
        "  output.backward()\n",
        "  optimizer.step()\n",
        "\n",
        "\n",
        "# Print the maximized value of the function\n",
        "print(\"Maximized EVaR:\", evar(x, alpha, beta).item())\n",
        "print(\"Maximized beta:\", beta.item())\n",
        "# print(evar(x,alpha,beta))\n",
        "evar,beta = RiskFunctions.EVaR_Hist(((-1*x).tolist()),alpha =1-alpha.item())\n",
        "print(\"Risk folio evar, beta\",evar, beta)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "LJI9ExHpnxJa",
        "outputId": "ebcfd4af-7550-4ee0-d835-2880a33e26e7"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.999490983762916\n",
            "0.4653855907291962\n",
            "0.46750255506358307\n",
            "0.456934635740809\n",
            "0.4579106600815706\n",
            "0.46022834379462174\n",
            "0.4667517659212582\n",
            "0.46195638282860463\n",
            "0.46372592589267697\n",
            "0.45565570776171277\n",
            "EVAR 0.44885776138842554\n"
          ]
        }
      ],
      "source": [
        "S = 0\n",
        "S_prime = 0\n",
        "beta = 1\n",
        "alpha = 0.1\n",
        "\n",
        "x = np.random.normal(0,1,size = 1000000)\n",
        "\n",
        "delta = 0.01\n",
        "delta2 = 0.001\n",
        "gamma = 0.0001\n",
        "\n",
        "for i in range(0,1000000):\n",
        "  # X = np.random.normal(0,1,size=1)\n",
        "  X = x[i]\n",
        "  S = S + delta * (np.exp(-beta * X) - S)\n",
        "\n",
        "  # S_prime = S_prime + delta * ( X * np.exp( -beta * X ) - S_prime)\n",
        "  # beta = beta + gamma * (beta**-2) *(np.log(S) + (beta*(S_prime/S)) - np.log(1-alpha))\n",
        "\n",
        "  S_prime = S_prime + delta2 * (X * np.exp(-beta * X) - (S_prime * beta * np.exp(-beta * X)))\n",
        "  beta = beta + gamma * ((beta**-2)*np.log(S)+S_prime - (beta**-2)*(np.log(1-alpha)))\n",
        "  if i % 100000 == 0:\n",
        "    print(beta)\n",
        "# print(\"S\",S)\n",
        "EVAR = (beta**-1) * (np.log(S/(1-alpha)))\n",
        "x = np.random.normal(0,1,size = 1000)\n",
        "avg = 0\n",
        "for X in x:\n",
        "  avg = avg + np.exp(-beta * X)\n",
        "# print(\"avg\",avg/1000)\n",
        "print(\"EVAR\",EVAR)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "6AKe2gIVISTh",
        "outputId": "c05d600d-0737-4a81-837d-be45ff01453a"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "[19.0, 31.0, 10.0, 17.0, 56.0, 21.0, 32.0, 14.0, 22.0, 12.0, 11.0, 17.0, 20.0, 25.0, 14.0, 16.0, 10.0, 34.0, 17.0, 20.0, 18.0, 13.0, 28.0, 13.0, 22.0, 13.0, 43.0, 15.0, 23.0, 23.0, 12.0, 16.0, 42.0, 13.0, 38.0, 22.0, 10.0, 13.0, 16.0, 13.0, 18.0, 34.0, 41.0, 14.0, 20.0, 12.0, 10.0, 15.0, 19.0, 17.0, 18.0, 13.0, 17.0, 22.0, 42.0, 10.0, 17.0, 19.0, 14.0, 11.0, 36.0, 42.0, 22.0, 28.0, 11.0, 16.0, 15.0, 18.0, 14.0, 26.0, 13.0, 39.0, 26.0, 43.0, 19.0, 12.0, 10.0, 28.0, 15.0, 14.0, 26.0, 16.0, 13.0, 14.0, 18.0, 19.0, 18.0, 31.0, 21.0, 14.0, 25.0, 11.0, 66.0, 19.0, 34.0, 40.0, 18.0, 14.0, 16.0, 21.0]\n"
          ]
        }
      ],
      "source": [
        "\n",
        "\n",
        "# Create the CartPole-v1 environment\n",
        "env = gym.make('CartPole-v1')\n",
        "\n",
        "# Define the number of episodes\n",
        "num_episodes = 100\n",
        "\n",
        "# Initialize a list to store rewards for each episode\n",
        "episode_rewards = []\n",
        "\n",
        "# Run the simulation for a number of episodes\n",
        "for episode in range(num_episodes):\n",
        "    observation = env.reset()[0]  # Reset the environment at the start of each episode\n",
        "    total_reward = 0  # Initialize the total reward for this episode\n",
        "    terminated  = False\n",
        "    truncated = False\n",
        "\n",
        "    while not terminated and not truncated:\n",
        "        # env.render()  # Render the environment (optional, can be commented out)\n",
        "        action = env.action_space.sample()  # Take a random action\n",
        "        observation, reward, terminated, truncated = env.step(action)  # Step the environment\n",
        "\n",
        "        total_reward += reward  # Accumulate the reward\n",
        "\n",
        "        # if done:  # Check if the episode is finished\n",
        "        #     break\n",
        "\n",
        "    episode_rewards.append(total_reward)  # Store the total reward for this episode\n",
        "\n",
        "# Close the environment\n",
        "env.close()\n",
        "\n",
        "# Print the rewards for each episode\n",
        "print(episode_rewards)\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "jRDjh7h8IWhZ",
        "outputId": "47e41630-eb4a-4ef8-abf1-18028b87caa8"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "tensor([-61.5002], grad_fn=<MulBackward0>)\n",
            "Maximized EVaR: nan\n",
            "Maximized beta: nan\n",
            "-10.21770476370568 [[0.64514151]]\n"
          ]
        }
      ],
      "source": [
        "def evar(x, alpha, beta):\n",
        "  return (beta**-1)*(-(torch.log(torch.mean(torch.exp(-beta * x)))) + (torch.log(1-alpha)))\n",
        "\n",
        "x = -1 * torch.tensor(episode_rewards, requires_grad=False)\n",
        "alpha = torch.tensor([0.1], requires_grad=False)\n",
        "beta = torch.tensor([1.0], requires_grad=True)\n",
        "\n",
        "# Initialize the optimizer (we'll use stochastic gradient descent)\n",
        "optimizer = optim.SGD([beta], lr=0.001, )\n",
        "\n",
        "\n",
        "print(evar(x,alpha,beta))\n",
        "\n",
        "# Number of optimization steps\n",
        "num_steps = 10000\n",
        "\n",
        "# Optimization loop\n",
        "for _ in range(num_steps):\n",
        "  optimizer.zero_grad()\n",
        "  output = evar(x, alpha, beta)\n",
        "  output.backward()\n",
        "  optimizer.step()\n",
        "\n",
        "\n",
        "# Print the maximized value of the function\n",
        "print(\"Maximized EVaR:\", evar(x, alpha, beta).item())\n",
        "print(\"Maximized beta:\", beta.item())\n",
        "\n",
        "\n",
        "evar,beta = RiskFunctions.EVaR_Hist(1*np.array(episode_rewards),alpha = alpha)\n",
        "print(evar, beta)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ZckprhEAL3Eb",
        "outputId": "517144b4-073d-41a9-8be5-74abb8f7a172"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.999999993695529\n",
            "EVAR -13.453746282151386\n"
          ]
        }
      ],
      "source": [
        "S = 0\n",
        "S_prime = 0\n",
        "beta = 1\n",
        "alpha = 0.1\n",
        "\n",
        "x = np.array(episode_rewards)\n",
        "\n",
        "delta = 0.12\n",
        "# delta2 = 0.1\n",
        "gamma = 0.0000000003\n",
        "\n",
        "for i in range(0,len(episode_rewards)):\n",
        "  # X = np.random.normal(0,1,size=1)\n",
        "  X = x[i]\n",
        "  S = S + delta * (np.exp(-beta * X) - S)\n",
        "\n",
        "  # S_prime = S_prime + delta * ( X * np.exp( -beta * X ) - S_prime)\n",
        "  # beta = beta + gamma * (beta**-2) *(np.log(S) + (beta*(S_prime/S)) - np.log(1-alpha))\n",
        "\n",
        "  S_prime = S_prime + delta * (X * np.exp(-beta * X) - (S_prime * beta * np.exp(-beta * X)))\n",
        "  beta = beta + gamma * ((beta**-2)*np.log(S)+S_prime - (beta**-2)*(np.log(1-alpha)))\n",
        "  if i % 1000 == 0:\n",
        "    print(beta)\n",
        "\n",
        "# print(\"S\",S)\n",
        "EVAR = (beta**-1) * (np.log(S/(1-alpha)))\n",
        "\n",
        "# x = np.random.normal(0,1,size = 1000)\n",
        "# avg = 0\n",
        "# for X in x:\n",
        "#   avg = avg + np.exp(-beta * X)\n",
        "# print(\"avg\",avg/1000)\n",
        "\n",
        "print(\"EVAR\",EVAR)"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "<h1>Main Algorithm Starts</h1>"
      ],
      "metadata": {
        "id": "k1_ZOcAA9N-m"
      }
    },
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "I58xr4qVlQcu"
      },
      "outputs": [],
      "source": [
        "import gym\n",
        "!pip install riskfolio-lib --quiet\n",
        "from riskfolio import RiskFunctions\n",
        "import numpy as np\n",
        "import warnings\n",
        "# Suppress warnings\n",
        "warnings.filterwarnings(\"ignore\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "7sR2PMKANL57",
        "outputId": "c81a62c3-ac79-48ea-f812-d39159c4cd79"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "BATCH  0 ==================\n",
            "From func evar, beta :  -9.43220123760129 [[0.84013869]]\n",
            "EVAR SA 2.1538645494148745 1.000000020210099\n",
            "From func evar, beta :  -9.888419564422135 [[0.95129903]]\n",
            "EVAR SA -0.40280074681116584 1.0000000250811472\n",
            "From func evar, beta :  -10.108941521151431 [[0.92032633]]\n",
            "EVAR SA -2.959419972501021 1.0000000146125623\n",
            "From func evar, beta :  -9.572653408994661 [[0.87520499]]\n",
            "EVAR SA -5.511966992023999 0.9999999888131849\n",
            "From func evar, beta :  -9.567627933791153 [[0.91621581]]\n",
            "EVAR SA -8.035411338728498 0.9999999477447893\n",
            "From func evar, beta :  -9.622163594526912 [[0.86965261]]\n",
            "EVAR SA -10.325095116855227 0.9999998918285997\n",
            "From func evar, beta :  -9.739193520728264 [[0.92402617]]\n",
            "EVAR SA -12.65147009008233 0.9999998227085184\n",
            "From func evar, beta :  -9.845883873454255 [[0.97510405]]\n",
            "EVAR SA -13.578008678423377 0.999999742879367\n",
            "From func evar, beta :  -9.720135692018939 [[0.91621904]]\n",
            "EVAR SA -11.312489546136936 0.9999996715431256\n",
            "From func evar, beta :  -9.795772935649703 [[0.94047268]]\n",
            "EVAR SA -12.957973740257817 0.9999995977884715\n",
            "From func evar, beta :  -9.78557164874035 [[0.89044604]]\n",
            "EVAR SA -11.947643185965582 0.9999995246625637\n",
            "From func evar, beta :  -9.558562145598607 [[0.99149685]]\n",
            "EVAR SA -11.511598624339808 0.9999994599070974\n",
            "From func evar, beta :  -9.559801710856323 [[0.94821814]]\n",
            "EVAR SA -11.729992016941061 0.9999993898760797\n",
            "From func evar, beta :  -9.619479481916667 [[0.96428]]\n",
            "EVAR SA -13.271469494736383 0.9999993142367037\n",
            "From func evar, beta :  -9.634883514603889 [[0.95263045]]\n",
            "EVAR SA -11.43321877492288 0.9999992338152416\n",
            "From func evar, beta :  -9.6924630443902 [[0.97493208]]\n",
            "EVAR SA -13.354681149669881 0.9999991582802389\n",
            "From func evar, beta :  -9.719788181943642 [[0.97587135]]\n",
            "EVAR SA -12.950235535751098 0.9999990821910334\n",
            "From func evar, beta :  -9.650087985879388 [[0.96682957]]\n",
            "EVAR SA -11.77577732880794 0.9999990135480854\n",
            "From func evar, beta :  -9.522969119169481 [[0.99500259]]\n",
            "EVAR SA -10.418987029295597 0.9999989463394595\n",
            "From func evar, beta :  -9.473861947846933 [[0.97338178]]\n",
            "EVAR SA -11.574922614109912 0.9999988818649552\n",
            "BATCH  1 ==================\n",
            "From func evar, beta :  -9.459974720571777 [[0.95927215]]\n",
            "EVAR SA -11.039304209455773 0.9999988111558457\n",
            "From func evar, beta :  -9.447164297732078 [[0.9444357]]\n",
            "EVAR SA -11.428728912882864 0.9999987431313682\n",
            "From func evar, beta :  -9.454723103447463 [[0.92781534]]\n",
            "EVAR SA -11.520139088166694 0.9999986723420277\n",
            "From func evar, beta :  -9.489284422796018 [[0.94119812]]\n",
            "EVAR SA -13.184638674021338 0.9999985976133786\n",
            "From func evar, beta :  -9.521777914988098 [[0.95022493]]\n",
            "EVAR SA -13.482521655948894 0.9999985178650146\n",
            "From func evar, beta :  -9.499767881914435 [[0.93406248]]\n",
            "EVAR SA -11.49864705150073 0.9999984482502783\n",
            "From func evar, beta :  -9.52409059204353 [[0.94377785]]\n",
            "EVAR SA -13.18753403009304 0.9999983750725492\n",
            "From func evar, beta :  -9.435552785942438 [[0.9610524]]\n",
            "EVAR SA -11.315084127253467 0.9999983099963612\n",
            "From func evar, beta :  -9.459843005983714 [[0.96410407]]\n",
            "EVAR SA -12.40245073504499 0.9999982371949242\n",
            "From func evar, beta :  -9.45753670680213 [[0.9598094]]\n",
            "EVAR SA -12.279263748978257 0.9999981669417587\n",
            "From func evar, beta :  -9.478117826563638 [[0.96519492]]\n",
            "EVAR SA -13.069594791392941 0.999998091600884\n",
            "From func evar, beta :  -9.47451453618786 [[0.95968501]]\n",
            "EVAR SA -11.579814619161864 0.9999980170455628\n",
            "From func evar, beta :  -9.433266061922456 [[0.98622102]]\n",
            "EVAR SA -11.24484743278983 0.9999979500158941\n",
            "From func evar, beta :  -9.449617165492395 [[0.98462742]]\n",
            "EVAR SA -11.980393023936776 0.9999978778888506\n",
            "From func evar, beta :  -9.448708295337827 [[0.98237881]]\n",
            "EVAR SA -11.879877718722303 0.9999978073895429\n",
            "From func evar, beta :  -9.470599521113774 [[0.98724834]]\n",
            "EVAR SA -13.04033712059804 0.9999977320109262\n",
            "From func evar, beta :  -9.410489749170544 [[1.00255953]]\n",
            "EVAR SA -10.336977086236011 0.9999976597462827\n",
            "From func evar, beta :  -9.42776918335604 [[1.00625157]]\n",
            "EVAR SA -12.11027195934227 0.999997591602311\n",
            "From func evar, beta :  -9.438198651793115 [[1.0054308]]\n",
            "EVAR SA -12.022722180935846 0.9999975176198842\n",
            "From func evar, beta :  -9.459884558748037 [[1.01100521]]\n",
            "EVAR SA -13.306037636647899 0.9999974405667573\n",
            "BATCH  2 ==================\n",
            "From func evar, beta :  -9.473027357052242 [[1.0107731]]\n",
            "EVAR SA -12.112163801229174 0.9999973616978436\n",
            "From func evar, beta :  -9.482317652628472 [[1.01050308]]\n",
            "EVAR SA -12.414425850279859 0.9999972890269636\n",
            "From func evar, beta :  -9.485838177841533 [[1.01526413]]\n",
            "EVAR SA -12.944099841138186 0.9999972171016761\n",
            "From func evar, beta :  -9.493538574259603 [[1.00937805]]\n",
            "EVAR SA -12.480203526693945 0.9999971429852256\n",
            "From func evar, beta :  -9.47514465621881 [[1.00321598]]\n",
            "EVAR SA -11.047899583229759 0.9999970734305613\n",
            "From func evar, beta :  -9.492466834212713 [[1.00724961]]\n",
            "EVAR SA -12.527500379196503 0.9999970007413915\n",
            "From func evar, beta :  -9.477837218565869 [[1.00586222]]\n",
            "EVAR SA -11.82784571646664 0.9999969316876759\n",
            "From func evar, beta :  -9.49583206919893 [[1.0110533]]\n",
            "EVAR SA -13.158449879855588 0.9999968554989153\n",
            "From func evar, beta :  -9.51462459900683 [[1.0179714]]\n",
            "EVAR SA -13.75398129218069 0.9999967731514168\n",
            "From func evar, beta :  -9.518768934843905 [[1.01264334]]\n",
            "EVAR SA -11.590250271227795 0.9999966955259133\n",
            "From func evar, beta :  -9.531442281961702 [[1.01585363]]\n",
            "EVAR SA -11.965694889086754 0.9999966200695097\n",
            "From func evar, beta :  -9.526882136025836 [[1.01394803]]\n",
            "EVAR SA -11.050227459935689 0.9999965461993905\n",
            "From func evar, beta :  -9.536343535196307 [[1.01335508]]\n",
            "EVAR SA -12.748194669246674 0.9999964755865034\n",
            "From func evar, beta :  -9.554302570412876 [[1.02134274]]\n",
            "EVAR SA -14.147623176933202 0.9999963931481932\n",
            "From func evar, beta :  -9.570269958062074 [[1.02749244]]\n",
            "EVAR SA -13.996260666407698 0.9999963097911964\n",
            "From func evar, beta :  -9.5672095549574 [[1.02424026]]\n",
            "EVAR SA -12.128740693210453 0.999996236247671\n",
            "From func evar, beta :  -9.58323559596256 [[1.0301315]]\n",
            "EVAR SA -13.917133411293634 0.9999961582982709\n",
            "From func evar, beta :  -9.581722411957605 [[1.03022428]]\n",
            "EVAR SA -12.061105032496139 0.9999960824375113\n",
            "From func evar, beta :  -9.583473799629225 [[1.02347557]]\n",
            "EVAR SA -11.840307197340211 0.9999960100784836\n",
            "From func evar, beta :  -9.592316517752684 [[1.02273603]]\n",
            "EVAR SA -12.703004380103703 0.999995936729099\n",
            "BATCH  3 ==================\n",
            "From func evar, beta :  -9.608839525512412 [[1.03112159]]\n",
            "EVAR SA -14.828570839798854 0.9999958535488795\n",
            "From func evar, beta :  -9.60851579325395 [[1.03325136]]\n",
            "EVAR SA -12.3952745782046 0.9999957781414772\n",
            "From func evar, beta :  -9.590728626790305 [[1.02083639]]\n",
            "EVAR SA -10.847124919278084 0.9999957084409195\n",
            "From func evar, beta :  -9.605332620572016 [[1.02667337]]\n",
            "EVAR SA -12.858069574917161 0.999995635928541\n",
            "From func evar, beta :  -9.609255766939153 [[1.02466442]]\n",
            "EVAR SA -13.028919260653932 0.999995562580379\n",
            "From func evar, beta :  -9.623264758161806 [[1.02981224]]\n",
            "EVAR SA -13.716783395686901 0.9999954800997869\n",
            "From func evar, beta :  -9.6242854552406 [[1.02403232]]\n",
            "EVAR SA -11.667042177326007 0.9999954022129938\n",
            "From func evar, beta :  -9.613326467925214 [[1.01749107]]\n",
            "EVAR SA -10.678239410236088 0.9999953294046131\n",
            "From func evar, beta :  -9.61673488881549 [[1.0123589]]\n",
            "EVAR SA -11.681748934994298 0.9999952603122204\n",
            "From func evar, beta :  -9.620185116128766 [[1.01020567]]\n",
            "EVAR SA -12.174064927867942 0.9999951885471456\n",
            "From func evar, beta :  -9.619964584911143 [[1.00307578]]\n",
            "EVAR SA -11.498876354525361 0.9999951156443353\n",
            "From func evar, beta :  -9.626599261093615 [[1.00312639]]\n",
            "EVAR SA -12.269833364279092 0.9999950430723363\n",
            "From func evar, beta :  -9.63027237457821 [[0.99842809]]\n",
            "EVAR SA -12.924310926998022 0.9999949706651938\n",
            "From func evar, beta :  -9.641326054515527 [[1.00176879]]\n",
            "EVAR SA -13.594041024370773 0.9999948911190305\n",
            "From func evar, beta :  -9.63468596173821 [[0.99863888]]\n",
            "EVAR SA -12.404115398682372 0.9999948210672039\n",
            "From func evar, beta :  -9.638979611586926 [[0.99577941]]\n",
            "EVAR SA -12.32780303986492 0.9999947472891965\n",
            "From func evar, beta :  -9.64527817063329 [[0.99598351]]\n",
            "EVAR SA -13.297492868439916 0.9999946730534444\n",
            "From func evar, beta :  -9.657263111978505 [[1.00103167]]\n",
            "EVAR SA -14.46194589644415 0.9999945895365083\n",
            "From func evar, beta :  -9.6604217500085 [[0.99987049]]\n",
            "EVAR SA -12.178838868918104 0.9999945133496669\n",
            "From func evar, beta :  -9.660673423049051 [[0.99416666]]\n",
            "EVAR SA -12.098031791928658 0.9999944414874333\n",
            "BATCH  4 ==================\n",
            "From func evar, beta :  -9.670817016223042 [[0.99749809]]\n",
            "EVAR SA -13.661489390068157 0.9999943645755002\n",
            "From func evar, beta :  -9.682231920846327 [[1.00281218]]\n",
            "EVAR SA -14.686718544685837 0.999994279754266\n",
            "From func evar, beta :  -9.685822756047902 [[0.99980101]]\n",
            "EVAR SA -12.664016589932636 0.9999942032594056\n",
            "From func evar, beta :  -9.686707682071944 [[0.9962348]]\n",
            "EVAR SA -12.079307656644952 0.9999941302681047\n",
            "From func evar, beta :  -9.686167191785056 [[0.99110488]]\n",
            "EVAR SA -11.55719289552498 0.9999940573621937\n",
            "From func evar, beta :  -9.663240214786379 [[1.00448049]]\n",
            "EVAR SA -10.098293336212476 0.99999398531228\n",
            "From func evar, beta :  -9.669787001419511 [[1.00593229]]\n",
            "EVAR SA -11.823437965926882 0.9999939180992253\n",
            "From func evar, beta :  -9.658490824750608 [[0.99782638]]\n",
            "EVAR SA -10.974971339536657 0.9999938486051866\n",
            "From func evar, beta :  -9.652458624594384 [[0.9947579]]\n",
            "EVAR SA -11.083460727801967 0.999993779919345\n",
            "From func evar, beta :  -9.657277767349292 [[0.9940828]]\n",
            "EVAR SA -11.592941315025653 0.9999937074992397\n",
            "From func evar, beta :  -9.661678069144912 [[0.98995825]]\n",
            "EVAR SA -12.211219189189713 0.9999936350822952\n",
            "From func evar, beta :  -9.667910249021158 [[0.9883783]]\n",
            "EVAR SA -12.22852012384765 0.9999935585343493\n",
            "From func evar, beta :  -9.673651153675234 [[0.98924272]]\n",
            "EVAR SA -13.044551371886712 0.9999934834727252\n",
            "From func evar, beta :  -9.682589932067668 [[0.99270749]]\n",
            "EVAR SA -13.887664953650907 0.9999934029494381\n",
            "From func evar, beta :  -9.672785836419227 [[0.98710807]]\n",
            "EVAR SA -10.73717404465877 0.9999933242378409\n",
            "From func evar, beta :  -9.679126081732267 [[0.98663514]]\n",
            "EVAR SA -12.574290673633296 0.999993254281357\n",
            "From func evar, beta :  -9.68438464773545 [[0.98696419]]\n",
            "EVAR SA -13.152253551723772 0.9999931787195482\n",
            "From func evar, beta :  -9.693099644698496 [[0.98970998]]\n",
            "EVAR SA -13.747953783137568 0.9999930974220802\n",
            "From func evar, beta :  -9.671200166655268 [[1.00120309]]\n",
            "EVAR SA -11.319883009247315 0.9999930265181186\n",
            "From func evar, beta :  -9.662726356081961 [[0.99638367]]\n",
            "EVAR SA -11.75320597235017 0.999992959495221\n",
            "BATCH  5 ==================\n",
            "From func evar, beta :  -9.658286061113358 [[0.99496761]]\n",
            "EVAR SA -11.886038798120675 0.9999928902211692\n",
            "From func evar, beta :  -9.639414515609726 [[1.00536998]]\n",
            "EVAR SA -11.039964106900149 0.9999928222306768\n",
            "From func evar, beta :  -9.644080749447586 [[1.00478078]]\n",
            "EVAR SA -11.803673125577248 0.9999927501400449\n",
            "From func evar, beta :  -9.651326371726562 [[1.00603666]]\n",
            "EVAR SA -13.009647124717674 0.9999926749443541\n",
            "From func evar, beta :  -9.648100637370664 [[1.00630909]]\n",
            "EVAR SA -12.779195927996136 0.9999926042162699\n",
            "From func evar, beta :  -9.65157026384622 [[1.00435884]]\n",
            "EVAR SA -12.396558084263315 0.9999925292631635\n",
            "From func evar, beta :  -9.653258787978864 [[1.00070835]]\n",
            "EVAR SA -12.510631524629291 0.9999924569323609\n",
            "From func evar, beta :  -9.658709057225192 [[1.00219883]]\n",
            "EVAR SA -12.295895673304624 0.9999923787365913\n",
            "From func evar, beta :  -9.66339503535125 [[1.00052688]]\n",
            "EVAR SA -12.182220247185072 0.9999923028385199\n",
            "From func evar, beta :  -9.658349499306276 [[0.99827724]]\n",
            "EVAR SA -11.992881403754826 0.9999922332174302\n",
            "From func evar, beta :  -9.663123624139562 [[0.99705278]]\n",
            "EVAR SA -12.613617239831441 0.9999921592152976\n",
            "From func evar, beta :  -9.669919062640263 [[0.99854957]]\n",
            "EVAR SA -13.316465147919931 0.9999920812320203\n",
            "From func evar, beta :  -9.666058011966506 [[0.99779476]]\n",
            "EVAR SA -12.353270627395906 0.9999920100466214\n",
            "From func evar, beta :  -9.673183595000689 [[1.00015375]]\n",
            "EVAR SA -13.059507876764822 0.9999919312497011\n",
            "From func evar, beta :  -9.676863317618944 [[0.99951765]]\n",
            "EVAR SA -12.002975669250933 0.9999918528533468\n",
            "From func evar, beta :  -9.678372516318852 [[0.99772029]]\n",
            "EVAR SA -12.12518243710348 0.9999917805505445\n",
            "From func evar, beta :  -9.671063372215915 [[0.99444442]]\n",
            "EVAR SA -11.60661661486578 0.9999917111575423\n",
            "From func evar, beta :  -9.674841725823635 [[0.99268201]]\n",
            "EVAR SA -12.70582871602619 0.9999916390168805\n",
            "From func evar, beta :  -9.680049591727997 [[0.99249242]]\n",
            "EVAR SA -12.789718749311092 0.9999915619162686\n",
            "From func evar, beta :  -9.684443119870583 [[0.99290757]]\n",
            "EVAR SA -11.997818865157171 0.999991482420433\n",
            "BATCH  6 ==================\n",
            "From func evar, beta :  -9.675468237357501 [[0.99291607]]\n",
            "EVAR SA -12.102728003801744 0.9999914146990212\n",
            "From func evar, beta :  -9.673497913875757 [[0.99252465]]\n",
            "EVAR SA -10.895090152148875 0.9999913389543447\n",
            "From func evar, beta :  -9.677152974835014 [[0.99251683]]\n",
            "EVAR SA -12.401837646906253 0.9999912686892289\n",
            "From func evar, beta :  -9.681564173828633 [[0.99192269]]\n",
            "EVAR SA -13.578765816452684 0.9999911936547289\n",
            "From func evar, beta :  -9.684680475153316 [[0.99100977]]\n",
            "EVAR SA -12.887878583987058 0.9999911184184643\n",
            "From func evar, beta :  -9.688526443689927 [[0.99155439]]\n",
            "EVAR SA -12.692035912739462 0.9999910421471426\n",
            "From func evar, beta :  -9.687254006332548 [[0.98819698]]\n",
            "EVAR SA -11.399204908245228 0.9999909674058896\n",
            "From func evar, beta :  -9.693596127035839 [[0.98958515]]\n",
            "EVAR SA -13.070338190762588 0.9999908932561006\n",
            "From func evar, beta :  -9.699059556488779 [[0.98993664]]\n",
            "EVAR SA -12.612421399909676 0.9999908127725736\n",
            "From func evar, beta :  -9.702710253078248 [[0.98990351]]\n",
            "EVAR SA -12.850643496207704 0.9999907374344096\n",
            "From func evar, beta :  -9.70819900746865 [[0.99059938]]\n",
            "EVAR SA -13.123024136053754 0.9999906589462335\n",
            "From func evar, beta :  -9.70939403408056 [[0.98914503]]\n",
            "EVAR SA -11.359723651453171 0.9999905782517494\n",
            "From func evar, beta :  -9.712955562395882 [[0.98968291]]\n",
            "EVAR SA -12.311029065882844 0.999990506019527\n",
            "From func evar, beta :  -9.712549875754604 [[0.99204027]]\n",
            "EVAR SA -13.141779482437265 0.9999904342406778\n",
            "From func evar, beta :  -9.718339001361091 [[0.993621]]\n",
            "EVAR SA -13.548407251950964 0.9999903543722265\n",
            "From func evar, beta :  -9.720022274918323 [[0.98971275]]\n",
            "EVAR SA -11.770429438557114 0.9999902771479525\n",
            "From func evar, beta :  -9.721063749856285 [[0.98697418]]\n",
            "EVAR SA -11.955151169591149 0.999990205183023\n",
            "From func evar, beta :  -9.716700396146479 [[0.98575509]]\n",
            "EVAR SA -12.133771178875437 0.9999901362593525\n",
            "From func evar, beta :  -9.71714879626744 [[0.98366513]]\n",
            "EVAR SA -11.575887419749144 0.9999900624903468\n",
            "From func evar, beta :  -9.721892260124072 [[0.98417826]]\n",
            "EVAR SA -12.463949462290076 0.9999899878758447\n",
            "BATCH  7 ==================\n",
            "From func evar, beta :  -9.717467213105447 [[0.9825791]]\n",
            "EVAR SA -12.001538347636272 0.999989918511608\n",
            "From func evar, beta :  -9.714202498637231 [[0.98261846]]\n",
            "EVAR SA -12.216489545503537 0.9999898487226554\n",
            "From func evar, beta :  -9.719063309699735 [[0.98309139]]\n",
            "EVAR SA -13.085332977313538 0.9999897723909253\n",
            "From func evar, beta :  -9.72054866448336 [[0.98262321]]\n",
            "EVAR SA -11.702525893733466 0.9999896936449939\n",
            "From func evar, beta :  -9.725624645626546 [[0.98342179]]\n",
            "EVAR SA -13.12269644955225 0.9999896186837994\n",
            "From func evar, beta :  -9.730302440641582 [[0.98419194]]\n",
            "EVAR SA -12.740368248917019 0.9999895388489025\n",
            "From func evar, beta :  -9.733199070465465 [[0.98402385]]\n",
            "EVAR SA -11.895499178613322 0.9999894603714126\n",
            "From func evar, beta :  -9.737444238556062 [[0.98406352]]\n",
            "EVAR SA -13.25022039554959 0.9999893859011689\n",
            "From func evar, beta :  -9.742845031411743 [[0.98580928]]\n",
            "EVAR SA -13.732437289018586 0.9999893051708235\n",
            "From func evar, beta :  -9.744245655496828 [[0.98376217]]\n",
            "EVAR SA -11.748809620974681 0.9999892273579791\n",
            "From func evar, beta :  -9.739737599487 [[0.98198149]]\n",
            "EVAR SA -11.847549206595923 0.999989158659743\n",
            "From func evar, beta :  -9.746207735377046 [[0.98556563]]\n",
            "EVAR SA -14.376204765711591 0.9999890797389533\n",
            "From func evar, beta :  -9.750756770236379 [[0.9861457]]\n",
            "EVAR SA -13.768281371185768 0.9999889999757172\n",
            "From func evar, beta :  -9.747643455850884 [[0.98659071]]\n",
            "EVAR SA -11.289681467862742 0.9999889200468065\n",
            "From func evar, beta :  -9.746626056170665 [[0.98797804]]\n",
            "EVAR SA -11.620277997763624 0.9999888494797949\n",
            "From func evar, beta :  -9.731737970529323 [[0.99495972]]\n",
            "EVAR SA -10.846273690022604 0.9999887817988248\n",
            "From func evar, beta :  -9.730641853446393 [[0.99579291]]\n",
            "EVAR SA -11.008439214622593 0.9999887109918285\n",
            "From func evar, beta :  -9.730968872443775 [[0.99398699]]\n",
            "EVAR SA -11.703432183729985 0.9999886414352936\n",
            "From func evar, beta :  -9.728114156485086 [[0.99429591]]\n",
            "EVAR SA -10.93465813375109 0.9999885682858505\n",
            "From func evar, beta :  -9.724375699276884 [[0.99323022]]\n",
            "EVAR SA -11.004863778490533 0.9999884992370094\n",
            "BATCH  8 ==================\n",
            "From func evar, beta :  -9.730070561580543 [[0.9956369]]\n",
            "EVAR SA -13.37670635641765 0.9999884259398375\n",
            "From func evar, beta :  -9.726211736964828 [[0.99444883]]\n",
            "EVAR SA -11.336742954669752 0.9999883508506785\n",
            "From func evar, beta :  -9.730485877449091 [[0.99473246]]\n",
            "EVAR SA -13.079376990040759 0.9999882778842096\n",
            "From func evar, beta :  -9.734073663366308 [[0.99605055]]\n",
            "EVAR SA -13.325392015322542 0.999988200492429\n",
            "From func evar, beta :  -9.733617952334876 [[0.99342767]]\n",
            "EVAR SA -11.586763064323327 0.9999881227804489\n",
            "From func evar, beta :  -9.732578053893002 [[0.99429857]]\n",
            "EVAR SA -11.24621314563328 0.9999880495163859\n",
            "From func evar, beta :  -9.72990345698539 [[0.9947563]]\n",
            "EVAR SA -11.779984574332925 0.9999879809363587\n",
            "From func evar, beta :  -9.723441224457336 [[0.99086975]]\n",
            "EVAR SA -11.192623478478712 0.9999879122018092\n",
            "From func evar, beta :  -9.726513106132934 [[0.99125397]]\n",
            "EVAR SA -12.17855140554889 0.999987840020714\n",
            "From func evar, beta :  -9.728553618403595 [[0.99016551]]\n",
            "EVAR SA -12.537730359535548 0.9999877663506385\n",
            "From func evar, beta :  -9.727094422408138 [[0.99056039]]\n",
            "EVAR SA -12.19217447219461 0.9999876944762398\n",
            "From func evar, beta :  -9.731662836107231 [[0.99176538]]\n",
            "EVAR SA -13.343690628021669 0.999987617350861\n",
            "From func evar, beta :  -9.73537645079562 [[0.99202277]]\n",
            "EVAR SA -13.043419757464529 0.9999875387047176\n",
            "From func evar, beta :  -9.737540503099147 [[0.99141817]]\n",
            "EVAR SA -13.187048677446818 0.9999874640199155\n",
            "From func evar, beta :  -9.734085204489851 [[0.9905633]]\n",
            "EVAR SA -11.887774142615402 0.9999873936020847\n",
            "From func evar, beta :  -9.73236436681539 [[0.99054703]]\n",
            "EVAR SA -12.301314533214267 0.9999873236044782\n",
            "From func evar, beta :  -9.728401654106424 [[0.98838305]]\n",
            "EVAR SA -11.550495202226443 0.9999872530890944\n",
            "From func evar, beta :  -9.730605220558934 [[0.98697138]]\n",
            "EVAR SA -12.1288891411865 0.9999871804259917\n",
            "From func evar, beta :  -9.73341307686899 [[0.98715897]]\n",
            "EVAR SA -12.742333663964377 0.9999871058673825\n",
            "From func evar, beta :  -9.737735195514947 [[0.98839269]]\n",
            "EVAR SA -13.776434690766497 0.9999870273843503\n",
            "BATCH  9 ==================\n",
            "From func evar, beta :  -9.73726991314098 [[0.99024224]]\n",
            "EVAR SA -11.002284661113734 0.9999869413991468\n",
            "From func evar, beta :  -9.73994010819222 [[0.99043753]]\n",
            "EVAR SA -12.077074170150864 0.9999868700383807\n",
            "From func evar, beta :  -9.731987066394206 [[0.98453212]]\n",
            "EVAR SA -11.178455054196696 0.9999868026212072\n",
            "From func evar, beta :  -9.7360484909772 [[0.98552129]]\n",
            "EVAR SA -12.811923151993339 0.9999867298502935\n",
            "From func evar, beta :  -9.740091261729253 [[0.98653839]]\n",
            "EVAR SA -13.094324883231804 0.9999866503461108\n",
            "From func evar, beta :  -9.743777612307106 [[0.98725161]]\n",
            "EVAR SA -12.857322991026193 0.9999865706150584\n",
            "From func evar, beta :  -9.746157101914038 0.9874888381433212\n",
            "EVAR SA -13.215365286662697 0.9999864952527971\n",
            "From func evar, beta :  -9.746801048277637 [[0.9862922]]\n",
            "EVAR SA -12.125348829495222 0.9999864206596198\n",
            "From func evar, beta :  -9.743923039994169 [[0.98327989]]\n",
            "EVAR SA -11.258796611561802 0.9999863493758447\n",
            "From func evar, beta :  -9.739143483377688 0.9805139299704646\n",
            "EVAR SA -11.577209883783077 0.9999862821551742\n",
            "From func evar, beta :  -9.735960015861412 0.9798215843344733\n",
            "EVAR SA -12.158066334481019 0.9999862137095937\n",
            "From func evar, beta :  -9.738297069884547 0.9800314681006329\n",
            "EVAR SA -13.200602227618978 0.999986139778253\n",
            "From func evar, beta :  -9.741930919177797 [[0.98095179]]\n",
            "EVAR SA -13.952569352249151 0.999986061437439\n",
            "From func evar, beta :  -9.744233883677238 0.981170621925118\n",
            "EVAR SA -13.194422288783267 0.9999859845478433\n",
            "From func evar, beta :  -9.74565654948275 [[0.98003723]]\n",
            "EVAR SA -11.813837718384105 0.9999859069493555\n",
            "From func evar, beta :  -9.74528825950928 [[0.98215704]]\n",
            "EVAR SA -11.940693997501686 0.9999858347457055\n",
            "From func evar, beta :  -9.744597934457463 [[0.98358327]]\n",
            "EVAR SA -11.33679302464675 0.9999857600812228\n",
            "From func evar, beta :  -9.741895663882486 0.983258328367254\n",
            "EVAR SA -10.966750783322844 0.9999856886955224\n",
            "From func evar, beta :  -9.72771986286612 [[0.97964211]]\n",
            "EVAR SA -10.381059112305282 0.9999856233583614\n",
            "From func evar, beta :  -9.717956256251835 [[0.98799471]]\n",
            "EVAR SA -10.432854109495041 0.9999855572448884\n"
          ]
        }
      ],
      "source": [
        "x1={}\n",
        "x2={}\n",
        "env = gym.make('CartPole-v1')\n",
        "episode_rewards = []\n",
        "alpha = 0.1\n",
        "for batch in range(0,10):\n",
        "  x1[batch] = []\n",
        "  x2[batch] = []\n",
        "\n",
        "  print(\"BATCH \",batch,\"==================\")\n",
        "  for _ in range(0,20):\n",
        "\n",
        "    for episode in range(20):\n",
        "      observation = env.reset()[0]  # Reset the environment at the start of each episode\n",
        "      total_reward = 0  # Initialize the total reward for this episode\n",
        "      terminated  = False\n",
        "      truncated = False\n",
        "\n",
        "      while not terminated and not truncated:\n",
        "          # env.render()  # Render the environment (optional, can be commented out)\n",
        "          action = env.action_space.sample()  # Take a random action\n",
        "          observation, reward, terminated, truncated = env.step(action)  # Step the environment\n",
        "\n",
        "          total_reward += reward  # Accumulate the reward\n",
        "\n",
        "          # if done:  # Check if the episode is finished\n",
        "          #     break\n",
        "\n",
        "      episode_rewards.append(total_reward)  # Store the total reward for this episode\n",
        "\n",
        "    # Close the environment\n",
        "    # env.close()\n",
        "\n",
        "      evar,beta = RiskFunctions.EVaR_Hist(1*np.array(episode_rewards),alpha = alpha)\n",
        "\n",
        "    x1[batch].append(evar)\n",
        "    print(\"From func evar, beta : \",evar, beta)\n",
        "\n",
        "\n",
        "    S = 100\n",
        "    S_prime = 0\n",
        "    beta = 1\n",
        "    alpha = 0.1\n",
        "\n",
        "    x = np.array(episode_rewards)\n",
        "\n",
        "    delta = 0.12\n",
        "    # delta2 = 0.1\n",
        "    gamma = 0.0000000003\n",
        "\n",
        "    for i in range(0,len(episode_rewards)):\n",
        "      # X = np.random.normal(0,1,size=1)\n",
        "      X = x[i]\n",
        "      S = S + delta * (np.exp(-beta * X) - S)\n",
        "\n",
        "      # S_prime = S_prime + delta * ( X * np.exp( -beta * X ) - S_prime)\n",
        "      # beta = beta + gamma * (beta**-2) *(np.log(S) + (beta*(S_prime/S)) - np.log(1-alpha))\n",
        "\n",
        "      S_prime = S_prime + delta * (X * np.exp(-beta * X) - (S_prime * beta * np.exp(-beta * X)))\n",
        "      beta = beta + gamma * ((beta**-2)*np.log(S)+S_prime - (beta**-2)*(np.log(1-alpha)))\n",
        "      # if i % 1000 == 0:\n",
        "      #   print(beta)\n",
        "\n",
        "    # print(\"S\",S)\n",
        "      EVAR = (beta**-1) * (np.log(S/(1-alpha)))\n",
        "\n",
        "    x2[batch].append(EVAR)\n",
        "    # x = np.random.normal(0,1,size = 1000)\n",
        "    # avg = 0\n",
        "    # for X in x:\n",
        "    #   avg = avg + np.exp(-beta * X)\n",
        "    # print(\"avg\",avg/1000)\n",
        "\n",
        "    print(\"EVAR SA\",EVAR, beta)\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import seaborn as sns\n",
        "import matplotlib.pyplot as plt"
      ],
      "metadata": {
        "id": "P_bFkjPhzQBS"
      },
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Example dictionary with keys 0 to 4, each containing a sequence of real numbers\n",
        "# data = {\n",
        "#     0: [1.2, 2.3, 3.4, 4.5, 5.6],\n",
        "#     1: [2.1, 3.2, 4.3, 5.4, 6.5],\n",
        "#     2: [3.0, 4.1, 5.2, 6.3, 7.4],\n",
        "#     3: [4.1, 5.2, 6.3, 7.4, 8.5],\n",
        "#     4: [5.2, 6.3, 7.4, 8.5, 9.6]\n",
        "# }\n",
        "data = x1\n",
        "# Calculate average and standard deviation\n",
        "averages = {}\n",
        "std_devs = {}\n",
        "\n",
        "for key, value in data.items():\n",
        "    averages[key] = np.mean(value)  # Calculate average\n",
        "    std_devs[key] = np.std(value)  # Calculate standard deviation\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(8, 3))\n",
        "\n",
        "x = list(data.keys())  # X-axis values (keys)\n",
        "y = list(averages.values())  # Y-axis values (averages)\n",
        "std = list(std_devs.values())  # Standard deviations\n",
        "\n",
        "plt.plot(x, y, label='Average')\n",
        "plt.fill_between(x, np.subtract(y, std), np.add(y, std), alpha=0.3, label='Standard Deviation Band')\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "data = x2\n",
        "# Calculate average and standard deviation\n",
        "averages = {}\n",
        "std_devs = {}\n",
        "\n",
        "for key, value in data.items():\n",
        "    averages[key] = np.mean(value)  # Calculate average\n",
        "    std_devs[key] = np.std(value)  # Calculate standard deviation\n",
        "\n",
        "\n",
        "x = list(data.keys())  # X-axis values (keys)\n",
        "y = list(averages.values())  # Y-axis values (averages)\n",
        "std = list(std_devs.values())  # Standard deviations\n",
        "\n",
        "plt.plot(x, y, label='Average')\n",
        "plt.fill_between(x, np.subtract(y, std), np.add(y, std), alpha=0.3, label='Standard Deviation Band')\n",
        "\n",
        "plt.title('Two Time Scale EVaR SA')\n",
        "plt.ylim(-15,-5)\n",
        "plt.xlabel('Batch')\n",
        "plt.ylabel('EVaR')\n",
        "plt.legend()\n",
        "plt.grid(True)\n",
        "\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 333
        },
        "id": "TNetxtQ04Qoi",
        "outputId": "30f2748e-c44c-4b9a-b09b-4c6823f6917f"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 800x300 with 1 Axes>"
            ],
            "image/png": "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OnVi3759Lo8jR45w3333AdClSxeaNWvG559/TnZ2NitXriyx2wK4f0wrypWcm5CQEOLi4oiLi6NHjx4sWLCA33//naVLlwLun6+r/bmoLDKObk2Xcgwi23m6FkIIIaqxNm3auAwnZjQasdlsLmW2bdvGqFGjGDp0KKAFP8fX+u5q3bo1n3zyCTk5Oc6W1x9//LHIfrp378748eOd8xwtple77fJYtGgRKSkpzm4H1113HUuXLqV+/foEBweXuF5CQgKLFy+mcePG6HQ6Bg4cWGJZd46pj49PkXNRWOvWrdm2bRsjR4502XabNm3Kepvl5miVdXQruNLzVVCrVq2wWq3s3r2bLl26AHD48OEqGSdYWnRrurQzYMnxdC2EEEJUA5cuXaJXr158+umnHDhwgGPHjvHll1/y2muvcfvttzvLxcTEsGHDBs6dO+e8uUHz5s1ZsWKF82vs++67r9wtcvfddx+KojBmzBh+/fVXVq9eXaQfafPmzfn555/57rvvOHLkCNOnT3deEHe12y5JVlYW586d46+//uLHH3/k6aef5pFHHmHcuHHccsstgBZgw8PDuf3229myZQvHjh1j06ZNPPbYY/z111/ObSUkJLBnzx5mzpzJnXfeiclkKnG/7hzTmJgYNm/ezOnTp7l48WKx25k6dSqJiYm8//77/P7777z55pusWLHiqi7GK3xszp07x/79+xk3bhy+vr707dvX+R6u5HwV1LJlS/r378/YsWP56aef2L17Nw899BB+fn5XXf+ySItuTafatbul1Wvp6ZoIIUSt4M6dyux2O2lpaQQHB6OrwjtZBgYG0rVrV/7v//6Po0ePYrFYiIqKYsyYMTz77LPOcm+88QaTJ09m3rx5NGrUiOPHj/Pmm2/ywAMP0L17d8LDw3n66adJS0sr9/7/85//8Mgjj9CxY0fatGnDnDlzXC7WGjt2LHv37uXuu+9GURTuvfdexo8fz5o1a6562yWZN28e8+bNw8fHh7p169KpUyeWLl3qbGkFbZitzZs38/TTT3PHHXeQnp5Oo0aN6N27t0sLb1xcHNdffz07d+4scqOHwtw5pi+99BJjx46lWbNm5Obmoqpqke0MGTKEt99+m7lz5/L4448TGxvLwoULiY+PL/O9l8VxbEC7oKx9+/asXr3aOaTblZ6vwhYuXMhDDz1Ez549iYiI4JVX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t7d5JWw2G7///juxsbGAFko7derEvn37XB5HjhzhvvvuA6BLly40a9aMzz//nOzsbFauXFlitwVw/5hWlCs5NyEhIcTFxREXF0ePHj1YsGABv//+O0uXLgXcP19X+3NRWWQcXZEv9SSENQW9/FgIIYQ3adOmjctwYkajEZvN5lJm27ZtjBo1iqFDhwJa8HN8re+u1q1b88knn5CTk+Nsef3xxx+L7Kd79+6MHz/eOc/RYnq12y6PRYsWkZKS4ux2cN1117F06VLq169PcHBwieslJCSwePFiGjdujE6nY+DAgSWWdeeY+vj4FDkXhbVu3Zpt27YxcuRIl223adOmrLdZbo5WWUe3gis9XwW1atUKq9XK7t276dKlCwCHDx+uknGCpUVX5LNb4PIpT9dCCCHEFbp06RK9evXi008/5cCBAxw7dowvv/yS1157jdtvv91ZLiYmhg0bNnDu3DnnzQ2aN2/OihUrnF9j33fffeVukbvvvvtQFIUxY8bw66+/snr16iL9SJs3b87PP//Md999x5EjR5g+fbrzgrir3XZJsrKyOHfuHH/99Rc//vgjTz/9NI888gjjxo3jlltuAbQAGx4ezu23386WLVs4duwYmzZt4rHHHuOvv/5ybishIYE9e/Ywc+ZM7rzzTkwmU4n7deeYxsTEsHnzZk6fPs3FixeL3c7UqVNJTEzk/fff5/fff+fNN99kxYoVV3UxXuFjc+7cOfbv38+4cePw9fWlb9++zvdwJeeroJYtW9K/f3/Gjh3LTz/9xO7du3nooYfw8/O76vqXRZruhKuU4xAaffV38hFCCG/lzp3K7HasaWkQHFylf08DAwPp2rUr//d//8fRo0exWCxERUUxZswYnn32WWe5N954g8mTJzNv3jwaNWrE8ePHefPNN3nggQfo3r074eHhPP3006SlpZV7///5z3945JFH6NixI23atGHOnDkuF2uNHTuWvXv3cvfdd6MoCvfeey/jx49nzZrS7zjnzrZLMm/ePObNm4ePjw9169alU6dOLF261NnSCtowW5s3b+bpp5/mjjvuID09nUaNGtG7d2+XFt64uDiuv/56du7cWeRGD4W5c0xfeuklxo4dS7NmzcjNzUVV1SLbGTJkCG+//TZz587l8ccfJzY2loULFxIfH1/mey+L49iAdkFZ+/btWb16tXNItys9X4Ut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\n"
          },
          "metadata": {}
        }
      ]
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "gpuType": "T4",
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}