{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import wilcoxon\n",
    "from scipy.stats import rankdata\n",
    "\n",
    "def string2pair(information):\n",
    "    if type(information) == np.float64:\n",
    "        mean = information\n",
    "        std = 0\n",
    "    else:\n",
    "        information = information.strip()\n",
    "        information = information.strip(')')\n",
    "        result = information.split('(')\n",
    "        mean = float(result[0])\n",
    "        std = float(result[1])\n",
    "    return (mean,std)\n",
    "\n",
    "\n",
    "# deep learning classifier:\n",
    "#'MLP','FCN','ResNet','Encoder','MCNN','t-LeNet','MCDCNN','Time-CNN','TWIESN','InceptionTime','OS-CNN'\n",
    "#'OS-CNN-ENS(2)','OS-CNN-ENS(3)','OS-CNN-ENS(4)',...,'OS-CNN-ENS(10)',\n",
    "\n",
    "# traditional classifier:\n",
    "#'1-NN DTW','1-NN DTW CV','TSBF','LS','EE(PROP)','BOSS','ST','WEASEL','HIVE-COTE','COTE','PF'\n",
    "\n",
    "\n",
    "# full\n",
    "#'./Full_result_on_85_datasets.csv'\n",
    "get_result_list = ['Encoder','FCN','ResNet','MLP','MCNN','t-LeNet','MCDCNN',\n",
    "                    'Time-CNN','TWIESN','1-NN DTW CV','1-NN DTW',\n",
    "                    'LS','TSBF','EE(PROP)','PF','ST','BOSS','WEASEL','Flat-COTE','HIVE-COTE','InceptionTime','Inception',\n",
    "                   'OS-CNN','OS-CNN-ENS(5)','OS-CNN-ENS(8)']\n",
    "\n",
    "# Result_for_30_UEA_datasets\n",
    "# get_result_list = [\n",
    "#     'TapNet',\n",
    "#     'MLSTM-FCN',\n",
    "#     'WEASEL+MUSE',\n",
    "#     'ED-1NN',\n",
    "#     'DTW-1NN-I',\n",
    "#     'DTW-1NND',\n",
    "#     'ED-1NN(norm)',\n",
    "#     'DTW-1NN-I(norm)',\n",
    "#     'DTW-1NND(norm)',\n",
    "#     'OS-CNN',\n",
    "# ]\n",
    "\n",
    "# Result_for_85_UCR_datasets\n",
    "get_result_list = [\n",
    "        'TS-CHIEF',\n",
    "        'HIVE-COTE',\n",
    "        'ROCKET',\n",
    "        'InceptionTime',\n",
    "        'STC',\n",
    "        'ResNet',\n",
    "        'PF',\n",
    "        'UOS-CNN',\n",
    "]\n",
    "\n",
    "#Result_for_128_UCR_datasets_set2\n",
    "# get_result_list = [\n",
    "#         'ROCKET',\n",
    "#         'InceptionTime',\n",
    "#         'ResNet',\n",
    "#         'UOS-CNN',\n",
    "# ]\n",
    "\n",
    "# # Result_for_128_UCR_datasets_set1\n",
    "# get_result_list = [\n",
    "#         'ROCKET',\n",
    "#         'Inception',\n",
    "#         'ResNet',\n",
    "#         'OS-CNN-RES(2)',\n",
    "# ]\n",
    "\n",
    "# get_result_list = [\n",
    "#         'OS-CNN',\n",
    "#     'OS-CNN-ENS(2)',\n",
    "#     'OS-CNN-ENS(3)',\n",
    "#     'OS-CNN-ENS(4)',\n",
    "#     'OS-CNN-ENS(5)',\n",
    "#     'OS-CNN-ENS(6)',\n",
    "#     'OS-CNN-ENS(7)',\n",
    "#     'OS-CNN-ENS(8)',\n",
    "#     'OS-CNN-RES(2)',\n",
    "#     'OS-CNN-RES(3)',\n",
    "#     'UOS-CNN',\n",
    "# ]\n",
    "\n",
    "# get_result_list = [\n",
    "\n",
    "#         'TS-CHIEF',\n",
    "#         'UOS-CNN',\n",
    "# ]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "average accuracy [84.64141176 84.7139969  85.07741972 84.52887304 84.15706813 82.20125791\n",
      " 80.41877305 85.07028551]\n"
     ]
    }
   ],
   "source": [
    "# result_path = './Result_for_30_UEA_datasets.csv'\n",
    "result_path = './Result_for_85_UCR_datasets.csv'\n",
    "#result_path = './Result_for_128_UCR_datasets.csv'\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "file = pd.read_csv(result_path)\n",
    "result_block = np.zeros([file.shape[0],len(get_result_list)])\n",
    "for i in range(file.shape[0]):\n",
    "    data_name = file['dataset_name'][i]\n",
    "    for j, keras_Baseline in enumerate (get_result_list):\n",
    "        temp = string2pair(file[keras_Baseline][i])\n",
    "        result_block[i,j] = temp[0]\n",
    "print('average accuracy', np.mean(result_block,axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "average rank [3.68 3.99 3.64 4.05 5.05 5.41 6.57 3.59]\n",
      "wins [18  9  8  7 12  5  1 17]\n"
     ]
    }
   ],
   "source": [
    "def get_maxest_index(result_block):\n",
    "    index = np.argsort(result_block,axis = 1)\n",
    "    temp = np.zeros(result_block.shape)\n",
    "    for i in range(result_block.shape[0]):\n",
    "        l=result_block[i,:]\n",
    "        temp[i,:] = rankdata(l,method='min')\n",
    "        temp[i,:] = rankdata(l)\n",
    "    return temp\n",
    "\n",
    "\n",
    "\n",
    "def get_average_rank_and_wins(result_block):\n",
    "    max_index_result = get_maxest_index(-result_block)\n",
    "    average_rank =  np.around( np.average(max_index_result,axis=0), decimals=6)\n",
    "    \n",
    "\n",
    "    wins = np.count_nonzero(max_index_result==1, axis = 0)\n",
    "\n",
    "    return average_rank, wins\n",
    "\n",
    "average_rank, wins= get_average_rank_and_wins(result_block)\n",
    "\n",
    "print('average rank',np.round(average_rank,2))\n",
    "print('wins', wins)\n",
    "number_of_dataset = result_block.shape[0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Index(['Average rank'], dtype='object')\n",
      "                       0          1         2              3         4  \\\n",
      "Classifier      TS-CHIEF  HIVE-COTE    ROCKET  InceptionTime       STC   \n",
      "Average rank    3.682353   3.994118  3.641176       4.052941  5.052941   \n",
      "Counts of wins        18          9         8              7        12   \n",
      "\n",
      "                       5         6         7  \n",
      "Classifier        ResNet        PF   UOS-CNN  \n",
      "Average rank    5.411765  6.570588  3.594118  \n",
      "Counts of wins         5         1        17  \n",
      "\n",
      "\\begin{tabular}{|l|l|l|l|l|l|l|l|l|}\n",
      "\\hline\n",
      "Classifier           &              TS-CHIEF &  HIVE-COTE &                   ROCKET &  InceptionTime &       STC &    ResNet &        PF &                     UOS-CNN  \\\\ \\hline\n",
      "Average rank         &              3.682353 &   3.994118 &                 3.641176 &       4.052941 &  5.052941 &  5.411765 &  6.570588 &  \\textbf{3.594118} \\\\ \\hline\n",
      "Counts of wins       &  \\textbf{18}&          9 &                        8 &              7 &        12 &         5 &         1 &                          17  \\\\ \\hline\n",
      "Average accuracy(\\textbackslash \\%) &                 84.64 &      84.71 &  \\textbf{85.08}&          84.53 &     84.16 &      82.2 &     80.42 &                       85.07  \\\\ \\hline\n",
      "\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "def blod_min(array):\n",
    "    blod_val = min(array)\n",
    "    output_result = []\n",
    "    for i in array:\n",
    "        if i == blod_val:\n",
    "            element_str = 'blodstart '+str(i)+' blodend'\n",
    "        else:\n",
    "            element_str = str(i)\n",
    "        output_result.append(element_str)    \n",
    "    return output_result\n",
    "\n",
    "def blod_max(array):\n",
    "    blod_val = max(array)\n",
    "    output_result = []\n",
    "    for i in array:\n",
    "        if i == blod_val:\n",
    "            element_str = 'blodstart '+str(i)+' blodend'\n",
    "        else:\n",
    "            element_str = str(i)\n",
    "        output_result.append(element_str)    \n",
    "    return output_result\n",
    "\n",
    "\n",
    "df = pd.DataFrame({'Classifier': get_result_list})\n",
    "df = df.T\n",
    "\n",
    "df.loc['Average rank'] = average_rank\n",
    "df.loc['Counts of wins'] = wins\n",
    "print(df.index[df.index=='Average rank'])\n",
    "print(df,end='\\n\\n')\n",
    "\n",
    "\n",
    "\n",
    "df = pd.DataFrame({'Classifier': get_result_list})\n",
    "df = df.T\n",
    "\n",
    "average_accuracy_dp = np.round(np.mean(result_block,axis=0),2)\n",
    "\n",
    "df.loc['Average rank'] = blod_min(average_rank)\n",
    "df.loc['Counts of wins'] = blod_max(wins)\n",
    "df.loc['Average accuracy(\\%)'] = blod_max(average_accuracy_dp)\n",
    "\n",
    "z = df.to_latex(header = None)\n",
    "z = z.replace(\"blodstart \", \"\\\\textbf{\")\n",
    "z = z.replace(\" blodend \", \"}\")\n",
    "z = z.replace(\"\\\\\\\\\", \" \\\\\\\\ \\hline\")\n",
    "z = z.replace(\"\\\\toprule\", \"\\hline\")\n",
    "z = z.replace(\"\\\\bottomrule\", \"\")\n",
    "z = z.replace(\"l\"*(df.shape[1]+1), \"|l\"*(df.shape[1]+1)+\"|\")\n",
    "\n",
    "print(z)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "TS-CHIEF WilcoxonResult(statistic=1594.5, pvalue=0.7559926498968383)\n",
      "HIVE-COTE WilcoxonResult(statistic=1306.5, pvalue=0.3221168231174575)\n",
      "ROCKET WilcoxonResult(statistic=1319.0, pvalue=0.35410923308205666)\n",
      "InceptionTime WilcoxonResult(statistic=1254.0, pvalue=0.2792172521326697)\n",
      "STC WilcoxonResult(statistic=1352.0, pvalue=0.0758661083077428)\n",
      "ResNet WilcoxonResult(statistic=777.0, pvalue=5.270560875472493e-05)\n",
      "PF WilcoxonResult(statistic=429.0, pvalue=1.1140287367535381e-08)\n",
      "                                  0                     1     2\n",
      "Classifier            Baseline wins          UOS-CNN wins  Same\n",
      "TS-CHIEF       blodstart 42 blodend                    39     4\n",
      "HIVE-COTE                        34  blodstart 43 blodend     8\n",
      "ROCKET                           33  blodstart 44 blodend     8\n",
      "InceptionTime                    34  blodstart 42 blodend     9\n",
      "STC                              27  blodstart 56 blodend     2\n",
      "ResNet                           19  blodstart 61 blodend     5\n",
      "PF                               13  blodstart 67 blodend     5\n",
      "\\begin{tabular}{|l|l|l|l|}\n",
      "\\hline\n",
      "Classifier    &         Baseline wins &          UOS-CNN wins &  Same  \\\\ \\hline\n",
      "TS-CHIEF      &  \\textbf{42}&                    39 &     4  \\\\ \\hline\n",
      "HIVE-COTE     &                    34 &  \\textbf{43}&     8  \\\\ \\hline\n",
      "ROCKET        &                    33 &  \\textbf{44}&     8  \\\\ \\hline\n",
      "InceptionTime &                    34 &  \\textbf{42}&     9  \\\\ \\hline\n",
      "STC           &                    27 &  \\textbf{56}&     2  \\\\ \\hline\n",
      "ResNet        &                    19 &  \\textbf{61}&     5  \\\\ \\hline\n",
      "PF            &                    13 &  \\textbf{67}&     5  \\\\ \\hline\n",
      "\n",
      "\\end{tabular}\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = pd.DataFrame({'Classifier': ['Baseline wins',get_result_list[-1]+' wins','Same']})\n",
    "df = df.T\n",
    "\n",
    "fig = plt.figure()\n",
    "plt.xlabel('Baseline better')\n",
    "plt.ylabel(get_result_list[-1]+' better')\n",
    "plt.plot([0,100], [0,100], '--', linewidth=2, markersize=0, label ='Equal',c ='C0')\n",
    "plt.axis('equal')\n",
    "for i in range(len(get_result_list)-1):\n",
    "    temp = result_block[:,[i,-1]]\n",
    "    temp = np.around(result_block[:,[i,-1]], decimals=2)\n",
    "    print(get_result_list[i],wilcoxon(temp[:,0],temp[:,1])) \n",
    "    max_index_temp = get_maxest_index(-temp)\n",
    "    wins = np.count_nonzero(max_index_temp<2, axis = 0)\n",
    "    count_same = (wins[0]+wins[1]-number_of_dataset)\n",
    "    loss_win_tie = [wins[0]-count_same,wins[1]-count_same,count_same]\n",
    "    df.loc[get_result_list[i]] = blod_max(loss_win_tie)\n",
    "    plt.scatter(temp[:,0],temp[:,1],label = get_result_list[-1]+' VS '+get_result_list[i], s =10)\n",
    "    plt.legend(loc='lower left', bbox_to_anchor=(1, 0))\n",
    "print(df)\n",
    "z = df.to_latex(header = None)\n",
    "z = z.replace(\"blodstart \", \"\\\\textbf{\")\n",
    "z = z.replace(\" blodend \", \"}\")\n",
    "z = z.replace(\"\\\\\\\\\", \" \\\\\\\\ \\hline\")\n",
    "z = z.replace(\"\\\\toprule\", \"\\hline\")\n",
    "z = z.replace(\"\\\\bottomrule\", \"\")\n",
    "z = z.replace(\"l\"*(df.shape[1]+1), \"|l\"*(df.shape[1]+1)+\"|\")\n",
    "print(z)\n",
    "\n",
    "fig.savefig(\"./result_compare.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame(['classifier_name','dataset_name','accuracy'])\n",
    "df = df.T\n",
    "dataset_name_list = file['dataset_name']\n",
    "#print(dataset_name_list)\n",
    "for j,classifier_name in enumerate(get_result_list):\n",
    "    for i,dataset_name in enumerate(dataset_name_list):\n",
    "        #print(classifier_name,i,result_block[i,j])\n",
    "        #print(classifier_name,i,result_block[i,j])\n",
    "        df = df.append([[classifier_name,i,result_block[i,j]]]) \n",
    "example_path = './CD_diagram/example.csv'\n",
    "df.to_csv(example_path,index=False,header =False )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
