{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "93b9edba",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "import re\n",
    "import pandas as pd\n",
    "\n",
    "folder = Path(\"results\")\n",
    "metric_files = folder.glob(\"*_test_metrics.csv\")\n",
    "\n",
    "pattern = re.compile(r\"\"\"\n",
    "    (?P<models>Signature_FULL)_ # models\n",
    "    dp(?P<dp>\\d+)_             # dp\n",
    "    sl(?P<sl>\\d+)_             # sl\n",
    "    pl(?P<pl>\\d+)_             # pl\n",
    "    dm(?P<dm>\\d+)_             # dm\n",
    "    nh(?P<nh>\\d+)_             # nh\n",
    "    nl(?P<nl>\\d+)_             # nl\n",
    "    si(?P<si>\\d+)_             # si\n",
    "    sc(?P<sc>\\d+)_             # sc\n",
    "    hc(?P<hc>\\d+)_             # hc\n",
    "    mp(?P<mp>\\d+)_             # mp\n",
    "    ff(?P<ff>\\d+)_             # ff\n",
    "    deExp_tp(?P<tp>[\\d\\.]+?)_   # tp (temperature)\n",
    "    cb(?P<cb>[\\d\\.]+?)_         ## 변경된 부분: cb 파라미터 추가\n",
    "    (?P<itr>\\d+)_test_metrics\\.csv$ # itr\n",
    "\"\"\", re.VERBOSE)\n",
    "\n",
    "dfs = []\n",
    "for f in metric_files:\n",
    "    m = pattern.search(f.name)\n",
    "    if not m:\n",
    "        print(f\"pass: {f.name}\")\n",
    "        continue\n",
    "\n",
    "    meta = m.groupdict()\n",
    "\n",
    "    int_fields = [\"dp\", \"sl\", \"pl\", \"dm\", \"nh\", \"nl\",\n",
    "                  \"si\", \"sc\", \"hc\", \"mp\", \"ff\", \"itr\"]\n",
    "    for k in int_fields:\n",
    "        if meta.get(k):\n",
    "            meta[k] = int(meta[k])\n",
    "\n",
    "    float_fields = ['tp', 'cb'] \n",
    "    for k in float_fields:\n",
    "        if meta.get(k):\n",
    "            meta[k] = float(meta[k])\n",
    "\n",
    "    df = pd.read_csv(f)\n",
    "\n",
    "    meta_cols = [\"models\", \"dp\", \"sl\", \"pl\", \"dm\", \"nh\",\n",
    "                 \"nl\", \"si\", \"sc\", \"hc\", \"mp\", \"ff\", \"tp\", \"cb\", \"itr\"] \n",
    "    for col in meta_cols:\n",
    "        df[col] = meta[col]\n",
    "\n",
    "    dfs.append(df)\n",
    "\n",
    "if not dfs:\n",
    "    print(\"error\")\n",
    "else:\n",
    "    combined_df = pd.concat(dfs, ignore_index=True)\n",
    "\n",
    "    combined_df['tp'] = (combined_df['tp'] * 10).astype(int)\n",
    "    combined_df['cb'] = (combined_df['cb'] * 10).astype(int)\n",
    "\n",
    "    # 4) 컬럼 순서\n",
    "    metric_cols = [\"Sharpe\", \"Sortino\", \"MaxDrawdown\",\n",
    "                   \"AnnualReturn\", \"AnnualVol\",\n",
    "                   \"FinalWealthFactor\", \"WinRate\"]\n",
    "\n",
    "    param_cols = [\"models\", \"dp\", \"sl\", \"pl\", \"dm\", \"nh\", \"nl\",\n",
    "                  \"si\", \"sc\", \"hc\", \"mp\", \"ff\", \"tp\", \"cb\", \"itr\"] \n",
    "\n",
    "    combined_df = combined_df[param_cols + metric_cols]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b479ddd8",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_data = combined_df.groupby([\"models\",\"dp\",\"sl\",\"pl\",\"dm\",\"nh\",\"nl\",\"si\",\"hc\", \"mp\", \"ff\",\"tp\"]).mean().round(4)\n",
    "std_data = combined_df.groupby([\"models\",\"dp\",\"sl\",\"pl\",\"dm\",\"nh\",\"nl\",\"si\",\"hc\", \"mp\", \"ff\",\"tp\"]).std().round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "16795bc5-8912-4ccc-9b01-b8f6329a7ada",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_data = mean_data.reset_index()\n",
    "std_data = std_data.reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3e6da8c4-0f06-456d-a760-f63a6566710a",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_data[\"dp\"].unique()\n",
    "pd.set_option('display.max_columns', 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "bac3d769-c712-438d-bcc3-70ace91ad3dc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>models</th>\n",
       "      <th>dp</th>\n",
       "      <th>sl</th>\n",
       "      <th>pl</th>\n",
       "      <th>dm</th>\n",
       "      <th>nh</th>\n",
       "      <th>nl</th>\n",
       "      <th>si</th>\n",
       "      <th>hc</th>\n",
       "      <th>mp</th>\n",
       "      <th>ff</th>\n",
       "      <th>tp</th>\n",
       "      <th>sc</th>\n",
       "      <th>cb</th>\n",
       "      <th>itr</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>AnnualReturn</th>\n",
       "      <th>AnnualVol</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "      <th>WinRate</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Signature_FULL</td>\n",
       "      <td>30</td>\n",
       "      <td>60</td>\n",
       "      <td>20</td>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>64</td>\n",
       "      <td>5</td>\n",
       "      <td>64</td>\n",
       "      <td>13</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.5496</td>\n",
       "      <td>0.6797</td>\n",
       "      <td>0.3415</td>\n",
       "      <td>0.0943</td>\n",
       "      <td>0.2004</td>\n",
       "      <td>1.5678</td>\n",
       "      <td>0.5275</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           models  dp  sl  pl  dm  nh  nl  si  hc  mp  ff  tp   sc   cb  itr  \\\n",
       "0  Signature_FULL  30  60  20   8   8   1   2  64   5  64  13  1.0  0.0  1.0   \n",
       "\n",
       "   Sharpe  Sortino  MaxDrawdown  AnnualReturn  AnnualVol  FinalWealthFactor  \\\n",
       "0  0.5496   0.6797       0.3415        0.0943     0.2004             1.5678   \n",
       "\n",
       "   WinRate  \n",
       "0   0.5275  "
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_data[mean_data[\"dp\"] == 30].sort_values(\"Sharpe\", ascending= False).head(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0191af7c-0987-4a26-92f0-ead524bac7d5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dp</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>30</td>\n",
       "      <td>0.0552</td>\n",
       "      <td>0.0727</td>\n",
       "      <td>0.0162</td>\n",
       "      <td>0.0973</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dp  Sharpe  Sortino  MaxDrawdown  FinalWealthFactor\n",
       "0  30  0.0552   0.0727       0.0162             0.0973"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "std_data[(std_data[\"dp\"] == 30) &\n",
    "         (std_data[\"dm\"] == 8) &\n",
    "         (std_data[\"nh\"] == 8) &\n",
    "         (std_data[\"nl\"] == 1) &\n",
    "         (std_data[\"hc\"] == 64) &\n",
    "         (std_data[\"ff\"] == 64)][[\"dp\",\"Sharpe\",\"Sortino\",\"MaxDrawdown\",\"FinalWealthFactor\"]].round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c241ece3-c617-4bb8-88ba-c8e743675985",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>models</th>\n",
       "      <th>dp</th>\n",
       "      <th>sl</th>\n",
       "      <th>pl</th>\n",
       "      <th>dm</th>\n",
       "      <th>nh</th>\n",
       "      <th>nl</th>\n",
       "      <th>si</th>\n",
       "      <th>hc</th>\n",
       "      <th>mp</th>\n",
       "      <th>ff</th>\n",
       "      <th>tp</th>\n",
       "      <th>sc</th>\n",
       "      <th>cb</th>\n",
       "      <th>itr</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>AnnualReturn</th>\n",
       "      <th>AnnualVol</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "      <th>WinRate</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Signature_FULL</td>\n",
       "      <td>40</td>\n",
       "      <td>60</td>\n",
       "      <td>20</td>\n",
       "      <td>8</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>5</td>\n",
       "      <td>32</td>\n",
       "      <td>13</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.6717</td>\n",
       "      <td>0.8232</td>\n",
       "      <td>0.3611</td>\n",
       "      <td>0.1239</td>\n",
       "      <td>0.2057</td>\n",
       "      <td>1.7903</td>\n",
       "      <td>0.5341</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           models  dp  sl  pl  dm  nh  nl  si  hc  mp  ff  tp   sc   cb  itr  \\\n",
       "1  Signature_FULL  40  60  20   8   4   2   2   8   5  32  13  1.0  0.0  1.0   \n",
       "\n",
       "   Sharpe  Sortino  MaxDrawdown  AnnualReturn  AnnualVol  FinalWealthFactor  \\\n",
       "1  0.6717   0.8232       0.3611        0.1239     0.2057             1.7903   \n",
       "\n",
       "   WinRate  \n",
       "1   0.5341  "
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_data[mean_data[\"dp\"] == 40].sort_values(\"Sharpe\", ascending= False).head(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bcf5f168-e857-433a-aa72-2ca5150993dc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dp</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>40</td>\n",
       "      <td>0.0628</td>\n",
       "      <td>0.0792</td>\n",
       "      <td>0.0037</td>\n",
       "      <td>0.1023</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dp  Sharpe  Sortino  MaxDrawdown  FinalWealthFactor\n",
       "1  40  0.0628   0.0792       0.0037             0.1023"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "std_data[(std_data[\"dp\"] == 40) &\n",
    "         (std_data[\"dm\"] == 8) &\n",
    "         (std_data[\"nh\"] == 4) &\n",
    "         (std_data[\"nl\"] == 2) &\n",
    "         (std_data[\"hc\"] == 8) &\n",
    "         (std_data[\"ff\"] == 32)][[\"dp\",\"Sharpe\",\"Sortino\",\"MaxDrawdown\",\"FinalWealthFactor\"]].round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "323a4cab-6830-4b81-a538-f64d9e355c6c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>models</th>\n",
       "      <th>dp</th>\n",
       "      <th>sl</th>\n",
       "      <th>pl</th>\n",
       "      <th>dm</th>\n",
       "      <th>nh</th>\n",
       "      <th>nl</th>\n",
       "      <th>si</th>\n",
       "      <th>hc</th>\n",
       "      <th>mp</th>\n",
       "      <th>ff</th>\n",
       "      <th>tp</th>\n",
       "      <th>sc</th>\n",
       "      <th>cb</th>\n",
       "      <th>itr</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>AnnualReturn</th>\n",
       "      <th>AnnualVol</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "      <th>WinRate</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Signature_FULL</td>\n",
       "      <td>50</td>\n",
       "      <td>60</td>\n",
       "      <td>20</td>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>64</td>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>13</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.7715</td>\n",
       "      <td>0.9743</td>\n",
       "      <td>0.3271</td>\n",
       "      <td>0.1396</td>\n",
       "      <td>0.193</td>\n",
       "      <td>1.9215</td>\n",
       "      <td>0.5331</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           models  dp  sl  pl  dm  nh  nl  si  hc  mp  ff  tp   sc   cb  itr  \\\n",
       "2  Signature_FULL  50  60  20   8   8   2   2  64   5   8  13  1.0  0.0  1.0   \n",
       "\n",
       "   Sharpe  Sortino  MaxDrawdown  AnnualReturn  AnnualVol  FinalWealthFactor  \\\n",
       "2  0.7715   0.9743       0.3271        0.1396      0.193             1.9215   \n",
       "\n",
       "   WinRate  \n",
       "2   0.5331  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_data[mean_data[\"dp\"] == 50].sort_values(\"Sharpe\", ascending= False).head(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "00a74457-1dc9-46d3-89d4-d8f5df7fc2fb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dp</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>50</td>\n",
       "      <td>0.0627</td>\n",
       "      <td>0.0998</td>\n",
       "      <td>0.0094</td>\n",
       "      <td>0.1795</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dp  Sharpe  Sortino  MaxDrawdown  FinalWealthFactor\n",
       "2  50  0.0627   0.0998       0.0094             0.1795"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "std_data[(std_data[\"dp\"] == 50) &\n",
    "         (std_data[\"dm\"] == 8) &\n",
    "         (std_data[\"nh\"] == 8) &\n",
    "         (std_data[\"nl\"] == 2) &\n",
    "         (std_data[\"hc\"] == 64) &\n",
    "         (std_data[\"ff\"] == 8)][[\"dp\",\"Sharpe\",\"Sortino\",\"MaxDrawdown\",\"FinalWealthFactor\"]].round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c2adfda-d07f-418e-b4b9-b28f1f448bda",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "bc26503f-2ebe-4d53-8480-9f9fb4eee284",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dp</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>50</td>\n",
       "      <td>0.7715</td>\n",
       "      <td>0.9743</td>\n",
       "      <td>0.3271</td>\n",
       "      <td>1.9215</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dp  Sharpe  Sortino  MaxDrawdown  FinalWealthFactor\n",
       "2  50  0.7715   0.9743       0.3271             1.9215"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# BASE SETTING\n",
    "mean_data[(mean_data[\"dm\"] == 8) &\n",
    "         (mean_data[\"nh\"] == 8) &\n",
    "         (mean_data[\"nl\"] == 2) &\n",
    "         (mean_data[\"hc\"] == 64) &\n",
    "         (mean_data[\"ff\"] == 8)][[\"dp\",\"Sharpe\",\"Sortino\",\"MaxDrawdown\",\"FinalWealthFactor\"]].round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9919356c-4dc8-4534-a68f-8c41e27b423b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dp</th>\n",
       "      <th>Sharpe</th>\n",
       "      <th>Sortino</th>\n",
       "      <th>MaxDrawdown</th>\n",
       "      <th>FinalWealthFactor</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>50</td>\n",
       "      <td>0.0627</td>\n",
       "      <td>0.0998</td>\n",
       "      <td>0.0094</td>\n",
       "      <td>0.1795</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dp  Sharpe  Sortino  MaxDrawdown  FinalWealthFactor\n",
       "2  50  0.0627   0.0998       0.0094             0.1795"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# BASE SETTING\n",
    "std_data[(std_data[\"dm\"] == 8) &\n",
    "         (std_data[\"nh\"] == 8) &\n",
    "         (std_data[\"nl\"] == 2) &\n",
    "         (std_data[\"hc\"] == 64) &\n",
    "         (std_data[\"ff\"] == 8)][[\"dp\",\"Sharpe\",\"Sortino\",\"MaxDrawdown\",\"FinalWealthFactor\"]].round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "866d1777-e70d-42b3-8e9c-db3644630e59",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ccc91321-5c9a-460d-a525-c09e267c587e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44a115d5-cef7-4d70-804e-c1078904083c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2a633aa-bf6a-4016-bd40-3e663b06ead1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1dcd0a1-b894-489d-bfc8-d5ebd0acd25b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a618c989-38f4-4097-9c12-ebe6fd365049",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "PyTorch 2.6 (NGC 25.01/Python 3.12) on Backend.AI",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
