{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "4cf1faa1",
   "metadata": {},
   "source": [
    "The goal of this notebook is to generate data that highlight the value of correlated uncertainty estimates to sequential learning. The Friedman-Grosse function is used to generate 128 output values, `y`, given inputs `x` uniformly generated on [0, 1]^12. The data are then split into two equally-sized chunks to generate a second output, `z`. These two chunks are identified by a \"phase\" column. For the first chunk, labeled \"A\" phase, `z` has a strong positive correlation with `y`. For the second chunk, labeled \"B\" phase, `z` is anti-correlated with `y`. The goal of sequential learning will be to find a point that simultaneously has a large value of both `y` and `z`. In theory, the model will be able to recognize the anti-correlation for points in the B phase, and these points will not be considered good candidates for meeting both objectives."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8d4ac2cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.linear_model import LinearRegression\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2f5271ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "def FriedmanGrosse(X):\n",
    "    \"\"\"The Friedman-Grosse function. Dimensions past 5 are ignored.\"\"\"\n",
    "    if len(X.shape) == 1:\n",
    "        X = np.reshape(X, (1, -1))\n",
    "    return 10 * np.sin(np.pi * X[:,0] * X[:,1]) + \\\n",
    "        20 * (X[:,2] - 0.5)**2 + \\\n",
    "        10 * X[:,3] + \\\n",
    "        5 * X[:,4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2aaa11a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generateLinearlyCorrelatedData(x, rho, rng = np.random.default_rng()):\n",
    "    \"\"\"Generate data that are linearly correlated with input data, x.\n",
    "    rho is the desired correlation coefficient.\n",
    "    rng is a random number generator, for reproducibility.\n",
    "    \"\"\"\n",
    "    assert len(x.shape) == 1, \"X must be 1-dimensional\"\n",
    "    y = rng.normal(size = x.size, )\n",
    "    X = x.reshape(-1, 1)\n",
    "    reg = LinearRegression().fit(X, y)\n",
    "    y_pred = reg.predict(X)\n",
    "    residuals = y - y_pred\n",
    "    return rho * np.std(residuals) * x + math.sqrt(1 - rho ** 2) * np.std(x) * residuals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "5f5eb2d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_cols = 12\n",
    "num_points = 128"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c838bdd5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Generate inputs X, output Y from Friedman-Grosse, and output Z as sqrt(30^2 - y^2)\n",
    "seed = 6531901145\n",
    "rng = np.random.default_rng(seed)\n",
    "X = rng.uniform(low=0.0, high=1.0, size=(num_points, num_cols))\n",
    "num_A = int(num_points / 2)\n",
    "# Split into two chunks of data.\n",
    "X_A = X[:num_A, :]\n",
    "X_B = X[num_A:, :]\n",
    "Y_A = FriedmanGrosse(X_A)\n",
    "Y_B = FriedmanGrosse(X_B)\n",
    "Z_A = generateLinearlyCorrelatedData(Y_A, 0.98, rng)\n",
    "Z_B = np.sqrt(30**2 - Y_B**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "df99075e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the data to ensure it has the desired properties\n",
    "plt.scatter(Y_A, Z_A, label=\"A data\")\n",
    "plt.scatter(Y_B, Z_B, label=\"B data\")\n",
    "plt.xlabel(\"first output (y)\")\n",
    "plt.ylabel(\"second output (z)\")\n",
    "plt.title(\"Two regions of data generated with Friedman-Grosse function\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8102bdbe",
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_df(X, Y, Z, phase):\n",
    "    \"\"\"Combine X, Y, and Z into a single dataframe.\"\"\"\n",
    "    num_points, num_x_cols = X.shape\n",
    "    assert len(Y) == num_points\n",
    "    assert len(Z) == num_points\n",
    "    df_X = pd.DataFrame(data=X, columns=[f\"x_{i}\" for i in range(num_x_cols)])\n",
    "    df_other = pd.DataFrame(data={\"phase\": [phase]*num_points, \"y\": Y, \"z\": Z})\n",
    "    return pd.concat([df_X, df_other], axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "da18c53d",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_A = make_df(X_A, Y_A, Z_A, phase=\"A\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d7b8e8be",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_B = make_df(X_B, Y_B, Z_B, phase=\"B\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "67193415",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.concat([df_A, df_B], axis=0, ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "45e5b990",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>x_0</th>\n",
       "      <th>x_1</th>\n",
       "      <th>x_2</th>\n",
       "      <th>x_3</th>\n",
       "      <th>x_4</th>\n",
       "      <th>x_5</th>\n",
       "      <th>x_6</th>\n",
       "      <th>x_7</th>\n",
       "      <th>x_8</th>\n",
       "      <th>x_9</th>\n",
       "      <th>x_10</th>\n",
       "      <th>x_11</th>\n",
       "      <th>phase</th>\n",
       "      <th>y</th>\n",
       "      <th>z</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.929358</td>\n",
       "      <td>0.653710</td>\n",
       "      <td>0.797578</td>\n",
       "      <td>0.780395</td>\n",
       "      <td>0.730314</td>\n",
       "      <td>0.205159</td>\n",
       "      <td>0.495299</td>\n",
       "      <td>0.383110</td>\n",
       "      <td>0.851800</td>\n",
       "      <td>0.147143</td>\n",
       "      <td>0.343926</td>\n",
       "      <td>0.203845</td>\n",
       "      <td>A</td>\n",
       "      <td>22.661374</td>\n",
       "      <td>21.948502</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>0.886872</td>\n",
       "      <td>0.539663</td>\n",
       "      <td>0.603401</td>\n",
       "      <td>0.838245</td>\n",
       "      <td>0.790461</td>\n",
       "      <td>0.986462</td>\n",
       "      <td>0.954338</td>\n",
       "      <td>0.198913</td>\n",
       "      <td>0.805813</td>\n",
       "      <td>0.954274</td>\n",
       "      <td>0.105736</td>\n",
       "      <td>0.197874</td>\n",
       "      <td>A</td>\n",
       "      <td>22.526030</td>\n",
       "      <td>21.564773</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>0.715608</td>\n",
       "      <td>0.952157</td>\n",
       "      <td>0.839638</td>\n",
       "      <td>0.856736</td>\n",
       "      <td>0.691391</td>\n",
       "      <td>0.458034</td>\n",
       "      <td>0.724146</td>\n",
       "      <td>0.559770</td>\n",
       "      <td>0.540253</td>\n",
       "      <td>0.565460</td>\n",
       "      <td>0.376978</td>\n",
       "      <td>0.419407</td>\n",
       "      <td>A</td>\n",
       "      <td>22.751512</td>\n",
       "      <td>22.854839</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>61</th>\n",
       "      <td>0.876506</td>\n",
       "      <td>0.692159</td>\n",
       "      <td>0.876006</td>\n",
       "      <td>0.798372</td>\n",
       "      <td>0.529613</td>\n",
       "      <td>0.457647</td>\n",
       "      <td>0.577009</td>\n",
       "      <td>0.639616</td>\n",
       "      <td>0.898312</td>\n",
       "      <td>0.663450</td>\n",
       "      <td>0.707975</td>\n",
       "      <td>0.069513</td>\n",
       "      <td>A</td>\n",
       "      <td>22.903000</td>\n",
       "      <td>23.086941</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>65</th>\n",
       "      <td>0.649831</td>\n",
       "      <td>0.358901</td>\n",
       "      <td>0.986803</td>\n",
       "      <td>0.889413</td>\n",
       "      <td>0.615011</td>\n",
       "      <td>0.479688</td>\n",
       "      <td>0.638708</td>\n",
       "      <td>0.022706</td>\n",
       "      <td>0.084101</td>\n",
       "      <td>0.655546</td>\n",
       "      <td>0.300311</td>\n",
       "      <td>0.445240</td>\n",
       "      <td>B</td>\n",
       "      <td>23.397491</td>\n",
       "      <td>18.776512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>85</th>\n",
       "      <td>0.717748</td>\n",
       "      <td>0.938932</td>\n",
       "      <td>0.021664</td>\n",
       "      <td>0.875379</td>\n",
       "      <td>0.931795</td>\n",
       "      <td>0.892580</td>\n",
       "      <td>0.648662</td>\n",
       "      <td>0.078989</td>\n",
       "      <td>0.371356</td>\n",
       "      <td>0.850696</td>\n",
       "      <td>0.112546</td>\n",
       "      <td>0.833351</td>\n",
       "      <td>B</td>\n",
       "      <td>26.532997</td>\n",
       "      <td>14.000002</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108</th>\n",
       "      <td>0.640371</td>\n",
       "      <td>0.624592</td>\n",
       "      <td>0.032030</td>\n",
       "      <td>0.361062</td>\n",
       "      <td>0.933310</td>\n",
       "      <td>0.137962</td>\n",
       "      <td>0.173491</td>\n",
       "      <td>0.392234</td>\n",
       "      <td>0.944317</td>\n",
       "      <td>0.099711</td>\n",
       "      <td>0.505507</td>\n",
       "      <td>0.589238</td>\n",
       "      <td>B</td>\n",
       "      <td>22.167366</td>\n",
       "      <td>20.214051</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>111</th>\n",
       "      <td>0.694248</td>\n",
       "      <td>0.653660</td>\n",
       "      <td>0.869042</td>\n",
       "      <td>0.637604</td>\n",
       "      <td>0.612329</td>\n",
       "      <td>0.054063</td>\n",
       "      <td>0.346759</td>\n",
       "      <td>0.327805</td>\n",
       "      <td>0.038413</td>\n",
       "      <td>0.849023</td>\n",
       "      <td>0.467037</td>\n",
       "      <td>0.880190</td>\n",
       "      <td>B</td>\n",
       "      <td>22.056380</td>\n",
       "      <td>20.335095</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>126</th>\n",
       "      <td>0.396540</td>\n",
       "      <td>0.799699</td>\n",
       "      <td>0.174039</td>\n",
       "      <td>0.874060</td>\n",
       "      <td>0.932801</td>\n",
       "      <td>0.051566</td>\n",
       "      <td>0.708045</td>\n",
       "      <td>0.322171</td>\n",
       "      <td>0.538629</td>\n",
       "      <td>0.166961</td>\n",
       "      <td>0.823541</td>\n",
       "      <td>0.319087</td>\n",
       "      <td>B</td>\n",
       "      <td>23.923943</td>\n",
       "      <td>18.100966</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          x_0       x_1       x_2       x_3       x_4       x_5       x_6  \\\n",
       "21   0.929358  0.653710  0.797578  0.780395  0.730314  0.205159  0.495299   \n",
       "29   0.886872  0.539663  0.603401  0.838245  0.790461  0.986462  0.954338   \n",
       "31   0.715608  0.952157  0.839638  0.856736  0.691391  0.458034  0.724146   \n",
       "61   0.876506  0.692159  0.876006  0.798372  0.529613  0.457647  0.577009   \n",
       "65   0.649831  0.358901  0.986803  0.889413  0.615011  0.479688  0.638708   \n",
       "85   0.717748  0.938932  0.021664  0.875379  0.931795  0.892580  0.648662   \n",
       "108  0.640371  0.624592  0.032030  0.361062  0.933310  0.137962  0.173491   \n",
       "111  0.694248  0.653660  0.869042  0.637604  0.612329  0.054063  0.346759   \n",
       "126  0.396540  0.799699  0.174039  0.874060  0.932801  0.051566  0.708045   \n",
       "\n",
       "          x_7       x_8       x_9      x_10      x_11 phase          y  \\\n",
       "21   0.383110  0.851800  0.147143  0.343926  0.203845     A  22.661374   \n",
       "29   0.198913  0.805813  0.954274  0.105736  0.197874     A  22.526030   \n",
       "31   0.559770  0.540253  0.565460  0.376978  0.419407     A  22.751512   \n",
       "61   0.639616  0.898312  0.663450  0.707975  0.069513     A  22.903000   \n",
       "65   0.022706  0.084101  0.655546  0.300311  0.445240     B  23.397491   \n",
       "85   0.078989  0.371356  0.850696  0.112546  0.833351     B  26.532997   \n",
       "108  0.392234  0.944317  0.099711  0.505507  0.589238     B  22.167366   \n",
       "111  0.327805  0.038413  0.849023  0.467037  0.880190     B  22.056380   \n",
       "126  0.322171  0.538629  0.166961  0.823541  0.319087     B  23.923943   \n",
       "\n",
       "             z  \n",
       "21   21.948502  \n",
       "29   21.564773  \n",
       "31   22.854839  \n",
       "61   23.086941  \n",
       "65   18.776512  \n",
       "85   14.000002  \n",
       "108  20.214051  \n",
       "111  20.335095  \n",
       "126  18.100966  "
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[df[\"y\"] > 22]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "67273353",
   "metadata": {},
   "source": [
    "Inspecting points for which y > 22 (above), we see that the only ones that there are only two points that also have z > 22, and they are both in the A phase. These points will be the targets."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "786e849c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Write the data to CSV\n",
    "df.to_csv(\"../src/main/resources/friedman_grosse_data.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2a9196b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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S+uxOXDzybBqWTjkqmXhea5AomAjIlK0srbOMrMmM1sCvAb8yd0fBDaPJsXJTI7z4YRtjzezhWa2cMWKFd078J3nQXtb52XtbWF5XHeCjYiU3N57783ee+9d7WQU7cYbb8TMeOaZZ1KtP23aNH7605/mXWfevHk89dRTpUheRZQ1iLj7WncfQ5g+dRcz+2Q3tr3C3ce7+/ghQ7rZa3/V8nTL0wabnlJuR6QuzZo1iz322IPrrruuZPtUEMnB3VcCdxNm+nvVzLYAiP6/VvIDDhyebnnaYNMTyu2IVN28xa1MmL6AUWfcyoTpC5i3uEfTigOwZs0a7r//fq688sq8QeSCCy5g9OjR7LfffixdurRj+a9+9St23nlndtppJw477DDeffddHnjgAW666SamTp3KmDFjeO6553KuV0vK2TprSDR/OWbWAuwHPEOYYjIz692xlGPuiX3PgeaWzsuaW8LyuLTBpieKze3kyr0oRyN15uyzz+bss88u6zHmLW7lzLmP07qyDQdaV7Zx5tzHexxI5s2bxwEHHMA222zDpptuyiOPPNJlnUWLFnHdddexePFi5s6dy8MPP9zx2qRJk3j44Yd59NFH2W677bjyyivZfffdOeSQQ5gxYwZLlixh6623zrleLSlnP5EtgKvNrIkQrOa4+y1m9hdgjpl9gzAf8hElP/KOk8P/O88LuYqBw0MAySzP2PeckCuI3+RzBZueKCa3k8m9ZNK1ahn84bvgDuva1y+b9x24/XRoeyv5PYrUsP3226/sx5gxfylt7Ws7LWtrX8uM+UuZOHZY0fudNWsWU6ZMAeCoo45i1qxZjBs3rtM6f/7znzn00EPp378/AIccckjHa0888QRnn302K1euZM2aNey///45j5N2vWopWxBx98eAsTmWvwHsW67jdthxcuEbatpg0xMDh0dFWTmWJ8mVe1n7ftf11rVD25vhcaaYLOP209e/Zn3A18HAEQo0UlOWLFkCwJgxY8p2jJdXtnVreRpvvPEGCxYs4IknnsDMWLt2LWbGT37yky7NbZOa3x533HHMmzePnXbaiZkzZ3L33Xf3aL1q0dhZO06GU56AaSvD/1LfYNMWrcUVWyfT3haCx7zvrA8gEAIIhEAz91twwVAViUlNmDJlSsev+XIZOqilW8vTuP766znmmGN48cUXeeGFF1i2bBmjRo3i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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Re-plot the data, showing the objective region\n",
    "plt.scatter(Y_A, Z_A, label=\"A data\")\n",
    "plt.scatter(Y_B, Z_B, label=\"B data\")\n",
    "plt.hlines(22.0, xmin=22.0, xmax=28.0, linestyles='dashed', colors='k')\n",
    "plt.vlines(22.0, ymin=22.0, ymax=30.0, linestyles='dashed', colors='k')\n",
    "plt.xlabel(\"first output (y)\")\n",
    "plt.ylabel(\"second output (z)\")\n",
    "plt.title(\"Two regions of data generated with Friedman-Grosse function\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5bf5fe4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "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.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
