{"cells":[{"cell_type":"code","execution_count":null,"metadata":{"colab":{"background_save":true,"base_uri":"https://localhost:8080/"},"id":"JorHtT7g0nPC","outputId":"983b0224-4388-450d-94c4-527a2ebb4a49"},"outputs":[{"name":"stdout","output_type":"stream","text":["Mounted at /content/drive\n","\n","Starting experiment: Synthetic MSE (Sphere sampling + 1/k feature decay)\n","Deltas: [0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1. ]\n","\n","Delta = 0.10 ... .............................done.\n","Delta = 0.20 ... .............................done.\n","Delta = 0.30 ... .............................done.\n","Delta = 0.40 ... .............................done.\n","Delta = 0.50 ... .............................done.\n","Delta = 0.60 ... .............................done.\n","Delta = 0.70 ... .............................done.\n","Delta = 0.80 ... .............................done.\n","Delta = 0.90 ... .............................done.\n","Delta = 1.00 ... .............................done.\n","\n","========================================================================================================================\n","Delta    | DP (mean±std, se)          | ITL (mean±std, se)         | ARMUL (mean±std, se)       | OURS (mean±std, se)       \n","------------------------------------------------------------------------------------------------------------------------\n","0.10     | 0.0317±0.0040, 0.0007      | 0.0285±0.0043, 0.0008      | 0.0306±0.0043, 0.0008      | 0.0194±0.0026, 0.0005     \n","0.20     | 0.0322±0.0040, 0.0007      | 0.0288±0.0043, 0.0008      | 0.0310±0.0043, 0.0008      | 0.0196±0.0026, 0.0005     \n","0.30     | 0.0327±0.0040, 0.0007      | 0.0292±0.0044, 0.0008      | 0.0314±0.0044, 0.0008      | 0.0198±0.0026, 0.0005     \n","0.40     | 0.0332±0.0040, 0.0007      | 0.0296±0.0044, 0.0008      | 0.0318±0.0043, 0.0008      | 0.0200±0.0026, 0.0005     \n","0.50     | 0.0338±0.0040, 0.0007      | 0.0300±0.0044, 0.0008      | 0.0322±0.0044, 0.0008      | 0.0206±0.0032, 0.0006     \n","0.60     | 0.0343±0.0041, 0.0007      | 0.0304±0.0045, 0.0008      | 0.0327±0.0044, 0.0008      | 0.0204±0.0025, 0.0005     \n","0.70     | 0.0349±0.0041, 0.0007      | 0.0308±0.0045, 0.0008      | 0.0332±0.0045, 0.0008      | 0.0207±0.0026, 0.0005     \n","0.80     | 0.0355±0.0041, 0.0008      | 0.0313±0.0045, 0.0008      | 0.0336±0.0044, 0.0008      | 0.0209±0.0028, 0.0005     \n","0.90     | 0.0362±0.0042, 0.0008      | 0.0317±0.0046, 0.0008      | 0.0341±0.0045, 0.0008      | 0.0214±0.0028, 0.0005     \n","1.00     | 0.0368±0.0042, 0.0008      | 0.0322±0.0046, 0.0008      | 0.0346±0.0046, 0.0008      | 0.0216±0.0028, 0.0005     \n","========================================================================================================================\n"]},{"data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAlgAAAHHCAYAAABjvibXAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAyCNJREFUeJzsnXmcE+X9xz8zk/ve+2LZ5VIuC4KcilRFQcGrVhG1HFp/tiqKWO8qotazKlhEqgVRC4Ko1YqKVVDEgqjgUe+D5d47m2RzZ2ae3x+TZJNNspvdTTaT7PPmFbKZPJl55nmSySff7/f5fhlCCAGFQqFQKBQKJWWwme4AhUKhUCgUSq5BBRaFQqFQKBRKiqECi0KhUCgUCiXFUIFFoVAoFAqFkmKowKJQKBQKhUJJMVRgUSgUCoVCoaQYKrAoFAqFQqFQUgwVWBQKhUKhUCgphgosCoVCoVAolBRDBRaFkgRr164FwzDYv39/rxzP6XSiuLgY69at65XjUSi5wq233ooJEyak9Rj79+8HwzBYu3Zt0m3/+te/prVP2UCy19H58+fDYDD0TqeS5O677wbDMF16TZ8XWKEJZxgGH330UczzhBBUVlaCYRjMmjUrAz1MnurqajAMg2nTpsV9/plnngmf62effRb13EcffYQzzzwTFRUV0Gg06N+/P84++2ysX78+ql3o9fFuf/jDH9J2bskQ+gCEbjqdLnwezz77LHw+X0qPt3LlyqQusN1h+fLlMBqNuPjii8PbunN+8+fPj3qNyWTCqFGj8Oijj3ZpPMaOHYurr7464fOhz9Fnn30W/kJJ5rZ//3588MEHYBgGL7/8ctcGKYI33ngDLMuirq6u07aCIKC8vBwMw+Dtt9+O26b9WCuVSlRXV+O6666DzWaLad/dz15nXyQGgwHz588PP+7NsQoEAnjiiScwbtw4GI1GGAwGjBs3Dk888QQCgUBMe4ZhcO2118bd18svvwyGYfDBBx+Et7V/b6rVahxzzDG466674PV6Y/bhdDqxZMkSjBw5Enq9HgUFBRg9ejSuv/56HD16NNxu0aJF+PLLL/Hvf/87yRFJDW+99RbuvvvuXj1mR4TGa8aMGcjPz09aEHaFdF4DcwFFpjsgFzQaDdavX4+TTjopavv27dtx+PBhqNXqDPWsa2g0Grz//vuoq6tDaWlp1HPr1q2DRqOJuXht2rQJs2fPDl+s8vLyUFNTgw8//BDPPPMMLrnkkqj2p59+OubOnRtz7GOOOSb1J9QNnnrqKRgMBvh8Phw5cgTvvPMOLr/8cixbtgybN29GZWVlSo6zcuVKFBYWRn0BpoJAIIDly5fjhhtuAMdxMc939fzUajX+8Y9/AABsNhteeeUV/OlPf8Knn36KDRs2dNqf2tpafP7557jnnnuS6n9RURFeeOGFqG2PPvooDh8+jMcffzymbSqsgm+++SbGjh0b856Px7Zt21BbW4vq6mqsW7cOZ555ZsK2obF2uVzYunUr/va3v2Hv3r1xf4x157OXCZIZK5fLhZkzZ2L79u2YNWsW5s+fD5ZlsWXLFlx//fV49dVX8eabb0Kv1/eoL5HvTbvdjtdffx333nsvfvnllyjrbSAQwMknn4zvv/8e8+bNw8KFC+F0OvHNN99g/fr1OP/881FeXg4AKC0txbnnnou//vWvOOecc3rUv0RUVVXB4/FAqVSGt7311lt48sknZSOympqacM8996B///4YNWpUlLhNFem6BuYMpI/z7LPPEgDkN7/5DSksLCSBQCDq+SuvvJKMHTuWVFVVkZkzZ2aol8lRVVVFTjvtNGIymciyZcuinjt06BBhWZZccMEFBAD59NNPw88NHz6cjBgxgvh8vph91tfXRz0GQK655pr0nEAPWbJkCQFAGhsbY5775z//SViWJRMmTOjWvkPvk5qamvC2ESNGkKlTp3azt4l59dVXCQDy888/R23vzvnNmzeP6PX6qG2CIJATTjiBACBHjhzptD+rV68mWq2WuN3uhG1C4xP5vopk5syZpKqqKu5z77//PgFANm3a1GlfElFZWUmWLFmSVNu5c+eSMWPGkOXLlxO9Xk+cTmdMm0RjPXv2bAKA7N69O2p7dz978eYnEr1eT+bNmxd+3Ftj9X//938EAPnb3/4W89yKFSsIAPKHP/whantH14ZNmzYRAOT9998Pb4t37qIokokTJxKGYUhdXV14+0svvUQAkHXr1sXs2+PxELvdHrXt5ZdfJgzDkF9++aXD80wl11xzDYn3lVpTU0MAkEceeSRlx5o3b16n1x6v10tqa2sJIYR8+umnBAB59tlnU9YHQrp+DYx3HY1HZ5+LTBC6JnSFPu8iDDFnzhw0Nzfj3XffDW/z+/14+eWXYyw4IURRxLJlyzBixAhoNBqUlJTgqquuQktLS1S7119/HTNnzkR5eTnUajUGDRqEe++9F4IgRLX79a9/jZEjR+Lbb7/FKaecAp1Oh4qKCjz88MNJn4dGo8FvfvObGNfeiy++iLy8PEyfPj3mNb/88gvGjRsHlUoV81xxcXHSx+6IkItg+/btMc/9/e9/B8Mw+PrrrwEAdXV1WLBgAfr16we1Wo2ysjKce+65PbJ0XHrppfj973+P3bt3R80xAOzevRszZsyA2WyGTqfD1KlT8d///rfD/VVXV+Obb77B9u3bwy6OX//61wAAq9WKP/3pTzjuuONgMBhgMplw5pln4ssvv0yqr6+99hqqq6sxaNCglJxfe1iWDfc1mTF98803ccopp0Cr1Sbdn97kf//7Hw4dOoSZM2d22tbj8eBf//oXLr74Ylx00UXweDx4/fXXkz7WlClTAEifmfZ057PX2yQzVocPH8bq1atx6qmnxnX5XXPNNTjllFPwj3/8A4cPH05p/xiGwUknnQRCCPbt2xfeHhrvE088MeY1Go0GJpMpalvIVdvZ3C5evBgFBQUghIS3LVy4EAzD4Iknnghvq6+vB8MweOqppwDExmDNnz8fTz75ZPgcQrf2PP300xg0aBDUajXGjRuHTz/9tMP+9QS1Wp2URTcRnV2HO7oGAsA333yDU089FVqtFv369cN9990HURS71Id9+/Zh+vTp0Ov1KC8vxz333BM1VwDw17/+FZMnT0ZBQQG0Wi3Gjh0b14UecmG/9tprGDlyJNRqNUaMGIEtW7bEtP3oo48wbtw4aDQaDBo0CH//+9+71O8QVGAFqa6uxqRJk/Diiy+Gt7399tuw2+1RcTCRXHXVVbjppptw4oknYvny5ViwYAHWrVuH6dOnR8UorF27FgaDAYsXL8by5csxduxY3HXXXbj11ltj9tnS0oIZM2aE42SGDh2KW265JWGsSDwuueQSfPLJJ1FfAuvXr8dvf/vbKJN2iKqqKmzdujXpi6XX60VTU1PMze/3J3zNzJkzYTAY8NJLL8U8t3HjRowYMQIjR44EAFxwwQX417/+hQULFmDlypW47rrr0NraioMHDybVv0T87ne/AwD85z//CW/btm0bTj75ZDgcDixZsgT3338/bDYbTj31VHzyyScJ97Vs2TL069cPQ4cOxQsvvIAXXngBd9xxBwDpovDaa69h1qxZeOyxx3DTTTfhf//7H6ZOnRoVK5KInTt3YsyYMSk5v0SE3hsFBQUdtgsEAnjvvfdw1llndbk/vcVbb72F4uJinHDCCZ22/fe//w2n04mLL74YpaWl+PWvf92lhQShL5e8vLy4z3f1s9fbJDNWb7/9NgRBiBsGEGLu3LngeT7ul1NPiTfGVVVVAIDnn38+5gs2HmazGYMGDer0h9KUKVNgtVrxzTffhLft2LEDLMtix44dUdsA4OSTT467n6uuugqnn346AISvB+3d5OvXr8cjjzyCq666Cvfddx/279+P3/zmN3Hj2SIRRTHmWuvz+RAIBGK2d7avrtDZdbija2BdXR1OOeUUfPHFF7j11luxaNEiPP/881i+fHnSxxcEATNmzEBJSQkefvhhjB07FkuWLMGSJUui2i1fvhzHH3887rnnHtx///1QKBS48MIL8eabb8bs86OPPsLVV1+Niy++GA8//DC8Xi8uuOACNDc3h9v873//wxlnnIGGhgbcfffdWLBgAZYsWYJ//etfXR/ENFjSsopI18aKFSuI0WgMu0IuvPBCcsoppxBCSIyLcMeOHXFN1lu2bInZHs+1ctVVVxGdTke8Xm9429SpUwkA8vzzz4e3+Xw+UlpaSi644IJOzyXUR57nSWlpKbn33nsJIYR8++23BADZvn17XFfO6tWrCQCiUqnIKaecQu68806yY8cOIghCzDEAJLy9+OKLHfZvzpw5pLi4mPA8H95WW1tLWJYl99xzDyGEkJaWlm6b0ztyoUXu+/zzzyeESO6IIUOGkOnTpxNRFMPt3G43GTBgADn99NPD27riIvR6vTFjV1NTQ9Rqdfg8ExEIBAjDMOTGG2/s8fkR0mZqb2xsJI2NjeTnn38m999/P2EYhvzqV7/qsC+EELJ169akTPqZdBFOmTIlyo3WEbNmzSInnnhi+PHTTz9NFAoFaWhoiGoXGusffviBNDY2kv3795M1a9YQrVZLioqKiMvlimrf3c9eb7sIkxmrRYsWEQDk888/T9hm7969BABZvHhxeBu66SKMfG/+9a9/JQzDkJEjR8Z8Jo899lgCgFRVVZH58+eT1atXx4QwRHLGGWeQYcOGdXiuDQ0NBABZuXIlIYQQm81GWJYlF154ISkpKQm3u+6660h+fn64TyG3X6TLrTMXYUFBAbFareHtr7/+OgFA3njjjQ77GHp9MrfI8Y2kqy7CZK/Dia6BofdQpCu9oaGBmM3mpF2EAMjChQvD20RRJDNnziQqlSrqGtj++9Xv95ORI0eSU089NWp76DsuMvTiyy+/jHGFn3feeUSj0ZADBw6Et3377beE4zjqIuwJIZfB5s2b0drais2bNyd0D27atAlmsxmnn3561C+IsWPHwmAw4P333w+3jXSttLa2oqmpCVOmTIHb7cb3338ftV+DwYDLLrss/FilUmH8+PFR5vLO4DgOF110Udgat27dOlRWVobdG+25/PLLsWXLFvz617/GRx99hHvvvRdTpkzBkCFDsHPnzpj25557Lt59992Y2ymnnNJhv2bPno2GhoaoYMuXX34Zoihi9uzZAKSxUqlU+OCDD2JcrT0ltFqrtbUVAPDFF1/gp59+wiWXXILm5ubwHLpcLpx22mn48MMPu2zSBiTTPMtKHy1BENDc3AyDwYBjjz0We/fu7fC1VqsVhJCEFpKOaH9+IVwuF4qKilBUVITBgwfj9ttvx6RJk5L6RfbWW29h+PDhqK6u7nJ/egObzYZdu3Yl5R5sbm7GO++8gzlz5oS3XXDBBWAYJq5lFQCOPfZYFBUVobq6GpdffjkGDx6Mt99+GzqdLm77rn72epNkxyr0/jEajQnbhJ5zOBw96lP79+af/vQnnHjiiXj99dejXGxarRa7d+/GTTfdBEDyClxxxRUoKyvDwoUL466IzcvLQ1NTU4fHLyoqwtChQ/Hhhx8CAP773/+C4zjcdNNNqK+vx08//QRAsmCddNJJXV6mH8ns2bOjPteh90Rn1/bS0tKYa+0ZZ5yBX/3qVzHbR40a1e3+RdLT6/Bbb72FiRMnYvz48eFtRUVFuPTSS7u0n0gXdcjF5/f78d5770X1NURLSwvsdjumTJkS91o7bdq0qNCLX/3qVzCZTOE5EAQB77zzDs477zz0798/3G7YsGHdcvHTVYQRFBUVYdq0aVi/fj3cbjcEQcBvf/vbuG1/+ukn2O32hDFKDQ0N4b+/+eYb/PnPf8a2bdtiLkh2uz3qcb9+/WI+xHl5efjqq6+6dC6XXHIJnnjiCXz55ZdYv349Lr744g4vDtOnT8f06dPhdruxZ88ebNy4EatWrcKsWbPw/fffR51nv379Ei5H74hQnNPGjRtx2mmnAZDcg6NHjw6vQFSr1XjooYdw4403oqSkBBMnTsSsWbMwd+7cHsUTANKyZaDtyyF08Zw3b17C19jt9i6LHVEUsXz5cqxcuRI1NTVRsXadueRCkCTcIO1pf34hNBoN3njjDQDS+A4YMAD9+vVLap9vvvkmzj777C73pbd45513AABnnHFGp203btyIQCCA448/Hj///HN4+4QJE7Bu3Tpcc801Ma955ZVXYDKZ0NjYiCeeeAI1NTWdxqJ19bPXGT15bSTJjlXo/dNeqEeSjAiLR/tziXxvHj58GA8//DAaGhrijrHZbMbDDz+Mhx9+GAcOHMDWrVvx17/+FStWrIDZbMZ9990X1Z4QktTYTZkyBW+99RYASUidcMIJOOGEE5Cfn48dO3agpKQEX375ZcIf28kS+YUNtLlAOxMwGo0m5nr7z3/+Ez6fr1vX4WTo6XX4wIEDcXORHXvssUn3gWVZDBw4MGpb6HsiMnZ08+bNuO+++/DFF19ECe14c99+DgBpHkJz0NjYCI/HgyFDhsTte+h9kixUYLXjkksuwZVXXom6ujqceeaZsFgscduJothhIsiioiIA0q/GqVOnwmQy4Z577sGgQYOg0Wiwd+9e3HLLLTEWknjL8oGuf+FOmDABgwYNwqJFi1BTU5P0xUGn02HKlCmYMmUKCgsLsXTpUrz99tsdipBkUavVOO+88/Cvf/0LK1euRH19Pf773//i/vvvj2q3aNEinH322Xjttdfwzjvv4M4778QDDzyAbdu24fjjj+/28UNB9IMHDwaA8Ng/8sgjGD16dNzXdCfZ3f33348777wTl19+Oe69917k5+eDZVksWrSoU4tYKF9Nd341tj+/EBzHdetCXFNTg++//z4c2CtH3nrrLZx44okwm82dtg19VuMFSgOSJaH9Bf3kk09GYWEhAODss8/Gcccdh0svvRR79uwJWynb05XPnkajgc/niysGCCHwer3QaDSdnlsyJDtWw4YNAwB89dVXCT8XoR98w4cPD29Tq9XweDxx27vdbgCIOZf2783p06dj6NChuOqqqzrMY1VVVYXLL78c559/PgYOHIh169bFCKyWlpbw3HXESSedhGeeeQb79u3Djh07MGXKlHCw/Y4dO1BeXg5RFHtshUzVtb23SNd1OJXs2LED55xzDk4++WSsXLkSZWVlUCqVePbZZ2MWmwC9PwdUYLXj/PPPx1VXXYWPP/4YGzduTNhu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ysrKDHt8RRgd4QqUrus4cuQISkpKLL+cvxEGBgZQX1+PlpYWlJaWmt0cAmsiG9ZDLqyHXIyshxACg4ODqK2thaoaN1OKPVjTpKoqFixYYHYzpFdaWsoPK8mwJnJhPeTCesjFqHoY2XOVxEnuRERERHnGgEVERESUZwxYZAiXy4WNGzfC5XKZ3RRKYE3kwnrIhfWQSyHUg5PciYiIiPKMPVhEREREecaARURERJRnDFhEREREecaARURERJRnDFg0bVu2bMGiRYvgdruxcuVK/PGPfxxz39/85jc455xzUFFRgYqKCqxevXrc/WnqplKPdI2NjVAUBVdccYWxDZyDplqTvr4+3HzzzaipqYHL5cJJJ52E7du3z1JrC99U6/HQQw/h5JNPhsfjQX19PdatW4fh4eFZam1h+5//+R9cdtllqK2thaIo2LZt24T32bNnD04//XS4XC6ccMIJePLJJw1v54wIomlobGwUTqdTPP744+LPf/6zuOGGG0R5ebno6OjIuf/Xv/51sWXLFvHee++JgwcPimuvvVaUlZWJ1tbWWW55YZpqPZIOHz4s6urqxDnnnCP+6Z/+aXYaO0dMtSbhcFgsX75cXHLJJeKtt94Shw8fFnv27BEHDhyY5ZYXpqnW4+mnnxYul0s8/fTT4vDhw+L1118XNTU1Yt26dbPc8sK0fft2ceedd4oXXnhBABAvvvjiuPsfOnRIFBUVifXr14u//OUv4pFHHhE2m03s2LFjdho8DQxYNC0rVqwQN998c+q6pmmitrZWbNq0aVL3j8VioqSkRDz11FNGNXFOmU49YrGYOOuss8Rvf/tbsXbtWgasPJtqTR599FGxePFiEYlEZquJc8pU63HzzTeLCy64IGPb+vXrxdlnn21oO+eiyQSs2267TZxyyikZ29asWSMuuugiA1s2MxwipCmLRCLYv38/Vq9endqmqipWr16Nffv2TeoxQqEQotEofD6fUc2cM6Zbj3//939HVVUV/vVf/3U2mjmnTKcmL7/8MlatWoWbb74Zfr8fS5YswX333QdN02ar2QVrOvU466yzsH///tQw4qFDh7B9+3Zccskls9JmyrRv376M+gHARRddNOnvHDPwZM80Zd3d3dA0DX6/P2O73+/HRx99NKnHuP3221FbWzvqHwxN3XTq8dZbb+E//uM/cODAgVlo4dwznZocOnQIu3btwje+8Q1s374df//73/Htb38b0WgUGzdunI1mF6zp1OPrX/86uru78fnPfx5CCMRiMXzrW9/Chg0bZqPJlKW9vT1n/QYGBjA0NASPx2NSy8bGHiyadZs3b0ZjYyNefPFFuN1us5sz5wwODuLqq6/Gb37zG1RWVprdHErQdR1VVVX49a9/jWXLlmHNmjW48847sXXrVrObNift2bMH9913H371q1/h3XffxQsvvIBXX30VP/rRj8xuGlkEe7BoyiorK2Gz2dDR0ZGxvaOjA9XV1ePe92c/+xk2b96M3//+9zj11FONbOacMdV6fPLJJ/j0009x2WWXpbbpug4AsNvt+Pjjj3H88ccb2+gCN51/IzU1NXA4HLDZbKlt//AP/4D29nZEIhE4nU5D21zIplOPu+++G1dffTWuv/56AMDnPvc5BINB3HjjjbjzzjuhquyfmE3V1dU561daWipl7xXAHiyaBqfTiWXLlmHnzp2pbbquY+fOnVi1atWY93vggQfwox/9CDt27MDy5ctno6lzwlTr8ZnPfAYffvghDhw4kPq5/PLLcf755+PAgQOor6+fzeYXpOn8Gzn77LPx97//PRV2AeCvf/0rampqGK5maDr1CIVCo0JUMvwKnsJ31q1atSqjfgDw5ptvjvudYzqzZ9mTNTU2NgqXyyWefPJJ8Ze//EXceOONory8XLS3twshhLj66qvFHXfckdp/8+bNwul0iueff14cPXo09TM4OGjWUygoU61HNh5FmH9TrUlzc7MoKSkRt9xyi/j444/FK6+8IqqqqsSPf/xjs55CQZlqPTZu3ChKSkrEf/7nf4pDhw6JN954Qxx//PHiqquuMuspFJTBwUHx3nvviffee08AED//+c/Fe++9J5qamoQQQtxxxx3i6quvTu2fXKbh3/7t38TBgwfFli1buEwDFa5HHnlENDQ0CKfTKVasWCH+93//N3XbueeeK9auXZu6vnDhQgFg1M/GjRtnv+EFair1yMaAZYyp1mTv3r1i5cqVwuVyicWLF4uf/OQnIhaLzXKrC9dU6hGNRsU999wjjj/+eOF2u0V9fb349re/LXp7e2e/4QVo9+7dOb8TkjVYu3atOPfcc0fdZ+nSpcLpdIrFixeLJ554YtbbPRWKEOzrJCIiIsonzsEiIiIiyjMGLCIiIqI8Y8AiIiIiyjMGLCIiIqI8Y8AiIiIiyjMGLCIiIqI8Y8AiIiIiyjMGLCKiHO655x4sXbrU7GYQkUUxYBFRQbn22muhKAoURYHD4YDf78c//uM/4vHHH884z990HveKK67IX0OJqKAxYBFRwfnSl76Eo0eP4tNPP8Vrr72G888/H7feeisuvfRSxGIxs5tHRHMAAxYRFRyXy4Xq6mrU1dXh9NNPx4YNG/DSSy/htddew5NPPgkA6Ovrw/XXX4/58+ejtLQUF1xwAd5///2cj3fPPffgqaeewksvvZTqHduzZw8A4Pbbb8dJJ52EoqIiLF68GHfffTei0egsPVMikpXd7AYQEc2GCy64AKeddhpeeOEFXH/99fjnf/5neDwevPbaaygrK8Njjz2GCy+8EH/961/h8/ky7vv9738fBw8exMDAAJ544gkASO1TUlKCJ598ErW1tfjwww9xww03oKSkBLfddtusP0cikgcDFhHNGZ/5zGfwwQcf4K233sIf//hHdHZ2wuVyAQB+9rOfYdu2bXj++edx4403ZtyvuLgYHo8H4XAY1dXVGbfdddddqcuLFi3C97//fTQ2NjJgEc1xDFhENGcIIaAoCt5//30EAgHMmzcv4/ahoSF88sknU3rMZ599Fg8//DA++eQTBAIBxGIxlJaW5rPZRGRBDFhENGccPHgQxx13HAKBAGpqalLzqNKVl5dP+vH27duHb3zjG7j33ntx0UUXoaysDI2NjXjwwQfz12gisiQGLCKaE3bt2oUPP/wQ69atw4IFC9De3g673Y5FixZN6v5OpxOapmVs27t3LxYuXIg777wzta2pqSmfzSYii2LAIqKCEw6H0d7eDk3T0NHRgR07dmDTpk249NJLcc0110BVVaxatQpXXHEFHnjgAZx00kk4cuQIXn31VXzlK1/B8uXLRz3mokWL8Prrr+Pjjz/GvHnzUFZWhhNPPBHNzc1obGzEGWecgVdffRUvvviiCc+YiGTDZRqIqODs2LEDNTU1WLRoEb70pS9h9+7dePjhh/HSSy/BZrNBURRs374dX/jCF3DdddfhpJNOwr/8y7+gqakJfr8/52PecMMNOPnkk7F8+XLMnz8ff/jDH3D55Zdj3bp1uOWWW7B06VLs3bsXd9999yw/WyKSkSKEEGY3goiIiKiQsAeLiIiIKM8YsIiIiIjyjAGLiIiIKM8YsIiIiIjyjAGLiIiIKM8YsIiIiIjyjAGLiIiIKM8YsIiIiIjyjAGLiIiIKM8YsIiIiIjyjAGLiIiIKM8YsIiIiIjy7P8Dw3Kn2FAcK1UAAAAASUVORK5CYII=\n","text/plain":["<Figure size 640x480 with 1 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["# -*- coding: utf-8 -*-\n","\"\"\"\n","Synthetic regression experiment: MSE under sphere sampling with 1/k feature decay.\n","\n","This script compares:\n","  - DP  : data pooling baseline (single global model)\n","  - ITL : independent task learning baseline\n","  - ARMUL (Duan & Wang, GitHub implementation) : vanilla ARMUL training loop\n","  - OURS: ARMUL-style decomposition with a task-dependent Sigma-norm penalty,\n","          optimized via joint L-BFGS-B (objective matches the experiment setup)\n","\n","Notes:\n","  - This script intentionally disables standardization (standardization=False) and\n","    relies on a safe preprocessing patch so downstream code never divides by zero.\n","  - The data generator samples features uniformly on the unit sphere and then applies\n","    coordinate-wise decay weights 1/k (k=1..d).\n","\"\"\"\n","\n","import os\n","import sys\n","import math\n","import numpy as np\n","import pandas as pd\n","from scipy.optimize import minimize\n","\n","# NEW: plotting\n","import matplotlib.pyplot as plt\n","\n","# =========================================================\n","# 1) Optional Colab drive mount + local module imports\n","# =========================================================\n","try:\n","    from google.colab import drive  # type: ignore\n","    drive.mount(\"/content/drive\")\n","except Exception:\n","    # Not running in Colab (or drive is unavailable). Safe to ignore.\n","    pass\n","\n","WORK_DIR = \"/content/drive/MyDrive/Colab Notebooks/MTLR\"\n","if os.path.isdir(WORK_DIR):\n","    os.chdir(WORK_DIR)\n","if WORK_DIR not in sys.path:\n","    sys.path.append(WORK_DIR)\n","\n","try:\n","    import preprocessing\n","    import MTL\n","    from ARMUL import ARMUL, Baselines\n","except ImportError as e:\n","    raise ImportError(\n","        \"Could not import local modules. Make sure WORK_DIR contains \"\n","        \"ARMUL.py, MTL.py, and preprocessing.py, and that WORK_DIR is on sys.path.\"\n","    ) from e\n","\n","\n","# =========================================================\n","# 2) Safe preprocessing patch for standardization=False\n","# =========================================================\n","_ORIG_PREPROCESSING = getattr(preprocessing, \"MTL_preprocessing\", None)\n","_ORIG_MTL = getattr(MTL, \"MTL_preprocessing\", None)\n","\n","\n","def safe_MTL_preprocessing(\n","    data,\n","    link=\"linear\",\n","    intercept=True,\n","    n_class=1,\n","    standardization=True,\n","):\n","    \"\"\"\n","    A safe drop-in replacement for preprocessing.MTL_preprocessing.\n","\n","    When standardization=False:\n","      - return X_means = 0 and X_stds = 1 (no scaling),\n","      - so downstream code never divides by zero.\n","\n","    When standardization=True:\n","      - fall back to the original implementation, if available.\n","    \"\"\"\n","    if standardization:\n","        if _ORIG_PREPROCESSING is None:\n","            raise RuntimeError(\"Original preprocessing.MTL_preprocessing not found.\")\n","        return _ORIG_PREPROCESSING(\n","            data=data,\n","            link=link,\n","            intercept=intercept,\n","            n_class=n_class,\n","            standardization=standardization,\n","        )\n","\n","    m = len(data[0])\n","    d = data[0][0].shape[1]\n","    n_list = np.zeros(m, dtype=int)\n","\n","    X_means = np.zeros((d, 1))\n","    X_stds = np.ones((d, 1))  # IMPORTANT: ones, not zeros (avoid division by zero)\n","\n","    if intercept:\n","        X_means = np.vstack((np.zeros((1, 1)), X_means))\n","        X_stds = np.vstack((np.ones((1, 1)), X_stds))\n","\n","    y_mean, y_std = 0, 1\n","    X, Y = [], []\n","\n","    for j in range(m):\n","        tmp = data[0][j]\n","        n_list[j] = tmp.shape[0]\n","\n","        if intercept:\n","            tmp = np.hstack((np.ones((n_list[j], 1)), tmp))\n","        X.append(tmp)\n","\n","        if link == \"logistic\":\n","            if n_class == 2:\n","                for y_dat in data[1]:\n","                    Y.append(y_dat.reshape(-1, 1))\n","            else:\n","                # Multiclass logistic is not used in this experiment.\n","                pass\n","        else:\n","            for y_dat in data[1]:\n","                Y.append(y_dat.reshape(-1, 1))\n","\n","    d_out = 1 if n_class == 2 else n_class\n","    return [X, Y, X_means, X_stds, y_mean, y_std, n_list, d_out]\n","\n","\n","# Apply the patch to both modules (keeps experiment behavior identical while avoiding std=0 issues)\n","sys.modules[\"preprocessing\"].MTL_preprocessing = safe_MTL_preprocessing\n","sys.modules[\"MTL\"].MTL_preprocessing = safe_MTL_preprocessing\n","\n","# Convenience alias used below (matches the original script structure)\n","MTL_preprocessing = safe_MTL_preprocessing\n","\n","\n","# =========================================================\n","# 3) CV split helper (per-task folds)\n","# =========================================================\n","def split_cv(n_list, n_fold, seed=0):\n","    \"\"\"\n","    Create per-task CV splits.\n","\n","    Returns\n","    -------\n","    splits : list of length m\n","        splits[j] is a list of length n_fold\n","        splits[j][k] is a 1D numpy array of validation indices for task j, fold k\n","    \"\"\"\n","    rng = np.random.default_rng(seed)\n","    splits = []\n","\n","    for n in n_list:\n","        n = int(n)\n","        if n_fold > n:\n","            raise ValueError(\n","                f\"n_fold={n_fold} cannot exceed n={n} for a task (empty folds).\"\n","            )\n","        perm = rng.permutation(n)\n","        folds = np.array_split(perm, n_fold)  # nearly equal-sized folds\n","        splits.append([f.astype(int) for f in folds])\n","\n","    return splits\n","\n","\n","# =========================================================\n","# 4) Synthetic data generator + baseline runner\n","# =========================================================\n","class ExperimentSyntheticMSE:\n","    \"\"\"\n","    Synthetic linear regression multitask experiment.\n","\n","    - True parameters Theta* are correlated across tasks via a shared signal and delta-perturbations.\n","    - Outlier tasks can be injected via epsilon fraction.\n","    - Features are sampled uniformly on the unit sphere, then scaled by 1/k decay weights.\n","    \"\"\"\n","\n","    def __init__(self, n, m, d):\n","        self.n, self.m, self.d = int(n), int(m), int(d)\n","        self.data = []\n","        self.Theta = None\n","        self.scales = None\n","        self.err = {}\n","\n","    @staticmethod\n","    def sample_unit_hemisphere(d: int) -> np.ndarray:\n","        \"\"\"\n","        Sample uniformly from the unit sphere conditioned on the first coordinate >= 0.\n","        Implementation: sample g ~ N(0, I_d), reflect if g[0] < 0, then normalize.\n","        \"\"\"\n","        g = np.random.randn(d)\n","        if g[0] < 0:\n","            g = -g\n","        return g / np.linalg.norm(g)\n","\n","    def getsamples(\n","        self,\n","        setting=\"vanilla\",\n","        K=1,\n","        signal_norm=2,\n","        sigma=1,\n","        delta=0.5,\n","        epsilon=0.0,\n","        norm_outliers=2,\n","        seed=1000,\n","        decay_variance=True,\n","    ):\n","        np.random.seed(seed)\n","\n","        # (1) Construct Theta*\n","        self.Theta = np.zeros((self.d, self.m))\n","        if setting == \"vanilla\":\n","            self.Theta[0, :] = signal_norm\n","\n","        n_outliers = int(self.m * epsilon)\n","        outlier_indices = set(np.random.choice(self.m, n_outliers, replace=False))\n","\n","        # NOTE: u_j is now sampled uniformly on the hemisphere {u : ||u||=1, u[0] >= 0}.\n","        for j in range(self.m):\n","            u_j = self.sample_unit_hemisphere(self.d)\n","\n","            if j in outlier_indices:\n","                self.Theta[:, j] = norm_outliers * u_j\n","            else:\n","                self.Theta[:, j] = self.Theta[:, j] + delta * u_j\n","\n","        # (2) Generate X and y\n","        data_X, data_y = [], []\n","\n","        # Coordinate decay weights: w_k = 1/k\n","        if decay_variance:\n","            self.scales = 1 / np.arange(1, self.d + 1)\n","        else:\n","            self.scales = np.ones(self.d)\n","\n","        for j in range(self.m):\n","            # Uniform sampling on S^{d-1}: normalize Gaussian rows\n","            raw_X = np.random.randn(self.n, self.d)\n","            X_sphere = raw_X / np.linalg.norm(raw_X, axis=1, keepdims=True)\n","\n","            # Apply coordinate-wise decay weights\n","            X_j = X_sphere * self.scales\n","            data_X.append(X_j)\n","\n","            # Linear response\n","            y_j = (X_j @ self.Theta[:, j]) + sigma * np.random.randn(self.n)\n","            data_y.append(y_j)\n","\n","        self.data = [data_X, data_y]\n","\n","    def calc_mse(self, Theta_hat):\n","        \"\"\"\n","        Per-task population MSE proxy under the experiment's X distribution:\n","            E[(x^T(Theta_hat - Theta*))^2]\n","        Here it reduces to a scaled squared error because X is spherical with coordinate weights.\n","        \"\"\"\n","        Diff = Theta_hat - self.Theta  # (d, m)\n","        WeightedDiff = Diff * self.scales.reshape(-1, 1)\n","        return np.sum(WeightedDiff ** 2, axis=0) / self.d\n","\n","    def run_baselines(self, eta=0.01, T=200):\n","        \"\"\"\n","        Train DP and ITL baselines using the original Baselines implementation.\n","        \"\"\"\n","        base = Baselines(link=\"linear\", n_class=1)\n","\n","        # DP (data pooling)\n","        base.DP_train(self.data, eta=eta, T=T, standardization=False, intercept=False)\n","        Theta_DP = base.models[\"DP\"][:, :, 0].T\n","        self.err[\"DP\"] = self.calc_mse(Theta_DP)\n","\n","        # ITL (independent task learning)\n","        base.STL_train(self.data, eta=eta, T=T, standardization=False, intercept=False)\n","        Theta_ITL = base.models[\"STL\"][:, :, 0].T\n","        self.err[\"ITL\"] = self.calc_mse(Theta_ITL)\n","\n","\n","# =========================================================\n","# 5) OURS (Sigma-norm penalty) for the synthetic linear setting\n","# =========================================================\n","class OURS_Synthetic_Custom:\n","    \"\"\"\n","    ARMUL-style parameterization: w_j = gamma - v_j.\n","\n","    Objective (per task j):\n","        (1 / (2 n_j)) ||X_j (gamma - v_j) - y_j||^2 + lambda_j * ||v_j||_{Sigma_j}\n","    where Sigma_j = X_j^T X_j / n_j and ||v||_{Sigma} = sqrt(v^T Sigma v).\n","    \"\"\"\n","\n","    def __init__(self):\n","        self.models = {}\n","\n","    def train(self, data, lbd_list, T_global=200):\n","        pack = MTL_preprocessing(\n","            data,\n","            link=\"linear\",\n","            intercept=False,\n","            n_class=1,\n","            standardization=False,\n","        )\n","        X, y, _, _, _, _, n_list, _ = pack\n","\n","        m = len(X)\n","        d = X[0].shape[1]\n","        for j in range(m):\n","            if y[j].ndim == 1:\n","                y[j] = y[j].reshape(-1, 1)\n","\n","        Sigmas = [(X[j].T @ X[j]) / n_list[j] for j in range(m)]\n","\n","        def objective_and_grad(params):\n","            gamma = params[:d].reshape(d, 1)\n","            V = params[d:].reshape(m, d, 1)\n","\n","            total_loss = 0.0\n","            grad_gamma = np.zeros_like(gamma)\n","            grad_V = np.zeros_like(V)\n","\n","            eps_floor = 1e-12  # smoothing for numerical stability\n","\n","            for j in range(m):\n","                v_j = V[j]\n","                w_j = gamma - v_j\n","                diff = X[j] @ w_j - y[j]\n","                nj = n_list[j]\n","\n","                # Data loss: (1/(2n)) * RSS\n","                total_loss += 0.5 * np.sum(diff ** 2) / nj\n","                g_part = (X[j].T @ diff) / nj\n","                grad_gamma += g_part\n","                grad_V[j] -= g_part\n","\n","                # Penalty: lambda_j * ||v_j||_{Sigma_j}\n","                Sv = Sigmas[j] @ v_j\n","                norm_val = np.sqrt(np.sum(v_j * Sv) + eps_floor)\n","                total_loss += lbd_list[j] * norm_val\n","\n","                if norm_val > 1e-10:\n","                    g_pen = lbd_list[j] * Sv / norm_val\n","                    grad_V[j] += g_pen\n","\n","            return total_loss, np.concatenate([grad_gamma.ravel(), grad_V.ravel()])\n","\n","        res = minimize(\n","            objective_and_grad,\n","            np.zeros(d + m * d),\n","            method=\"L-BFGS-B\",\n","            jac=True,\n","            options={\"maxiter\": T_global, \"ftol\": 1e-9},\n","        )\n","\n","        final_gamma = res.x[:d].reshape(d, 1)\n","        final_V = res.x[d:].reshape(m, d, 1)\n","\n","        Theta_hat = np.zeros((d, m))\n","        for j in range(m):\n","            Theta_hat[:, j] = (final_gamma - final_V[j]).flatten()\n","\n","        self.models[\"ours\"] = Theta_hat\n","        return self\n","\n","    def predict(self, X_test):\n","        y_pred = []\n","        Theta = self.models[\"ours\"]\n","        for j, X in enumerate(X_test):\n","            y_pred.append(X @ Theta[:, j])\n","        return y_pred\n","\n","\n","# =========================================================\n","# 6) CV helper for synthetic experiments (ARMUL vs OURS)\n","# =========================================================\n","def run_cv_synthetic(data, model_type, q_grid, d_dim, n_fold=5, eta=0.05, t_iter=200):\n","    \"\"\"\n","    Inner CV selects q, then refits on the full dataset and returns Theta_hat.\n","\n","    IMPORTANT:\n","      - For fairness, both ARMUL and OURS use the same lambda scaling:\n","            lambda_j = q * sqrt(d / n_j)\n","    \"\"\"\n","    m = len(data[0])\n","    n_list = np.array([len(y) for y in data[1]])\n","    splits = split_cv(n_list, n_fold, seed=np.random.randint(10000))\n","\n","    best_q = q_grid[0]\n","    best_val_err = float(\"inf\")\n","\n","    def mean_task_mse(y_true, y_pred):\n","        errs = [np.mean((yt.ravel() - yp.ravel()) ** 2) for yt, yp in zip(y_true, y_pred)]\n","        return float(np.mean(errs))\n","\n","    for q in q_grid:\n","        fold_errors = []\n","\n","        for k in range(n_fold):\n","            X_tr, y_tr, X_val, y_val = [], [], [], []\n","\n","            for j in range(m):\n","                idx_val = splits[j][k]\n","                idx_tr = np.delete(np.arange(n_list[j]), idx_val)\n","\n","                X_tr.append(data[0][j][idx_tr])\n","                y_tr.append(data[1][j][idx_tr])\n","                X_val.append(data[0][j][idx_val])\n","                y_val.append(data[1][j][idx_val])\n","\n","            n_train_cur = np.array([len(y) for y in y_tr])\n","            lbd_vec = q * np.sqrt(d_dim / n_train_cur)\n","\n","            if model_type == \"ARMUL\":\n","                model = ARMUL(link=\"linear\", penalty=\"new\")\n","                model.vanilla(\n","                    [X_tr, y_tr],\n","                    lbd=lbd_vec,\n","                    eta_global=eta,\n","                    eta_local=eta,\n","                    T_global=t_iter,\n","                    standardization=False,\n","                    intercept=False,\n","                )\n","\n","                # Keep behavior consistent with the original script (safe override for no-standardize mode)\n","                model.X_stds = np.ones((d_dim, 1))\n","                model.X_means = np.zeros((d_dim, 1))\n","\n","                y_pred = model.predict(X_val, model=\"vanilla\")\n","                fold_errors.append(mean_task_mse(y_val, y_pred))\n","\n","            elif model_type == \"OURS\":\n","                ours = OURS_Synthetic_Custom()\n","                ours.train([X_tr, y_tr], lbd_list=lbd_vec, T_global=t_iter)\n","                y_pred = ours.predict(X_val)\n","                fold_errors.append(mean_task_mse(y_val, y_pred))\n","\n","            else:\n","                raise ValueError(\"model_type must be one of {'ARMUL', 'OURS'}\")\n","\n","        avg_err = float(np.mean(fold_errors))\n","        if (not np.isnan(avg_err)) and (avg_err < best_val_err):\n","            best_val_err = avg_err\n","            best_q = q\n","\n","    # Refit on full data with the selected q\n","    lbd_vec_full = best_q * np.sqrt(d_dim / n_list)\n","\n","    if model_type == \"ARMUL\":\n","        model = ARMUL(link=\"linear\", penalty=\"new\")\n","        model.vanilla(\n","            data,\n","            lbd=lbd_vec_full,\n","            eta_global=eta,\n","            eta_local=eta,\n","            T_global=t_iter,\n","            standardization=False,\n","            intercept=False,\n","        )\n","        final_theta = model.models[\"vanilla\"][:, :, 0].T\n","        return final_theta, best_q\n","\n","    if model_type == \"OURS\":\n","        ours = OURS_Synthetic_Custom()\n","        ours.train(data, lbd_list=lbd_vec_full, T_global=t_iter)\n","        final_theta = ours.models[\"ours\"]\n","        return final_theta, best_q\n","\n","    raise ValueError(\"model_type must be one of {'ARMUL', 'OURS'}\")\n","\n","\n","# =========================================================\n","# 7) Main experiment loop\n","# =========================================================\n","def main():\n","    # Core dimensions\n","    n, m, d = 100, 30, 30\n","\n","    # Monte Carlo settings\n","    n_simul = 30\n","    eta = 0.05\n","    t_iter = 500\n","    q_grid = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0]\n","\n","    # Data settings\n","    epsilon = 0.1  # fraction of outlier tasks\n","    deltas = np.arange(0.1, 1.1, 0.1)\n","    use_decay_variance = True\n","\n","    # We'll store mean/std/se per (Delta, Method)\n","    results_table = []\n","\n","    print(\"\\nStarting experiment: Synthetic MSE (Sphere sampling + 1/k feature decay)\")\n","    print(f\"Deltas: {np.round(deltas, 2)}\\n\")\n","\n","    for delta_val in deltas:\n","        print(f\"Delta = {delta_val:.2f} ...\", end=\" \")\n","        sim_res = {\"DP\": [], \"ITL\": [], \"ARMUL\": [], \"OURS\": []}\n","\n","        for i in range(n_simul):\n","            seed = (i + 1) * 10\n","\n","            exp = ExperimentSyntheticMSE(n, m, d)\n","            exp.getsamples(\n","                setting=\"vanilla\",\n","                delta=delta_val,\n","                epsilon=epsilon,\n","                seed=seed,\n","                decay_variance=use_decay_variance,\n","            )\n","\n","            # Baselines\n","            exp.run_baselines(eta=eta, T=t_iter)\n","            sim_res[\"DP\"].append(float(np.mean(exp.err[\"DP\"])))\n","            sim_res[\"ITL\"].append(float(np.mean(exp.err[\"ITL\"])))\n","\n","            # ARMUL (auto-tuned q)\n","            theta_armul, _ = run_cv_synthetic(\n","                exp.data,\n","                \"ARMUL\",\n","                q_grid,\n","                d,\n","                n_fold=5,\n","                eta=eta,\n","                t_iter=t_iter,\n","            )\n","            sim_res[\"ARMUL\"].append(float(np.mean(exp.calc_mse(theta_armul))))\n","\n","            # OURS (auto-tuned q)\n","            theta_ours, _ = run_cv_synthetic(\n","                exp.data,\n","                \"OURS\",\n","                q_grid,\n","                d,\n","                n_fold=5,\n","                eta=eta,\n","                t_iter=t_iter,\n","            )\n","            sim_res[\"OURS\"].append(float(np.mean(exp.calc_mse(theta_ours))))\n","\n","            # Progress indicator\n","            if i == n_simul - 1:\n","                print(\"done.\")\n","            else:\n","                print(\".\", end=\"\")\n","\n","        # Summaries for this delta\n","        row = {\"Delta\": float(delta_val)}\n","        for alg in [\"DP\", \"ITL\", \"ARMUL\", \"OURS\"]:\n","            vals = np.array(sim_res[alg], dtype=float)\n","            mean = float(np.mean(vals))\n","            std = float(np.std(vals, ddof=1)) if len(vals) > 1 else 0.0\n","            se = float(std / np.sqrt(len(vals))) if len(vals) > 0 else float(\"nan\")\n","\n","            row[alg] = mean\n","            row[f\"{alg}_std\"] = std\n","            row[f\"{alg}_se\"] = se\n","\n","        results_table.append(row)\n","\n","    df = pd.DataFrame(results_table)\n","\n","    # ---- print table: mean/std/se\n","    print(\"\\n\" + \"=\" * 120)\n","    header = (\n","        f\"{'Delta':<8} | \"\n","        f\"{'DP (mean±std, se)':<26} | \"\n","        f\"{'ITL (mean±std, se)':<26} | \"\n","        f\"{'ARMUL (mean±std, se)':<26} | \"\n","        f\"{'OURS (mean±std, se)':<26}\"\n","    )\n","    print(header)\n","    print(\"-\" * 120)\n","    for _, r in df.iterrows():\n","        def fmt(alg):\n","            return f\"{r[alg]:.4f}±{r[f'{alg}_std']:.4f}, {r[f'{alg}_se']:.4f}\"\n","\n","        print(\n","            f\"{r['Delta']:<8.2f} | \"\n","            f\"{fmt('DP'):<26} | \"\n","            f\"{fmt('ITL'):<26} | \"\n","            f\"{fmt('ARMUL'):<26} | \"\n","            f\"{fmt('OURS'):<26}\"\n","        )\n","    print(\"=\" * 120)\n","\n","    # =========================================================\n","    # 8) Plot: Delta vs Mean MSE with ±1 std shaded region\n","    # =========================================================\n","    plt.figure()\n","\n","    x = df[\"Delta\"].values\n","    for alg in [\"DP\", \"ITL\", \"ARMUL\", \"OURS\"]:\n","        y = df[alg].values\n","        ystd = df[f\"{alg}_std\"].values\n","\n","        line = plt.plot(x, y, marker=\"o\", label=alg)[0]\n","        # Shade ±1 std around mean using the same line color (with alpha)\n","        plt.fill_between(\n","            x,\n","            y - ystd,\n","            y + ystd,\n","            alpha=0.15,\n","            color=line.get_color(),\n","            linewidth=0,\n","        )\n","\n","    plt.xlabel(\"Delta\")\n","    plt.ylabel(\"Mean MSE\")\n","    plt.title(\"Mean MSE vs Delta (DP / ITL / ARMUL / OURS) with ±1 std band\")\n","    plt.legend()\n","    plt.grid(True, which=\"both\", linestyle=\"--\", linewidth=0.5, alpha=0.6)\n","\n","    # Save as PDF (not PNG)\n","    plt.savefig(\"mse_vs_delta.pdf\", bbox_inches=\"tight\")\n","    plt.show()\n","\n","\n","if __name__ == \"__main__\":\n","    main()\n"]}],"metadata":{"colab":{"provenance":[],"authorship_tag":"ABX9TyOlQ9lRlDzClENBKpxtQHfO"},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}