{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "RcXB1L_GfRhW"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import random\n",
        "import scipy.integrate as integrate\n",
        "import scipy.special as special\n",
        "from scipy.optimize import minimize_scalar\n",
        "from scipy.optimize import minimize\n",
        "from scipy.stats import norm\n",
        "from scipy.stats import uniform\n",
        "import matplotlib.pyplot as plt\n",
        "import warnings\n",
        "from google.colab import files\n",
        "import seaborn as sns"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "gwOjikyG8Eau"
      },
      "outputs": [],
      "source": [
        "class stoch_market:\n",
        "  def __init__(self, util1, util2, wage, cost):\n",
        "    self.a = util1\n",
        "    self.b = util2\n",
        "    self.w = wage\n",
        "    self.c = cost\n",
        "    self.Y = uniform.rvs(size = 1000)\n",
        "\n",
        "  def conditional_pdf(self,x, p):\n",
        "    return (p+1)*x**p\n",
        "  def firm_utility(self, theta):\n",
        "    def integrand(x,y):\n",
        "      return 1*self.conditional_pdf(x,y)*(self.a*y - 1)\n",
        "    return -1*integrate.dblquad(integrand, 0, 1, theta, 1)[0]\n",
        "\n",
        "  def new_response(self,y, theta):\n",
        "    def worker_utility(skill, param, y0):\n",
        "      return -1*(self.w*(1-param**(skill+1)) - (self.c/2)*np.square(skill-y0))\n",
        "    return min(minimize_scalar(worker_utility, args = (theta, y)).x,1)\n",
        "  def performative_firm_utility(self, theta, theta_dep):\n",
        "    def integrand(x,y):\n",
        "      y_old = np.copy(y)\n",
        "      y = self.new_response(y_old, theta_dep)\n",
        "      return 1*self.conditional_pdf(x,y)*(self.a*y - self.b)\n",
        "    return -1*integrate.dblquad(integrand, 0, 1, theta, 1)[0]\n",
        "  def optimal_firm_utility(self,theta):\n",
        "      def integrand(x,y):\n",
        "        y_old = np.copy(y)\n",
        "        y = self.new_response(y_old, theta)\n",
        "        return 1*self.conditional_pdf(x,y)*(self.a*y - self.b)\n",
        "      return -1*integrate.dblquad(integrand, 0, 1, theta, 1)[0]\n",
        "  def sample_firm_utility(self,theta, y):\n",
        "    y_new = self.new_response(y, theta)\n",
        "    return -1*integrate.quad(self.conditional_pdf, theta, 1, args = (y_new))[0]*(self.a*y_new -1)\n",
        "  def perfSGD(self, theta0, T, n):\n",
        "    def partial_2(x,y):\n",
        "      return (y+1)*np.log(x)*x**y + x**y\n",
        "    def partial_2_square(x,y):\n",
        "      return np.log(x)*((y+1)*(x**y)*np.log(x) + 2*x**y)\n",
        "    theta = theta0\n",
        "    thetaN = theta0\n",
        "    deployedP = []\n",
        "    resultsP = []\n",
        "    deployedN = []\n",
        "    resultsN = []\n",
        "    Y = self.Y\n",
        "    for t in range(T):\n",
        "      if t % 1==0:\n",
        "        sumP = 0\n",
        "        sumN = 0\n",
        "        for resp in Y:\n",
        "          sumP += self.sample_firm_utility(theta, resp)\n",
        "          sumN += self.sample_firm_utility(thetaN, resp)\n",
        "        resultsP.append(-sumP/len(Y))\n",
        "        resultsN.append(-sumN/len(Y))\n",
        "      deployedP.append(theta)\n",
        "      deployedN.append(thetaN)\n",
        "      N = np.random.randint(low = 0, high = 100, size = n)\n",
        "      for i in N:\n",
        "        y = Y[i]\n",
        "        #print(y)\n",
        "        y_new = self.new_response(y, theta)\n",
        "        y_new_N = self.new_response(y, thetaN)\n",
        "        grad1P = -self.conditional_pdf(theta, y_new)*(self.a*y_new - self.b)\n",
        "        grad1N = -self.conditional_pdf(thetaN, y_new)*(self.a*y_new_N - self.b)\n",
        "        strat_grad = self.w*(partial_2(theta, y_new))/(self.w*integrate.quad(partial_2_square, theta, 1, args = (y_new))[0] - self.c)\n",
        "        grad2 = (strat_grad*(integrate.quad(partial_2, theta, 1, args = (y_new))[0]*(self.a*y_new - self.b))\n",
        "          + strat_grad*integrate.quad(self.conditional_pdf, theta, 1, args = (y_new))[0]*self.a)\n",
        "        #print(grad1P+grad2)\n",
        "        #print((self.sample_firm_utility(theta + 0.00001,y)-self.sample_firm_utility(theta, y))/0.00001)\n",
        "        #print(strat_grad)\n",
        "        #print((self.new_response(y, theta+0.00001)-self.new_response(y,theta))/0.00001)\n",
        "        theta = theta + (0.5)/(t+1)*(grad1P+ grad2)*(1/n)\n",
        "        thetaN = thetaN + (0.5)/(t+1)*(grad1N)*(1/n)\n",
        "        theta = max(min(theta,1), 0.001)\n",
        "        thetaN = max(min(thetaN, 1),0.001)\n",
        "    return deployedP, deployedN, resultsP, resultsN"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "P_QHL4Z3ylbi"
      },
      "outputs": [],
      "source": [
        "test = stoch_market(4,1,1,4)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "OU29C8Pp0RFk"
      },
      "outputs": [],
      "source": [
        "runsperf = []\n",
        "runsR = []\n",
        "runsperf2 = []\n",
        "runsR2 = []\n",
        "n = 1\n",
        "for i in range(10):\n",
        "  res = test.perfSGD(0.1,20, 100)\n",
        "  runsperf2.append(res[0])\n",
        "  runsR2.append(res[1])\n",
        "  runsperf.append(res[2])\n",
        "  runsR.append(res[3])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "dUTmIM8p19Tc"
      },
      "outputs": [],
      "source": [
        "perfavg = np.array([np.mean(x) for x in zip(*runsperf)])\n",
        "Ravg = np.array([np.mean(x) for x in zip(*runsR)])\n",
        "perfSTD = np.array([np.std(x) for x in zip(*runsperf)])\n",
        "RSTD = np.array([np.std(x) for x in zip(*runsR)])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "VuMNrCk93XYo"
      },
      "outputs": [],
      "source": [
        "z = 1.65\n",
        "lbP = perfavg - z*perfSTD\n",
        "ubP = perfavg + z*perfSTD\n",
        "lbR = Ravg - z*RSTD\n",
        "ubR = Ravg + z*RSTD"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 251
        },
        "id": "aekzJMb54ifJ",
        "outputId": "1f5fb498-45ac-4d96-d78d-f988d8dc9b0c"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_71bc810b-3de8-4fef-89eb-35c910bd772b\", \"sec5test1Usm.png\", 17045)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x250 with 1 Axes>"
            ],
            "image/png": "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mvLy8nb/q+bmZlavXj0g/lfbt2+nvr4+7/5XahjVDboqD5xP3HHHHUyaNInKykp27tzJPffcg6ZpTJ8+vb+7lhahUKidFbZ582bWrl1LIBCgsrKSiy++mPvvv58DDjiA6upq7r77bioqKlKzU7nEvs4lEAhw7733MnXqVMrKyti0aRPz58/ngAMO4MQTT+zHXncfVcqlmzz++OMsXLgwVR74l7/8JWPHju3vbnWba665hvfee4/6+npKSkr4xje+wTXXXMOwYcP6u2tp8c4773DxxRd32P/d736X22+/HSklCxYs4JlnnqGxsZFvfOMb3HLLLRx00EH90Nt9s69zufXWW7nyyiv59NNPaWpqoqKighNOOIGf/vSneTckVGKjUCiygvLZKBSKrKDERqFQZAUlNgqFIisosVEoFFlBiY1CocgKSmwUCkVWUGKjUCiyghIbhUKRFZTYKBSdkEybqug9VGyUos947rnnuOGGG1Lbuq5TWlrKCSecwDXXXMOgQYP6sXeKbKPERtHnXH311VRXVxOLxVi1ahWLFy/mgw8+4Pnnn8ftdvd39xRZQomNos856aSTGD16NAAzZswgGAzy4IMP8vLLLzNt2rR+7p0iWyifjSLrHHPMMQBs2rQptW/FihVccMEFHHXUURxzzDH8+Mc/Zv369e1ed/311zN58uQOx+vMvzJixAhuu+02li9fzvTp0znyyCM544wz+L//+78Or3///fc599xzGT16NFOmTOHPf/5zb5ymYg+UZaPIOlu2bAHs7IAAb731Fj/60Y+orq7mqquuIhKJ8Pjjj3P++efz3HPPUV1dndH7fPDBB/zzn//kggsuwO/389hjj3H11Vfz6quvEgwGAfj3v//NrFmzKCkpYfbs2RiGwT333NMhf7Gi5yixUfQ5zc3N1NbWEovFWL16Nffeey8ul4tJkyYBdpmVQCDA008/TXFxMQBTpkzhu9/9Lvfccw933HFHRu+7fv16li1blsrRc+yxx/Kd73yHv//971x00UUALFiwACklTzzxBJWVlQBMnTqVM888s4dnrdgTJTaKPueSSy5pt11VVcX8+fMZPHgwO3fuZO3atVx22WUpoQE7CfuECRN4/fXXM37fCRMmtEsGNnLkSAoKClLDN9M0efPNN5kyZUpKaAAOOeQQJk6c2KP3VnRE+WwUfc7NN9/Mww8/zIIFCzj55JOpq6vD5XIBpGpVdZZB75BDDqGuro6WlpaM3nfIkCEd9gUCARobGwGora0lEolwwAEHdGiXixn98h1l2Sj6nDFjxqRmo6ZMmcIFF1zAtddey4svvtit4wghOt1vmman+/dWU0klp+wflGWjyCq6rvPzn/+cnTt3tvOTfPnllx3abtiwgWAwiM/nA2yHctIqaUumlTxLSkrweDydlkTprD+KnqHERpF1jj322FR1ikAgwOGHH86SJUvaCcnnn3/Ov/71r3bF9IYNG0ZTUxOfffZZat/OnTt56aWXMuqHrutMnDiR5cuXtxOs9evX8+abb2Z0TMXeUWKj6BdmzZrFrl27eO6557juuuuor6/ne9/7HgsXLuS+++7jhz/8IYWFhVx11VWp10ybNg2fz8dVV13FI488wh//+EdmzpzZI//K7NmzAbjwwgt54IEHuP/++7n44osZPnx4j89R0R4lNop+4bTTTmPYsGEsWrSIY489loceeoji4mIWLFjAokWLGDt2LE899RRDhw5NvSYYDHLvvffi9XqZP38+ixcv5uc//3lqCj0TRo4cycKFCwkGgyxYsIBnn32W2bNnc+qpp/bGaSraoEq5KBSKrKAsG4VCkRWU2CgUiqygxEahUGQFJTYKhSIrKLFRKBRZQYmNQqHICkpsFApFVlBio1AosoISG4VCkRWU2CgUiqygxEahUGQFJTYKhSIrKLFRKBRZ4f8HnqNfCGS3oSYAAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "sns.set_theme()\n",
        "plt.figure(figsize=(3,2.5))\n",
        "plt.plot(perfavg, label = \"Alg 1\", color = 'darkorange')\n",
        "plt.fill_between(range(len(lbP)), lbP, ubP, alpha = 0.2, color = 'darkorange')\n",
        "plt.plot(Ravg, label = \"RSGD\", color = 'royalblue')\n",
        "plt.fill_between(range(len(lbR)), lbR, ubR, alpha = 0.2, color = 'royalblue')\n",
        "plt.legend(loc = 'lower right', prop={'size': 9.5})\n",
        "plt.xlabel(\"Round\", fontsize = 12)\n",
        "plt.ylabel(\"Firm Utility\", fontsize = 12)\n",
        "plt.xticks(fontsize = 10)\n",
        "plt.yticks(fontsize = 10)\n",
        "plt.xlim((0, 19))\n",
        "#plt.xticks(np.arange(0, len(runsperf[0]), 2.0))\n",
        "plt.tight_layout()\n",
        "#plt.savefig(\"sec5test1Usm.png\")\n",
        "#files.download(\"sec5test1Usm.png\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "zaWNCvJC7dik"
      },
      "outputs": [],
      "source": [
        "perfavg2 = np.array([np.mean(x) for x in zip(*runsperf2)])\n",
        "Ravg2 = np.array([np.mean(x) for x in zip(*runsR2)])\n",
        "perfSTD2 = np.array([np.std(x) for x in zip(*runsperf2)])\n",
        "RSTD2 = np.array([np.std(x) for x in zip(*runsR2)])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "i_shw0-GeAUW"
      },
      "outputs": [],
      "source": [
        "z = 1.65\n",
        "lbP = perfavg2 - z*perfSTD2\n",
        "ubP = perfavg2 + z*perfSTD2\n",
        "lbR = Ravg2 - z*RSTD2\n",
        "ubR = Ravg2 + z*RSTD2"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 251
        },
        "id": "TUZp9Y-keKjw",
        "outputId": "fa01bd68-7b5e-405c-b074-52677731016b"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_f0e1c4dc-825d-4666-95a5-7d6da7065193\", \"sec5test1Psm.png\", 20145)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x250 with 1 Axes>"
            ],
            "image/png": "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GWecwbp16wgGgwDMnDmTDz/8kOOOO44TTjiBDRs2MGPGjBY3rj2JCU4dh3FJica332q89po0DK+5JlhvhikclmKTmysXWWYltoWVAti48VPOO29iq9X/s59N4t1332m1+hX1SWhINX36dKZPnx57ftppp7Fy5coulYDLqIrMUHkGgO4iHIbduzWee86OZWmcdFKYo4+OH18Hg9ICKigQDB5sNWuTu87ORx99wGOPPcK3336NrusMHz6SGTOuZfDgpqUwKSraw5Qp5/Lqq2+TFkkmNHLkMaxevaY1m90on3yygeuum4nb7QY00tPTOfPMiVx55cykTA+3Nj/72SSuu24uP/7xqe3dlDiaJTiBQIB169axa9cusrKyGDt2LN27dwe6XgIuoypi4aQOA02u2H73XYPPPpPxNlddFYwr7/NBSYnOgAEWgwZZTZry7iq8//6/WbjwNmbPnsOf/rSYcNjkX/96jlmzruL++x9myJCj2ruJCZGamsprr70DwJYt33H99deSn9+Dc889r1n1hMPh2ORKZ6G12tzkGktKSvj5z3/Orl27YkF+brebBx98kDFjxiS9Ye2KsNADewAIpxUCsGuXxlNPSRU577wQvXrF572prNQ48kiTAQOaFsjXVRBCsHjxvVx88WVxF+Ill1zBrl07eeCBv/DAA0sBOPnkUVx33VxWr/4HZWWlHH/8idx0029JTU3lqqsuA+D88+UQ6je/uZXc3G7ceuuNsYt+1qwZHHXUML7++is2bfqCAQMG8cc/3sPLL7/Ac889i93u4Prrf8PYsacB8OGH/8fDDz/Irl3f43K5OOWU05g9+3qczuZv7DVw4CBGjjyaLVu+Ze/evdx11+/57rtvCIdNRowoZM6cefTo0ROAP/5xAbqu4/V6+eCD9cyYcQ2FhUdz332L2L59G4ahc+yxxzNnzk1kZGQ22re77voTq1c/x+rV/6jXNyEE//znM6xe/Q9KS0sYNOhIbrzxFvr1689tt81j3769LFjwWwxDZ8KEn/Cb39xKWVkpS5b8mU8++QjQGDfuDK65ZjYOh4NPPtnArbfeyNVXz2LlysfIzs5h2bInmv05HY4m24Z//etf2b17N5dffjkPP/wwt956K06nk/nz5ye9Ue2OJa0Xy56N5cynqgqeespOUZFOZqbg4otDsaJlZTJp+VFHWQwa1DZiYwUC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414XQrB48WJOPvlkCgsLufzyy9m+fXv7NLYZHK5fN998c73vcPr06e3U2pajBCdCc3f97CwcccQRvP/++7Hb3//+9/ZuUkJ4vV4GDx7M7bff3uDrjzzyCCtXrmTBggU8++yzuN1upk+fTiAQaOOWNo/D9QvglFNOifsO//znP7dhC5NLh0ox2p7U3fUTYOHChbzzzjs899xzzJgxo51blziGYSR1G+T2YuzYsYwdO7bB14QQPPHEE1xzzTWxBPz33HMPY8aM4c033+Tss89uy6Y2i0P1K4rD4egS3yEoCwfoaLt+JpcdO3Zw8sknc/rppzN37lz27NnT3k1KOrt27aK4uDju+0tLS2PkyJGd/vsD+PDDDznxxBM588wzuf322ykrK2vvJiWMsnDoaLt+Jo/CwkLuvPNO+vfvT3FxMQ8++CAXX3wxL730Eqmpqe3dvKRRXCz37Gro+ztw4EB7NClpnHLKKZxxxhkUFBSwc+dO/vznP3PVVVfxzDPPYHTCPaiV4HRh6prqQ4YMYeTIkZx22mm8+uqrTJkypR1bpmgqdYeDUafx+PHjY1ZPZ0MNqehYu362Junp6fTr14/vv/++vZuSVKL+ja7+/QH07t2brKwsduzY0d5NSQglOMTv+hkluuvnMccc044tSy41NTXs3LmzyzggoxQUFNCtW7e476+6upqNGzd2qe8PYO/evZSXl3fa71ANqSIcbtfPzsjdd9/NaaedRs+ePdm/fz/3338/uq5zzjnntHfTmk1NTU2cZbZr1y42b95MRkYGPXv25NJLL+Vvf/sbffv2paCggMWLF9O9e/fYrFVH5VD9ysjI4IEHHuDMM88kNzeXnTt3smjRIvr27cspp5zSjq1OHLVNTB2efPJJli9fHtv187bbbmPkyJHt3ayEueGGG/joo48oLy8nOzubY489lhtuuIE+ffq0d9OazQcffMCll15a7/h5553HXXfdhRCCJUuW8Oyzz1JZWcmxxx7L7bffTv/+/duhtU3nUP1asGABv/rVr/jyyy+pqqqie/funHTSSfz617/utENFJTgKhaLNUD4chULRZijBUSgUbYYSHIVC0WYowVEoFG2GEhyFQtFmKMFRKBRthhIchULRZijBUSgUbYYSHIWC2nSsitZFraVSJI3nn3+eW265JfbcMAxycnI46aSTuOGGG8jLy2vH1ik6AkpwFEnnuuuuo6CggGAwyGeffcbq1av5+OOPefnll3E6ne3dPEU7ogRHkXR+/OMfM2LECACmTJlCVlYWjzzyCOvWrWPixInt3DpFe6J8OIpWZ9SoUQDs3Lkzdmz9+vVcdNFFHH300YwaNYprrrmGLVu2xJ138803M27cuHr1NeRvGTx4ML///e958803Oeeccxg+fDhnn3027777br3zN2zYwAUXXMCIESMYP348Tz/9dDK6qWgCysJRtDq7d+8GZMZBgP/+979cddVVFBQUMGvWLPx+P08++SS/+MUveP755ykoKEjofT7++GNef/11LrroIlJSUli5ciXXXXcdb7/9NllZWQB8/fXXTJ8+nezsbGbPnk04HOb++++vlw9Z0ToowVEknerqakpLSwkGg2zcuJEHHngAh8PBaaedBsgtXDIyMnjmmWfIzMwEYPz48Zx33nncf//93H333Qm975YtW1izZk0s38/o0aOZPHkyr7zyCtOmTQNgyZIlCCFYtWoVPXv2BODMM89k0qRJLey1oikowVEkncsvvzzuea9evVi0aBH5+fns37+fzZs3c+WVV8bEBmSS9zFjxvDvf/874fcdM2ZMXHKxIUOGkJqaGhvKmabJ+++/z/jx42NiAzBw4EBOPvnkFr23omkoH44i6cyfP5/HHnuMJUuWMHbsWMrKynA4HACxfbEaysQ3cOBAysrK8Hq9Cb1vjx496h3LyMigsrISgNLSUvx+P3379q1XrqNnBuwqKAtHkXQKCwtjs1Tjx4/noosuYu7cubz22mvNqkfTtAaPm6bZ4PHG9mlSSS07DsrCUbQqhmEwZ84c9u/fH+c32bZtW72yW7duJSsrC4/HA0gnc9Q6qUuiu4dmZ2fjcrka3GKlofYoko8SHEWrM3r06NhOGBkZGQwdOpQXXnghTky++eYb/vOf/8Rt3tenTx+qqqr46quvYsf279/PG2+8kVA7DMPg5JNP5s0334wTrS1btvD+++8nVKeieSjBUbQJ06dP58CBAzz//PPcdNNNlJeXM3XqVJYvX86DDz7IZZddRlpaGrNmzYqdM3HiRDweD7NmzWLFihU8/PDDXHjhhS3yt8yePRuAiy++mKVLl/K3v/2NSy+9lEGDBrW4j4rDowRH0SZMmDCBPn368OijjzJ69GiWLVtGZmYmS5Ys4dFHH2XkyJE89dRT9O7dO3ZOVlYWDzzwAG63m0WLFrF69WrmzJkTm15PhCFDhrB8+XKysrJYsmQJzz33HLNnz+aMM85IRjcVh0FtE6NQKNoMZeEoFIo2QwmOQqFoM5TgKBSKNkMJjkKhaDOU4CgUijZDCY5CoWgzlOAoFIo2QwmOQqFoM5TgKBSKNkMJjkKhaDOU4CgUijZDCY5CoWgzlOAoFIo24/8DjsVDmjHbfpwAAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "sns.set_theme()\n",
        "plt.figure(figsize=(3,2.5))\n",
        "plt.plot(perfavg2, color = 'orange')\n",
        "plt.fill_between(range(len(lbP)), lbP, ubP, alpha = 0.2, color = 'orange')\n",
        "plt.plot(Ravg2, color = 'blue')\n",
        "plt.fill_between(range(len(lbR)), lbR, ubR, alpha = 0.2, color = 'blue')\n",
        "plt.xlabel(\"Round\", fontsize = 12)\n",
        "plt.ylabel(\"Parameter Value\", fontsize = 12)\n",
        "plt.xlim((0, 19))\n",
        "plt.xticks(fontsize = 10)\n",
        "plt.yticks(fontsize = 10)\n",
        "plt.hlines(y=0.415, color='r', xmin = 0, xmax = 19, linestyles='dashed', label = 'Optimal Parameter')\n",
        "plt.legend(loc = 'lower right', prop={'size': 9})\n",
        "plt.tight_layout()\n",
        "plt.savefig(\"sec5test1Psm.png\")\n",
        "files.download(\"sec5test1Psm.png\")"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}