{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ce93ab14-3eee-407e-be4d-b7a2820cc7ac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "merge regret mean:  22526.393999999975 cumulative regret std:  10828.857210854523\n",
      "merge cumulative regret mean:  2159852.3663999983 cumulative regret std:  479750.7005181186\n",
      "mallows regret mean:  88584.85799999996 cumulative regret std:  7559.063691745153\n",
      "mallows cumulative regret mean:  5289282.623999998 cumulative regret std:  331490.3419659594\n",
      "regret win:  50 , tie:  0 , loss:  0\n",
      "AUC win:  50 , tie:  0 , loss:  0\n"
     ]
    }
   ],
   "source": [
    "# import torch\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "def read_file(folder):\n",
    "    merge = []\n",
    "    mallows = []\n",
    "    random = []\n",
    "    methods = ['Merge', 'DPPMallows', 'Random']\n",
    "    arrays = [merge, mallows, random]\n",
    "    for method, array in zip(methods, arrays):\n",
    "        for i in range(50):\n",
    "            df = pd.read_csv(f'./{folder}/{method}_{i}.csv')\n",
    "            value = df.value.to_list()[:55]\n",
    "            array.append(value)\n",
    "        array = np.array(array)\n",
    "    return {'merge': np.array(merge), 'mallows': np.array(mallows), 'random': np.array(random)}\n",
    "\n",
    "d = read_file('instances_a280_n279_uncorr_08.ttp_2_10000_60000')\n",
    "\n",
    "def array_to_regret(d):\n",
    "    max = np.max([d['merge'], d['mallows'], d['random']])\n",
    "    best_so_far = [np.maximum.accumulate(res, axis=1) for res in [d['merge'], d['mallows'], d['random']]]\n",
    "    regrets = [max - bfs for bfs in best_so_far]\n",
    "    return {'merge': regrets[0], 'mallows': regrets[1], 'random': regrets[2]}\n",
    "\n",
    "regrets = array_to_regret(d)\n",
    "\n",
    "for i in ['merge', 'mallows']:\n",
    "    print(i, 'regret mean: ', regrets[i][:, -1].mean(), 'cumulative regret std: ', regrets[i][:, -1].std())\n",
    "    print(i, 'cumulative regret mean: ', regrets[i].sum(axis=1).mean(), 'cumulative regret std: ', regrets[i].sum(axis=1).std())\n",
    "    \n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i, -1] < regrets['mallows'][i, -1]:\n",
    "        win += 1\n",
    "    elif regrets['merge'][i, -1] == regrets['mallows'][i, -1]:\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('regret win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i].sum() < regrets['mallows'][i].sum():\n",
    "        win += 1\n",
    "    elif regrets['merge'][i].sum() == regrets['mallows'][i].sum():\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('AUC win: ', win, ', tie: ', tie, ', loss: ', loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7baacae8-fa11-4c0e-8ab6-0225c740c630",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ---------- 1. 读取并整理数据 ----------\n",
    "results = {'Mallows': d['mallows'], 'Merge': d['merge']}\n",
    "\n",
    "global_max = -np.inf\n",
    "for arr in results.values():\n",
    "    global_max = max(global_max, arr[:, :].max())\n",
    "\n",
    "# 把每个算法的 simple regret（best‑so‑far – global_min）整理成均值±std\n",
    "mean_regret = {}\n",
    "std_regret  = {}\n",
    "\n",
    "for algo, outputs in results.items():\n",
    "    outputs        = outputs[:, :]                          \n",
    "    best_so_far    = np.maximum.accumulate(outputs, axis=1)    \n",
    "    regrets        = global_max - best_so_far              \n",
    "    mean_regret[algo] = regrets.mean(axis=0)             \n",
    "    std_regret[algo]  = regrets.std(axis=0)\n",
    "\n",
    "# ---------- 2. 画图 ----------\n",
    "iters = np.arange(1, 56)\n",
    "\n",
    "plt.figure(figsize=(3, 3))\n",
    "\n",
    "for algo in mean_regret:\n",
    "    mean = mean_regret[algo]\n",
    "    std  = std_regret[algo]\n",
    "    plt.plot(iters, mean, label=algo)\n",
    "    plt.fill_between(iters, mean - std, mean + std, alpha=0.2)\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Simple Regret (mean ± 1 std)\")\n",
    "plt.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "# plt.yscale(\"log\")           # 若差距跨数量级，建议用对数轴；可去掉\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"ttp_1.pdf\", dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "961e944f-0ca6-453e-a15d-4a29f7d816e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "merge regret mean:  145961.83499945735 cumulative regret std:  71609.04924044195\n",
      "merge cumulative regret mean:  13050540.5690045 cumulative regret std:  3519536.4087797604\n",
      "mallows regret mean:  556663.5545998329 cumulative regret std:  58116.0186344121\n",
      "mallows cumulative regret mean:  33266720.951492514 cumulative regret std:  2688482.805945845\n",
      "regret win:  50 , tie:  0 , loss:  0\n",
      "AUC win:  50 , tie:  0 , loss:  0\n"
     ]
    }
   ],
   "source": [
    "# import torch\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "def read_file(folder):\n",
    "    merge = []\n",
    "    mallows = []\n",
    "    random = []\n",
    "    methods = ['Merge', 'DPPMallows', 'Random']\n",
    "    arrays = [merge, mallows, random]\n",
    "    for method, array in zip(methods, arrays):\n",
    "        for i in range(50):\n",
    "            df = pd.read_csv(f'./{folder}/{method}_{i}.csv')\n",
    "            value = df.value.to_list()[:55]\n",
    "            array.append(value)\n",
    "        array = np.array(array)\n",
    "    return {'merge': np.array(merge), 'mallows': np.array(mallows), 'random': np.array(random)}\n",
    "\n",
    "d = read_file('instances_a280_n837_bounded-strongly-corr_08.ttp_2_10000_60000')\n",
    "\n",
    "def array_to_regret(d):\n",
    "    max = np.max([d['merge'], d['mallows'], d['random']])\n",
    "    best_so_far = [np.maximum.accumulate(res, axis=1) for res in [d['merge'], d['mallows'], d['random']]]\n",
    "    regrets = [max - bfs for bfs in best_so_far]\n",
    "    return {'merge': regrets[0], 'mallows': regrets[1], 'random': regrets[2]}\n",
    "\n",
    "regrets = array_to_regret(d)\n",
    "\n",
    "for i in ['merge', 'mallows']:\n",
    "    print(i, 'regret mean: ', regrets[i][:, -1].mean(), 'cumulative regret std: ', regrets[i][:, -1].std())\n",
    "    print(i, 'cumulative regret mean: ', regrets[i].sum(axis=1).mean(), 'cumulative regret std: ', regrets[i].sum(axis=1).std())\n",
    "    \n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i, -1] < regrets['mallows'][i, -1]:\n",
    "        win += 1\n",
    "    elif regrets['merge'][i, -1] == regrets['mallows'][i, -1]:\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('regret win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i].sum() < regrets['mallows'][i].sum():\n",
    "        win += 1\n",
    "    elif regrets['merge'][i].sum() == regrets['mallows'][i].sum():\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('AUC win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0e1a080d-abe9-4883-b9ce-d4a24fc8ef10",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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CL1eH/A+7t69m/z8/Fb9Po4ePZrt27ezZcsW/zZ48GAmT57sfyzet0YS6Wh5qFmyZIlsNBrlhQsXyjt37pR/97vfycnJyfLJkycjbVrU8Ic//EFOSkqSV65cKZ84ccK/Wa1W/zn33HOP3KlTJ/mHH36QN2zYIA8bNkweNmxYBK2OTqrPmsmyeN8aS4sTIlmW5ddee03u1KmTbDAY5PPPP1/+6aefIm1SVAHUui1YsMB/js1mk++99145JSVFjouLkydMmCCfOHEickZHKWcKkXjfGoeovhcIBBGnRcWIBAJB80QIkUAgiDhCiAQCQcQRQiQQCCKOECKBQBBxhBAJBIKII4RIIBBEHCFEAoEg4gghEjQ7srOzeeWVVyJthiCECCES1MuUKVMYP348AJdccklAf+Zws3Dhwhq9fUBp0/q73/2uyewQhB/Rj0jQ5DgcDgwGQ6OvT09PD6E1gmhAeESCoJgyZQq5ubnMnz8fSZKQJIlDhw4BsGPHDq688koSEhJo27Ytt912G4WFhf5rL7nkEu677z4eeugh2rRpwxVXXAHAyy+/TL9+/YiPjycrK4t7770Xi8UCwMqVK5k6dSpms9n/ek899RRQc2iWn5/PddddR0JCAomJidx0000BPameeuopBgwYwL/+9S+ys7NJSkrilltuoby8PLxvmiBohBAJgmL+/PkMGzaMu+++mxMnTnDixAmysrIoLS3l0ksvJScnhw0bNvD1119z6tQpbrrppoDrFy1ahMFgYM2aNbz55puA0k/81Vdf5ZdffmHRokX88MMP/PGPfwRg+PDhvPLKKyQmJvpfb8aMGTXs8ng8XHfddRQXF5Obm8t3333HgQMHuPnmmwPO279/P5988gmff/45n3/+Obm5ubz44othercEqol0+b8gurnjjjvk6667Tpblmi0vZFmWn332Wfnyyy8P2HfkyBEZkHfv3u2/Licnp8HX+vDDD+W0tDT/8wULFshJSUk1zuvcubP8t7/9TZZlWf72229lrVYr5+fn+4//8ssvMiCvX79elmVZnj17thwXFyeXlZX5z3n00UfloUOHNmiToGkQHpHgrNi6dSsrVqwgISHBv/Xq1QtQvBAfgwYNqnHt999/z+jRo+nQoQMmk4nbbruNoqIirFZr0K+/a9cusrKyyMrK8u/r06cPycnJ7Nq1y78vOzsbk8nkf96+fXux1l0UIYLVgrPCYrFwzTXXMHfu3BrH2rdv738cHx8fcOzQoUNcffXV/OEPf+D5558nNTWV1atXc+edd+JwOIiLiwupnXq9PuC5JEl4PJ6Qvoag8QghEgSNwWDA7XYH7Bs4cCAfffQR2dnZ6HTB/ztt3LgRj8fDvHnz0GgUx3zp0qUNvt6Z9O7dmyNHjnDkyBG/V7Rz505KS0vp06dP0PYIIosYmgmCJjs7m59//plDhw5RWFiIx+Nh2rRpFBcXM2nSJPLy8ti/fz/ffPMNU6dOrVdEunXrhtPp5LXXXuPAgQP861//8gexq7+exWJh+fLlFBYW1jpkGzNmDP369WPy5Mls2rSJ9evXc/vttzNy5EgGDx4c8vdAEB6EEAmCZsaMGWi1Wvr06UN6ejr5+flkZmayZs0a3G43l19+Of369eOhhx4iOTnZ7+nURv/+/Xn55ZeZO3cuffv25f3332fOnDkB5wwfPpx77rmHm2++mfT0dP7yl7/UuI8kSXz66aekpKRw8cUXM2bMGLp27cp//vOfkP/+gvAhelYLBIKIIzwigUAQcYQQCQSCiCOESCAQRBwhRAKBIOIIIRIIBBFHCJFAIIg4QogEAkHEEUIkEAgijhAigUAQcYQQCQSCiCOESCAQRBwhRAKBIOL8Pws9OUf6POukAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ---------- 1. 读取并整理数据 ----------\n",
    "results = {'Mallows': d['mallows'], 'Merge': d['merge']}\n",
    "\n",
    "global_max = -np.inf\n",
    "for arr in results.values():\n",
    "    global_max = max(global_max, arr[:, :].max())\n",
    "\n",
    "# 把每个算法的 simple regret（best‑so‑far – global_min）整理成均值±std\n",
    "mean_regret = {}\n",
    "std_regret  = {}\n",
    "\n",
    "for algo, outputs in results.items():\n",
    "    outputs        = outputs[:, :]                          \n",
    "    best_so_far    = np.maximum.accumulate(outputs, axis=1)    \n",
    "    regrets        = global_max - best_so_far              \n",
    "    mean_regret[algo] = regrets.mean(axis=0)             \n",
    "    std_regret[algo]  = regrets.std(axis=0)\n",
    "\n",
    "# ---------- 2. 画图 ----------\n",
    "iters = np.arange(1, 56)\n",
    "\n",
    "plt.figure(figsize=(3, 3))\n",
    "\n",
    "for algo in mean_regret:\n",
    "    mean = mean_regret[algo]\n",
    "    std  = std_regret[algo]\n",
    "    plt.plot(iters, mean, label=algo)\n",
    "    plt.fill_between(iters, mean - std, mean + std, alpha=0.2)\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Simple Regret (mean ± 1 std)\")\n",
    "plt.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "# plt.yscale(\"log\")           # 若差距跨数量级，建议用对数轴；可去掉\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"ttp_2.pdf\", dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4967f801-d43f-4ec3-87f2-454ec0a9e5a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "merge regret mean:  74965.35892147488 cumulative regret std:  29562.25562402866\n",
      "merge cumulative regret mean:  7095727.4420137815 cumulative regret std:  1538834.2145249024\n",
      "mallows regret mean:  278589.7429801994 cumulative regret std:  26469.638394077123\n",
      "mallows cumulative regret mean:  16575741.826229028 cumulative regret std:  1446788.1571732673\n",
      "regret win:  50 , tie:  0 , loss:  0\n",
      "AUC win:  50 , tie:  0 , loss:  0\n"
     ]
    }
   ],
   "source": [
    "# import torch\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "def read_file(folder):\n",
    "    merge = []\n",
    "    mallows = []\n",
    "    random = []\n",
    "    methods = ['Merge', 'DPPMallows', 'Random']\n",
    "    arrays = [merge, mallows, random]\n",
    "    for method, array in zip(methods, arrays):\n",
    "        for i in range(50):\n",
    "            df = pd.read_csv(f'./{folder}/{method}_{i}.csv')\n",
    "            value = df.value.to_list()[:55]\n",
    "            array.append(value)\n",
    "        array = np.array(array)\n",
    "    return {'merge': np.array(merge), 'mallows': np.array(mallows), 'random': np.array(random)}\n",
    "\n",
    "d = read_file('instances_a280_n837_uncorr_08.ttp_2_10000_60000')\n",
    "\n",
    "def array_to_regret(d):\n",
    "    max = np.max([d['merge'], d['mallows'], d['random']])\n",
    "    best_so_far = [np.maximum.accumulate(res, axis=1) for res in [d['merge'], d['mallows'], d['random']]]\n",
    "    regrets = [max - bfs for bfs in best_so_far]\n",
    "    return {'merge': regrets[0], 'mallows': regrets[1], 'random': regrets[2]}\n",
    "\n",
    "regrets = array_to_regret(d)\n",
    "\n",
    "for i in ['merge', 'mallows']:\n",
    "    print(i, 'regret mean: ', regrets[i][:, -1].mean(), 'cumulative regret std: ', regrets[i][:, -1].std())\n",
    "    print(i, 'cumulative regret mean: ', regrets[i].sum(axis=1).mean(), 'cumulative regret std: ', regrets[i].sum(axis=1).std())\n",
    "    \n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i, -1] < regrets['mallows'][i, -1]:\n",
    "        win += 1\n",
    "    elif regrets['merge'][i, -1] == regrets['mallows'][i, -1]:\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('regret win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i].sum() < regrets['mallows'][i].sum():\n",
    "        win += 1\n",
    "    elif regrets['merge'][i].sum() == regrets['mallows'][i].sum():\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('AUC win: ', win, ', tie: ', tie, ', loss: ', loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "2108d1a2-c1c4-4b6f-90d1-e437615c0b38",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ---------- 1. 读取并整理数据 ----------\n",
    "results = {'Mallows': d['mallows'], 'Merge': d['merge']}\n",
    "\n",
    "global_max = -np.inf\n",
    "for arr in results.values():\n",
    "    global_max = max(global_max, arr[:, :].min())\n",
    "\n",
    "# 把每个算法的 simple regret（best‑so‑far – global_min）整理成均值±std\n",
    "mean_regret = {}\n",
    "std_regret  = {}\n",
    "\n",
    "for algo, outputs in results.items():\n",
    "    outputs        = outputs[:, :]                          \n",
    "    best_so_far    = np.maximum.accumulate(outputs, axis=1)    \n",
    "    regrets        = global_max - best_so_far              \n",
    "    mean_regret[algo] = regrets.mean(axis=0)             \n",
    "    std_regret[algo]  = regrets.std(axis=0)\n",
    "\n",
    "# ---------- 2. 画图 ----------\n",
    "iters = np.arange(1, 56)\n",
    "\n",
    "plt.figure(figsize=(3, 3))\n",
    "\n",
    "for algo in mean_regret:\n",
    "    mean = mean_regret[algo]\n",
    "    std  = std_regret[algo]\n",
    "    plt.plot(iters, mean, label=algo)\n",
    "    plt.fill_between(iters, mean - std, mean + std, alpha=0.2)\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Simple Regret (mean ± 1 std)\")\n",
    "plt.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "# plt.yscale(\"log\")           # 若差距跨数量级，建议用对数轴；可去掉\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"ttp_3.pdf\", dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
