{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import pickle\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "root_dir = r'/home/jianming/PONet/programs/BPQP/'\n",
    "# cnHuber = r'results/CN/huber_loss/mlp/bpqp/1676998901-8522532'\n",
    "cnHuber = r'results/CN/huber_loss/mlp/bpqp/1677506885-760933'\n",
    "# results/CN/huber_loss/mlp/bpqp/1676176317-1800838\n",
    "cnMSE = r'results/CN/mse/mlp/bpqp/1677561975-6623201'\n",
    "cnRegret = r'results/CN/regret/mlp/bpqp/1676144319-821679'"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [
    {
     "data": {
      "text/plain": "    train_loss  train_regret  train_mse  train_score  train_ic  train_rank_ic  \\\n0     1.021057     13.714712   1.021057     0.032707  0.032707       0.035265   \n1     1.010056     13.989693   1.010056     0.042209  0.042209       0.045205   \n2     1.005012     14.295711   1.005012     0.048768  0.048768       0.052023   \n3     1.002013     14.509285   1.002013     0.053631  0.053631       0.057158   \n4     0.999972     14.663292   0.999972     0.057521  0.057521       0.061151   \n5     0.998481     14.780321   0.998481     0.060895  0.060895       0.064584   \n6     0.997322     14.873756   0.997322     0.063736  0.063736       0.067430   \n7     0.996384     14.949255   0.996384     0.066338  0.066338       0.070029   \n8     0.995608     15.014496   0.995608     0.068579  0.068579       0.072247   \n9     0.994972     15.069002   0.994972     0.070567  0.070567       0.074236   \n10    0.994430     15.113810   0.994430     0.072407  0.072407       0.076021   \n11    0.993951     15.149652   0.993951     0.074118  0.074118       0.077662   \n12    0.993541     15.182568   0.993541     0.075683  0.075683       0.079174   \n13    0.993204     15.211255   0.993204     0.077092  0.077092       0.080541   \n14    0.992901     15.238413   0.992901     0.078362  0.078362       0.081726   \n15    0.992634     15.258163   0.992634     0.079547  0.079547       0.082824   \n16    0.992382     15.276007   0.992382     0.080646  0.080646       0.083814   \n17    0.992179     15.291256   0.992179     0.081681  0.081681       0.084772   \n18    0.991993     15.304655   0.991993     0.082645  0.082645       0.085662   \n19    0.991828     15.316535   0.991828     0.083580  0.083580       0.086514   \n20    0.991659     15.326437   0.991659     0.084434  0.084434       0.087275   \n21    0.991538     15.335515   0.991538     0.085237  0.085237       0.087995   \n22    0.991426     15.342097   0.991426     0.085997  0.085997       0.088676   \n23    0.991327     15.348646   0.991327     0.086694  0.086694       0.089284   \n24    0.991240     15.354338   0.991240     0.087358  0.087358       0.089887   \n25    0.991156     15.359694   0.991156     0.087993  0.087993       0.090448   \n26    0.991083     15.363800   0.991083     0.088601  0.088601       0.090974   \n27    0.991008     15.367693   0.991008     0.089190  0.089190       0.091498   \n28    0.990961     15.370435   0.990961     0.089757  0.089757       0.092012   \n29    0.990909     15.374546   0.990909     0.090278  0.090278       0.092456   \n\n    train_rank_icir  train_icir  train_avg_ret  train_avg_std  ...  test_mse  \\\n0          0.466840    0.427567       0.047308       0.414674  ...  0.000548   \n1          0.577383    0.535119       0.064710       0.389087  ...  0.000544   \n2          0.647684    0.603721       0.076463       0.377921  ...  0.000542   \n3          0.697996    0.650651       0.085845       0.370974  ...  0.000541   \n4          0.733979    0.685566       0.092522       0.365394  ...  0.000540   \n5          0.763873    0.714599       0.097727       0.360492  ...  0.000540   \n6          0.787356    0.738206       0.102712       0.356516  ...  0.000539   \n7          0.808309    0.759395       0.108037       0.354210  ...  0.000539   \n8          0.827216    0.778303       0.113285       0.352632  ...  0.000539   \n9          0.843742    0.794956       0.118265       0.351876  ...  0.000539   \n10         0.858263    0.809834       0.122947       0.351634  ...  0.000539   \n11         0.871332    0.823495       0.127585       0.351501  ...  0.000539   \n12         0.883729    0.835981       0.131864       0.351314  ...  0.000538   \n13         0.894365    0.846557       0.136254       0.351350  ...  0.000538   \n14         0.904290    0.856792       0.140400       0.351513  ...  0.000538   \n15         0.913045    0.865711       0.144307       0.351813  ...  0.000538   \n16         0.920917    0.874012       0.147824       0.352177  ...  0.000538   \n17         0.928302    0.881757       0.151394       0.353047  ...  0.000538   \n18         0.935920    0.889241       0.154817       0.353993  ...  0.000538   \n19         0.942822    0.896384       0.158025       0.354713  ...  0.000538   \n20         0.949742    0.903796       0.160939       0.355548  ...  0.000538   \n21         0.955456    0.909829       0.163563       0.356407  ...  0.000538   \n22         0.960563    0.915554       0.166071       0.357241  ...  0.000538   \n23         0.965298    0.921115       0.168255       0.357905  ...  0.000538   \n24         0.970525    0.926514       0.170269       0.358637  ...  0.000538   \n25         0.974972    0.931713       0.172334       0.359376  ...  0.000538   \n26         0.979245    0.936886       0.174263       0.360201  ...  0.000538   \n27         0.983893    0.942252       0.176114       0.361133  ...  0.000538   \n28         0.988287    0.946761       0.178043       0.362176  ...  0.000538   \n29         0.992274    0.951813       0.179849       0.363172  ...  0.000538   \n\n    test_score   test_ic  test_rank_ic  test_rank_icir  test_icir  \\\n0     0.019093  0.019093      0.016151        0.201253   0.235454   \n1     0.022182  0.022182      0.019211        0.240773   0.271386   \n2     0.024320  0.024320      0.022179        0.277894   0.293431   \n3     0.025788  0.025788      0.024161        0.300274   0.305720   \n4     0.026924  0.026924      0.025640        0.314754   0.313158   \n5     0.027864  0.027864      0.026827        0.325218   0.318366   \n6     0.028666  0.028666      0.027767        0.332491   0.322438   \n7     0.029338  0.029338      0.028573        0.337847   0.325159   \n8     0.029909  0.029909      0.029239        0.342592   0.327736   \n9     0.030423  0.030423      0.029813        0.346643   0.330063   \n10    0.030899  0.030899      0.030274        0.349178   0.332048   \n11    0.031368  0.031368      0.030788        0.352373   0.334206   \n12    0.031794  0.031794      0.031242        0.355197   0.336160   \n13    0.032219  0.032219      0.031724        0.358415   0.338207   \n14    0.032575  0.032575      0.032104        0.361162   0.340198   \n15    0.032945  0.032945      0.032453        0.363276   0.342220   \n16    0.033275  0.033275      0.032801        0.365490   0.343869   \n17    0.033597  0.033597      0.033169        0.368092   0.345518   \n18    0.033924  0.033924      0.033485        0.370162   0.347426   \n19    0.034233  0.034233      0.033791        0.372308   0.349302   \n20    0.034493  0.034493      0.034014        0.373836   0.351022   \n21    0.034735  0.034735      0.034259        0.375379   0.352264   \n22    0.034944  0.034944      0.034484        0.376721   0.353290   \n23    0.035140  0.035140      0.034705        0.378024   0.354333   \n24    0.035342  0.035342      0.034916        0.379453   0.355503   \n25    0.035533  0.035533      0.035108        0.380670   0.356717   \n26    0.035727  0.035727      0.035301        0.382039   0.357981   \n27    0.035905  0.035905      0.035472        0.383288   0.359279   \n28    0.036099  0.036099      0.035638        0.384166   0.360457   \n29    0.036249  0.036249      0.035779        0.385067   0.361502   \n\n    test_avg_ret  test_avg_std  test_net_value  test_mdd  \n0      -0.000065      0.023246        0.749001 -0.500584  \n1      -0.000369      0.023395        0.573133 -0.578268  \n2       0.000021      0.023768        0.798434 -0.491118  \n3      -0.000048      0.024100        0.746888 -0.536561  \n4      -0.000158      0.024284        0.676074 -0.618570  \n5       0.000053      0.024132        0.814053 -0.600791  \n6       0.000322      0.023946        1.032941 -0.583196  \n7       0.000455      0.023540        1.168428 -0.574703  \n8       0.000582      0.023593        1.302594 -0.561995  \n9       0.000650      0.023570        1.383499 -0.531994  \n10      0.000712      0.023648        1.457521 -0.496240  \n11      0.000790      0.023644        1.560366 -0.444589  \n12      0.000915      0.023483        1.743926 -0.347711  \n13      0.000855      0.023322        1.660219 -0.309891  \n14      0.000758      0.023151        1.531485 -0.329706  \n15      0.000597      0.023100        1.333104 -0.396652  \n16      0.000472      0.023067        1.196695 -0.459798  \n17      0.000409      0.023074        1.132937 -0.505313  \n18      0.000346      0.023076        1.072357 -0.544104  \n19      0.000335      0.022927        1.065730 -0.555841  \n20      0.000337      0.022848        1.069046 -0.549186  \n21      0.000320      0.022742        1.055983 -0.547511  \n22      0.000209      0.022657        0.960388 -0.591394  \n23      0.000109      0.022619        0.880833 -0.621091  \n24      0.000028      0.022631        0.820882 -0.638387  \n25     -0.000048      0.022602        0.769340 -0.648714  \n26     -0.000132      0.022645        0.714769 -0.661842  \n27     -0.000180      0.022669        0.685129 -0.664550  \n28     -0.000175      0.022664        0.688152 -0.656704  \n29     -0.000182      0.022661        0.683831 -0.654283  \n\n[30 rows x 36 columns]",
      "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>train_loss</th>\n      <th>train_regret</th>\n      <th>train_mse</th>\n      <th>train_score</th>\n      <th>train_ic</th>\n      <th>train_rank_ic</th>\n      <th>train_rank_icir</th>\n      <th>train_icir</th>\n      <th>train_avg_ret</th>\n      <th>train_avg_std</th>\n      <th>...</th>\n      <th>test_mse</th>\n      <th>test_score</th>\n      <th>test_ic</th>\n      <th>test_rank_ic</th>\n      <th>test_rank_icir</th>\n      <th>test_icir</th>\n      <th>test_avg_ret</th>\n      <th>test_avg_std</th>\n      <th>test_net_value</th>\n      <th>test_mdd</th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>0</th>\n      <td>1.021057</td>\n      <td>13.714712</td>\n      <td>1.021057</td>\n      <td>0.032707</td>\n      <td>0.032707</td>\n      <td>0.035265</td>\n      <td>0.466840</td>\n      <td>0.427567</td>\n      <td>0.047308</td>\n      <td>0.414674</td>\n      <td>...</td>\n      <td>0.000548</td>\n      <td>0.019093</td>\n      <td>0.019093</td>\n      <td>0.016151</td>\n      <td>0.201253</td>\n      <td>0.235454</td>\n      <td>-0.000065</td>\n      <td>0.023246</td>\n      <td>0.749001</td>\n      <td>-0.500584</td>\n    </tr>\n    <tr>\n      <th>1</th>\n      <td>1.010056</td>\n      <td>13.989693</td>\n      <td>1.010056</td>\n      <td>0.042209</td>\n      <td>0.042209</td>\n      <td>0.045205</td>\n      <td>0.577383</td>\n      <td>0.535119</td>\n      <td>0.064710</td>\n      <td>0.389087</td>\n      <td>...</td>\n      <td>0.000544</td>\n      <td>0.022182</td>\n      <td>0.022182</td>\n      <td>0.019211</td>\n      <td>0.240773</td>\n      <td>0.271386</td>\n      <td>-0.000369</td>\n      <td>0.023395</td>\n      <td>0.573133</td>\n      <td>-0.578268</td>\n    </tr>\n    <tr>\n      <th>2</th>\n      <td>1.005012</td>\n      <td>14.295711</td>\n      <td>1.005012</td>\n      <td>0.048768</td>\n      <td>0.048768</td>\n      <td>0.052023</td>\n      <td>0.647684</td>\n      <td>0.603721</td>\n      <td>0.076463</td>\n      <td>0.377921</td>\n      <td>...</td>\n      <td>0.000542</td>\n      <td>0.024320</td>\n      <td>0.024320</td>\n      <td>0.022179</td>\n      <td>0.277894</td>\n      <td>0.293431</td>\n      <td>0.000021</td>\n      <td>0.023768</td>\n      <td>0.798434</td>\n      <td>-0.491118</td>\n    </tr>\n    <tr>\n      <th>3</th>\n      <td>1.002013</td>\n      <td>14.509285</td>\n      <td>1.002013</td>\n      <td>0.053631</td>\n      <td>0.053631</td>\n      <td>0.057158</td>\n      <td>0.697996</td>\n      <td>0.650651</td>\n      <td>0.085845</td>\n      <td>0.370974</td>\n      <td>...</td>\n      <td>0.000541</td>\n      <td>0.025788</td>\n      <td>0.025788</td>\n      <td>0.024161</td>\n      <td>0.300274</td>\n      <td>0.305720</td>\n      <td>-0.000048</td>\n      <td>0.024100</td>\n      <td>0.746888</td>\n      <td>-0.536561</td>\n    </tr>\n    <tr>\n      <th>4</th>\n      <td>0.999972</td>\n      <td>14.663292</td>\n      <td>0.999972</td>\n      <td>0.057521</td>\n      <td>0.057521</td>\n      <td>0.061151</td>\n      <td>0.733979</td>\n      <td>0.685566</td>\n      <td>0.092522</td>\n      <td>0.365394</td>\n      <td>...</td>\n      <td>0.000540</td>\n      <td>0.026924</td>\n      <td>0.026924</td>\n      <td>0.025640</td>\n      <td>0.314754</td>\n      <td>0.313158</td>\n      <td>-0.000158</td>\n      <td>0.024284</td>\n      <td>0.676074</td>\n      <td>-0.618570</td>\n    </tr>\n    <tr>\n      <th>5</th>\n      <td>0.998481</td>\n      <td>14.780321</td>\n      <td>0.998481</td>\n      <td>0.060895</td>\n      <td>0.060895</td>\n      <td>0.064584</td>\n      <td>0.763873</td>\n      <td>0.714599</td>\n      <td>0.097727</td>\n      <td>0.360492</td>\n      <td>...</td>\n      <td>0.000540</td>\n      <td>0.027864</td>\n      <td>0.027864</td>\n      <td>0.026827</td>\n      <td>0.325218</td>\n      <td>0.318366</td>\n      <td>0.000053</td>\n      <td>0.024132</td>\n      <td>0.814053</td>\n      <td>-0.600791</td>\n    </tr>\n    <tr>\n      <th>6</th>\n      <td>0.997322</td>\n      <td>14.873756</td>\n      <td>0.997322</td>\n      <td>0.063736</td>\n      <td>0.063736</td>\n      <td>0.067430</td>\n      <td>0.787356</td>\n      <td>0.738206</td>\n      <td>0.102712</td>\n      <td>0.356516</td>\n      <td>...</td>\n      <td>0.000539</td>\n      <td>0.028666</td>\n      <td>0.028666</td>\n      <td>0.027767</td>\n      <td>0.332491</td>\n      <td>0.322438</td>\n      <td>0.000322</td>\n      <td>0.023946</td>\n      <td>1.032941</td>\n      <td>-0.583196</td>\n    </tr>\n    <tr>\n      <th>7</th>\n      <td>0.996384</td>\n      <td>14.949255</td>\n      <td>0.996384</td>\n      <td>0.066338</td>\n      <td>0.066338</td>\n      <td>0.070029</td>\n      <td>0.808309</td>\n      <td>0.759395</td>\n      <td>0.108037</td>\n      <td>0.354210</td>\n      <td>...</td>\n      <td>0.000539</td>\n      <td>0.029338</td>\n      <td>0.029338</td>\n      <td>0.028573</td>\n      <td>0.337847</td>\n      <td>0.325159</td>\n      <td>0.000455</td>\n      <td>0.023540</td>\n      <td>1.168428</td>\n      <td>-0.574703</td>\n    </tr>\n    <tr>\n      <th>8</th>\n      <td>0.995608</td>\n      <td>15.014496</td>\n      <td>0.995608</td>\n      <td>0.068579</td>\n      <td>0.068579</td>\n      <td>0.072247</td>\n      <td>0.827216</td>\n      <td>0.778303</td>\n      <td>0.113285</td>\n      <td>0.352632</td>\n      <td>...</td>\n      <td>0.000539</td>\n      <td>0.029909</td>\n      <td>0.029909</td>\n      <td>0.029239</td>\n      <td>0.342592</td>\n      <td>0.327736</td>\n      <td>0.000582</td>\n      <td>0.023593</td>\n      <td>1.302594</td>\n      <td>-0.561995</td>\n    </tr>\n    <tr>\n      <th>9</th>\n      <td>0.994972</td>\n      <td>15.069002</td>\n      <td>0.994972</td>\n      <td>0.070567</td>\n      <td>0.070567</td>\n      <td>0.074236</td>\n      <td>0.843742</td>\n      <td>0.794956</td>\n      <td>0.118265</td>\n      <td>0.351876</td>\n      <td>...</td>\n      <td>0.000539</td>\n      <td>0.030423</td>\n      <td>0.030423</td>\n      <td>0.029813</td>\n      <td>0.346643</td>\n      <td>0.330063</td>\n      <td>0.000650</td>\n      <td>0.023570</td>\n      <td>1.383499</td>\n      <td>-0.531994</td>\n    </tr>\n    <tr>\n      <th>10</th>\n      <td>0.994430</td>\n      <td>15.113810</td>\n      <td>0.994430</td>\n      <td>0.072407</td>\n      <td>0.072407</td>\n      <td>0.076021</td>\n      <td>0.858263</td>\n      <td>0.809834</td>\n      <td>0.122947</td>\n      <td>0.351634</td>\n      <td>...</td>\n      <td>0.000539</td>\n      <td>0.030899</td>\n      <td>0.030899</td>\n      <td>0.030274</td>\n      <td>0.349178</td>\n      <td>0.332048</td>\n      <td>0.000712</td>\n      <td>0.023648</td>\n      <td>1.457521</td>\n      <td>-0.496240</td>\n    </tr>\n    <tr>\n      <th>11</th>\n      <td>0.993951</td>\n      <td>15.149652</td>\n      <td>0.993951</td>\n      <td>0.074118</td>\n      <td>0.074118</td>\n      <td>0.077662</td>\n      <td>0.871332</td>\n      <td>0.823495</td>\n      <td>0.127585</td>\n      <td>0.351501</td>\n      <td>...</td>\n      <td>0.000539</td>\n      <td>0.031368</td>\n      <td>0.031368</td>\n      <td>0.030788</td>\n      <td>0.352373</td>\n      <td>0.334206</td>\n      <td>0.000790</td>\n      <td>0.023644</td>\n      <td>1.560366</td>\n      <td>-0.444589</td>\n    </tr>\n    <tr>\n      <th>12</th>\n      <td>0.993541</td>\n      <td>15.182568</td>\n      <td>0.993541</td>\n      <td>0.075683</td>\n      <td>0.075683</td>\n      <td>0.079174</td>\n      <td>0.883729</td>\n      <td>0.835981</td>\n      <td>0.131864</td>\n      <td>0.351314</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.031794</td>\n      <td>0.031794</td>\n      <td>0.031242</td>\n      <td>0.355197</td>\n      <td>0.336160</td>\n      <td>0.000915</td>\n      <td>0.023483</td>\n      <td>1.743926</td>\n      <td>-0.347711</td>\n    </tr>\n    <tr>\n      <th>13</th>\n      <td>0.993204</td>\n      <td>15.211255</td>\n      <td>0.993204</td>\n      <td>0.077092</td>\n      <td>0.077092</td>\n      <td>0.080541</td>\n      <td>0.894365</td>\n      <td>0.846557</td>\n      <td>0.136254</td>\n      <td>0.351350</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.032219</td>\n      <td>0.032219</td>\n      <td>0.031724</td>\n      <td>0.358415</td>\n      <td>0.338207</td>\n      <td>0.000855</td>\n      <td>0.023322</td>\n      <td>1.660219</td>\n      <td>-0.309891</td>\n    </tr>\n    <tr>\n      <th>14</th>\n      <td>0.992901</td>\n      <td>15.238413</td>\n      <td>0.992901</td>\n      <td>0.078362</td>\n      <td>0.078362</td>\n      <td>0.081726</td>\n      <td>0.904290</td>\n      <td>0.856792</td>\n      <td>0.140400</td>\n      <td>0.351513</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.032575</td>\n      <td>0.032575</td>\n      <td>0.032104</td>\n      <td>0.361162</td>\n      <td>0.340198</td>\n      <td>0.000758</td>\n      <td>0.023151</td>\n      <td>1.531485</td>\n      <td>-0.329706</td>\n    </tr>\n    <tr>\n      <th>15</th>\n      <td>0.992634</td>\n      <td>15.258163</td>\n      <td>0.992634</td>\n      <td>0.079547</td>\n      <td>0.079547</td>\n      <td>0.082824</td>\n      <td>0.913045</td>\n      <td>0.865711</td>\n      <td>0.144307</td>\n      <td>0.351813</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.032945</td>\n      <td>0.032945</td>\n      <td>0.032453</td>\n      <td>0.363276</td>\n      <td>0.342220</td>\n      <td>0.000597</td>\n      <td>0.023100</td>\n      <td>1.333104</td>\n      <td>-0.396652</td>\n    </tr>\n    <tr>\n      <th>16</th>\n      <td>0.992382</td>\n      <td>15.276007</td>\n      <td>0.992382</td>\n      <td>0.080646</td>\n      <td>0.080646</td>\n      <td>0.083814</td>\n      <td>0.920917</td>\n      <td>0.874012</td>\n      <td>0.147824</td>\n      <td>0.352177</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.033275</td>\n      <td>0.033275</td>\n      <td>0.032801</td>\n      <td>0.365490</td>\n      <td>0.343869</td>\n      <td>0.000472</td>\n      <td>0.023067</td>\n      <td>1.196695</td>\n      <td>-0.459798</td>\n    </tr>\n    <tr>\n      <th>17</th>\n      <td>0.992179</td>\n      <td>15.291256</td>\n      <td>0.992179</td>\n      <td>0.081681</td>\n      <td>0.081681</td>\n      <td>0.084772</td>\n      <td>0.928302</td>\n      <td>0.881757</td>\n      <td>0.151394</td>\n      <td>0.353047</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.033597</td>\n      <td>0.033597</td>\n      <td>0.033169</td>\n      <td>0.368092</td>\n      <td>0.345518</td>\n      <td>0.000409</td>\n      <td>0.023074</td>\n      <td>1.132937</td>\n      <td>-0.505313</td>\n    </tr>\n    <tr>\n      <th>18</th>\n      <td>0.991993</td>\n      <td>15.304655</td>\n      <td>0.991993</td>\n      <td>0.082645</td>\n      <td>0.082645</td>\n      <td>0.085662</td>\n      <td>0.935920</td>\n      <td>0.889241</td>\n      <td>0.154817</td>\n      <td>0.353993</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.033924</td>\n      <td>0.033924</td>\n      <td>0.033485</td>\n      <td>0.370162</td>\n      <td>0.347426</td>\n      <td>0.000346</td>\n      <td>0.023076</td>\n      <td>1.072357</td>\n      <td>-0.544104</td>\n    </tr>\n    <tr>\n      <th>19</th>\n      <td>0.991828</td>\n      <td>15.316535</td>\n      <td>0.991828</td>\n      <td>0.083580</td>\n      <td>0.083580</td>\n      <td>0.086514</td>\n      <td>0.942822</td>\n      <td>0.896384</td>\n      <td>0.158025</td>\n      <td>0.354713</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.034233</td>\n      <td>0.034233</td>\n      <td>0.033791</td>\n      <td>0.372308</td>\n      <td>0.349302</td>\n      <td>0.000335</td>\n      <td>0.022927</td>\n      <td>1.065730</td>\n      <td>-0.555841</td>\n    </tr>\n    <tr>\n      <th>20</th>\n      <td>0.991659</td>\n      <td>15.326437</td>\n      <td>0.991659</td>\n      <td>0.084434</td>\n      <td>0.084434</td>\n      <td>0.087275</td>\n      <td>0.949742</td>\n      <td>0.903796</td>\n      <td>0.160939</td>\n      <td>0.355548</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.034493</td>\n      <td>0.034493</td>\n      <td>0.034014</td>\n      <td>0.373836</td>\n      <td>0.351022</td>\n      <td>0.000337</td>\n      <td>0.022848</td>\n      <td>1.069046</td>\n      <td>-0.549186</td>\n    </tr>\n    <tr>\n      <th>21</th>\n      <td>0.991538</td>\n      <td>15.335515</td>\n      <td>0.991538</td>\n      <td>0.085237</td>\n      <td>0.085237</td>\n      <td>0.087995</td>\n      <td>0.955456</td>\n      <td>0.909829</td>\n      <td>0.163563</td>\n      <td>0.356407</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.034735</td>\n      <td>0.034735</td>\n      <td>0.034259</td>\n      <td>0.375379</td>\n      <td>0.352264</td>\n      <td>0.000320</td>\n      <td>0.022742</td>\n      <td>1.055983</td>\n      <td>-0.547511</td>\n    </tr>\n    <tr>\n      <th>22</th>\n      <td>0.991426</td>\n      <td>15.342097</td>\n      <td>0.991426</td>\n      <td>0.085997</td>\n      <td>0.085997</td>\n      <td>0.088676</td>\n      <td>0.960563</td>\n      <td>0.915554</td>\n      <td>0.166071</td>\n      <td>0.357241</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.034944</td>\n      <td>0.034944</td>\n      <td>0.034484</td>\n      <td>0.376721</td>\n      <td>0.353290</td>\n      <td>0.000209</td>\n      <td>0.022657</td>\n      <td>0.960388</td>\n      <td>-0.591394</td>\n    </tr>\n    <tr>\n      <th>23</th>\n      <td>0.991327</td>\n      <td>15.348646</td>\n      <td>0.991327</td>\n      <td>0.086694</td>\n      <td>0.086694</td>\n      <td>0.089284</td>\n      <td>0.965298</td>\n      <td>0.921115</td>\n      <td>0.168255</td>\n      <td>0.357905</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.035140</td>\n      <td>0.035140</td>\n      <td>0.034705</td>\n      <td>0.378024</td>\n      <td>0.354333</td>\n      <td>0.000109</td>\n      <td>0.022619</td>\n      <td>0.880833</td>\n      <td>-0.621091</td>\n    </tr>\n    <tr>\n      <th>24</th>\n      <td>0.991240</td>\n      <td>15.354338</td>\n      <td>0.991240</td>\n      <td>0.087358</td>\n      <td>0.087358</td>\n      <td>0.089887</td>\n      <td>0.970525</td>\n      <td>0.926514</td>\n      <td>0.170269</td>\n      <td>0.358637</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.035342</td>\n      <td>0.035342</td>\n      <td>0.034916</td>\n      <td>0.379453</td>\n      <td>0.355503</td>\n      <td>0.000028</td>\n      <td>0.022631</td>\n      <td>0.820882</td>\n      <td>-0.638387</td>\n    </tr>\n    <tr>\n      <th>25</th>\n      <td>0.991156</td>\n      <td>15.359694</td>\n      <td>0.991156</td>\n      <td>0.087993</td>\n      <td>0.087993</td>\n      <td>0.090448</td>\n      <td>0.974972</td>\n      <td>0.931713</td>\n      <td>0.172334</td>\n      <td>0.359376</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.035533</td>\n      <td>0.035533</td>\n      <td>0.035108</td>\n      <td>0.380670</td>\n      <td>0.356717</td>\n      <td>-0.000048</td>\n      <td>0.022602</td>\n      <td>0.769340</td>\n      <td>-0.648714</td>\n    </tr>\n    <tr>\n      <th>26</th>\n      <td>0.991083</td>\n      <td>15.363800</td>\n      <td>0.991083</td>\n      <td>0.088601</td>\n      <td>0.088601</td>\n      <td>0.090974</td>\n      <td>0.979245</td>\n      <td>0.936886</td>\n      <td>0.174263</td>\n      <td>0.360201</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.035727</td>\n      <td>0.035727</td>\n      <td>0.035301</td>\n      <td>0.382039</td>\n      <td>0.357981</td>\n      <td>-0.000132</td>\n      <td>0.022645</td>\n      <td>0.714769</td>\n      <td>-0.661842</td>\n    </tr>\n    <tr>\n      <th>27</th>\n      <td>0.991008</td>\n      <td>15.367693</td>\n      <td>0.991008</td>\n      <td>0.089190</td>\n      <td>0.089190</td>\n      <td>0.091498</td>\n      <td>0.983893</td>\n      <td>0.942252</td>\n      <td>0.176114</td>\n      <td>0.361133</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.035905</td>\n      <td>0.035905</td>\n      <td>0.035472</td>\n      <td>0.383288</td>\n      <td>0.359279</td>\n      <td>-0.000180</td>\n      <td>0.022669</td>\n      <td>0.685129</td>\n      <td>-0.664550</td>\n    </tr>\n    <tr>\n      <th>28</th>\n      <td>0.990961</td>\n      <td>15.370435</td>\n      <td>0.990961</td>\n      <td>0.089757</td>\n      <td>0.089757</td>\n      <td>0.092012</td>\n      <td>0.988287</td>\n      <td>0.946761</td>\n      <td>0.178043</td>\n      <td>0.362176</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.036099</td>\n      <td>0.036099</td>\n      <td>0.035638</td>\n      <td>0.384166</td>\n      <td>0.360457</td>\n      <td>-0.000175</td>\n      <td>0.022664</td>\n      <td>0.688152</td>\n      <td>-0.656704</td>\n    </tr>\n    <tr>\n      <th>29</th>\n      <td>0.990909</td>\n      <td>15.374546</td>\n      <td>0.990909</td>\n      <td>0.090278</td>\n      <td>0.090278</td>\n      <td>0.092456</td>\n      <td>0.992274</td>\n      <td>0.951813</td>\n      <td>0.179849</td>\n      <td>0.363172</td>\n      <td>...</td>\n      <td>0.000538</td>\n      <td>0.036249</td>\n      <td>0.036249</td>\n      <td>0.035779</td>\n      <td>0.385067</td>\n      <td>0.361502</td>\n      <td>-0.000182</td>\n      <td>0.022661</td>\n      <td>0.683831</td>\n      <td>-0.654283</td>\n    </tr>\n  </tbody>\n</table>\n<p>30 rows × 36 columns</p>\n</div>"
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "path = r'results/CN/mse/mlp/bpqp/1676998901-7645214'\n",
    "with open(os.path.join(root_dir, path,'0output.dict'), \"rb\") as f:\n",
    "    df_results = pickle.load(f)\n",
    "\n",
    "df_results = pd.DataFrame(df_results)\n",
    "df_results"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "outputs": [
    {
     "data": {
      "text/plain": "<AxesSubplot:>"
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_results.train_regret.plot()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Evaluation"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Backtest"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [
    {
     "data": {
      "text/plain": "           instrument     score     lable        weight\ndatetime                                               \n2017-01-03   SH600006 -0.000243  0.001409  3.826929e-10\n2017-01-03   SH600017 -0.000655 -0.002421 -2.627824e-10\n2017-01-03   SH600022 -0.004294 -0.003905 -2.491723e-09\n2017-01-03   SH600026 -0.005300  0.001435 -2.023505e-09\n2017-01-03   SH600039 -0.000179 -0.002041 -5.894314e-11\n...               ...       ...       ...           ...\n2020-07-31   SZ300482  0.000236 -0.015278 -8.754332e-06\n2020-07-31   SZ300496 -0.003891 -0.036710 -5.973875e-06\n2020-07-31   SZ300558 -0.005442  0.011445 -8.067203e-06\n2020-07-31   SZ300595 -0.002056 -0.004674 -8.145432e-06\n2020-07-31   SZ300630  0.005598 -0.026292 -8.569430e-06\n\n[413461 rows x 4 columns]",
      "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>instrument</th>\n      <th>score</th>\n      <th>lable</th>\n      <th>weight</th>\n    </tr>\n    <tr>\n      <th>datetime</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>2017-01-03</th>\n      <td>SH600006</td>\n      <td>-0.000243</td>\n      <td>0.001409</td>\n      <td>3.826929e-10</td>\n    </tr>\n    <tr>\n      <th>2017-01-03</th>\n      <td>SH600017</td>\n      <td>-0.000655</td>\n      <td>-0.002421</td>\n      <td>-2.627824e-10</td>\n    </tr>\n    <tr>\n      <th>2017-01-03</th>\n      <td>SH600022</td>\n      <td>-0.004294</td>\n      <td>-0.003905</td>\n      <td>-2.491723e-09</td>\n    </tr>\n    <tr>\n      <th>2017-01-03</th>\n      <td>SH600026</td>\n      <td>-0.005300</td>\n      <td>0.001435</td>\n      <td>-2.023505e-09</td>\n    </tr>\n    <tr>\n      <th>2017-01-03</th>\n      <td>SH600039</td>\n      <td>-0.000179</td>\n      <td>-0.002041</td>\n      <td>-5.894314e-11</td>\n    </tr>\n    <tr>\n      <th>...</th>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n    </tr>\n    <tr>\n      <th>2020-07-31</th>\n      <td>SZ300482</td>\n      <td>0.000236</td>\n      <td>-0.015278</td>\n      <td>-8.754332e-06</td>\n    </tr>\n    <tr>\n      <th>2020-07-31</th>\n      <td>SZ300496</td>\n      <td>-0.003891</td>\n      <td>-0.036710</td>\n      <td>-5.973875e-06</td>\n    </tr>\n    <tr>\n      <th>2020-07-31</th>\n      <td>SZ300558</td>\n      <td>-0.005442</td>\n      <td>0.011445</td>\n      <td>-8.067203e-06</td>\n    </tr>\n    <tr>\n      <th>2020-07-31</th>\n      <td>SZ300595</td>\n      <td>-0.002056</td>\n      <td>-0.004674</td>\n      <td>-8.145432e-06</td>\n    </tr>\n    <tr>\n      <th>2020-07-31</th>\n      <td>SZ300630</td>\n      <td>0.005598</td>\n      <td>-0.026292</td>\n      <td>-8.569430e-06</td>\n    </tr>\n  </tbody>\n</table>\n<p>413461 rows × 4 columns</p>\n</div>"
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(os.path.join(root_dir, path,'pred.pkl.test0'), \"rb\") as f:\n",
    "    df_weights = pickle.load(f)\n",
    "\n",
    "df_weights = pd.DataFrame(df_weights)\n",
    "df_weights.index.name = 'datetime'\n",
    "df_weights.columns = ['instrument','score','lable','weight']\n",
    "df_weights"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "outputs": [
    {
     "data": {
      "text/plain": "<AxesSubplot:xlabel='datetime'>"
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_weights[df_weights.instrument == 'SH600006'].lable.cumsum().plot()\n",
    "df_weights[df_weights.instrument == 'SH600006'].score.cumsum().plot()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "outputs": [
    {
     "data": {
      "text/plain": "            score       lable        weight\ncount  860.000000  860.000000  8.600000e+02\nmean    -0.001301   -0.000688 -6.301970e-06\nstd      0.002616    0.019594  8.554393e-06\nmin     -0.014543   -0.098851 -1.874109e-05\n25%     -0.002516   -0.010576 -1.408833e-05\n50%     -0.000999    0.000000 -8.462195e-06\n75%      0.000335    0.008979  2.951182e-12\nmax      0.009950    0.092233  1.661471e-05",
      "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>score</th>\n      <th>lable</th>\n      <th>weight</th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>count</th>\n      <td>860.000000</td>\n      <td>860.000000</td>\n      <td>8.600000e+02</td>\n    </tr>\n    <tr>\n      <th>mean</th>\n      <td>-0.001301</td>\n      <td>-0.000688</td>\n      <td>-6.301970e-06</td>\n    </tr>\n    <tr>\n      <th>std</th>\n      <td>0.002616</td>\n      <td>0.019594</td>\n      <td>8.554393e-06</td>\n    </tr>\n    <tr>\n      <th>min</th>\n      <td>-0.014543</td>\n      <td>-0.098851</td>\n      <td>-1.874109e-05</td>\n    </tr>\n    <tr>\n      <th>25%</th>\n      <td>-0.002516</td>\n      <td>-0.010576</td>\n      <td>-1.408833e-05</td>\n    </tr>\n    <tr>\n      <th>50%</th>\n      <td>-0.000999</td>\n      <td>0.000000</td>\n      <td>-8.462195e-06</td>\n    </tr>\n    <tr>\n      <th>75%</th>\n      <td>0.000335</td>\n      <td>0.008979</td>\n      <td>2.951182e-12</td>\n    </tr>\n    <tr>\n      <th>max</th>\n      <td>0.009950</td>\n      <td>0.092233</td>\n      <td>1.661471e-05</td>\n    </tr>\n  </tbody>\n</table>\n</div>"
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_weights[df_weights.instrument == 'SH600006'].describe()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "outputs": [
    {
     "data": {
      "text/plain": "                          score     lable        weight\ndatetime   instrument                                  \n2017-01-03 SH600006   -0.003386  0.001409 -3.317142e-06\n           SH600017   -0.011407 -0.002421 -1.047036e-05\n           SH600022   -0.163875 -0.003905 -1.089625e-05\n           SH600026   -0.246483  0.001435 -8.870413e-06\n           SH600039   -0.012486 -0.002041 -9.435147e-06\n...                         ...       ...           ...\n2020-07-31 SZ300482    0.046982 -0.015278 -4.101802e-07\n           SZ300496   -0.097650 -0.036710 -4.312199e-07\n           SZ300558   -0.168639  0.011445  6.252971e-07\n           SZ300595   -0.100978 -0.004674  6.725735e-07\n           SZ300630    0.188699 -0.026292  2.942343e-02\n\n[413461 rows x 3 columns]",
      "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></th>\n      <th>score</th>\n      <th>lable</th>\n      <th>weight</th>\n    </tr>\n    <tr>\n      <th>datetime</th>\n      <th>instrument</th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th rowspan=\"5\" valign=\"top\">2017-01-03</th>\n      <th>SH600006</th>\n      <td>-0.003386</td>\n      <td>0.001409</td>\n      <td>-3.317142e-06</td>\n    </tr>\n    <tr>\n      <th>SH600017</th>\n      <td>-0.011407</td>\n      <td>-0.002421</td>\n      <td>-1.047036e-05</td>\n    </tr>\n    <tr>\n      <th>SH600022</th>\n      <td>-0.163875</td>\n      <td>-0.003905</td>\n      <td>-1.089625e-05</td>\n    </tr>\n    <tr>\n      <th>SH600026</th>\n      <td>-0.246483</td>\n      <td>0.001435</td>\n      <td>-8.870413e-06</td>\n    </tr>\n    <tr>\n      <th>SH600039</th>\n      <td>-0.012486</td>\n      <td>-0.002041</td>\n      <td>-9.435147e-06</td>\n    </tr>\n    <tr>\n      <th>...</th>\n      <th>...</th>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n    </tr>\n    <tr>\n      <th rowspan=\"5\" valign=\"top\">2020-07-31</th>\n      <th>SZ300482</th>\n      <td>0.046982</td>\n      <td>-0.015278</td>\n      <td>-4.101802e-07</td>\n    </tr>\n    <tr>\n      <th>SZ300496</th>\n      <td>-0.097650</td>\n      <td>-0.036710</td>\n      <td>-4.312199e-07</td>\n    </tr>\n    <tr>\n      <th>SZ300558</th>\n      <td>-0.168639</td>\n      <td>0.011445</td>\n      <td>6.252971e-07</td>\n    </tr>\n    <tr>\n      <th>SZ300595</th>\n      <td>-0.100978</td>\n      <td>-0.004674</td>\n      <td>6.725735e-07</td>\n    </tr>\n    <tr>\n      <th>SZ300630</th>\n      <td>0.188699</td>\n      <td>-0.026292</td>\n      <td>2.942343e-02</td>\n    </tr>\n  </tbody>\n</table>\n<p>413461 rows × 3 columns</p>\n</div>"
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_backtest = df_weights.reset_index().set_index(['datetime','instrument'])\n",
    "df_backtest"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "outputs": [
    {
     "data": {
      "text/plain": "datetime\n2017-01-03    0.188620\n2017-01-04    0.127590\n2017-01-05    0.263459\n2017-01-06    0.119656\n2017-01-09    0.119161\n                ...   \n2020-07-27    0.189931\n2020-07-28    0.253958\n2020-07-29    0.171562\n2020-07-30    0.373055\n2020-07-31    0.335547\nLength: 868, dtype: float32"
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_backtest.groupby('datetime').apply(lambda  x: np.nanmax(x.weight))"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "outputs": [
    {
     "data": {
      "text/plain": "<AxesSubplot:xlabel='datetime'>"
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "ret_b = df_backtest.groupby('datetime').apply(lambda x: np.dot(x.weight,x.lable))\n",
    "(1+ret_b).cumprod().plot()\n",
    "ret_index = df_backtest.groupby('datetime').apply(lambda x: x.lable.mean())\n",
    "ret_median = df_backtest.groupby('datetime').apply(lambda x: x.lable.median())\n",
    "(1+ret_index).cumprod().plot(style=':')\n",
    "# (1+ret_median).cumprod().plot()\n",
    "(1+report_normal[\"return\"] ).cumprod().plot()\n",
    "(1+report_normal[\"bench\"] ).cumprod().plot()\n",
    "# plt.legend(['back','benchmark1','qlib','benchmark2'])"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "outputs": [
    {
     "data": {
      "text/plain": "datetime\n2017-01-03    1.0\n2017-01-04    1.0\n2017-01-05    1.0\n2017-01-06    1.0\n2017-01-09    1.0\n             ... \n2020-07-27    1.0\n2020-07-28    1.0\n2020-07-29    1.0\n2020-07-30    1.0\n2020-07-31    1.0\nName: weight, Length: 868, dtype: float32"
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_backtest.weight.groupby('datetime').apply(sum)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Top k strategy for end-to-end prediction model"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jianming/anaconda3/envs/env_qlib3.7/lib/python3.7/site-packages/diffcp/cones.py:7: DeprecationWarning: distutils Version classes are deprecated. Use packaging.version instead.\n",
      "  if StrictVersion(scs.__version__) >= StrictVersion('3.0.0'):\n",
      "[2817:MainThread](2023-02-28 21:15:48,570) INFO - qlib.Initialization - [config.py:416] - default_conf: client.\n",
      "[2817:MainThread](2023-02-28 21:15:48,899) INFO - qlib.Initialization - [__init__.py:74] - qlib successfully initialized based on client settings.\n",
      "[2817:MainThread](2023-02-28 21:15:48,901) INFO - qlib.Initialization - [__init__.py:76] - data_path={'__DEFAULT_FREQ': PosixPath('/home/jianming/.qlib/qlib_data/cn_data')}\n",
      "[2817:MainThread](2023-02-28 21:15:48,904) WARNING - qlib.data - [data.py:667] - load calendar error: freq=day, future=True; return current calendar!\n",
      "[2817:MainThread](2023-02-28 21:15:48,905) WARNING - qlib.data - [data.py:670] - You can get future calendar by referring to the following document: https://github.com/microsoft/qlib/blob/main/scripts/data_collector/contrib/README.md\n",
      "[2817:MainThread](2023-02-28 21:15:48,930) WARNING - qlib.BaseExecutor - [executor.py:121] - `common_infra` is not set for <qlib.backtest.executor.SimulatorExecutor object at 0x7f68e638ad10>\n",
      "[2817:MainThread](2023-02-28 21:15:48,963) INFO - qlib.backtest caller - [__init__.py:93] - Create new exchange\n",
      "[2817:MainThread](2023-02-28 21:15:53,656) WARNING - qlib.online operator - [exchange.py:219] - $close field data contains nan.\n",
      "[2817:MainThread](2023-02-28 21:15:53,659) WARNING - qlib.online operator - [exchange.py:219] - $close field data contains nan.\n",
      "[2817:MainThread](2023-02-28 21:15:53,666) WARNING - qlib.online operator - [exchange.py:226] - factor.day.bin file not exists or factor contains `nan`. Order using adjusted_price.\n",
      "[2817:MainThread](2023-02-28 21:15:53,667) WARNING - qlib.online operator - [exchange.py:228] - trade unit 100 is not supported in adjusted_price mode.\n"
     ]
    },
    {
     "data": {
      "text/plain": "backtest loop:   0%|          | 0/871 [00:00<?, ?it/s]",
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "0943e938e0a045d1a16e149bc48b6f6d"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jianming/PONet/programs/qlib/qlib/utils/index_data.py:482: RuntimeWarning: Mean of empty slice\n",
      "  return np.nanmean(self.data)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                                                  risk\n",
      "return_without_cost        mean               0.000058\n",
      "                           std                0.014792\n",
      "                           annualized_return  0.013826\n",
      "                           information_ratio  0.060587\n",
      "                           max_drawdown      -0.489947\n",
      "excess_return_without_cost mean              -0.000419\n",
      "                           std                0.008236\n",
      "                           annualized_return -0.099736\n",
      "                           information_ratio -0.784957\n",
      "                           max_drawdown      -0.435112\n",
      "excess_return_with_cost    mean              -0.000618\n",
      "                           std                0.008234\n",
      "                           annualized_return -0.147147\n",
      "                           information_ratio -1.158444\n",
      "                           max_drawdown      -0.594307\n"
     ]
    }
   ],
   "source": [
    "from pprint import pprint\n",
    "\n",
    "import qlib\n",
    "import pandas as pd\n",
    "from qlib.utils.time import Freq\n",
    "from qlib.utils import flatten_dict\n",
    "from qlib.contrib.evaluate import backtest_daily\n",
    "from qlib.contrib.evaluate import risk_analysis\n",
    "from qlib.contrib.strategy import TopkDropoutStrategy\n",
    "\n",
    "# init qlib\n",
    "qlib.init()\n",
    "\n",
    "CSI300_BENCH = \"SH000905\"\n",
    "STRATEGY_CONFIG = {\n",
    "    \"topk\": 50,\n",
    "    \"n_drop\": 5,\n",
    "    # pred_score, pd.Series\n",
    "    \"signal\": df_backtest.score,\n",
    "}\n",
    "\n",
    "\n",
    "strategy_obj = TopkDropoutStrategy(**STRATEGY_CONFIG)\n",
    "report_normal, positions_normal = backtest_daily(\n",
    "    start_time=\"2017-01-01\", end_time=\"2020-08-01\", strategy=strategy_obj\n",
    ")\n",
    "analysis = dict()\n",
    "# default frequency will be daily (i.e. \"day\")\n",
    "analysis[\"return_without_cost\"] = risk_analysis(report_normal[\"return\"])\n",
    "analysis[\"excess_return_without_cost\"] = risk_analysis(report_normal[\"return\"] - report_normal[\"bench\"])\n",
    "analysis[\"excess_return_with_cost\"] = risk_analysis(report_normal[\"return\"] - report_normal[\"bench\"] - report_normal[\"cost\"])\n",
    "\n",
    "analysis_df = pd.concat(analysis)  # type: pd.DataFrame\n",
    "pprint(analysis_df)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "# weight"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "outputs": [],
   "source": [
    "from qlib.contrib.strategy import WeightStrategyBase\n",
    "class Predweight(WeightStrategyBase):\n",
    "    def __init__(\n",
    "        self,\n",
    "        **kwargs,\n",
    "    ):\n",
    "        super().__init__(**kwargs)\n",
    "\n",
    "    def generate_target_weight_position(self, score, current, trade_start_time, trade_end_time):\n",
    "\n",
    "        target_weight_position = {stock: weight for stock, weight in zip(score.index.values, score.values) if weight>0}\n",
    "\n",
    "        #输出是字典\n",
    "        return target_weight_position"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2817:MainThread](2023-02-28 21:16:42,182) WARNING - qlib.BaseExecutor - [executor.py:121] - `common_infra` is not set for <qlib.backtest.executor.SimulatorExecutor object at 0x7f68e638aad0>\n",
      "[2817:MainThread](2023-02-28 21:16:42,196) INFO - qlib.backtest caller - [__init__.py:93] - Create new exchange\n",
      "[2817:MainThread](2023-02-28 21:16:47,349) WARNING - qlib.online operator - [exchange.py:219] - $close field data contains nan.\n",
      "[2817:MainThread](2023-02-28 21:16:47,352) WARNING - qlib.online operator - [exchange.py:219] - $close field data contains nan.\n",
      "[2817:MainThread](2023-02-28 21:16:47,358) WARNING - qlib.online operator - [exchange.py:226] - factor.day.bin file not exists or factor contains `nan`. Order using adjusted_price.\n",
      "[2817:MainThread](2023-02-28 21:16:47,360) WARNING - qlib.online operator - [exchange.py:228] - trade unit 100 is not supported in adjusted_price mode.\n"
     ]
    },
    {
     "data": {
      "text/plain": "backtest loop:   0%|          | 0/871 [00:00<?, ?it/s]",
      "application/vnd.jupyter.widget-view+json": {
       "version_major": 2,
       "version_minor": 0,
       "model_id": "79146b04b4a146ac82f9da1ce429f9b7"
      }
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jianming/PONet/programs/qlib/qlib/utils/index_data.py:482: RuntimeWarning: Mean of empty slice\n",
      "  return np.nanmean(self.data)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "'The following are analysis results of benchmark return(1day).'\n",
      "                       risk\n",
      "mean               0.000161\n",
      "std                0.014384\n",
      "annualized_return  0.038237\n",
      "information_ratio  0.172313\n",
      "max_drawdown      -0.487617\n",
      "'The following are analysis results of the excess return without cost(1day).'\n",
      "                       risk\n",
      "mean              -0.000002\n",
      "std                0.007014\n",
      "annualized_return -0.000476\n",
      "information_ratio -0.004399\n",
      "max_drawdown      -0.389725\n",
      "'The following are analysis results of the excess return with cost(1day).'\n",
      "                       risk\n",
      "mean              -0.001548\n",
      "std                0.007022\n",
      "annualized_return -0.368445\n",
      "information_ratio -3.401125\n",
      "max_drawdown      -1.370934\n"
     ]
    }
   ],
   "source": [
    "from pprint import pprint\n",
    "from qlib.utils.time import Freq\n",
    "import pandas as pd\n",
    "from qlib.backtest import backtest, executor\n",
    "from qlib.contrib.evaluate import risk_analysis\n",
    "from qlib.utils import flatten_dict\n",
    "from qlib.contrib.strategy import TopkDropoutStrategy\n",
    "\n",
    "STRATEGY_CONFIG = {\n",
    "    \"signal\": df_backtest.weight,\n",
    "}\n",
    "\n",
    "EXECUTOR_CONFIG = {\n",
    "    \"time_per_step\": \"day\",\n",
    "    \"generate_portfolio_metrics\": True,\n",
    "}\n",
    "FREQ = \"day\"\n",
    "backtest_config = {\n",
    "    \"start_time\": \"2017-01-01\",\n",
    "    \"end_time\": \"2020-08-01\",\n",
    "    \"account\": 100000000,\n",
    "    \"benchmark\": \"SH000905\",\n",
    "    \"exchange_kwargs\": {\n",
    "        \"freq\": FREQ,\n",
    "        \"limit_threshold\": 0.099,\n",
    "        \"deal_price\": \"close\",\n",
    "        \"open_cost\": 0.0005,\n",
    "        \"close_cost\": 0.0015,\n",
    "        \"min_cost\": 5,\n",
    "    },\n",
    "}\n",
    "strategy_obj = Predweight(**STRATEGY_CONFIG)\n",
    "executor_obj = executor.SimulatorExecutor(**EXECUTOR_CONFIG)\n",
    "\n",
    "portfolio_metric_dict, indicator_dict = backtest(executor=executor_obj,strategy=strategy_obj,**backtest_config)\n",
    "analysis_freq = \"{0}{1}\".format(*Freq.parse(FREQ))\n",
    "\n",
    "\n",
    "report_normal, positions_normal = portfolio_metric_dict.get(analysis_freq)\n",
    "\n",
    "# analysis\n",
    "analysis = dict()\n",
    "analysis[\"return_without_cost\"] = risk_analysis(\n",
    "    report_normal[\"return\"], freq=analysis_freq\n",
    ")\n",
    "analysis[\"excess_return_without_cost\"] = risk_analysis(\n",
    "    report_normal[\"return\"] - report_normal[\"bench\"], freq=analysis_freq\n",
    ")\n",
    "analysis[\"excess_return_with_cost\"] = risk_analysis(\n",
    "    report_normal[\"return\"] - report_normal[\"bench\"] - report_normal[\"cost\"], freq=analysis_freq\n",
    ")\n",
    "\n",
    "analysis_df = pd.concat(analysis)  # type: pd.DataFrame\n",
    "# log metrics\n",
    "analysis_dict = flatten_dict(analysis_df[\"risk\"].unstack().T.to_dict())\n",
    "# print out results\n",
    "pprint(f\"The following are analysis results of benchmark return({analysis_freq}).\")\n",
    "pprint(risk_analysis(report_normal[\"bench\"], freq=analysis_freq))\n",
    "pprint(f\"The following are analysis results of the excess return without cost({analysis_freq}).\")\n",
    "pprint(analysis[\"excess_return_without_cost\"])\n",
    "pprint(f\"The following are analysis results of the excess return with cost({analysis_freq}).\")\n",
    "pprint(analysis[\"excess_return_with_cost\"])"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "outputs": [
    {
     "data": {
      "text/plain": "                 account        return  total_turnover  turnover  \\\ndatetime                                                           \n2017-01-03  1.000000e+08  0.000000e+00    0.000000e+00  0.000000   \n2017-01-04  9.994954e+07  6.826303e-16    9.692861e+07  0.969286   \n2017-01-05  1.040876e+08  4.341134e-02    2.934328e+08  1.966033   \n2017-01-06  1.021673e+08 -1.839142e-02    3.012541e+08  0.075142   \n2017-01-09  1.007897e+08 -1.275195e-02    3.763859e+08  0.735379   \n...                  ...           ...             ...       ...   \n2020-07-27  1.854228e+07  1.376217e-02    7.254578e+10  1.952806   \n2020-07-28  1.981790e+07  7.093421e-02    7.258336e+10  2.026455   \n2020-07-29  2.063737e+07  4.336934e-02    7.262216e+10  1.957883   \n2020-07-30  2.196530e+07  6.511254e-02    7.263821e+10  0.777868   \n2020-07-31  2.167391e+07 -1.135011e-02    7.268036e+10  1.918778   \n\n              total_cost      cost         value          cash     bench  \ndatetime                                                                  \n2017-01-03  0.000000e+00  0.000000  0.000000e+00  1.000000e+08  0.009122  \n2017-01-04  5.045841e+04  0.000505  9.692861e+07  3.020934e+06  0.011693  \n2017-01-05  2.513906e+05  0.002010  9.523922e+07  8.848333e+06  0.000722  \n2017-01-06  2.572904e+05  0.000057  9.744807e+07  4.719263e+06 -0.004324  \n2017-01-09  3.320807e+05  0.000732  9.682813e+07  3.961582e+06  0.006874  \n...                  ...       ...           ...           ...       ...  \n2020-07-27  7.344750e+07  0.002017  1.776782e+07  7.744583e+05  0.002348  \n2020-07-28  7.348716e+07  0.002139  1.849204e+07  1.325866e+06  0.009673  \n2020-07-29  7.352718e+07  0.002019  1.944961e+07  1.187765e+06  0.026827  \n2020-07-30  7.354300e+07  0.000767  2.125461e+07  7.106925e+05 -0.002884  \n2020-07-31  7.358508e+07  0.001916  2.114124e+07  5.326718e+05  0.010479  \n\n[871 rows x 9 columns]",
      "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>account</th>\n      <th>return</th>\n      <th>total_turnover</th>\n      <th>turnover</th>\n      <th>total_cost</th>\n      <th>cost</th>\n      <th>value</th>\n      <th>cash</th>\n      <th>bench</th>\n    </tr>\n    <tr>\n      <th>datetime</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>2017-01-03</th>\n      <td>1.000000e+08</td>\n      <td>0.000000e+00</td>\n      <td>0.000000e+00</td>\n      <td>0.000000</td>\n      <td>0.000000e+00</td>\n      <td>0.000000</td>\n      <td>0.000000e+00</td>\n      <td>1.000000e+08</td>\n      <td>0.009122</td>\n    </tr>\n    <tr>\n      <th>2017-01-04</th>\n      <td>9.994954e+07</td>\n      <td>6.826303e-16</td>\n      <td>9.692861e+07</td>\n      <td>0.969286</td>\n      <td>5.045841e+04</td>\n      <td>0.000505</td>\n      <td>9.692861e+07</td>\n      <td>3.020934e+06</td>\n      <td>0.011693</td>\n    </tr>\n    <tr>\n      <th>2017-01-05</th>\n      <td>1.040876e+08</td>\n      <td>4.341134e-02</td>\n      <td>2.934328e+08</td>\n      <td>1.966033</td>\n      <td>2.513906e+05</td>\n      <td>0.002010</td>\n      <td>9.523922e+07</td>\n      <td>8.848333e+06</td>\n      <td>0.000722</td>\n    </tr>\n    <tr>\n      <th>2017-01-06</th>\n      <td>1.021673e+08</td>\n      <td>-1.839142e-02</td>\n      <td>3.012541e+08</td>\n      <td>0.075142</td>\n      <td>2.572904e+05</td>\n      <td>0.000057</td>\n      <td>9.744807e+07</td>\n      <td>4.719263e+06</td>\n      <td>-0.004324</td>\n    </tr>\n    <tr>\n      <th>2017-01-09</th>\n      <td>1.007897e+08</td>\n      <td>-1.275195e-02</td>\n      <td>3.763859e+08</td>\n      <td>0.735379</td>\n      <td>3.320807e+05</td>\n      <td>0.000732</td>\n      <td>9.682813e+07</td>\n      <td>3.961582e+06</td>\n      <td>0.006874</td>\n    </tr>\n    <tr>\n      <th>...</th>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n      <td>...</td>\n    </tr>\n    <tr>\n      <th>2020-07-27</th>\n      <td>1.854228e+07</td>\n      <td>1.376217e-02</td>\n      <td>7.254578e+10</td>\n      <td>1.952806</td>\n      <td>7.344750e+07</td>\n      <td>0.002017</td>\n      <td>1.776782e+07</td>\n      <td>7.744583e+05</td>\n      <td>0.002348</td>\n    </tr>\n    <tr>\n      <th>2020-07-28</th>\n      <td>1.981790e+07</td>\n      <td>7.093421e-02</td>\n      <td>7.258336e+10</td>\n      <td>2.026455</td>\n      <td>7.348716e+07</td>\n      <td>0.002139</td>\n      <td>1.849204e+07</td>\n      <td>1.325866e+06</td>\n      <td>0.009673</td>\n    </tr>\n    <tr>\n      <th>2020-07-29</th>\n      <td>2.063737e+07</td>\n      <td>4.336934e-02</td>\n      <td>7.262216e+10</td>\n      <td>1.957883</td>\n      <td>7.352718e+07</td>\n      <td>0.002019</td>\n      <td>1.944961e+07</td>\n      <td>1.187765e+06</td>\n      <td>0.026827</td>\n    </tr>\n    <tr>\n      <th>2020-07-30</th>\n      <td>2.196530e+07</td>\n      <td>6.511254e-02</td>\n      <td>7.263821e+10</td>\n      <td>0.777868</td>\n      <td>7.354300e+07</td>\n      <td>0.000767</td>\n      <td>2.125461e+07</td>\n      <td>7.106925e+05</td>\n      <td>-0.002884</td>\n    </tr>\n    <tr>\n      <th>2020-07-31</th>\n      <td>2.167391e+07</td>\n      <td>-1.135011e-02</td>\n      <td>7.268036e+10</td>\n      <td>1.918778</td>\n      <td>7.358508e+07</td>\n      <td>0.001916</td>\n      <td>2.114124e+07</td>\n      <td>5.326718e+05</td>\n      <td>0.010479</td>\n    </tr>\n  </tbody>\n</table>\n<p>871 rows × 9 columns</p>\n</div>"
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "report_normal"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}