{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b15e5cc2",
   "metadata": {},
   "source": [
    "Compare the risks of ``used_cars`` dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3122c80c",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "from random import random\n",
    "\n",
    "def compare_used_cars(dataset_name, location='../experiment_output_exhaustive/', max_risk=1, repeat=1, col=10, \n",
    "            max_length=30, title=None):\n",
    "    test_risks={}\n",
    "    train_risks={}\n",
    "    and_counts={}\n",
    "    aucs={}\n",
    "    file_numbers={}\n",
    "    desc=dataset_name\n",
    "    max_risk=get_max_risk(dataset_name)\n",
    "    print(max_risk)\n",
    "    objs = ['gpe','orth']\n",
    "    for obj in objs:\n",
    "        algos = ['fc'] if obj=='orth' else ['boosting'] if obj=='gpe' else ['keep']\n",
    "        for algo in algos:\n",
    "            methods = ['Newton-CG'] if algo=='fc' else ['']\n",
    "            for method in methods:\n",
    "                done = True\n",
    "                fc_train=[0]*10\n",
    "                fc_test=[0]*10\n",
    "                ands = [0]*10\n",
    "                file_number=0\n",
    "                for i in range(repeat):\n",
    "                    filename = dataset_name + '_' + obj + '_' + algo + '_' + method + '_realkd_col_' + \\\n",
    "                        str(col) + '_rep' + str(1) + '.txt'\n",
    "                    try:\n",
    "                        f = open(location+'/'+dataset_name+'/'+filename, 'r')\n",
    "                        file_number+=1\n",
    "                    except:\n",
    "                        print(obj, algo, method,'does not exist: ')\n",
    "                        print(location+'/'+dataset_name+'/'+filename)\n",
    "                        continue\n",
    "                    j=-1\n",
    "                    for line in f:\n",
    "                        if 'iteration ' in line:\n",
    "                            j+=1\n",
    "                        if j>=10:\n",
    "                            break\n",
    "                        words=line.split(' ')\n",
    "                        if 'fc train risk' in line:\n",
    "                            fc_train[j] += float(words[-1])\n",
    "                        elif 'fc test risk' in line:\n",
    "                            fc_test[j] += float(words[-1])\n",
    "                        if 'if' in line:\n",
    "                            ands[j]+=line.count('=')+1\n",
    "                if done:\n",
    "                    file_numbers[obj + '_' + algo + '_' + method] = file_number\n",
    "                    train_risks[obj + '_' + algo + '_' + method]=fc_train\n",
    "                    test_risks[obj + '_' + algo + '_' + method]=fc_test\n",
    "                    and_counts[obj + '_' + algo + '_' + method]=ands\n",
    "                    if file_number==0:\n",
    "                        continue\n",
    "                    print(obj + '_' + algo + '_' + method+': avg train risk:',sum(fc_train)/10/max_risk/file_number, \n",
    "                          'avg test risk', sum(fc_test)/10/max_risk/file_number, '&s:', sum(ands)/10/file_number)\n",
    "\n",
    "    rg=list(range(1,11))\n",
    "    plt.figure(figsize=(7.5,5.5))\n",
    "    colours = {}\n",
    "    line_width = {}\n",
    "    width = [1,1, 1, 1]*4\n",
    "    i = 0\n",
    "    colors=['green','red','gold','deepskyblue','violet','cyan','brown','deepskyblue','purple', 'lime',\n",
    "            'slategray','magenta','pink','olive','khaki']\n",
    "    label_map={'gpe_boosting_':'GB / XGBoost', 'gpe_fc_Newton-CG': 'Gradient Fully-corrective Boosting', \n",
    "               'orth_fc_Newton-CG': 'FCOGB', 'xgb_keep_': 'XGBoost', \n",
    "              'xgb_fc_Newton-CG': 'XG Fully-corrective Boosting'}\n",
    "    for item in train_risks:\n",
    "        color = colors[i]\n",
    "        colours[item] = color\n",
    "        line_width[item] = width[i]\n",
    "        i+=1\n",
    "        if file_numbers[item]==0:\n",
    "            continue\n",
    "        train_risks[item] = [risk / max_risk/file_numbers[item] for risk in train_risks[item]]\n",
    "        test_risks[item] = [risk / max_risk/file_numbers[item] for risk in test_risks[item]]\n",
    "        and_counts[item] = [ands / file_numbers[item] for ands in and_counts[item]]\n",
    "        aucs[item] = and_counts[item][0]+sum((train_risks[item][m])*\n",
    "                                             (min(max_length, and_counts[item][m+1])-\n",
    "                                                                   min(max_length, and_counts[item][m]))\n",
    "                                for m in range(len(train_risks[item])-1))\n",
    "        print(item, 'auc:', aucs[item])\n",
    "        print(and_counts[item], train_risks[item])\n",
    "        plt.step([0]+and_counts[item], [1]+train_risks[item], '--', color=colours[item],\n",
    "                 linewidth=line_width[item],where='post')\n",
    "        plt.step([0]+and_counts[item], [1]+test_risks[item], color=colours[item],\n",
    "                 label=label_map[item]+ '',linewidth=line_width[item],where='post')\n",
    "    plt.xlabel('Cognitive Complexity', fontsize=12)\n",
    "    plt.xlim(0,30)\n",
    "    plt.ylabel('Risk', fontsize=12)\n",
    "    plt.yscale('log')\n",
    "    boosting_rule='''Gradient Boosting:\n",
    " +17933.38 if PS>=120 & year>=2005\n",
    " +7090.75  if km<=125000 & year>=2011\n",
    " - 8206.32  if 120<=PS<=160 & year>=2005\n",
    " +2401.70  if True\n",
    " - 4397.03  if 120<=PS<=220 & 2005<=year<=2011\n",
    " +4585.17  if count<=69 & km>=50000 & PS>=160 \n",
    "              & year<=2005'''\n",
    "    orth_rule = '''Proposed algorithm:\n",
    " +7303.87  if year>=2005\n",
    " +6138.81  if count<=149 & PS>=160\n",
    " +10100.84 if PS>=120 & year>=2011\n",
    " +5744.60  if PS>=220 & year>=2000'''\n",
    "    plt.annotate('', xy=(21.2, 0.080), xytext=(22, 0.26), fontsize=12, arrowprops=dict(facecolor='black', width=0.2, shrink=0.05))\n",
    "    plt.annotate('', xy=(11, 0.09), xytext=(4.7, 0.071), fontsize=12,arrowprops=dict(facecolor='black', width=0.2, shrink=0.05))\n",
    "    \n",
    "    plt.ylim(0.025, 1.35)\n",
    "    bbox_props = dict(boxstyle=\"round\", fc=\"w\", ec=\"0.5\", alpha=0.9)\n",
    "    plt.text(7.8,0.25, boosting_rule, bbox=bbox_props, fontsize=11)\n",
    "    plt.text(1,0.031, orth_rule, bbox=bbox_props, fontsize=11)\n",
    "    plt.grid(visible=True, which='major')\n",
    "    plt.grid(visible=True, which='minor')\n",
    "    plt.gca().set_ylim(bottom=0)\n",
    "    plt.legend()\n",
    "    plt.savefig('used_cars_compare.pdf', dpi=300, bbox_inches='tight')\n",
    "    plt.show()\n",
    "    \n",
    "    return train_risks, test_risks, and_counts, aucs\n",
    "\n",
    "def get_max_risk(dataset_name):\n",
    "    d = {'gdp': 43.986571428571416,\n",
    "        'wage': 2029057842.6515312,\n",
    "        'titanic': 1.0,\n",
    "        'insurance': 322646873.58870494,\n",
    "        'used_cars': 194464336.77843493,\n",
    "        'tic_tac_toe': 1.0,\n",
    "        'boston': 592.1469169960473,\n",
    "        'world_happiness_indicator': 30.46778212179487,\n",
    "        'Demographics': 31.64835409252669,\n",
    "        'IBM_HR': 1.0, 'telco_churn': 1.0,\n",
    "        'mobile_prices': 3.5,\n",
    "        'GenderRecognition': 1.0,\n",
    "        'breast_cancer': 1.0,\n",
    "        'load_diabetes': 29074.481900452487,\n",
    "        'iris': 1.0,\n",
    "        'load_wine': 1.0,\n",
    "         'suicide_rates_cleaned': 523.7783290690134,\n",
    "         'videogamesales': 2.70680865164444,\n",
    "         'digits5': 1.0,\n",
    "         'red_wine_quality': 32.41651031894934, \n",
    "         'banknote': 1.0, \n",
    "         'liver': 1.0, \n",
    "         'magic': 1.0, \n",
    "         'adult': 1.0,\n",
    "         'who_life_expectancy': 4882.764241803283,\n",
    "         'vaccine': 228506505.50612897, \n",
    "         'ships': 12.342277392898044, \n",
    "         'smoking': 7.500299349437478, \n",
    "         'covid_vic': 51.62076805721374, \n",
    "         'covid_world': 14143.401514056353, \n",
    "         'covid': 1082.8170359400497, \n",
    "         'bicycle': 1076.416963882381, \n",
    "         'austin-water': 3975.767978495398,\n",
    "         'make_friedman2': 379683.4049960418, \n",
    "         'make_friedman3': 1.8780821278399789, \n",
    "         'make_friedman1': 226.89125115757616\n",
    "        }\n",
    "    return 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "76296933",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "194464336.77843493\n",
      "gpe_boosting_: avg train risk: 0.11487454540713478 avg test risk 0.12722486528807636 &s: 19.7\n",
      "orth_fc_Newton-CG: avg train risk: 0.10029036859594534 avg test risk 0.11924908580687092 &s: 15.9\n",
      "gpe_boosting_ auc: 6.457178249636495\n",
      "[3.0, 6.0, 10.0, 11.0, 16.0, 21.0, 25.0, 30.0, 35.0, 40.0] [0.2645509110573421, 0.2022870824853723, 0.14187958375417029, 0.11221783977219958, 0.0916455280655313, 0.08210179754828802, 0.07295471467740056, 0.0644309787818688, 0.06023299339480931, 0.056444024534365776]\n",
      "orth_fc_Newton-CG auc: 4.939863596764699\n",
      "[2.0, 5.0, 8.0, 11.0, 15.0, 17.0, 20.0, 24.0, 27.0, 30.0] [0.30332439036990055, 0.1618711977941554, 0.10198183908872074, 0.08398049183450944, 0.0736811325954079, 0.06703474590169989, 0.060176481642162445, 0.05434522178694212, 0.05006708428097964, 0.0464411006649755]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-32-34dbbc10f67f>:115: UserWarning: Attempted to set non-positive bottom ylim on a log-scaled axis.\n",
      "Invalid limit will be ignored.\n",
      "  plt.gca().set_ylim(bottom=0)\n"
     ]
    },
    {
     "data": {
      "image/png": "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9f3000949OgRPnz4gJcvX+LChQtYunQpLl26hKysLGhpaWHTpk1o1aoVACAgIABr166FhoYGevXqxbfz/PlzODk5IT4+HkSES5cu4fvvv+eFDX788Uf07t2bLzdhwgScOnUKGRkZCAgIgJOTEyZPnoyUlBQIhUI0aNCg0Njm2Z/377t376CsrAwFBQWIRCJER0dj6tSpePfuHerVq4eFCxfyzvX06dP44YcfIBaLoa2tjfXr18PIyAhRUVGYNGkSMjIyIBaLMWrUKPTo0QMBAQHIzc3FmTNnMGjQIAwaNIi/PkAy41qwYAGOHTuGpKQkLF68mNdFPnz4MObPn4/69etjwIABmD9/Pt69ewc1NTWpz4chgYjkOi56enpy67so6qJzzszMxPbt2/kznP/555+KabisG6Nr2ouJkBSmOolKPHv2jP744w+ptH379pFQKCy23vz586lFixb09u1bPi3//7ds2UJDhgwhIqK7d++Srq4uvX79moiIJk+eTFpaWkREFBsby///9evXZG1tTQkJCURElJCQQPr6+vT+/XuKjY0lABQSEkJERL///jt17NixUBuyiI2NJUVFRRIKhWRhYUHKysq0atUqPr9Dhw60detWIiJ6+PAhaWlpUWJiIr1584a0tbXp4cOHRES0detW6tChAxERffXVV/TLL7/wbSQnJ/PjMnPmTKm+89sGgH777TciIrp8+TLp6enx196kSROKiooiIqKVK1cSAEpNTaXMzEyaMGECHT16tMhrrItkZmbK24RqR10ck4yMDFq3bl2xZcBESBi1kcjISAwfPhwZGRno3bs31qxZAwBwd3fnnx0DwIkTJ7B+/XqkpaUhJyeHTw8LC0OfPn2go6MDAPDx8cH+/fsL9XP9+nXExsaid+/efBrHcXj27Bm0tbXRsGFDeHh4AAAcHBwwc+bMUl9D/mXthIQEdOzYEZ06dYKpqSkiIiIwbtw4ABL9YWtra1y/fh0AIBQK+WX8cePGYcqUKUhNTUWXLl0wZ84cZGRkwMXFpUzPlYcOHcpfQ0JCAjIzM3Hjxg3Y2trC2NgYADB+/HjMmDGDr7N169ZSt89gMD4fFhDGqHbY2Njg6dOnSElJASBxWBEREfjqq6/w4cMHvlz+02j++ecfTJ8+HXv37sWDBw+wfft2ZGZmlqlfIoJAIEBERAT/evnyJdq1awcA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\n",
      "text/plain": [
       "<Figure size 540x396 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "datasets = ['used_cars']\n",
    "\n",
    "values = ['gpe_boosting_', \n",
    "               'orth_fc_Newton-CG']\n",
    "print(len(datasets))\n",
    "cols = [10, 10, 10, 5, 10, 3, 10, 4, 10, 10, 10,\n",
    "       2, 20, 10, 5, 4, 10, 10, 10, 10, 10, \n",
    "       10, 10, 10, 10]\n",
    "max_components = [30] * len(datasets)\n",
    "f = open(\"../experiment_output_exhaustive/compare_used_cars.csv\", 'w')\n",
    "f.write('dataset'+(','+','.join(values))*4+'\\n')\n",
    "for i in range(len(datasets)):\n",
    "        max_risk = get_max_risk(datasets[i])\n",
    "        train, test, ands, aucs = compare_used_cars(datasets[i], col=cols[i], max_length=max_components[i])\n",
    "        f.write(datasets[i] + ',')\n",
    "        for value in values:\n",
    "            f.write(str(sum(train[value]))+',')\n",
    "        for value in values:\n",
    "            f.write(str(sum(test[value]))+',')\n",
    "        for value in values:\n",
    "            f.write(str(max(ands[value]))+',')\n",
    "        for value in values:\n",
    "            f.write(str(aucs[value])+',')\n",
    "        f.write('\\n')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "233fa8d9",
   "metadata": {},
   "source": [
    "Compare risks of gradient sum (mwg), gradient boosting (gpe), XGBoost (xgb) and FCOGB (orth)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d9795f9e",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "from random import random\n",
    "\n",
    "def compare_risks(dataset_name, location='../experiment_output_20230421_', max_risk=1, repeat=5, col=10, \n",
    "            max_length=30, title=None):\n",
    "    test_risks={}\n",
    "    train_risks={}\n",
    "    and_counts={}\n",
    "    aucs_test={}\n",
    "    aucs_train={}\n",
    "    file_numbers={}\n",
    "    desc=dataset_name\n",
    "    max_risk=get_max_risk(dataset_name)\n",
    "    print(max_risk)\n",
    "    objs = ['mwg','gpe','xgb','orth']\n",
    "    for obj in objs:\n",
    "        algos = ['fc'] if obj=='orth' else ['boosting'] if obj in ['gpe', 'mwg'] else ['keep']\n",
    "        search = 'exhaustive' if obj in ['xgb', 'orth'] else 'greedy'\n",
    "        for algo in algos:\n",
    "            methods = ['Newton-CG'] if algo=='fc' else ['']\n",
    "            for method in methods:\n",
    "                done = True\n",
    "                fc_train=[0]*30\n",
    "                fc_test=[0]*30\n",
    "                ands = [0]*30\n",
    "                file_number=0\n",
    "                for i in range(repeat):\n",
    "                    filename = dataset_name + '_' + obj + '_' + algo + '_' + method + '_realkd_col_' + \\\n",
    "                        str(col) + '_rep' + str(i) + '.txt'\n",
    "                    try:\n",
    "                        f = open(location+search+''+'/'+dataset_name+'/'+filename, 'r')\n",
    "                        file_number+=1\n",
    "                    except:\n",
    "#                         print(obj, algo, method,'does not exist: ')\n",
    "#                         print(location+'/'+dataset_name+'/'+filename)\n",
    "                        continue\n",
    "                    j=-1\n",
    "                    for line in f:\n",
    "                        if 'iteration' in line:\n",
    "                            j+=1\n",
    "                        if j>=30:\n",
    "                            break\n",
    "                        words=line.split(' ')\n",
    "                        if 'train score' in line:\n",
    "                            fc_train[j] += float(words[-1])\n",
    "                        elif 'test score' in line:\n",
    "                            fc_test[j] += float(words[-1])\n",
    "                        if 'if' in line:\n",
    "                            ands[j]+=line.count('=')+1\n",
    "#                             print(line, ands[j])\n",
    "                if done:\n",
    "                    file_numbers[obj + '_' + algo + '_' + method] = file_number\n",
    "                    train_risks[obj + '_' + algo + '_' + method]=fc_train\n",
    "                    test_risks[obj + '_' + algo + '_' + method]=fc_test\n",
    "                    and_counts[obj + '_' + algo + '_' + method]=ands\n",
    "                    if file_number==0:\n",
    "                        continue\n",
    "                    print(obj + '_' + algo + '_' + method+': avg train risk:',sum(fc_train)/10/max_risk/file_number, \n",
    "                          'avg test risk', sum(fc_test)/10/max_risk/file_number, '&s:', sum(ands)/10/file_number)\n",
    "\n",
    "#     rg=list(range(1,11))\n",
    "    plt.figure(figsize=(8,6))\n",
    "    colours = {}\n",
    "    line_width = {}\n",
    "    width = [1,1, 1, 1]*4\n",
    "    i = 0\n",
    "    colors=['blue','green','red','gold','deepskyblue','violet','cyan','brown','deepskyblue','purple', 'lime',\n",
    "            'slategray','magenta','pink','olive','khaki']\n",
    "    label_map={'gpe_boosting_':'Gradient Boosting', 'gpe_fc_Newton-CG': 'Gradient Fully-corrective Boosting', \n",
    "               'orth_fc_Newton-CG': 'Orthogonal Fully-corrective Boosting', 'xgb_keep_': 'XGBoost', \n",
    "              'xgb_fc_Newton-CG': 'XG Fully-corrective Boosting',\n",
    "              'mwg_boosting_': 'Gradient Descent'}\n",
    "    for item in train_risks:\n",
    "        color = colors[i]\n",
    "        colours[item] = color\n",
    "        line_width[item] = width[i]\n",
    "        i+=1\n",
    "        if file_numbers[item]==0:\n",
    "            continue\n",
    "        train_risks[item] = [risk / max_risk/file_numbers[item] for risk in train_risks[item]]\n",
    "        test_risks[item] = [risk / max_risk/file_numbers[item] for risk in test_risks[item]]\n",
    "        and_counts[item] = [ands / file_numbers[item] for ands in and_counts[item]]\n",
    "        aucs_test[item] = sum((test_risks[item][m])*\n",
    "                                             (min(max_length, and_counts[item][m+1])-\n",
    "                                                 min(max_length, and_counts[item][m]))\n",
    "                                for m in range(0,len(test_risks[item])-1))\n",
    "        aucs_train[item] = sum((train_risks[item][m])*\n",
    "                                             (min(max_length, and_counts[item][m+1])-\n",
    "                                                 min(max_length, and_counts[item][m]))\n",
    "                                for m in range(0,len(train_risks[item])-1))\n",
    "        \n",
    "        \n",
    "#         if and_counts[item][-1]<max_length:\n",
    "#             aucs_test[item]+=test_risks[item][-1]*(max_length-and_counts[item][-1])\n",
    "#             aucs_train[item]+=train_risks[item][-1]*(max_length-and_counts[item][-1])\n",
    "        aucs_train[item] /= max_length # min(max_length, and_counts[item][-1])\n",
    "        aucs_test[item] /= max_length # min(max_length, and_counts[item][-1]) # min(max_length, and_counts[item][-1])\n",
    "        print(item, 'auc:', aucs_train[item], aucs_test[item])\n",
    "        print(and_counts[item], train_risks[item])\n",
    "        plt.step([0]+and_counts[item], [0]+train_risks[item], '--', color=colours[item],\n",
    "                 label=label_map[item],linewidth=line_width[item],where='post')\n",
    "#         plt.step([0]+and_counts[item], [1]+test_risks[item], color=colours[item],\n",
    "#                  label=label_map[item],linewidth=line_width[item],where='post')\n",
    "    plt.title(dataset_name if title is None else title + \" risks\")\n",
    "    plt.xlabel('number of rules')\n",
    "    plt.xlim(0,max_length)\n",
    "    plt.ylabel('risk')\n",
    "#     plt.yscale('log')\n",
    "    plt.grid(visible=True, which='major')\n",
    "    plt.grid(visible=True, which='minor')\n",
    "    plt.gca().set_ylim(bottom=0)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "    \n",
    "    return train_risks, test_risks, and_counts, aucs_train, aucs_test"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3011ba3e",
   "metadata": {},
   "source": [
    "Calculating largest gaps between two algorithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "0d36449f",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [],
   "source": [
    "def map_size_risk(train_risks, sizes):\n",
    "    risks = [1]\n",
    "    szs = [0]\n",
    "    sz = 0\n",
    "    for i in range(len(sizes)):\n",
    "        while sz<=sizes[i]:\n",
    "            sz+=0.2\n",
    "            szs.append(sz)\n",
    "            if i==0:\n",
    "                risk=1\n",
    "            else:\n",
    "                risk=train_risks[i-1]\n",
    "            risks.append(risk)\n",
    "            \n",
    "    return risks, szs\n",
    "def largest_gaps(train_risks, and_counts, a, b, max_size=150):\n",
    "    risks_a, szs_a = map_size_risk(train_risks[a], and_counts[a])\n",
    "    risks_b, szs_b = map_size_risk(train_risks[b], and_counts[b])\n",
    "    max_risk_index_ab = -1000\n",
    "    max_difference = -1000\n",
    "    for i in range(min([len(szs_a), len(szs_b), max_size])):\n",
    "        if risks_a[i]!=1 or risks_b[i]!=1:\n",
    "            if risks_a[i]-risks_b[i]>max_difference:\n",
    "                max_risk_index_ab=i\n",
    "                max_difference = risks_a[i]-risks_b[i]\n",
    "    return max_difference, szs_a[max_risk_index_ab], risks_a[max_risk_index_ab], risks_b[max_risk_index_ab]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "75849a0a",
   "metadata": {
    "scrolled": true,
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "34\n",
      "1\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'mwg_boosting_': [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 'gpe_boosting_': [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 'xgb_keep_': [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 'orth_fc_Newton-CG': [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]}\n"
     ]
    },
    {
     "ename": "IndexError",
     "evalue": "list index out of range",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_13637/27841749.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     32\u001b[0m         \u001b[0mtrain\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtest\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mands\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maucs_tr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maucs_te\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcompare_risks\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdatasets\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcol\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcols\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmax_length\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmax_components\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     33\u001b[0m         \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrain\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 34\u001b[0;31m         \u001b[0mgpe_orth_test\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlargest_gaps\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtest\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mands\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'gpe_boosting_'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'orth_fc_Newton-CG'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     35\u001b[0m         \u001b[0mxgb_orth_test\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlargest_gaps\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtest\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mands\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'xgb_keep_'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'orth_fc_Newton-CG'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     36\u001b[0m         \u001b[0morth_gpe_test\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlargest_gaps\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtest\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mands\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'orth_fc_Newton-CG'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'gpe_boosting_'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/tmp/ipykernel_13637/126064390.py\u001b[0m in \u001b[0;36mlargest_gaps\u001b[0;34m(train_risks, and_counts, a, b, max_size)\u001b[0m\n\u001b[1;32m     24\u001b[0m                 \u001b[0mmax_risk_index_ab\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     25\u001b[0m                 \u001b[0mmax_difference\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mrisks_a\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mrisks_b\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 26\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mmax_difference\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mszs_a\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mmax_risk_index_ab\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrisks_a\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mmax_risk_index_ab\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrisks_b\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mmax_risk_index_ab\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m: list index out of range"
     ]
    }
   ],
   "source": [
    "datasets = ['titanic','tic-tac-toe','iris','breast_cancer','load_wine',\n",
    "            'IBM_HR', 'telco_churn', 'GenderRecognition',\n",
    "            'banknote', 'liver', 'magic', 'adult', 'digits5',\n",
    "            'insurance','make_friedman1',\n",
    "            'make_friedman2','make_friedman3','wage', 'Demographics','gdp','used_cars','load_diabetes',\n",
    "            'boston','world_happiness_indicator', 'who_life_expectancy', 'mobile_prices', 'suicide_rates_cleaned','videogamesales',\n",
    "             'red_wine_quality',\n",
    "            'covid_vic','covid',\n",
    "            'bicycle','ships','smoking']\n",
    "\n",
    "values = [\n",
    "    'mwg_boosting_',\n",
    "    'gpe_boosting_', \n",
    "    'xgb_keep_', \n",
    "    'orth_fc_Newton-CG']\n",
    "print(len(datasets))\n",
    "cols = [10, 10, 10, 5, 6, \n",
    "        3, 4, 3, 10, 10, 5, 5, 3,\n",
    "        10, 4, 10, 10, 10,\n",
    "       2, 20, 10, 5, 4, 10, 5, 4, 3, 3, 5,\n",
    "        10, 10, 10, 10, 10]\n",
    "max_components = [100] * len(datasets)\n",
    "# max_components[14]=25\n",
    "# max_components[15]=20\n",
    "# max_components[5]=20\n",
    "f = open(\"../analysis_results/1compare_test.csv\", 'w')\n",
    "f2 = open(\"../analysis_results/1compare_train.csv\", 'w')\n",
    "f.write('dataset'+(','+','.join(values))*4+'\\n')\n",
    "for i in range(len(datasets)):\n",
    "#     try:\n",
    "        max_risk = get_max_risk(datasets[i])\n",
    "        train, test, ands, aucs_tr, aucs_te = compare_risks(datasets[i], col=cols[i], max_length=max_components[i])\n",
    "        print(train)\n",
    "        gpe_orth_test = largest_gaps(test, ands, 'gpe_boosting_', 'orth_fc_Newton-CG')\n",
    "        xgb_orth_test = largest_gaps(test, ands, 'xgb_keep_', 'orth_fc_Newton-CG')\n",
    "        orth_gpe_test = largest_gaps(test, ands, 'orth_fc_Newton-CG', 'gpe_boosting_')\n",
    "        orth_xgb_test = largest_gaps(test, ands, 'orth_fc_Newton-CG', 'xgb_keep_')\n",
    "        orth_mwg_test = largest_gaps(test, ands, 'orth_fc_Newton-CG', 'mwg_boosting_')\n",
    "        mwg_orth_test = largest_gaps(test, ands, 'mwg_boosting_', 'orth_fc_Newton-CG')\n",
    "        gpe_orth_train = largest_gaps(train, ands, 'gpe_boosting_', 'orth_fc_Newton-CG')\n",
    "        xgb_orth_train = largest_gaps(train, ands, 'xgb_keep_', 'orth_fc_Newton-CG')\n",
    "        orth_gpe_train = largest_gaps(train, ands, 'orth_fc_Newton-CG', 'gpe_boosting_')\n",
    "        orth_xgb_train = largest_gaps(train, ands, 'orth_fc_Newton-CG', 'xgb_keep_')\n",
    "        orth_mwg_train = largest_gaps(train, ands, 'orth_fc_Newton-CG', 'mwg_boosting_')\n",
    "        mwg_orth_train = largest_gaps(train, ands, 'mwg_boosting_', 'orth_fc_Newton-CG')\n",
    "        \n",
    "        f.write(datasets[i] + ',')\n",
    "        for value in values:\n",
    "            f.write(str(max(ands[value]))+',')\n",
    "        for value in values:\n",
    "            f.write(str(aucs_te[value])+',')\n",
    "        f.write(str(mwg_orth_test[0])+','+str(mwg_orth_test[1])+','+str(mwg_orth_test[2])+','+str(mwg_orth_test[3])+',')\n",
    "        f.write(str(gpe_orth_test[0])+','+str(gpe_orth_test[1])+','+str(gpe_orth_test[2])+','+str(gpe_orth_test[3])+',')\n",
    "        f.write(str(xgb_orth_test[0])+','+str(xgb_orth_test[1])+','+str(xgb_orth_test[2])+','+str(xgb_orth_test[3])+',')\n",
    "        f.write(str(orth_mwg_test[0])+','+str(orth_mwg_test[1])+','+str(orth_mwg_test[2])+','+str(orth_mwg_test[3])+',')\n",
    "        f.write(str(orth_gpe_test[0])+','+str(orth_gpe_test[1])+','+str(orth_gpe_test[2])+','+str(orth_gpe_test[3])+',')\n",
    "        f.write(str(orth_xgb_test[0])+','+str(orth_xgb_test[1])+','+str(orth_xgb_test[2])+','+str(orth_xgb_test[3])+',')\n",
    "        f.write('\\n')\n",
    "        \n",
    "        f2.write(datasets[i] + ',')\n",
    "        for value in values:\n",
    "            f2.write(str(max(ands[value]))+',')\n",
    "        for value in values:\n",
    "            f2.write(str(aucs_tr[value])+',')\n",
    "        f2.write(str(mwg_orth_train[0])+','+str(mwg_orth_train[1])+','+str(mwg_orth_train[2])+','+str(mwg_orth_train[3])+',')\n",
    "        f2.write(str(gpe_orth_train[0])+','+str(gpe_orth_train[1])+','+str(gpe_orth_train[2])+','+str(gpe_orth_train[3])+',')\n",
    "        f2.write(str(xgb_orth_train[0])+','+str(xgb_orth_train[1])+','+str(xgb_orth_train[2])+','+str(xgb_orth_train[3])+',')\n",
    "        f2.write(str(orth_mwg_train[0])+','+str(orth_mwg_train[1])+','+str(orth_mwg_train[2])+','+str(orth_mwg_train[3])+',')\n",
    "        f2.write(str(orth_gpe_train[0])+','+str(orth_gpe_train[1])+','+str(orth_gpe_train[2])+','+str(orth_gpe_train[3])+',')\n",
    "        f2.write(str(orth_xgb_train[0])+','+str(orth_xgb_train[1])+','+str(orth_xgb_train[2])+','+str(orth_xgb_train[3])+',')\n",
    "        f2.write('\\n')\n",
    "\n",
    "f.close()\n",
    "f2.close()\n",
    "print('done')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "e270b127",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "44.609114719797475"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a=[2.0, 5.0, 11.0, 17.2, 22.2, 27.8, 34.4, 40.0, 46.2] \n",
    "b=[0.7633096371635981, 0.795342951339558, 0.8320443255036457, 0.8638467928159417, 0.8714866426073122, 0.8784415310012307, 0.8839821912541048, 0.8920352479173271, 0.8965499393314535]\n",
    "ds=sum([b[i]*(a[i+1]-a[i]) for i in range(len(a)-1)])\n",
    "ds / 0.8450930656178037 "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "544900b4",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "6bd672cf",
   "metadata": {},
   "source": [
    "Ablation study:\n",
    "\n",
    "    GB -> FCGB -> Greedy FCOGB -> Optimal FCOGB"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a8032836",
   "metadata": {},
   "source": [
    "| dataset       | d  | n     | GS           | GB           | XGBoost  | SIRUS        | FCOGB        |\n",
    "|---------------|----|-------|--------------|--------------|----------|--------------|--------------|\n",
    "| titanic       | 7  | 1043  | **0.78752**  | 0.727948     | 0.7325   | 0.664431     | 0.778426     |\n",
    "| tic-tac-toe   | 27 | 958   | 0.708737     | 0.716479     | 0.717067 | 0.60964      | **0.726228** |\n",
    "| iris          | 4  | 150   | 0.875425     | 0.86651      | 0.839935 | 0.742919     | **0.881986** |\n",
    "| breast        | 30 | 569   | **0.897696** | 0.889331     | 0.893343 | 0.791486     | 0.889429     |\n",
    "| wine          | 13 | 178   | 0.894133     | 0.85058      | 0.861576 | 0.793705     | **0.912642** |\n",
    "| ibm hr        | 32 | 1470  | 0.667322     | **0.67223**  | 0.632674 | 0.607837     | 0.657805     |\n",
    "| telco churn   | 18 | 7043  | 0.725904     | 0.720219     | 0.722172 | 0.66231      | **0.729716** |\n",
    "| gender        | 20 | 3168  | 0.486778     | 0.470553     | 0.470984 | **0.775951** | 0.470553     |\n",
    "| banknote      | 4  | 1372  | **0.899631** | 0.890474     | 0.897367 | 0.753027     | 0.893664     |\n",
    "| liver         | 6  | 345   | **0.685153** | 0.611111     | 0.613133 | 0.605248     | 0.646615     |\n",
    "| magic         | 10 | 19020 | **0.744575** | 0.743076     | 0.744574 | 0.545998     | 0.7429       |\n",
    "| adult         | 11 | 30162 | **0.791683** | 0.773234     | 0.781667 | 0.632768     | 0.78947      |\n",
    "| digits5       | 64 | 3915  | 0.74688      | **0.748379** | 0.731503 | 0.296475     | 0.679976     |\n",
    "| insurance     | 6  | 1338  | 0.620298     | 0.664873     | 0.659807 | 0.486541     | **0.71715**  |\n",
    "| friedman1     | 10 | 2000  | 0.431334     | 0.361504     | 0.379854 | **0.437503** | 0.431486     |\n",
    "| friedman2     | 4  | 10000 | 0.584721     | 0.580484     | 0.592331 | 0.488965     | **0.656538** |\n",
    "| friedman3     | 4  | 5000  | 0.438531     | 0.459526     | 0.460006 | 0.388198     | **0.50676**  |\n",
    "| wage          | 5  | 1379  | 0.218629     | 0.207464     | 0.222415 | 0.153447     | **0.248165** |\n",
    "| demographics  | 13 | 6876  | 0.157453     | 0.16834      | 0.168314 | 0.162178     | **0.175056** |\n",
    "| gdp           | 1  | 35    | 0.587244     | 0.597622     | 0.600313 | 0.432508     | **0.62943**  |\n",
    "| used cars     | 4  | 1770  | 0.648908     | 0.570787     | 0.614504 | 0.50587      | **0.689341** |\n",
    "| diabetes      | 10 | 442   | 0.359284     | 0.348785     | 0.345223 | 0.301056     | **0.381975** |\n",
    "| boston        | 13 | 506   | 0.448998     | 0.431143     | 0.450646 | 0.474624     | **0.497284** |\n",
    "| happiness     | 8  | 315   | 0.622574     | 0.616553     | 0.571129 | 0.056363     | **0.640955** |\n",
    "| life expect.  | 21 | 1649  | 0.540651     | 0.497625     | 0.496597 | 0.465874     | **0.570566** |\n",
    "| mobile prices | 20 | 2000  | 0.622739     | 0.657299     | 0.657617 | 0.527975     | **0.665716** |\n",
    "| suicide rate  | 5  | 27820 | 0.178393     | 0.2163       | 0.216158 | 0.2066       | **0.229871** |\n",
    "| videogame     | 6  | 16327 | 0.001101     | 0.001101     | 0.001101 | **0.001106** | 0.001104     |\n",
    "| red wine      | 11 | 1599  | 0.226449     | 0.199057     | 0.209499 | 0.167853     | **0.232382** |\n",
    "| covid_vic     | 4  | 85    | 0.697194     | 0.758415     | NA       | NA           | **0.766479** |\n",
    "| covid         | 2  | 225   | 0.347911     | 0.366511     | NA       | NA           | **0.401122** |\n",
    "| bicycle       | 4  | 122   | 0.582707     | 0.591599     | 0.582928 | NA           | **0.599117** |\n",
    "| ships         | 4  | 34    | 0.727248     | 0.777        | NA       | NA           | **0.826615** |\n",
    "| smoking       | 2  | 36    | 0.82216      | 0.842706     | 0.485595 | NA           | **0.866948** |"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "4aae2f52",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "from random import random\n",
    "\n",
    "def compare4(dataset_name, max_risk=1, repeat=5, col=10, \n",
    "            max_length=30, title=None):\n",
    "    test_risks={}\n",
    "    train_risks={}\n",
    "    and_counts={}\n",
    "    aucs_test={}\n",
    "    file_numbers={}\n",
    "    desc=dataset_name\n",
    "    max_risk=get_max_risk(dataset_name)\n",
    "    print(max_risk)\n",
    "    searches=['greedy', 'exhaustive']\n",
    "    for search in searches:\n",
    "        location='../experiment_output_20230411_'+search\n",
    "        objs = ['mwg','gpe','orth']\n",
    "        for obj in objs:\n",
    "            algos = ['fc'] if obj=='orth' else ['boosting', 'fc'] if obj in ['gpe'] else ['keep']\n",
    "            for algo in algos:\n",
    "                methods = ['Newton-CG'] if algo=='fc' else ['']\n",
    "                for method in methods:\n",
    "                    done = True\n",
    "                    fc_train=[0]*10\n",
    "                    fc_test=[0]*10\n",
    "                    ands = [0]*10\n",
    "                    file_number=0\n",
    "                    for i in range(repeat):\n",
    "                        filename = dataset_name + '_' + obj + '_' + algo + '_' + method + '_realkd_col_' + \\\n",
    "                            str(col) + '_rep' + str(i) + '.txt'\n",
    "                        try:\n",
    "                            f = open(location+'/'+dataset_name+'/'+filename, 'r')\n",
    "                            file_number+=1\n",
    "                        except:\n",
    "                            continue\n",
    "                        j=-1\n",
    "                        for line in f:\n",
    "                            if 'iteration ' in line:\n",
    "                                j+=1\n",
    "                            if j>=10:\n",
    "                                break\n",
    "                            words=line.split(' ')\n",
    "                            if 'fc train risk' in line:\n",
    "                                fc_train[j] += float(words[-1])\n",
    "                            elif 'fc test risk' in line:\n",
    "                                fc_test[j] += float(words[-1])\n",
    "                            if 'if' in line:\n",
    "                                ands[j]+=line.count('=')+1\n",
    "                    if done:\n",
    "                        file_numbers[search+'_'+obj + '_' + algo + '_' + method] = file_number\n",
    "                        train_risks[search+'_'+obj + '_' + algo + '_' + method]=fc_train\n",
    "                        test_risks[search+'_'+obj + '_' + algo + '_' + method]=fc_test\n",
    "                        and_counts[search+'_'+obj + '_' + algo + '_' + method]=ands\n",
    "                        if file_number==0:\n",
    "                            continue\n",
    "                        print(obj + '_' + algo + '_' + method+': avg train risk:',sum(fc_train)/10/max_risk/file_number, \n",
    "                              'avg test risk', sum(fc_test)/10/max_risk/file_number, '&s:', sum(ands)/10/file_number)\n",
    "\n",
    "    rg=list(range(1,11))\n",
    "    plt.figure(figsize=(8,6))\n",
    "    colours = {}\n",
    "    line_width = {}\n",
    "    width = [1,1, 1, 1]*4\n",
    "    i = 0\n",
    "    colors=['blue','green','red','deepskyblue','gold','violet','cyan','brown','deepskyblue','purple', 'lime',\n",
    "            'slategray','magenta','pink','olive','khaki']\n",
    "    label_map={'greedy_gpe_boosting_':'Gradient Boosting', 'greedy_gpe_fc_Newton-CG': 'Gradient Fully-corrective Boosting', \n",
    "               'greedy_orth_fc_Newton-CG': 'Greedy Orthogonal Fully-corrective Boosting', 'xgb_keep_': 'XGBoost', \n",
    "              'xgb_fc_Newton-CG': 'XG Fully-corrective Boosting', 'exhaustive_gpe_boosting_':'Optimal Gradient Boosting', \n",
    "               'exhaustive_gpe_fc_Newton-CG': 'Optimal Gradient Fully-corrective Boosting',\n",
    "               'exhaustive_orth_fc_Newton-CG': 'Optimal Orthogonal Fully-corrective Boosting',\n",
    "               'greedy_mwg_boosting_':'Gradient Descent',\n",
    "               'exhaustive_mwg_boosting_': 'Optimal Gradient Descent',\n",
    "               'greedy_mwg_fc_Newton-CG':'FC Gradient Descent',\n",
    "               'exhaustive_mwg_fc_Newton-CG': 'Optimal FC Gradient Descent',\n",
    "              }\n",
    "    for item in train_risks:\n",
    "        color = colors[i]\n",
    "        colours[item] = color\n",
    "        line_width[item] = width[i]\n",
    "        i+=1\n",
    "        if file_numbers[item]==0:\n",
    "            continue\n",
    "        train_risks[item] = [risk / max_risk/file_numbers[item] for risk in train_risks[item]]\n",
    "        test_risks[item] = [risk / max_risk/file_numbers[item] for risk in test_risks[item]]\n",
    "        and_counts[item] = [ands / file_numbers[item] for ands in and_counts[item]]\n",
    "        aucs_test[item] = and_counts[item][0]+sum((test_risks[item][m])*\n",
    "                                             (min(max_length, and_counts[item][m+1])-\n",
    "                                                                   min(max_length, and_counts[item][m]))\n",
    "                                for m in range(len(test_risks[item])-1))\n",
    "        aucs_train[item] = and_counts[item][0]+sum((train_risks[item][m])*\n",
    "                                             (min(max_length, and_counts[item][m+1])-\n",
    "                                                                   min(max_length, and_counts[item][m]))\n",
    "                                for m in range(len(train_risks[item])-1))\n",
    "        if and_counts[item][-1]<max_length:\n",
    "            aucs_test[item]+=test_risks[item][-1]*(max_length-and_counts[item][-1])\n",
    "            aucs_train[item]+=train_risks[item][-1]*(max_length-and_counts[item][-1])\n",
    "        print(item, 'auc:', aucs_test[item])\n",
    "        plt.step([0]+and_counts[item], [1]+train_risks[item], '--', color=colours[item],\n",
    "                 label=label_map[item],linewidth=line_width[item],where='post')\n",
    "    plt.title(dataset_name if title is None else title + \" risks\")\n",
    "    plt.xlabel('number of rules')\n",
    "    plt.xlim(0,30)\n",
    "    plt.ylabel('risk')\n",
    "    plt.yscale('log')\n",
    "    plt.grid(visible=True, which='major')\n",
    "    plt.grid(visible=True, which='minor')\n",
    "    plt.gca().set_ylim(bottom=0)\n",
    "    plt.legend()\n",
    "    \n",
    "    return train_risks, test_risks, and_counts, aucs_test, aucs_train\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bdb5f34a",
   "metadata": {},
   "source": [
    "The next three functions computes the largest gaps from one algorithm to another."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "a5914281",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [],
   "source": [
    "def map_size_risk(train_risks, sizes):\n",
    "    risks = [1]\n",
    "    szs = [0]\n",
    "    sz = 0\n",
    "    for i in range(len(sizes)):\n",
    "        while sz<=sizes[i]:\n",
    "            sz+=0.2\n",
    "            szs.append(sz)\n",
    "            if i==0:\n",
    "                risk=1\n",
    "            else:\n",
    "                risk=train_risks[i-1]\n",
    "            risks.append(risk)\n",
    "    return risks, szs\n",
    "\n",
    "\n",
    "def largest_gaps(train_risks, and_counts, a, b, max_size=150):\n",
    "    risks_a, szs_a = map_size_risk(train_risks[a], and_counts[a])\n",
    "    risks_b, szs_b = map_size_risk(train_risks[b], and_counts[b])\n",
    "    max_risk_index_ab = -1000\n",
    "    max_diff=-100\n",
    "    for i in range(min([len(szs_a), len(szs_b), max_size])):\n",
    "        if i <= 25:\n",
    "            continue\n",
    "        if risks_a[i]!=1 and risks_b[i]!=1:\n",
    "            if risks_a[i]-risks_b[i]>max_diff:\n",
    "                max_risk_index_ab=i\n",
    "                max_diff = risks_a[i]-risks_b[i]\n",
    "    print(max_risk_index_ab)\n",
    "    print(risks_a[max_risk_index_ab], risks_b[max_risk_index_ab])\n",
    "    return risks_a[max_risk_index_ab]-risks_b[max_risk_index_ab], szs_a[max_risk_index_ab], risks_a[max_risk_index_ab], risks_b[max_risk_index_ab], max_risk_index_ab\n",
    "\n",
    "\n",
    "def internal_steps(train_risks, and_counts, a, b, max_risk_index_ab):\n",
    "    risks_a, szs_a = map_size_risk(train_risks[a], and_counts[a])\n",
    "    risks_b, szs_b = map_size_risk(train_risks[b], and_counts[b])\n",
    "    return  risks_a[max_risk_index_ab]-risks_b[max_risk_index_ab], szs_a[max_risk_index_ab], risks_a[max_risk_index_ab], risks_b[max_risk_index_ab]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d211a519",
   "metadata": {
    "scrolled": true,
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "33\n",
      "titanic\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.6118282572937578 avg test risk 0.6903799959890116 &s: 22.22\n",
      "gpe_fc_Newton-CG: avg train risk: 0.6119285414269393 avg test risk 0.6906056313509659 &s: 21.880000000000003\n",
      "orth_fc_Newton-CG: avg train risk: 0.6105959684846738 avg test risk 0.7186830683975195 &s: 21.6\n",
      "gpe_boosting_: avg train risk: 0.5901303876115521 avg test risk 0.6967930638888309 &s: 27.3\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5880366491430367 avg test risk 0.7008725524869737 &s: 27.619999999999997\n",
      "orth_fc_Newton-CG: avg train risk: 0.5940096769179378 avg test risk 0.7060952812311686 &s: 25.76\n",
      "tic-tac-toe\n",
      "1\n",
      "gpe_boosting_: avg train risk: 0.6351372504701496 avg test risk 0.7192877625452025 &s: 22.6\n",
      "gpe_fc_Newton-CG: avg train risk: 0.6290305795924229 avg test risk 0.7109624035401794 &s: 23.880000000000003\n",
      "orth_fc_Newton-CG: avg train risk: 0.614342265613755 avg test risk 0.7102513097695653 &s: 24.4\n",
      "gpe_boosting_: avg train risk: 0.5397645161218193 avg test risk 0.5833655812165542 &s: 25.78\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5266525907442361 avg test risk 0.5868289910385721 &s: 26.8\n",
      "orth_fc_Newton-CG: avg train risk: 0.5353418923826337 avg test risk 0.560820025847304 &s: 20.7\n",
      "iris\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.22036509226382725 avg test risk 0.42348306061757224 &s: 21.02\n",
      "gpe_fc_Newton-CG: avg train risk: 0.22803182201438407 avg test risk 0.4487339657183743 &s: 20.380000000000003\n",
      "orth_fc_Newton-CG: avg train risk: 0.22847983732752875 avg test risk 0.45858529653645286 &s: 16.56\n",
      "gpe_boosting_: avg train risk: 0.19805794967876345 avg test risk 0.40221466361195224 &s: 23.14\n",
      "gpe_fc_Newton-CG: avg train risk: 0.19523445817415924 avg test risk 0.4213652055487918 &s: 23.04\n",
      "orth_fc_Newton-CG: avg train risk: 0.21451796837097206 avg test risk 0.5057540579430347 &s: 21.419999999999998\n",
      "breast_cancer\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.25412899343025164 avg test risk 0.25588781636045255 &s: 22.72\n",
      "gpe_fc_Newton-CG: avg train risk: 0.25283022147648326 avg test risk 0.2502053596806967 &s: 22.22\n",
      "orth_fc_Newton-CG: avg train risk: 0.24727347414568496 avg test risk 0.25549712493300164 &s: 22.64\n",
      "gpe_boosting_: avg train risk: 0.2246161782327758 avg test risk 0.2796206886595892 &s: 30.639999999999997\n",
      "gpe_fc_Newton-CG: avg train risk: 0.21548191848813567 avg test risk 0.2750478863924233 &s: 30.8\n",
      "orth_fc_Newton-CG: avg train risk: 0.21421657360352664 avg test risk 0.2618014979910403 &s: 30.02\n",
      "IBM_HR\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.575707619298065 avg test risk 0.6197237788980794 &s: 11.34\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5702954707510424 avg test risk 0.6129776353307919 &s: 11.5\n",
      "orth_fc_Newton-CG: avg train risk: 0.5697450073689074 avg test risk 0.6084191787607234 &s: 11.5\n",
      "gpe_boosting_: avg train risk: 0.575117228231503 avg test risk 0.6080666844117469 &s: 13.419999999999998\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5693171099800388 avg test risk 0.5999741143444515 &s: 14.16\n",
      "orth_fc_Newton-CG: avg train risk: 0.5681487766431805 avg test risk 0.5988205634685655 &s: 13.88\n",
      "telco_churn\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.0 avg test risk 0.0 &s: 0.0\n",
      "gpe_fc_Newton-CG: avg train risk: 0.6751749061148187 avg test risk 0.6717009861238116 &s: 20.1\n",
      "orth_fc_Newton-CG: avg train risk: 0.6671383733235687 avg test risk 0.6549828277823527 &s: 16.3\n",
      "gpe_boosting_: avg train risk: 0.6772224489660232 avg test risk 0.6700789754456629 &s: 24.0\n",
      "gpe_fc_Newton-CG: avg train risk: 0.6749015409015555 avg test risk 0.6697527073761366 &s: 24.6\n",
      "orth_fc_Newton-CG: avg train risk: 0.6647405355922625 avg test risk 0.659977015457756 &s: 24.2\n",
      "GenderRecognition\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.9967361469515621 avg test risk 0.9985227473151832 &s: 11.0\n",
      "gpe_fc_Newton-CG: avg train risk: 0.9968730576837617 avg test risk 0.9985547179627187 &s: 11.0\n",
      "orth_fc_Newton-CG: avg train risk: 0.9968626792532731 avg test risk 0.9985547179633809 &s: 11.0\n",
      "gpe_boosting_: avg train risk: 0.9967361469515621 avg test risk 0.9985227473151832 &s: 11.0\n",
      "gpe_fc_Newton-CG: avg train risk: 0.9968730576837617 avg test risk 0.9985547179627187 &s: 11.0\n",
      "orth_fc_Newton-CG: avg train risk: 0.9968626792532731 avg test risk 0.9985547179633809 &s: 11.0\n",
      "banknote\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.256787779768445 avg test risk 0.270799438926478 &s: 22.0\n",
      "gpe_fc_Newton-CG: avg train risk: 0.24340933113303315 avg test risk 0.257829947567495 &s: 22.52\n",
      "orth_fc_Newton-CG: avg train risk: 0.23284657269646067 avg test risk 0.248266223559576 &s: 22.64\n",
      "gpe_boosting_: avg train risk: 0.24643130378870182 avg test risk 0.2604116511667621 &s: 23.32\n",
      "gpe_fc_Newton-CG: avg train risk: 0.2243713989613266 avg test risk 0.24051002069356203 &s: 23.119999999999997\n",
      "orth_fc_Newton-CG: avg train risk: 0.22172285493415758 avg test risk 0.23742681559231907 &s: 23.0\n",
      "liver\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.7482752046893586 avg test risk 0.9759761501082311 &s: 28.04\n",
      "gpe_fc_Newton-CG: avg train risk: 0.7454634417996315 avg test risk 0.9580702614796361 &s: 27.96\n",
      "orth_fc_Newton-CG: avg train risk: 0.7489977348074028 avg test risk 0.9899439631142034 &s: 26.32\n",
      "gpe_boosting_: avg train risk: 0.6897434326221928 avg test risk 1.0426888685664881 &s: 31.380000000000003\n",
      "gpe_fc_Newton-CG: avg train risk: 0.6845241171320178 avg test risk 1.0284966879146622 &s: 31.939999999999998\n",
      "orth_fc_Newton-CG: avg train risk: 0.6838363746556484 avg test risk 1.0878340766683654 &s: 32.839999999999996\n",
      "magic\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.7043326024989914 avg test risk 0.6875583939885261 &s: 20.3\n",
      "gpe_fc_Newton-CG: avg train risk: 0.7036154250825993 avg test risk 0.6833497126454212 &s: 20.3\n",
      "orth_fc_Newton-CG: avg train risk: 0.7041737331520785 avg test risk 0.6838848197902815 &s: 20.6\n",
      "gpe_boosting_: avg train risk: 0.7027965256040555 avg test risk 0.6833769435644214 &s: 19.3\n",
      "gpe_fc_Newton-CG: avg train risk: 0.7016442110504383 avg test risk 0.6813724253564851 &s: 21.1\n",
      "orth_fc_Newton-CG: avg train risk: 0.7014541191007349 avg test risk 0.6808827433299356 &s: 20.9\n",
      "adult\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.5870831496829368 avg test risk 0.6021453695986352 &s: 18.5\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5827705462125611 avg test risk 0.5956283686311018 &s: 18.1\n",
      "orth_fc_Newton-CG: avg train risk: 0.5745407325209627 avg test risk 0.5863465432150459 &s: 12.4\n",
      "gpe_boosting_: avg train risk: 0.5859838625737354 avg test risk 0.5988969501305872 &s: 20.8\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5878777582969417 avg test risk 0.6032393892704501 &s: 22.5\n",
      "orth_fc_Newton-CG: avg train risk: 0.5737933454479414 avg test risk 0.5871183516653498 &s: 17.8\n",
      "digits5\n",
      "1.0\n",
      "gpe_boosting_: avg train risk: 0.3457023618806624 avg test risk 0.3342303896094667 &s: 12.5\n",
      "gpe_fc_Newton-CG: avg train risk: 0.34588877147472197 avg test risk 0.33482810977242 &s: 12.9\n",
      "orth_fc_Newton-CG: avg train risk: 0.34573389269668553 avg test risk 0.33328618441851554 &s: 12.9\n",
      "gpe_boosting_: avg train risk: 0.3624988328404785 avg test risk 0.3534446004221216 &s: 14.2\n",
      "gpe_fc_Newton-CG: avg train risk: 0.3662124421311454 avg test risk 0.3550631166997283 &s: 15.8\n",
      "orth_fc_Newton-CG: avg train risk: 0.3662120452353713 avg test risk 0.35506479821687975 &s: 15.8\n",
      "insurance\n",
      "322646873.58870494\n",
      "gpe_boosting_: avg train risk: 0.12787269311388316 avg test risk 0.11924228916207555 &s: 17.16\n",
      "gpe_fc_Newton-CG: avg train risk: 0.12763492323990844 avg test risk 0.12067739765354209 &s: 17.68\n",
      "orth_fc_Newton-CG: avg train risk: 0.11840740725861354 avg test risk 0.11414082970820423 &s: 13.959999999999999\n",
      "gpe_boosting_: avg train risk: 0.125251043299104 avg test risk 0.1175901168719039 &s: 19.72\n",
      "gpe_fc_Newton-CG: avg train risk: 0.12010631019950484 avg test risk 0.11407278308881405 &s: 20.2\n",
      "orth_fc_Newton-CG: avg train risk: 0.11437779615854267 avg test risk 0.11166033703732237 &s: 16.44\n",
      "make_friedman1\n",
      "226.89125115757616\n",
      "gpe_boosting_: avg train risk: 0.05951579683547527 avg test risk 0.06371494860360166 &s: 16.7\n",
      "gpe_fc_Newton-CG: avg train risk: 0.05756061033665884 avg test risk 0.06241337424921274 &s: 17.2\n",
      "orth_fc_Newton-CG: avg train risk: 0.055200470513528756 avg test risk 0.0586315817868278 &s: 14.219999999999999\n",
      "gpe_boosting_: avg train risk: 0.05671614185928305 avg test risk 0.0632130976626977 &s: 19.7\n",
      "gpe_fc_Newton-CG: avg train risk: 0.05505872856261146 avg test risk 0.062157888910267224 &s: 21.32\n",
      "orth_fc_Newton-CG: avg train risk: 0.053573506838416454 avg test risk 0.059600905538132784 &s: 19.8\n",
      "make_friedman2\n",
      "379683.4049960418\n",
      "gpe_boosting_: avg train risk: 0.08456773878131998 avg test risk 0.08553780701737448 &s: 17.880000000000003\n",
      "gpe_fc_Newton-CG: avg train risk: 0.06988128623107936 avg test risk 0.07054684345537965 &s: 17.06\n",
      "orth_fc_Newton-CG: avg train risk: 0.06301070251233903 avg test risk 0.0634878601474152 &s: 15.580000000000002\n",
      "gpe_boosting_: avg train risk: 0.07860559818208859 avg test risk 0.07955431300749086 &s: 17.880000000000003\n",
      "gpe_fc_Newton-CG: avg train risk: 0.06911354198846432 avg test risk 0.06989891625378283 &s: 17.6\n",
      "orth_fc_Newton-CG: avg train risk: 0.06164737651450021 avg test risk 0.06210497861046229 &s: 16.6\n",
      "make_friedman3\n",
      "1.8780821278399789\n",
      "gpe_boosting_: avg train risk: 0.025498602838641905 avg test risk 0.02837615226602917 &s: 16.880000000000003\n",
      "gpe_fc_Newton-CG: avg train risk: 0.02425248873157172 avg test risk 0.027285125629061064 &s: 18.06\n",
      "orth_fc_Newton-CG: avg train risk: 0.024034003911303142 avg test risk 0.02619667000609486 &s: 16.380000000000003\n",
      "gpe_boosting_: avg train risk: 0.024578859060122756 avg test risk 0.027921018868654102 &s: 19.919999999999998\n",
      "gpe_fc_Newton-CG: avg train risk: 0.024088635755236124 avg test risk 0.027726377798325687 &s: 19.880000000000003\n",
      "orth_fc_Newton-CG: avg train risk: 0.02317568910689253 avg test risk 0.02647439500674808 &s: 18.3\n",
      "wage\n",
      "2029057842.6515312\n",
      "gpe_boosting_: avg train risk: 0.3535497401248422 avg test risk 0.3841759259554974 &s: 21.32\n",
      "gpe_fc_Newton-CG: avg train risk: 0.3428673005711354 avg test risk 0.3691423719861295 &s: 21.9\n",
      "orth_fc_Newton-CG: avg train risk: 0.2766977874723867 avg test risk 0.2820796168054664 &s: 16.259999999999998\n",
      "gpe_boosting_: avg train risk: 0.339938348273477 avg test risk 0.38007905751338356 &s: 23.68\n",
      "gpe_fc_Newton-CG: avg train risk: 0.334945764792557 avg test risk 0.3836854446924982 &s: 23.52\n",
      "orth_fc_Newton-CG: avg train risk: 0.3298988685304777 avg test risk 0.38318094818844495 &s: 22.419999999999998\n",
      "Demographics\n",
      "31.64835409252669\n",
      "gpe_boosting_: avg train risk: 0.20248728713858863 avg test risk 0.2058680134768569 &s: 12.16\n",
      "gpe_fc_Newton-CG: avg train risk: 0.20127915473604713 avg test risk 0.20472910737368263 &s: 12.64\n",
      "orth_fc_Newton-CG: avg train risk: 0.20070314215529544 avg test risk 0.20379840810547348 &s: 12.440000000000001\n",
      "gpe_boosting_: avg train risk: 0.20246693348496655 avg test risk 0.20586809318159704 &s: 12.440000000000001\n",
      "gpe_fc_Newton-CG: avg train risk: 0.20116860501597394 avg test risk 0.20495196970017635 &s: 13.580000000000002\n",
      "orth_fc_Newton-CG: avg train risk: 0.20065370474560545 avg test risk 0.2040118892993723 &s: 12.7\n",
      "gdp\n",
      "43.986571428571416\n",
      "gpe_boosting_: avg train risk: 0.00494734063834158 avg test risk 0.005972694150248067 &s: 11.84\n",
      "gpe_fc_Newton-CG: avg train risk: 0.004715639824265891 avg test risk 0.005760543017897864 &s: 11.8\n",
      "orth_fc_Newton-CG: avg train risk: 0.004427575191734507 avg test risk 0.0057340892037899185 &s: 11.98\n",
      "gpe_boosting_: avg train risk: 0.00489617217241471 avg test risk 0.005822101846289536 &s: 11.98\n",
      "gpe_fc_Newton-CG: avg train risk: 0.0045413879077113506 avg test risk 0.005642913316844348 &s: 12.8\n",
      "orth_fc_Newton-CG: avg train risk: 0.004414022822460403 avg test risk 0.0055367123835312155 &s: 12.379999999999999\n",
      "used_cars\n",
      "194464336.77843493\n",
      "gpe_boosting_: avg train risk: 0.1377526564790718 avg test risk 0.14791581221741226 &s: 19.48\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10655768932407798 avg test risk 0.1135254022186957 &s: 16.8\n",
      "orth_fc_Newton-CG: avg train risk: 0.09947860524465536 avg test risk 0.10522496526393943 &s: 15.419999999999998\n",
      "gpe_boosting_: avg train risk: 0.12023072606557723 avg test risk 0.1314479114610583 &s: 19.78\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10729438064606736 avg test risk 0.11520759537994293 &s: 18.18\n",
      "orth_fc_Newton-CG: avg train risk: 0.09842655945431904 avg test risk 0.1056039921240548 &s: 16.8\n",
      "load_diabetes\n",
      "29074.481900452487\n",
      "gpe_boosting_: avg train risk: 0.12620481335883152 avg test risk 0.13600096100818485 &s: 16.740000000000002\n",
      "gpe_fc_Newton-CG: avg train risk: 0.1264843932684559 avg test risk 0.1413845459821737 &s: 17.919999999999998\n",
      "orth_fc_Newton-CG: avg train risk: 0.12225734550311637 avg test risk 0.13701606216412046 &s: 15.040000000000001\n",
      "gpe_boosting_: avg train risk: 0.12225944285683625 avg test risk 0.14126447913012946 &s: 22.380000000000003\n",
      "gpe_fc_Newton-CG: avg train risk: 0.11991607004926982 avg test risk 0.1489870539851663 &s: 24.619999999999997\n",
      "orth_fc_Newton-CG: avg train risk: 0.11762531057859855 avg test risk 0.1440596835876041 &s: 21.02\n",
      "boston\n",
      "592.1469169960473\n",
      "gpe_boosting_: avg train risk: 0.0761948947360731 avg test risk 0.06907664680217467 &s: 18.6\n",
      "gpe_fc_Newton-CG: avg train risk: 0.07108095372374286 avg test risk 0.06555116061832682 &s: 18.86\n",
      "orth_fc_Newton-CG: avg train risk: 0.06811423654966384 avg test risk 0.06454743006918474 &s: 18.080000000000002\n",
      "gpe_boosting_: avg train risk: 0.07190101209592796 avg test risk 0.06947908596214722 &s: 20.78\n",
      "gpe_fc_Newton-CG: avg train risk: 0.06701459315766464 avg test risk 0.06621956658733479 &s: 23.78\n",
      "orth_fc_Newton-CG: avg train risk: 0.06657969688155173 avg test risk 0.06423625013522145 &s: 21.119999999999997\n",
      "world_happiness_indicator\n",
      "30.46778212179487\n",
      "gpe_boosting_: avg train risk: 0.013586376828277572 avg test risk 0.019595460882036494 &s: 17.48\n",
      "gpe_fc_Newton-CG: avg train risk: 0.012975009566826757 avg test risk 0.019157534265677893 &s: 16.96\n",
      "orth_fc_Newton-CG: avg train risk: 0.011963937085842037 avg test risk 0.015925573990160435 &s: 16.98\n",
      "gpe_boosting_: avg train risk: 0.0126474076589238 avg test risk 0.019082029113571868 &s: 23.8\n",
      "gpe_fc_Newton-CG: avg train risk: 0.011787595620250616 avg test risk 0.02198530493255366 &s: 23.740000000000002\n",
      "orth_fc_Newton-CG: avg train risk: 0.011057831918447784 avg test risk 0.017780851602805736 &s: 22.34\n",
      "who_life_expectancy\n",
      "4882.764241803283\n",
      "gpe_boosting_: avg train risk: 0.006376930826079331 avg test risk 0.0070724933285511325 &s: 23.9\n",
      "gpe_fc_Newton-CG: avg train risk: 0.006553296819991902 avg test risk 0.007533837448319764 &s: 23.0\n",
      "orth_fc_Newton-CG: avg train risk: 0.006042226233155578 avg test risk 0.006978898662932906 &s: 23.2\n",
      "gpe_boosting_: avg train risk: 0.0062449437893932385 avg test risk 0.006985780997470694 &s: 24.3\n",
      "gpe_fc_Newton-CG: avg train risk: 0.005941759207416971 avg test risk 0.00658163128311461 &s: 29.6\n",
      "orth_fc_Newton-CG: avg train risk: 0.0056696011947905455 avg test risk 0.00681689768923372 &s: 26.3\n",
      "mobile_prices\n",
      "3.5\n",
      "gpe_boosting_: avg train risk: 0.10577610082961697 avg test risk 0.11272515008321767 &s: 20.7\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10682902256018369 avg test risk 0.11438384899279974 &s: 19.7\n",
      "orth_fc_Newton-CG: avg train risk: 0.10549059111368508 avg test risk 0.111454714178809 &s: 19.1\n",
      "gpe_boosting_: avg train risk: 0.10419340095555278 avg test risk 0.11672467773861543 &s: 27.9\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10364267325053926 avg test risk 0.11470857051776098 &s: 28.5\n",
      "orth_fc_Newton-CG: avg train risk: 0.1036407858942616 avg test risk 0.11529409256685555 &s: 27.5\n",
      "suicide_rates_cleaned\n",
      "523.7783290690134\n",
      "gpe_boosting_: avg train risk: 0.5356370409820378 avg test risk 0.5145515803688424 &s: 10.9\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5344303478950759 avg test risk 0.5127075693555437 &s: 12.1\n",
      "orth_fc_Newton-CG: avg train risk: 0.5321716691139888 avg test risk 0.5102312312783713 &s: 12.2\n",
      "gpe_boosting_: avg train risk: 0.5349036916340525 avg test risk 0.5144823995278096 &s: 11.8\n",
      "gpe_fc_Newton-CG: avg train risk: 0.5254026371325122 avg test risk 0.5046668248873023 &s: 13.3\n",
      "orth_fc_Newton-CG: avg train risk: 0.5254015071424118 avg test risk 0.5046732213565607 &s: 13.2\n",
      "videogamesales\n",
      "2.70680865164444\n",
      "gpe_boosting_: avg train risk: 0.9521665165295372 avg test risk 0.7139149072862061 &s: 9.6\n",
      "gpe_fc_Newton-CG: avg train risk: 0.9521607988965333 avg test risk 0.7139165358454405 &s: 10.7\n",
      "orth_fc_Newton-CG: avg train risk: 0.9521609790292008 avg test risk 0.7139182510014449 &s: 11.4\n",
      "gpe_boosting_: avg train risk: 0.9521665165295372 avg test risk 0.7139149072862061 &s: 9.6\n",
      "gpe_fc_Newton-CG: avg train risk: 0.9521607988965333 avg test risk 0.7139165358454405 &s: 10.7\n",
      "orth_fc_Newton-CG: avg train risk: 0.952160798896561 avg test risk 0.7139165351433903 &s: 10.8\n",
      "red_wine_quality\n",
      "32.41651031894934\n",
      "gpe_boosting_: avg train risk: 0.01563845691769493 avg test risk 0.016375183137472164 &s: 16.6\n",
      "gpe_fc_Newton-CG: avg train risk: 0.01543813343448952 avg test risk 0.016247493953122496 &s: 17.6\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "orth_fc_Newton-CG: avg train risk: 0.014982576616962734 avg test risk 0.015753890433513225 &s: 14.2\n",
      "gpe_boosting_: avg train risk: 0.014951822549859075 avg test risk 0.016302923778737002 &s: 20.5\n",
      "gpe_fc_Newton-CG: avg train risk: 0.01472388525709281 avg test risk 0.01647363482212914 &s: 24.3\n",
      "orth_fc_Newton-CG: avg train risk: 0.01480847683596378 avg test risk 0.015467038970163688 &s: 22.380000000000003\n",
      "covid_vic\n",
      "51.62076805721374\n",
      "gpe_boosting_: avg train risk: 0.11463357278118995 avg test risk 0.11263060516476828 &s: 15.6\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10357588818625314 avg test risk 0.10720302607276233 &s: 15.24\n",
      "orth_fc_Newton-CG: avg train risk: 0.09974235460862203 avg test risk 0.1049463173461432 &s: 13.780000000000001\n",
      "gpe_boosting_: avg train risk: 0.11307162110142277 avg test risk 0.10581011837941634 &s: 16.240000000000002\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10395835665151036 avg test risk 0.10410631891355408 &s: 16.32\n",
      "orth_fc_Newton-CG: avg train risk: 0.10122063082559463 avg test risk 0.10939665754487597 &s: 15.52\n",
      "covid\n",
      "1082.8170359400497\n",
      "gpe_boosting_: avg train risk: 0.3297056206499036 avg test risk 0.4507806175593302 &s: 20.68\n",
      "gpe_fc_Newton-CG: avg train risk: 0.3194774145468923 avg test risk 0.4365283859625312 &s: 20.02\n",
      "orth_fc_Newton-CG: avg train risk: 0.3173629336897012 avg test risk 0.4459544371185656 &s: 18.32\n",
      "gpe_boosting_: avg train risk: 0.32822986406309024 avg test risk 0.44474026153866014 &s: 20.22\n",
      "gpe_fc_Newton-CG: avg train risk: 0.3140180762328234 avg test risk 0.4437499438474569 &s: 20.259999999999998\n",
      "orth_fc_Newton-CG: avg train risk: 0.3125675087882435 avg test risk 0.4397852838088189 &s: 20.4\n",
      "bicycle\n",
      "1076.416963882381\n",
      "gpe_boosting_: avg train risk: 0.27415048066667874 avg test risk 0.39912738759946037 &s: 23.46\n",
      "gpe_fc_Newton-CG: avg train risk: 0.26935498594837015 avg test risk 0.40325573199938536 &s: 22.2\n",
      "orth_fc_Newton-CG: avg train risk: 0.2659933249631298 avg test risk 0.40247057309682344 &s: 21.46\n",
      "gpe_boosting_: avg train risk: 0.2537584731249193 avg test risk 0.4141429259642206 &s: 24.380000000000003\n",
      "gpe_fc_Newton-CG: avg train risk: 0.24874763316166063 avg test risk 0.41489782639303147 &s: 24.44\n",
      "orth_fc_Newton-CG: avg train risk: 0.24620060566596114 avg test risk 0.4208737596918831 &s: 24.32\n",
      "ships\n",
      "12.342277392898044\n",
      "gpe_boosting_: avg train risk: 0.143728202125694 avg test risk 0.26381686052792896 &s: 18.22\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10629903056001459 avg test risk 0.4190921462170606 &s: 17.86\n",
      "orth_fc_Newton-CG: avg train risk: 0.09864172731180813 avg test risk 0.4431616930646552 &s: 17.6\n",
      "gpe_boosting_: avg train risk: 0.1423130325000928 avg test risk 0.24032479623786035 &s: 19.7\n",
      "gpe_fc_Newton-CG: avg train risk: 0.10097777699919015 avg test risk 0.32625814576670586 &s: 19.919999999999998\n",
      "orth_fc_Newton-CG: avg train risk: 0.10624587703314378 avg test risk 0.3364024102588953 &s: 20.48\n",
      "smoking\n",
      "7.500299349437478\n",
      "gpe_boosting_: avg train risk: 0.10026707091120968 avg test risk 0.19233110476613546 &s: 15.719999999999999\n",
      "gpe_fc_Newton-CG: avg train risk: 0.0867284782508873 avg test risk 0.15687663423177686 &s: 15.8\n",
      "orth_fc_Newton-CG: avg train risk: 0.08943505464359303 avg test risk 0.17043275337450306 &s: 14.219999999999999\n",
      "gpe_boosting_: avg train risk: 0.09530235938015126 avg test risk 0.20141039272174557 &s: 16.240000000000002\n",
      "gpe_fc_Newton-CG: avg train risk: 0.08781413595427226 avg test risk 0.18109755727657403 &s: 16.759999999999998\n",
      "orth_fc_Newton-CG: avg train risk: 0.08591136125258021 avg test risk 0.16547821104528967 &s: 15.02\n",
      "done\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_12401/3624857710.py:60: RuntimeWarning: More than 20 figures have been opened. Figures created through the pyplot interface (`matplotlib.pyplot.figure`) are retained until explicitly closed and may consume too much memory. (To control this warning, see the rcParam `figure.max_open_warning`).\n",
      "  plt.figure(figsize=(8,6))\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 576x432 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "values = ['greedy_gpe_boosting_', \n",
    "          'greedy_gpe_fc_Newton-CG', \n",
    "              'greedy_orth_fc_Newton-CG', \n",
    "               'exhaustive_orth_fc_Newton-CG',\n",
    "          'exhaustive_gpe_boosting_',\n",
    "         ]\n",
    "datasets = ['titanic','tic-tac-toe','iris','breast_cancer',\n",
    "            'IBM_HR', 'telco_churn', 'GenderRecognition',\n",
    "            'banknote', 'liver', 'magic', 'adult', 'digits5',\n",
    "            'insurance','make_friedman1',\n",
    "            'make_friedman2','make_friedman3','wage', 'Demographics','gdp','used_cars','load_diabetes',\n",
    "            'boston','world_happiness_indicator', 'who_life_expectancy', 'mobile_prices', 'suicide_rates_cleaned',\n",
    "            'videogamesales', 'red_wine_quality',\n",
    "            'covid_vic','covid',\n",
    "            'bicycle','ships','smoking']\n",
    "cols = [10, 10, 10, 5, \n",
    "        3, 4, 3, 10, 10, 5, 5, 3,\n",
    "        10, 4, 10, 10, 10,\n",
    "       2, 20, 10, 5, 4, 10, 5, 4, 3, 3, 5,\n",
    "        10, 10, 10, 10, 10]\n",
    "print(len(cols))\n",
    "datapoints = [891,958,150,569,178,1470, 7043, 3168, 1372, 345, 19020, 30162, 5620,\n",
    "              1338,1000,5000,2000,1379,8992,35,1770,442,506,156, 2928, 2000, 27820, 16598, 1599, \n",
    "              85,225,122,34,36]\n",
    "\n",
    "max_components = [30] * len(datasets)\n",
    "max_components[11]=25\n",
    "max_components[12]=25\n",
    "f = open(\"../analysis_results/1ablation_te.csv\", 'w')\n",
    "f.write('dataset'+(','+','.join(values))*4+'\\n')\n",
    "f2 = open(\"../analysis_results/1ablation_tr.csv\", 'w')\n",
    "f2.write('dataset'+(','+','.join(values))*4+'\\n')\n",
    "for i in range(len(datasets)):\n",
    "    try:\n",
    "        print(datasets[i])\n",
    "        max_risk = get_max_risk(datasets[i])\n",
    "        train, test, ands, aucs_te, aucs_tr = compare4(datasets[i], col=cols[i], max_length=max_components[i])\n",
    "        gpe_orth_test = largest_gaps(test, ands, 'exhaustive_gpe_boosting_', 'exhaustive_orth_fc_Newton-CG')\n",
    "        orth_gpe_test = largest_gaps(test, ands, 'exhaustive_orth_fc_Newton-CG', 'exhaustive_gpe_boosting_')\n",
    "        gpe_fc_test = internal_steps(test, ands, 'exhaustive_gpe_boosting_', 'greedy_gpe_fc_Newton-CG', gpe_orth[4])\n",
    "        fc_gpe_test = internal_steps(test, ands, 'greedy_gpe_fc_Newton-CG', 'exhaustive_gpe_boosting_', orth_gpe_test[4])\n",
    "        fc_orth_test = internal_steps(test, ands, 'greedy_gpe_fc_Newton-CG', 'greedy_orth_fc_Newton-CG', gpe_orth[4])\n",
    "        orth_fc_test = internal_steps(test, ands, 'greedy_orth_fc_Newton-CG', 'greedy_gpe_fc_Newton-CG', orth_gpe_test[4])\n",
    "        greedy_opt_test = internal_steps(test, ands, 'greedy_orth_fc_Newton-CG', 'exhaustive_orth_fc_Newton-CG', gpe_orth[4])\n",
    "        opt_greedy_test = internal_steps(test, ands, 'exhaustive_orth_fc_Newton-CG', 'greedy_orth_fc_Newton-CG', orth_gpe_test[4])\n",
    "        \n",
    "        f.write(datasets[i] + ',')\n",
    "        for value in values:\n",
    "            f.write(str(max(ands[value]))+',')\n",
    "        for value in values:\n",
    "            f.write(str(aucs_te[value])+',')\n",
    "        f.write(str(gpe_fc_test[0])+','+str(gpe_fc_test[1])+','+str(gpe_fc_test[2])+','+str(gpe_fc_test[3])+',')\n",
    "        f.write(str(fc_gpe_test[0])+','+str(fc_gpe_test[1])+','+str(fc_gpe_test[2])+','+str(fc_gpe_test[3])+',')\n",
    "        f.write(str(fc_orth_test[0])+','+str(fc_orth_test[1])+','+str(fc_orth_test[2])+','+str(fc_orth_test[3])+',')\n",
    "        f.write(str(orth_fc_test[0])+','+str(orth_fc_test[1])+','+str(orth_fc_test[2])+','+str(orth_fc_test[3])+',')\n",
    "        f.write(str(greedy_opt_test[0])+','+str(greedy_opt_test[1])+','+str(greedy_opt_test[2])+','+str(greedy_opt_test[3])+',')\n",
    "        f.write(str(opt_greedy_test[0])+','+str(opt_greedy_test[1])+','+str(opt_greedy_test[2])+','+str(opt_greedy_test[3])+',')\n",
    "        f.write(str(gpe_orth[0])+','+str(gpe_orth[1])+','+str(gpe_orth[2])+','+str(gpe_orth[3])+',')\n",
    "        f.write(str(orth_gpe_test[0])+','+str(orth_gpe_test[1])+','+str(orth_gpe_test[2])+','+str(orth_gpe_test[3])+',')\n",
    "        f.write('\\n')\n",
    "        \n",
    "        gpe_orth_train = largest_gaps(train, ands, 'exhaustive_gpe_boosting_', 'exhaustive_orth_fc_Newton-CG')\n",
    "        orth_gpe_train = largest_gaps(train, ands, 'exhaustive_orth_fc_Newton-CG', 'exhaustive_gpe_boosting_')\n",
    "        gpe_fc_train = internal_steps(train, ands, 'exhaustive_gpe_boosting_', 'greedy_gpe_fc_Newton-CG', gpe_orth[4])\n",
    "        fc_gpe_train = internal_steps(train, ands, 'greedy_gpe_fc_Newton-CG', 'exhaustive_gpe_boosting_', orth_gpe_train[4])\n",
    "        fc_orth_train = internal_steps(train, ands, 'greedy_gpe_fc_Newton-CG', 'greedy_orth_fc_Newton-CG', gpe_orth[4])\n",
    "        orth_fc_train = internal_steps(train, ands, 'greedy_orth_fc_Newton-CG', 'greedy_gpe_fc_Newton-CG', orth_gpe_train[4])\n",
    "        greedy_opt_train = internal_steps(train, ands, 'greedy_orth_fc_Newton-CG', 'exhaustive_orth_fc_Newton-CG', gpe_orth[4])\n",
    "        opt_greedy_train = internal_steps(train, ands, 'exhaustive_orth_fc_Newton-CG', 'greedy_orth_fc_Newton-CG', orth_gpe_train[4])\n",
    "        \n",
    "        f2.write(datasets[i] + ',')\n",
    "        for value in values:\n",
    "            f2.write(str(max(ands[value]))+',')\n",
    "        for value in values:\n",
    "            f2.write(str(aucs_te[value])+',')\n",
    "        f2.write(str(gpe_fc_train[0])+','+str(gpe_fc_train[1])+','+str(gpe_fc_train[2])+','+str(gpe_fc_train[3])+',')\n",
    "        f2.write(str(fc_gpe_train[0])+','+str(fc_gpe_train[1])+','+str(fc_gpe_train[2])+','+str(fc_gpe_train[3])+',')\n",
    "        f2.write(str(fc_orth_train[0])+','+str(fc_orth_train[1])+','+str(fc_orth_train[2])+','+str(fc_orth_train[3])+',')\n",
    "        f2.write(str(orth_fc_train[0])+','+str(orth_fc_train[1])+','+str(orth_fc_train[2])+','+str(orth_fc_train[3])+',')\n",
    "        f2.write(str(greedy_opt_train[0])+','+str(greedy_opt_train[1])+','+str(greedy_opt_train[2])+','+str(greedy_opt_train[3])+',')\n",
    "        f2.write(str(opt_greedy_train[0])+','+str(opt_greedy_train[1])+','+str(opt_greedy_train[2])+','+str(opt_greedy_train[3])+',')\n",
    "        f2.write(str(gpe_orth[0])+','+str(gpe_orth[1])+','+str(gpe_orth[2])+','+str(gpe_orth[3])+',')\n",
    "        f2.write(str(orth_gpe_train[0])+','+str(orth_gpe_train[1])+','+str(orth_gpe_train[2])+','+str(orth_gpe_train[3])+',')\n",
    "        f2.write('\\n')\n",
    "\n",
    "    except:\n",
    "        continue\n",
    "f.close()\n",
    "print('done')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9a892350",
   "metadata": {},
   "source": [
    "The next cell contains information copied from \"../analysis_results/ablation.csv\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "9c5f8428",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [],
   "source": [
    "sobc_s_tr=[ 0.647235376, 0.730860317, 0.799414394, 0.347304187, 1, 0.60229175, 0.834034523, 0.99982025, 0.257477808, 0.759072711, 0.755666211, 0.809681325, 0.438306947, 0.293338496, 0.092480269, 0.377630939, 0.040842982, 0.43344679, 0.210060048, 0.008228215, 0.433511162, 0.172192669, 0.111879207, 0.027924789, 0.01063357, 0.358464174, 0.691383103, 0.952094529, 0.018361956, 0.353681493, 0.432556002, 0.495503794, 0.460797543, 0.421743923]\n",
    "xobc_x_tr=[ 1, 0.560237926, 0.728851218, 0.40520651, 0.613777952, 0.629428953, 0.673028883, 0.996569179, 0.259545887, 0.600584726, 0.708955965, 0.683441837, 0.473827881, 0.350132077, 0.10580903, 0.153170807, 0.051921184, 0.484284884, 0.215529506, 0.008031839, 0.206621583, 0.20383851, 0.149077556, 0.040584198, 0.015813397, 0.162821205, 0.530081995, 0.952094533, 0.017201019, 0.365765398, ]\n",
    "gobc_g_tr=[ 1, 0.492682531, 0.670668727, 0.19118436, 1, 0.609348418, 0.735775967, 0.998151977, 0.320473543, 1, 0.715826599, 0.629694074, 0.398863006, 0.350132077, 0.10580903, 0.153170792, 0.051921184, 0.484284884, 0.215529516, 0.008031822, 0.206621571, 0.20383851, 0.149077556, 0.040584198, 0.015813397, 0.162821205, 0.53008201, 0.952094529, 0.017201052, 0.165515112, 0.28398386, 0.330820569, 0.130630112, 0.152859071  ]\n",
    "gfbc_g_tr=[ 0.794661558, 0.492682531, 0.670668727, 0.215761049, 0.609348418, 0.735775967, 0.998151977, 0.320473543, 0.841522206, 0.715826599, 0.629694074, 0.398863006, 0.350132077, 0.10580903, 0.153170792, 0.051921184, 0.484284884, 0.215529516, 0.008031822, 0.206621571, 0.20383851, 0.149077556, 0.040584198, 0.015813397, 0.162821205, 0.53008201, 0.952094529, 0.017201052, 0.165515112, 0.308996779, 0.330820569, 0.130630112, 0.152859071 ]\n",
    "fgbc_f_tr=[ 0.794662531, 0.570573263, 0.478697855, 0.201786961, 0.580021799, 0.698593022, 0.998191972, 0.23567532, 0.825106961, 0.713285564, 0.629692538, 0.361739604, 0.350132077, 0.10580903, 0.086118576, 0.051921184, 0.484284884, 0.208662265, 0.005552462, 0.188293139, 0.20383851, 0.149077556, 0.022943698, 0.015813397, 0.162821205, 0.521696382, 0.952047056, 0.017291532, 0.089921624, 0.308369857, 0.287241492, 0.056498644, 0.152859071 ]\n",
    "gebc_g_tr=[ 0.794662531, 0.553749789, 0.465179226, 0.195002628, 0.580020478, 0.683925933, 0.998191972, 0.340477057, 0.823494155, 0.713285564, 0.569870414, 0.361739604, 0.164425321, 0.075347718, 0.074919173, 0.032447574, 0.314408263, 0.208662265, 0.004592891, 0.111950602, 0.143378706, 0.081865126, 0.01838677, 0.007248069, 0.162821205, 0.521696382, 0.952047056, 0.016618201, 0.082778683, 0.29257456, 0.289524093, 0.040231992, 0.109953011 ]\n",
    "\n",
    "sobc_o_tr=[ 0.570854537, 0.422991079, 0.402350825, 0.320294225, 0.674293271, 0.580020478, 0.772266337, 0.998191972, 0.14924596, 0.687432168, 0.713285564, 0.658367032, 0.411902612, 0.164425321, 0.075347718, 0.218852118, 0.031563124, 0.387771226, 0.199947985, 0.004592891, 0.268413594, 0.138486112, 0.081865126, 0.017012644, 0.007248069, 0.162821205, 0.614736424, 0.952047056, 0.016124197, 0.251814035, 0.341750888, 0.330820569, 0.265717808, 0.180589665  ]\n",
    "xobc_o_tr=[0.82424626, 0.356129237, 0.402350825, 0.320294225, 0.233631531, 0.580020478, 0.646049192, 0.996121329, 0.14924596, 0.532959276, 0.689751925, 0.616645065, 0.411902612, 0.164425321, 0.075347718, 0.074919173, 0.031563124, 0.387771226, 0.208662265, 0.004592891, 0.111919317, 0.138486112, 0.081865126, 0.017012644, 0.007248069, 0.117620313, 0.507368268, 0.952047056, 0.016124197, 0.330820569, ]\n",
    "gobc_o_tr=[ 0.82424626, 0.356129237, 0.402350825, 0.153794955, 0.674293271, 0.580020478, 0.681926215, 0.998191972, 0.207166261, 0.935490108, 0.713285564, 0.580408533, 0.367875926, 0.164425321, 0.075347718, 0.074919173, 0.031563124, 0.387771226, 0.208662265, 0.004592891, 0.111919317, 0.138486112, 0.081865126, 0.017012644, 0.007248069, 0.117620313, 0.507368268, 0.952047056, 0.016124197, 0.082778683, 0.259718078, 0.274431136, 0.069766915, 0.102818162   ]\n",
    "gfbc_f_tr=[ 0.794662531, 0.570573263, 0.478697855, 0.201786961, 0.580021799, 0.698593022, 0.998191972, 0.23567532, 0.825106961, 0.713285564, 0.629692538, 0.361739604, 0.350132077, 0.10580903, 0.086118576, 0.051921184, 0.484284884, 0.208662265, 0.005552462, 0.188293139, 0.20383851, 0.149077556, 0.022943698, 0.015813397, 0.162821205, 0.521696382, 0.952047056, 0.017291532, 0.089921624, 0.308369857, 0.287241492, 0.056498644, 0.152859071 ]\n",
    "fgbc_g_tr=[ 0.794662531, 0.553749789, 0.465179226, 0.195002628, 0.580020478, 0.683925933, 0.998191972, 0.340477057, 0.823494155, 0.713285564, 0.569870414, 0.361739604, 0.164425321, 0.075347718, 0.074919173, 0.032447574, 0.314408263, 0.208662265, 0.004592891, 0.111950602, 0.143378706, 0.081865126, 0.01838677, 0.007248069, 0.162821205, 0.521696382, 0.952047056, 0.016618201, 0.082778683, 0.29257456, 0.289524093, 0.040231992, 0.109953011 ]\n",
    "gebc_e_tr=[ 0.672336222, 0.356129237, 0.402350825, 0.179683674, 0.580020478, 0.681926215, 0.998191972, 0.207166261, 0.788289377, 0.713285564, 0.580408533, 0.367875926, 0.164425321, 0.075347718, 0.074919173, 0.031563124, 0.387771226, 0.208662265, 0.004592891, 0.111919317, 0.138486112, 0.081865126, 0.017012644, 0.007248069, 0.117620313, 0.507368268, 0.952047056, 0.016124197, 0.082778683, 0.287392358, 0.274431136, 0.069766915, 0.102818162 ]\n",
    "\n",
    "soa_s_tr=[ 0.701629655, 0.80461534, 0.358502344, 0.347105391, 0.285846271, 0.215040116, 0.707363441, 0.997157328, 0.393606756, 0.855941549, 0.743992134, 0.620068421, 0.409799778, 0.19059611, 0.079771964, 0.125365263, 0.060687287, 0.395823429, 0.22926942, 0.037820524, 0.170926885, 0.156711717, 0.109951846, 0.047247001, 0.040045699, 0.156505265, 0.572832294, 0.95372265, 0.048004096, 0.201345565, 0.385764534, 0.434790556, 0.211964084, 0.169859531 ]\n",
    "xoa_x_tr=[ 0.689503223, 0.740291587, 0.41166092, 0.398372201, 0.35046424, 0.219943026, 0.703580335, 0.997048864, 0.394431787, 0.84066852, 0.736140861, 0.619783064, 0.38422979, 0.192359784, 0.08444077, 0.164835258, 0.059612408, 0.393691309, 0.226818851, 0.03766164, 0.223785523, 0.15997285, 0.110296537, 0.049383563, 0.040766726, 0.165500991, 0.561849454, 0.953722426, 0.04811256, 0.578550417, 0.411546037, 0.255499362 ]\n",
    "goa_g_tr=[ 0.675269765, 0.692832847, 0.344019539, 0.361306252, 0.302578509, 0.21475687, 0.713688665, 0.996576183, 0.354159789, 0.833033978, 0.728922425, 0.626036513, 0.384539843, 0.192359782, 0.084440775, 0.164835253, 0.059612405, 0.393691308, 0.226818852, 0.037661639, 0.223785516, 0.159972857, 0.110296534, 0.049383566, 0.040766722, 0.165500985, 0.56184946, 0.953722426, 0.048112565, 0.191957473, 0.418921063, 0.405162596, 0.254859678, 0.155285703 ]\n",
    "gfa_g_tr=[ 0.681567518, 0.737253102, 0.316034782, 0.36243086, 0.213994755, 0.713688665, 0.664802743, 0.363341786, 0.854764203, 0.732209614, 0.529805122, 0.266799644, 0.190027236, 0.093674508, 0.182552811, 0.059633591, 0.401178019, 0.189453895, 0.037005668, 0.242826664, 0.159246241, 0.113220854, 0.047539801, 0.040750483, 0.165615227, 0.372699702, 0.604639867, 0.048710293, 0.183949897, 0.434536721, 0.403810762, 0.244153792, 0.158900417]\n",
    "fga_f_tr=[0.681431296, 0.736335482, 0.321728789, 0.359764778, 0.211718654, 0.701961852, 0.664878429, 0.3539947, 0.855932477, 0.732003321, 0.528356258, 0.267167629, 0.189322988, 0.092240745, 0.162787434, 0.058967596, 0.395562073, 0.193954276, 0.036847257, 0.201912035, 0.16187492, 0.107781046, 0.046861641, 0.040897531, 0.166911357, 0.440875911, 0.63637248, 0.048510147, 0.170222395, 0.426047042, 0.40144017, 0.208848948, 0.144975554]\n",
    "gea_g_tr=[ 0.680076674, 0.734831808, 0.296380859, 0.355132933, 0.211693446, 0.692229527, 0.66487151, 0.35609814, 0.848167516, 0.732903506, 0.472165281, 0.267167592, 0.169270183, 0.083647864, 0.156312951, 0.057545264, 0.304517923, 0.197078473, 0.036462319, 0.188713152, 0.151146963, 0.103688859, 0.045619556, 0.039841846, 0.164704064, 0.473344682, 0.731576933, 0.047642943, 0.160643389, 0.42105661, 0.397423195, 0.202257047, 0.141460362  ]\n",
    "\n",
    "soa_o_tr=[ 0.658264689, 0.655737097, 0.317322084, 0.3578206, 0.24072109, 0.211937584, 0.695454593, 0.996722891, 0.337198679, 0.836705417, 0.73075061, 0.607634851, 0.392723485, 0.166006733, 0.079862672, 0.148688707, 0.057184541, 0.381149522, 0.225206574, 0.037322482, 0.19128495, 0.152512924, 0.103332215, 0.046555551, 0.039597032, 0.16259785, 0.553027925, 0.953720251, 0.048015976, 0.177892656, 0.408488917, 0.40096722, 0.222729427, 0.142078008 ]\n",
    "xoa_o_tr=[ 0.658264689, 0.655737097, 0.317322084, 0.3578206, 0.24072109, 0.211937584, 0.695454593, 0.996722891, 0.337198679, 0.836705417, 0.73075061, 0.607634851, 0.392723485, 0.166006733, 0.079862672, 0.148688707, 0.057184541, 0.381149522, 0.225206574, 0.037322482, 0.19128495, 0.152512924, 0.103332215, 0.046555551, 0.039597032, 0.16259785, 0.553027925, 0.953720251, 0.048015976, 0.177892656,  0.40096722, 0.142078008  ]\n",
    "goa_o_tr=[ 0.658264689, 0.655737097, 0.317322084, 0.3578206, 0.24072109, 0.211937584, 0.695454593, 0.996722891, 0.337198679, 0.836705417, 0.73075061, 0.607634851, 0.392723485, 0.166006733, 0.079862672, 0.148688707, 0.057184541, 0.381149522, 0.225206574, 0.037322482, 0.19128495, 0.152512924, 0.103332215, 0.046555551, 0.039597032, 0.16259785, 0.553027925, 0.953720251, 0.048015976, 0.177892656, 0.408488917, 0.40096722, 0.222729427, 0.142078008  ]\n",
    "gfa_f_tr=[ 0.681431296, 0.736335482, 0.321728789, 0.359764778, 0.211718654, 0.701961852, 0.664878429, 0.3539947, 0.855932477, 0.732003321, 0.528356258, 0.267167629, 0.189322988, 0.092240745, 0.162787434, 0.058967596, 0.395562073, 0.193954276, 0.036847257, 0.201912035, 0.16187492, 0.107781046, 0.046861641, 0.040897531, 0.166911357, 0.440875911, 0.63637248, 0.048510147, 0.170222395, 0.426047042, 0.40144017, 0.208848948, 0.144975554 ]\n",
    "fga_g_tr=[ 0.680076674, 0.734831808, 0.296380859, 0.355132933, 0.211693446, 0.692229527, 0.66487151, 0.35609814, 0.848167516, 0.732903506, 0.472165281, 0.267167592, 0.169270183, 0.083647864, 0.156312951, 0.057545264, 0.304517923, 0.197078473, 0.036462319, 0.188713152, 0.151146963, 0.103688859, 0.045619556, 0.039841846, 0.164704064, 0.473344682, 0.731576933, 0.047642943, 0.160643389, 0.42105661, 0.397423195, 0.202257047, 0.141460362 ]\n",
    "gea_e_tr=[ 0.658264689, 0.655737097, 0.317322084, 0.3578206, 0.211937584, 0.695454593, 0.66487151, 0.337198679, 0.836705417, 0.73075061, 0.516057482, 0.28128719, 0.166006733, 0.08676603, 0.15622218, 0.057184541, 0.381149522, 0.209853401, 0.036704382, 0.19128495, 0.152512924, 0.103332215, 0.046555551, 0.039597032, 0.16259785, 0.502392868, 0.699842034, 0.048015976, 0.17696856, 0.408488917, 0.40096722, 0.222729427, 0.141839407 ]\n",
    "\n",
    "sowc_s_tr=[0.824246048, 0.928393084, 0.374490352, 0.347304187, 0.394804827, 0.571138882, 0.834034523, 0.997927912, 0.384761579, 0.876126747, 0.773427591, 0.809681325, 0.446001726, 0.459636007, 0.092480269, 0.377630939, 0.040842982, 0.43344679, 0.242406727, 0.004562996, 0.433511162, 0.172192669, 0.111879207, 0.027924789, 0.006993141, 0.358464174, 0.691383103, 0.953212643, 0.018361956, 0.099187669, 0.540115161, 0.672891219, 0.460797543, 0.155441087]\n",
    "xowc_x_tr=[0.80289879, 0.863512299, 0.728851218, 0.325492978, 0.613777952, 0.556050964, 0.673028883, 0.997131142, 0.407202483, 0.758164381, 0.708955965, 0.61811202, 0.314136383, 0.350132077, 0.10580903, 0.153170807, 0.051921184, 0.484284884, 0.242406727, 0.00437605, 0.268413594, 0.20383851, 0.073188026, 0.011635888, 0.005739473, 0.090065945, 0.614736424, 0.953212643, 0.015318107, 0.070515942, 0.513392765, 0.297744445, 0.299172332, 0.052382266  ]\n",
    "gowc_g_tr=[ 0.642742013, 0.766917063, 0.670668727, 0.583773462, 0.551741712, 0.556358866, 0.675545131, 0.995634946, 0.430814943, 0.736055937, 0.698052285, 0.658367031, 0.296666089, 0.350132077, 0.10580903, 0.153170792, 0.051921184, 0.484284884, 0.242406727, 0.004376052, 0.268413594, 0.20383851, 0.073188026, 0.011635891, 0.005739472, 0.090065934, 0.614736424, 0.953212643, 0.015318113, 0.210547461, 0.32825758, 0.164214282, 0.197408595, 0.152859071 ]\n",
    "gfwc_g_tr=[ 0.642742013, 0.766917063, 0.670668727, 0.583773462, 0.556358866, 0.675545131, 0.995634946, 0.430814943, 0.736055937, 0.698052285, 0.658367031, 0.296666089, 0.350132077, 0.10580903, 0.153170792, 0.051921184, 0.484284884, 0.242406727, 0.004376052, 0.268413594, 0.20383851, 0.073188026, 0.011635891, 0.005739472, 0.162821205, 0.614736424, 0.953212643, 0.015318113, 0.210547461, 0.32825758, 0.636764146, 0.197408595, 0.152859071 ]\n",
    "fgwc_f_tr=[ 0.642752493, 0.826872802, 0.698660929, 0.583792445, 0.555126132, 0.670580637, 0.995847236, 0.430820028, 0.789566563, 0.702929691, 0.658367032, 0.288090116, 0.350132077, 0.10580903, 0.125467456, 0.051921184, 0.484284884, 0.242406727, 0.005552462, 0.268413594, 0.20383851, 0.083223021, 0.014385004, 0.006757161, 0.162821205, 0.614736424, 0.953212643, 0.017291532, 0.225433834, 0.341750888, 0.651841109, 0.158675452, 0.152859071 ]\n",
    "gewc_g_tr=[ 0.642752493, 0.826872802, 0.698660929, 0.583792445, 0.554083241, 0.666296512, 0.995847164, 0.430820028, 0.784862986, 0.70292969, 0.658367032, 0.288091646, 0.350132077, 0.10580903, 0.218852118, 0.051921184, 0.389471719, 0.242406727, 0.004592891, 0.268413594, 0.20383851, 0.071932405, 0.011751692, 0.005811975, 0.162821205, 0.614736424, 0.953212643, 0.015249178, 0.251814035, 0.341750888, 0.651841109, 0.159283677, 0.180589665 ]\n",
    "\n",
    "sowc_o_tr=[0.82424626, 1, 0.402350825, 0.583792445, 0.674293271, 0.57148931, 1, 0.998191972, 0.430820028, 0.935490108, 0.804558094, 1, 0.474191408, 1, 0.10580903, 1, 0.051921184, 0.484284884, 0.242406727, 0.004592891, 1, 0.20383851, 0.149077556, 0.040584198, 0.007248069, 1, 1, 0.953212643, 0.019995122, 0.159704863, 1, 1, 1, 0.180589665    ]\n",
    "xowc_o_tr=[ 0.82424626, 0.861264607, 0.772356042, 0.320294225, 0.674293271, 0.552227648, 0.681926215, 0.997019532, 0.430820028, 0.788289377, 0.713285564, 0.616645065, 0.352001235, 0.350132077, 0.10580903, 0.218852118, 0.051921184, 0.484284884, 0.242406727, 0.004592891, 0.268413594, 0.20383851, 0.081865126, 0.011729351, 0.005811975, 0.091326042, 0.614736424, 0.953212643, 0.016124197, 0.051554202, 0.283227232, 0.330820569, 0.049958423, 0.035260422 ]\n",
    "gowc_o_tr=[ 0.672336222, 0.767687451, 0.772356042, 0.583792445, 0.674293271, 0.558070109, 0.681926215, 0.995847164, 0.430820028, 0.788289377, 0.713285564, 0.658367032, 0.341047486, 0.350132077, 0.10580903, 0.218852118, 0.051921184, 0.484284884, 0.242406727, 0.004592891, 0.268413594, 0.20383851, 0.081865126, 0.011729351, 0.005811975, 0.091326042, 0.614736424, 0.953212643, 0.016124197, 0.251814035, 0.341750888, 0.167583875, 0.205597249, 0.180589665 ]\n",
    "gfwc_f_tr=[ 0.642752493, 0.826872802, 0.698660929, 0.583792445, 0.555126132, 0.670580637, 0.995847236, 0.430820028, 0.789566563, 0.702929691, 0.658367032, 0.288090116, 0.350132077, 0.10580903, 0.125467456, 0.051921184, 0.484284884, 0.242406727, 0.005552462, 0.268413594, 0.20383851, 0.083223021, 0.014385004, 0.006757161, 0.162821205, 0.614736424, 0.953212643, 0.017291532, 0.225433834, 0.341750888, 0.651841109, 0.158675452, 0.152859071 ]\n",
    "fgwc_g_tr=[ 0.642752493, 0.826872802, 0.698660929, 0.583792445, 0.554083241, 0.666296512, 0.995847164, 0.430820028, 0.784862986, 0.70292969, 0.658367032, 0.288091646, 0.350132077, 0.10580903, 0.218852118, 0.051921184, 0.389471719, 0.242406727, 0.004592891, 0.268413594, 0.20383851, 0.071932405, 0.011751692, 0.005811975, 0.162821205, 0.614736424, 0.953212643, 0.015249178, 0.251814035, 0.341750888, 0.651841109, 0.159283677, 0.180589665 ]\n",
    "gewc_e_tr=[ 0.672336222, 0.767687451, 0.772356042, 0.583792445, 0.558070109, 0.681926215, 0.995847164, 0.430820028, 0.788289377, 0.713285564, 0.658367032, 0.341047486, 0.350132077, 0.10580903, 0.218852118, 0.051921184, 0.484284884, 0.242406727, 0.004592891, 0.268413594, 0.20383851, 0.081865126, 0.011729351, 0.005811975, 0.162821205, 0.614736424, 0.953212643, 0.016124197, 0.251814035, 0.341750888, 0.636764146, 0.205597249, 0.180589665 ]\n",
    "\n",
    "\n",
    "\n",
    "sobc_s_te=[0.70831745, 0.805853807, 0.832999672, 0.296881555, 0.416008179, 0.620820856, 0.840629118, 1.001616494, 0.289719485, 0.957481069, 0.739271676, 0.809104034, 0.417042677, 0.209111207, 0.091489344, 0.388131572, 0.043386915, 0.421319105, 0.212891927, 0.009312415, 0.450501395, 0.172019833, 0.091902173, 0.027746986, 0.010702875, 0.352393816, 0.666511664, 0.71377753, 0.019136111, 0.376272989, 0.515086575, 0.545766873, 0.501848295, 0.09430422]\n",
    "xobc_x_te=[ 0.837299055, 0.629388398, 0.608570133, 0.373718044, 0.713757157, 0.665384173, 0.681423039, 1.001320418, 0.267962163, 0.949632257, 0.687236845, 0.685422922, 0.456968335, 0.339927776, 0.103251042, 0.154930516, 0.055177536, 0.469118299, 0.218561718, 0.008747079, 0.211261674, 0.204609586, 0.117345751, 0.040129167, 0.015234136, 0.184384517, 0.511934585, 0.713777526, 0.017929532,0.344536109,]\n",
    "gobc_g_te=[0.84074078, 0.548564368, 0.787877062, 0.252969894, 0.709533453, 0.62001782, 0.782548255, 0.998522747, 0.358116102, 1.019526029, 0.689719591, 0.645887491, 0.380175747, 0.339927771, 0.10325104, 0.1549305, 0.055177539, 0.469118306, 0.218561731, 0.008747069, 0.211261656, 0.204609594, 0.117345741, 0.040129164, 0.015234139, 0.184384505, 0.511934595, 0.71377753, 0.017929567, 0.132941809, 0.434632718, 0.609167093, 0.34524642, 0.201536335]\n",
    "gfbc_g_te=[ 0.84074078, 0.548564368, 0.787877062, 0.252969894, 0.62001782, 0.782548255, 0.998522747, 0.358116102, 1.019526029, 0.689719591, 0.645887491, 0.380175747, 0.339927771, 0.10325104, 0.1549305, 0.055177539, 0.469118306, 0.218561731, 0.008747069, 0.211261656, 0.204609594, 0.117345741, 0.040129164, 0.015234139, 0.184384505, 0.511934595, 0.71377753, 0.017929567, 0.132941809, 0.434632718, 0.609167093, 0.34524642, 0.201536335 ]\n",
    "fgbc_f_te=[ 0.840688294, 0.662801749, 0.553626654, 0.211307836, 0.601755582, 0.715925417, 0.998554718, 0.265250429, 0.942896962, 0.683138502, 0.645853563, 0.340571654, 0.339927776, 0.103251042, 0.086511305, 0.055177536, 0.469118299, 0.211511145, 0.006627609, 0.200192, 0.204609586, 0.117345751, 0.030381138, 0.015234136, 0.184384517, 0.500330876, 0.713751517, 0.017367715, 0.060519531, 0.443788769, 0.662897155, 0.233715123, 0.141457345 ]\n",
    "gebc_g_te=[ 0.840688294, 0.6445797, 0.686645328, 0.200630923, 0.601759891, 0.717896674, 0.998554718, 0.378485544, 0.941898278, 0.683138502, 0.578560331, 0.340571654, 0.168200009, 0.078181983, 0.074648581, 0.034358742, 0.310698947, 0.211511145, 0.005876164, 0.117683576, 0.150351589, 0.072897023, 0.019198691, 0.007899324, 0.184384517, 0.500330876, 0.713760765, 0.017378628, 0.068191565, 0.428557192, 0.662897155, 0.22752147, 0.164145638 ]\n",
    "\n",
    "sobc_o_te=[0.634384877, 0.42433372, 0.691596042, 0.273249656, 0.280362856, 0.601759891, 0.782547923, 0.998554718, 0.148171024, 0.947342967, 0.683138502, 0.663536982, 0.386592114, 0.105414314, 0.078181983, 0.222898016, 0.034121137, 0.403939009, 0.202180344, 0.005876164, 0.272871438, 0.14623809, 0.072897023, 0.017385714, 0.007899324, 0.184384517, 0.585904315, 0.713759129, 0.016087612, 0.307930643, 0.444133322, 0.333121558, 0.425893923, 0.111036001]\n",
    "xobc_o_te=[ 0.709578527, 0.368069586, 0.511525187, 0.273249656, 0.280362856, 0.600263506, 0.664471188, 0.998554718, 0.148171024, 0.947342967, 0.670620748, 0.627301089, 0.386592114, 0.168200009, 0.078181983, 0.074648581, 0.034121137, 0.403939009, 0.211511145, 0.005876164, 0.121911086, 0.14623809, 0.072897023, 0.017385714, 0.007899324, 0.125949807, 0.487480638, 0.713751517, 0.016087612,  0.333121558,  ]\n",
    "gobc_o_te=[0.709578527, 0.368069586, 0.691596042, 0.237882578, 0.280362856, 0.601759891, 0.717896674, 0.998554718, 0.241339305, 0.985197464, 0.683138502, 0.586988284, 0.358772683, 0.168200009, 0.078181983, 0.074648581, 0.034121137, 0.403939009, 0.211511145, 0.005876164, 0.121911086, 0.14623809, 0.072897023, 0.017385714, 0.007899324, 0.125949807, 0.487480638, 0.713751517, 0.016087612, 0.068191565, 0.415548526, 0.609167078, 0.210166516, 0.127013821]\n",
    "gfbc_f_te=[ 0.840688294, 0.662801749, 0.553626654, 0.211307836, 0.601755582, 0.715925417, 0.998554718, 0.265250429, 0.942896962, 0.683138502, 0.645853563, 0.340571654, 0.339927776, 0.103251042, 0.086511305, 0.055177536, 0.469118299, 0.211511145, 0.006627609, 0.200192, 0.204609586, 0.117345751, 0.030381138, 0.015234136, 0.184384517, 0.500330876, 0.713751517, 0.017367715, 0.060519531, 0.443788769, 0.662897155, 0.233715123, 0.141457345 ]\n",
    "fgbc_g_te=[ 0.840688294, 0.6445797, 0.686645328, 0.200630923, 0.601759891, 0.717896674, 0.998554718, 0.378485544, 0.941898278, 0.683138502, 0.578560331, 0.340571654, 0.168200009, 0.078181983, 0.074648581, 0.034358742, 0.310698947, 0.211511145, 0.005876164, 0.117683576, 0.150351589, 0.072897023, 0.019198691, 0.007899324, 0.184384517, 0.500330876, 0.713760765, 0.017378628, 0.068191565, 0.428557192, 0.662897155, 0.22752147, 0.164145638 ]\n",
    "gebc_e_te=[ 0.709578527, 0.368069586, 0.691596042, 0.237882578, 0.601759891, 0.717896674, 0.998554718, 0.241339305, 0.985197464, 0.683138502, 0.586988284, 0.358772683, 0.168200009, 0.078181983, 0.074648581, 0.034121137, 0.403939009, 0.211511145, 0.005876164, 0.121911086, 0.14623809, 0.072897023, 0.017385714, 0.007899324, 0.125949807, 0.487480638, 0.713751517, 0.016087612, 0.068191565, 0.415548526, 0.609167078, 0.210166516, 0.127013821 ]\n",
    "\n",
    "soa_s_te=[0.746743062, 0.852342584, 0.462963197, 0.296787085, 0.387856614, 0.219841825, 0.692934719, 1.001005725, 0.410350227, 0.919881885, 0.727245403, 0.626327742, 0.394867198, 0.17933583, 0.080526214, 0.127697314, 0.062749426, 0.397689654, 0.231645416, 0.038658379, 0.178637106, 0.164950261, 0.095501075, 0.048489824, 0.040599188, 0.16054156, 0.549717637, 0.723390892, 0.048522656, 0.215337225, 0.477963831, 0.484178392, 0.248710405, 0.169745794]\n",
    "xoa_x_te=[0.733953908, 0.781404854, 0.493621241, 0.383014262, 0.4577119, 0.229700914, 0.693856845, 1.000581698, 0.404527278, 0.944559468, 0.716615283, 0.629844194, 0.376598839, 0.18237849, 0.087465542, 0.16553302, 0.062440075, 0.417653817, 0.230166421, 0.038581145, 0.232705108, 0.170361327, 0.103016346, 0.053045277, 0.041364025, 0.172097102, 0.542988314, 0.723408257, 0.049132001, 0.603012505, 0.479315429,  0.340177482]\n",
    "goa_g_te=[0.73533221, 0.734494218, 0.489789102, 0.355826044, 0.46769665, 0.221255528, 0.701370465, 0.998621231, 0.371390365, 0.985154039, 0.709673351, 0.637450792, 0.37516693, 0.182378486, 0.087465546, 0.165533015, 0.062440074, 0.417653827, 0.230166425, 0.03858813, 0.2327051, 0.170361334, 0.103016343, 0.053045273, 0.041364021, 0.172097107, 0.542988316, 0.723408261, 0.049132007, 0.182871319, 0.52095952, 0.496830812, 0.344224705, 0.250346028]\n",
    "gfa_g_te=[ 0.73621324, 0.81129678, 0.468473266, 0.340534469, 0.221355609, 0.687776083, 0.665780315, 0.379582481, 0.957866713, 0.716179214, 0.539991527, 0.257310207, 0.180517244, 0.096986958, 0.183411886, 0.06233617, 0.419164661, 0.191988115, 0.037751407, 0.252592062, 0.166867728, 0.102577044, 0.053049579, 0.041334868, 0.170637701, 0.360573012, 0.461697322, 0.049253984, 0.179778272, 0.539512284, 0.469526738, 0.352772532, 0.244903723]\n",
    "fga_f_te=[ 0.738670068, 0.808968758, 0.481101379, 0.337908188, 0.217393102, 0.699047932, 0.665799497, 0.369297834, 0.958058868, 0.712051137, 0.53736238, 0.256065497, 0.181092108, 0.096109128, 0.163319246, 0.061808026, 0.413239535, 0.196676364, 0.037586708, 0.208182555, 0.172884602, 0.10039603, 0.052257404, 0.041683421, 0.172521291, 0.425587331, 0.485486237, 0.049103875, 0.170746896, 0.52494846, 0.478388078, 0.456712095, 0.21042707 ]\n",
    "gea_e_te=[ 0.759094382, 0.810209067, 0.503342213, 0.343555384, 0.21751232, 0.679200674, 0.665799497, 0.378585735, 0.967489358, 0.713023857, 0.480371341, 0.256065255, 0.165387059, 0.086486612, 0.156777405, 0.059539314, 0.307793845, 0.199553086, 0.037282275, 0.193728077, 0.164508467, 0.096829368, 0.049200456, 0.040592421, 0.168441678, 0.456488167, 0.55686284, 0.048371526, 0.165745248, 0.52942553, 0.467116193, 0.444598477, 0.209464758 ]\n",
    "\n",
    "sxoa_o_te=[ 0.711586986, 0.68289907, 0.551653962, 0.351583186, 0.368128247, 0.217323868, 0.687776083, 0.99865107, 0.355499095, 1.010728599, 0.709665315, 0.619253199, 0.380625922, 0.162657445, 0.082637349, 0.149106336, 0.059952597, 0.4191576, 0.228510863, 0.038424843, 0.197885601, 0.168540124, 0.096516581, 0.051103803, 0.040574015, 0.168141428, 0.533952947, 0.723403409, 0.048343245, 0.185267615, 0.514870839, 0.504800376, 0.337599249, 0.215821562]\n",
    "xoa_o_te=[0.711586986, 0.68289907, 0.551653962, 0.351583186, 0.368128247, 0.217323868, 0.687776083, 0.99865107, 0.355499095, 1.010728599, 0.709665315, 0.619253199, 0.380625922, 0.162657445, 0.082637349, 0.149106336, 0.059952597, 0.4191576, 0.228510863, 0.038424843, 0.197885601, 0.168540124, 0.096516581, 0.051103803, 0.040574015, 0.168141428, 0.533952947, 0.723403409, 0.048343245, 0.185267615, 0.504800376, 0.215821562]\n",
    "goa_o_te=[0.711586986, 0.68289907, 0.551653962, 0.351583186, 0.368128247, 0.217323868, 0.687776083, 0.99865107, 0.355499095, 1.010728599, 0.709665315, 0.619253199, 0.380625922, 0.162657445, 0.082637349, 0.149106336, 0.059952597, 0.4191576, 0.228510863, 0.038424843, 0.197885601, 0.168540124, 0.096516581, 0.051103803, 0.040574015, 0.168141428, 0.533952947, 0.723403409, 0.048343245, 0.185267615, 0.514870839, 0.504800376, 0.337599249, 0.215821562]\n",
    "gfa_f_te=[ 0.738670068, 0.808968758, 0.481101379, 0.337908188, 0.217393102, 0.699047932, 0.665799497, 0.369297834, 0.958058868, 0.712051137, 0.53736238, 0.256065497, 0.181092108, 0.096109128, 0.163319246, 0.061808026, 0.413239535, 0.196676364, 0.037586708, 0.208182555, 0.172884602, 0.10039603, 0.052257404, 0.041683421, 0.172521291, 0.425587331, 0.485486237, 0.049103875, 0.170746896, 0.52494846, 0.478388078, 0.456712095, 0.21042707 ]\n",
    "fga_g_te=[ 0.759094382, 0.810209067, 0.503342213, 0.343555384, 0.21751232, 0.679200674, 0.665799497, 0.378585735, 0.967489358, 0.713023857, 0.480371341, 0.256065255, 0.165387059, 0.086486612, 0.156777405, 0.059539314, 0.307793845, 0.199553086, 0.037282275, 0.193728077, 0.164508467, 0.096829368, 0.049200456, 0.040592421, 0.168441678, 0.456488167, 0.55686284, 0.048371526, 0.165745248, 0.52942553, 0.467116193, 0.444598477, 0.209464758 ]\n",
    "gea_g_te=[ 0.711586986, 0.68289907, 0.551653962, 0.351583186, 0.217323868, 0.687776083, 0.99865107, 0.355499095, 1.010728599, 0.709665315, 0.619253199, 0.380625922, 0.162657445, 0.082637349, 0.149106336, 0.059952597, 0.4191576, 0.228510863, 0.038424843, 0.197885601, 0.168540124, 0.096516581, 0.051103803, 0.040574015, 0.168141428, 0.533952947, 0.723403409, 0.048343245, 0.185267615, 0.514870839, 0.504800376, 0.337599249, 0.215821562 ]\n",
    "\n",
    "sowc_s_te=[0.852773051, 0.921158722, 0.512050093, 0.296881555, 0.416008179, 0.596393877, 0.698435921, 1.000103818, 0.39574983, 0.866914982, 0.757512331, 0.608518845, 0.429271513, 0.263162926, 0.091489344, 0.034340177, 0.043386915, 0.421319105, 0.245644784, 0.004897391, 0.145841137, 0.172019833, 0.091902173, 0.027746986, 0.007303201, 0.09876615, 0.522166446, 0.713647344, 0.019136111, 0.113866278, 0.515086575, 0.326050449, 0.227979052, 0.117581811]\n",
    "xowc_x_te=[0.837299055, 0.893644873, 0.266188805, 0.236448592, 0.240524637, 0.662145147, 0.655259178, 0.998754451, 0.421990672, 0.900829345, 0.659826312, 0.577308558, 0.315236546, 0.15729124, 0.103251042, 0.154930516, 0.055177536, 0.371881998, 0.245644785, 0.004468132, 0.272871438, 0.128163275, 0.061572494, 0.014533494, 0.005311329, 0.125949807, 0.585904315, 0.713647342, 0.015999689, 0.057401705, 0.693692397, 0.355922521, 0.85780201, 0.150604955]\n",
    "gowc_g_te=[0.652275564, 0.895519108, 0.335717415, 0.525806397, 0.291656053, 0.588978625, 0.659729414, 0.998522747, 0.697996618, 0.973516023, 0.670121206, 0.663537378, 0.300427504, 0.157291231, 0.10325104, 0.1549305, 0.055177539, 0.371882012, 0.245644784, 0.004468136, 0.272871433, 0.128163277, 0.061572498, 0.014533488, 0.005311325, 0.184384505, 0.58590431, 0.713647344, 0.015999697, 0.175538041, 0.397634377, 0.333121563, 0.165289077, 0.263245872]\n",
    "gfwc_g_te=[ 0.652275564, 0.895519108, 0.335717415, 0.525806397, 0.588978625, 0.659729414, 0.998522747, 0.697996618, 0.973516023, 0.670121206, 0.663537378, 0.300427504, 0.157291231, 0.10325104, 0.1549305, 0.055177539, 0.371882012, 0.245644784, 0.004468136, 0.272871433, 0.128163277, 0.061572498, 0.014533488, 0.005311325, 0.184384505, 0.58590431, 0.713647344, 0.015999697, 0.175538041, 0.397634377, 0.333121563, 0.165289077, 0.263245872 ]\n",
    "fgwc_f_te=[ 0.691577246, 0.895504451, 0.401941938, 0.525950196, 0.611970275, 0.659128719, 0.998554718, 0.698007045, 0.95617679, 0.683023583, 0.663536981, 0.291777148, 0.15729124, 0.103251042, 0.126178646, 0.055177536, 0.353499924, 0.245644785, 0.006627609, 0.272871438, 0.130128011, 0.073824486, 0.014260316, 0.006216055, 0.184384517, 0.585904315, 0.713759129, 0.017367715, 0.252027111, 0.391296447, 0.342537045, 0.502986529, 0.263245866 ]\n",
    "gewc_g_te=[ 0.693988819, 0.895504451, 0.427102517, 0.525950196, 0.603148801, 0.643696196, 0.998554718, 0.698007045, 0.975015565, 0.683023882, 0.663536982, 0.291796215, 0.168200009, 0.103251042, 0.222898016, 0.055177536, 0.261730887, 0.245644785, 0.005876164, 0.272871438, 0.127290054, 0.063642899, 0.011915743, 0.005712218, 0.184384517, 0.585904315, 0.713759129, 0.015693116, 0.307930643, 0.401213479, 0.348747779, 0.555443931, 0.306297647 ]\n",
    "\n",
    "sowc_o_te=[0.852759935, 0.895504451, 0.691596042, 0.525950196, 0.686181511, 0.601759891, 0.717896674, 0.998554718, 0.470564862, 1.072628119, 0.794566246, 0.627301089, 0.437141311, 0.339927776, 0.103251042, 0.030884176, 0.055177536, 0.469118299, 0.245644785, 0.005876164, 0.187301278, 0.204609586, 0.117345751, 0.040129167, 0.007899324, 0.101584779, 0.500748587, 0.713759129, 0.020550817, 0.175473171, 0.720666478, 0.416549586, 0.425893923, 0.306297647]\n",
    "xowc_o_te=[0.852759935, 0.895504451, 0.413067311, 0.242351985, 0.283675532, 0.65833102, 0.664471188, 0.998554718, 0.470564862, 1.072628119, 0.663216705, 0.573687192, 0.349629679, 0.168200009, 0.103251042, 0.222898016, 0.055177536, 0.385398159, 0.245644785, 0.005876164, 0.272871438, 0.135963681, 0.072897023, 0.015352118, 0.00586598, 0.125949807, 0.585904315, 0.713759129, 0.016087612, 0.055420749, 0.403337804, 0.416549586, 0.252541143, 0.115477882]\n",
    "gowc_o_te=[0.673005784, 0.895504451, 0.511525187, 0.525950196, 0.283675532, 0.590932244, 0.664471188, 0.998554718, 0.698007045, 1.059799904, 0.683138502, 0.663536982, 0.334194189, 0.168200009, 0.103251042, 0.222898016, 0.055177536, 0.385398159, 0.245644785, 0.005876164, 0.272871438, 0.135963681, 0.072897023, 0.015352118, 0.00586598, 0.184384517, 0.585904315, 0.713759129, 0.016087612, 0.307930643, 0.403337804, 0.380226867, 0.262296201, 0.306297647]\n",
    "gfwc_f_te=[0.691577246, 0.895504451, 0.401941938, 0.525950196, 0.611970275, 0.659128719, 0.998554718, 0.698007045, 0.95617679, 0.683023583, 0.663536981, 0.291777148, 0.15729124, 0.103251042, 0.126178646, 0.055177536, 0.353499924, 0.245644785, 0.006627609, 0.272871438, 0.130128011, 0.073824486, 0.014260316, 0.006216055, 0.184384517, 0.585904315, 0.713759129, 0.017367715, 0.252027111, 0.391296447, 0.342537045, 0.502986529, 0.263245866  ]\n",
    "fgwc_g_te=[ 0.693988819, 0.895504451, 0.427102517, 0.525950196, 0.603148801, 0.643696196, 0.998554718, 0.698007045, 0.975015565, 0.683023882, 0.663536982, 0.291796215, 0.168200009, 0.103251042, 0.222898016, 0.055177536, 0.261730887, 0.245644785, 0.005876164, 0.272871438, 0.127290054, 0.063642899, 0.011915743, 0.005712218, 0.184384517, 0.585904315, 0.713759129, 0.015693116, 0.307930643, 0.401213479, 0.348747779, 0.555443931, 0.306297647 ]\n",
    "gewc_e_te=[ 0.673005784, 0.895504451, 0.511525187, 0.525950196, 0.590932244, 0.664471188, 0.998554718, 0.698007045, 1.059799904, 0.683138502, 0.663536982, 0.334194189, 0.168200009, 0.103251042, 0.222898016, 0.055177536, 0.385398159, 0.245644785, 0.005876164, 0.272871438, 0.135963681, 0.072897023, 0.015352118, 0.00586598, 0.184384517, 0.585904315, 0.713759129, 0.016087612, 0.307930643, 0.403337804, 0.380226867, 0.262296201, 0.306297647 ]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "36cb4174",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABHkAAAGoCAYAAADSNjn1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAAEAAElEQVR4nOzdd3xUVfr48c+dmmQmhVRIgYTQVUCMgiIE/IlrFBULdsS1YYkVO3ZXd3UXRRfdrx1RjKhrQQQbKwEsSBELRUgIgUxIQnomyfT7++NmkkklkEmm5Lx9zSvMnTtzH/CZm3PPfc45kizLCIIgCIIgCIIgCIIgCIFN5esABEEQBEEQBEEQBEEQhJ4TnTyCIAiCIAiCIAiCIAhBQHTyCIIgCIIgCIIgCIIgBAHRySMIgiAIgiAIgiAIghAERCePIAiCIAiCIAiCIAhCEBCdPIIgCIIgCIIgCIIgCEFA47Mjx8bKpKb67PCC0G1btpQjy3FH/X6R60KgELku9Bc9zXUgNjZWThX5Lvi5LVu2lMsi14V+oqf5LnJdCBSHy3XfdfKkpsLmzT47vCB0myQV9uj9IteFQCFyXegveprrQGpqKptFvgt+ThK5LvQjPc13ketCoDhcrovhWoIgCIIgCIIgCIIgCEFAdPIIgiAIgiAIgiAIgiAEAdHJIwiCIAiCIAiCIAiCEAREJ48gCIIgCIIgCIIgCEIQ8N3Ey4IgCIIgCIIgCILgx1wuF0VFRdTX1/s6FKEbDAYDycnJqFT9t55FdPIIgiAIgiAIgiAIQgfKy8uRJImRI0f2646DQOByuTCZTJSXlxMfH+/rcHxGZKkgCIIgCIIgCIIgdKC6upqEhATRwRMAVCoVCQkJ1NTU+DoUn+p3mXr11Vczc+bMI3rPtGnTyM7O7qWIvHv8xx57jGOPPbaXIxIEQRAEQRAEQQh+TqcTrVbr6zCEbtJqtTgcDl+H4VN+O1xLkqQuX587dy5Lliw54s994YUXkGX5iN7z8ccf+/SL7evjC4IgCIIgCIIg9FeHuzYV/If4f+XHnTwHDx5s/vPKlSu5/vrrW20LDQ1ttb/dbu9WR0hkZOQRxxIdHX3E7/EGm82GTqfz2fEFQRAEQRAEQRAEQQgcfjtca+DAgc2PqKioVtssFgtRUVHk5ORw2mmnERoayiuvvEJFRQWXXXYZycnJhIaGcswxx/DWW2+1+ty2w7WmTZvGzTffzIMPPkhsbCzx8fHcfffduFyuVvt4DpdKTU3lb3/7G/PmzSMiIoLk5GT++c9/tjrO7t27yczMJCQkhJEjR7Jq1SqMRmOX1Ufu2J555hmSk5NJTk7u8Pgff/wxY8eOJTQ0lOjoaDIzMyktLe3wM/fv38+oUaOYO3cuDoeDmpoa5syZQ3x8PCEhIQwdOpRFixZ1+f9CEARBEARBEARB8C+pqamEhoZiNBoZMGAAZ599NgcOHPDK53777bdeiFDwBb/t5OmOBx54gJtvvpkdO3Ywa9YsLBYLEyZMYOXKlWzfvp3bb7+defPmsWbNmi4/Z9myZWg0Gn744QcWL17MokWLWL58eZfvef755znuuOPYunUr9913H/feey8//vgjoMzqff7556PRaPjpp59YsmQJjz/+OFar9bB/p9zcXH777Te+/PLLDuMuKSnh0ksvZe7cuezcuZN169YxZ86cDj9r586dTJ48mbPOOoslS5ag0Wh46KGH+P3331m5ciV//vknb775JklJSYeNSxAEQRAEQRAEQfAvn3/+OWazmYMHD5KQkMCtt97q65AEHwvoTp5bb72Viy66iLS0NJKTk0lKSuKee+5h/PjxDB06lBtuuIELLriAnJycLj9nzJgxPPHEE4wYMYKLL76Y6dOnH7Zj6IwzziA7O5thw4Zx6623MmzYsOb3fPPNN/z5558sXbqU8ePHc/LJJ/P88893awKokJAQ3nzzTY499liOO+64dq8XFxdjt9u56KKLSE1N5dhjj+W6664jISGh1X4bN25kypQp3HjjjTz33HPNYxMLCwuZMGECJ510EkOGDGHatGnMnj37sHEJgiAIgiAIgiAI/ikkJISLLrqIHTt2NG+zWq3cfffdDB48mISEBG688UYaGxsBZWn4mTNnEhUVRXR0NFOmTMHlcjFnzhz279/POeecg9Fo5Nlnn+3weJ999hnjx48nIiKC9PR0vvzySwDeeustRo8eTXh4OEOHDuWVV15pfk9nxwTlOvfCCy8kLi6OtLQ0Xnzxxd76pwp6Ad3Jk5GR0eq50+nkqaeeYuzYscTExGA0Gvn444/Zv39/l58zduzYVs8TExMpKys76vfs2rWLxMTEVhUyJ554YreW3Tv22GPR6/Wdvj5u3DhOP/10jj32WC688EL+85//cOjQoVb7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0qu4oklOjlz8iuFH8lqI7hUWWhU8bUnfKiGEEEJEi+xsqxI5Kan12EC3Z4jKSZ7bb7+da6+9lh/84AcATJkyhbvuuouLL76Ye+65h6KiIgKBAN/73veYNGkSQLsePAkJCdjtdsaMGdPje11yySVcfPHFAPz2t7/lgQceYN26dVx88cWsXLmSUCjEE088QWxsLAcffDA33HADF110UY+vm52dzfLly7u9f9euXcTHx/Od73yHxMREJk2axOGHH97pcS+//DIXXnghK1as4Pvf/37L8Z07d3LOOee0PCdbmnoIIYSIckMxMBJCCCGEGCx5edZSc7C+qPJ4Br49Q8Qu19qXDRs2cPvtt5OQkNDyc+GFF1JfX09xcTGHH344p5xyCocccgjnnHMOf/zjHykrK+vTex122GEt/7bb7aSnp1NaWgrA5s2bOeSQQ4iNjW15zNy5c3v1urNnz97n/QsXLmTSpElkZ2dz0UUX8fTTT1NXV9fuMRs2bODss8/miSeeaDfBA3D11Vfzf//3fxx77LHceOONbNiwoVdxCSGEEJFK+lYJIYQQIpoNRXuGHit5lFJPAouAUq11py2plFIKeAD4FtAAXKa13jhwIXZmmia33HILixcv7nRfeno6NpuN119/nQ8++IDXX3+dJ554guuuu478/Pwuq2H2xeFwtLutlMI0zX7FDxAfH7/P+xMTE9m4cSPr1q3jv//9L3feeSfXX389H3/8MePGjQOs6pyMjAz+/Oc/853vfAeXy9Xy/CuuuILTTjuNV199lTfeeIPjjjuO6667jltvvbXfsUe63JW5lHhKOh3PTMhkzUVrwhCREANH8luMZM0DoxUrrCVa2dnWBI8scRRCCCFEtBjs9gy9qeR5Cjh9H/fnAtOafpYAf+x/WPs2a9YsNm/ezNSpUzv92O3WvJVSimOPPZZbbrmlZWJk9erVADidTkKhUL/jmDFjBl9++SWNjY0txz766KN+v24zu93OSSedxJ133snnn39OfX09L7/8csv9KSkp/O9//8PtdnP22Wfj8/naPX/8+PEsWbKEv//979x22208+uijAxZbJCvxlJCVlNXpp6sLYyGijeS3GOlycsBzVi7mD2dRcMosfr55FrMesX5yV+aGOzwhhBADLD8fFp/pY05qIYvP9MuOikL0oMdKHq31OqXU5H085EzgL9rqHvyB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\n",
      "text/plain": [
       "<Figure size 1152x432 with 12 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "xs_bc_tr = [xobc_x_tr, sobc_s_tr, gobc_g_tr, gfbc_g_tr, fgbc_f_tr, gebc_g_tr, ]\n",
    "ys_bc_tr = [xobc_o_tr, sobc_o_tr, gobc_o_tr, gfbc_f_tr, fgbc_g_tr, gebc_e_tr, ]\n",
    "xs_avg_tr = [xoa_x_tr, soa_s_tr, goa_g_tr, gfa_g_tr, fga_f_tr, gea_g_tr, ]\n",
    "ys_avg_tr = [xoa_o_tr, soa_o_tr, goa_o_tr, gfa_f_tr, fga_g_tr, gea_e_tr, ]\n",
    "xs_wc_tr = [xowc_x_tr, sowc_s_tr, gowc_g_tr, gfwc_g_tr, fgwc_f_tr, gewc_g_tr, ]\n",
    "ys_wc_tr = [xowc_o_tr, sowc_o_tr, gowc_o_tr, gfwc_f_tr, fgwc_g_tr, gewc_e_tr, ]\n",
    "xs_bc_te = [xobc_x_te,sobc_s_te,  gobc_g_te, gfbc_g_te, fgbc_f_te, gebc_g_te, ]\n",
    "ys_bc_te = [xobc_o_te, sobc_o_te, gobc_o_te, gfbc_f_te, fgbc_g_te, gebc_e_te, ]\n",
    "xs_avg_te = [xoa_x_te, soa_s_te, goa_g_te, gfa_g_te, fga_f_te, gea_g_te, ]\n",
    "ys_avg_te = [xoa_o_te, sxoa_o_te, goa_o_te, gfa_f_te, fga_g_te, gea_e_te, ]\n",
    "xs_wc_te = [xowc_x_te, sowc_s_te, gowc_g_te, gfwc_g_te, fgwc_f_te, gewc_g_te, ]\n",
    "ys_wc_te = [xowc_o_te, sowc_o_te, gowc_o_te, gfwc_f_te, fgwc_g_te, gewc_e_te, ]\n",
    "xlabels=['XGBoost', 'Gradient Sum', 'Gradient Boosting', 'Gradient Boosting', 'FC Gradient Boosting', 'Greedy FCOGB']\n",
    "ylabels=['BB FCOGB', 'BB FCOGB', 'BB FCOGB', 'FC Gradient Boosting', 'Greedy FCOGB', 'BB FCOGB']\n",
    "fig, axs = plt.subplots(2, 6, figsize=(16,6), sharey=True, tight_layout=True, squeeze=False)\n",
    "for i in range(2):\n",
    "    for j in range(6):\n",
    "        ax = axs[i, j]\n",
    "        ax.set_aspect('equal', adjustable='box')\n",
    "        if i==1:\n",
    "            ax.set_xlabel(''+xlabels[j], fontsize=13)\n",
    "        ax.set_ylabel(''+ylabels[j], fontsize=13)\n",
    "        ax.yaxis.set_label_coords(0.12, 0.5)\n",
    "        if j<3:\n",
    "            for spine in ax.spines.values():\n",
    "                spine.set_edgecolor('red')\n",
    "        if i==0:\n",
    "            ax.set_xticklabels([])\n",
    "            ax.scatter(xs_bc_tr[j], ys_bc_tr[j], label='Best case', c='red', alpha=0.7, marker='^')\n",
    "            ax.scatter(xs_wc_tr[j], ys_wc_tr[j], label='Worst case', c='blue', alpha=0.7,  marker='o')\n",
    "            ax.scatter(xs_avg_tr[j], ys_avg_tr[j], label='Average', c='green', alpha=0.7, marker='s')\n",
    "        if i==1:\n",
    "            ax.scatter(xs_bc_te[j], ys_bc_te[j], label='Best case', c='red', alpha=0.7,marker='^')\n",
    "            ax.scatter(xs_wc_te[j], ys_wc_te[j], label='Worst case', c='blue', alpha=0.7,  marker='o')\n",
    "            ax.scatter(xs_avg_te[j], ys_avg_te[j], label='Average', c='green', alpha=0.7,  marker='s')\n",
    "        ax.plot([0,1], [0,1], linestyle=(0, (1,3)))\n",
    "axs[0,5].legend(fontsize=12)\n",
    "axs[0, 0].text(0, 1, 'Training risks', fontsize=14)\n",
    "axs[1, 0].text(0, 1, 'Testing risks', fontsize=14)\n",
    "plt.show()\n",
    "fig.savefig('1ablation_study.pdf') "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2575cd0",
   "metadata": {
    "vscode": {
     "languageId": "python"
    }
   },
   "outputs": [],
   "source": []
  }
 ],
 "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
