{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import os\n",
    "from collections import defaultdict\n",
    "import pandas\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.gridspec import GridSpec"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "HOME = \"../../results/dfa_0.85\"\n",
    "BDIM_LOOKUP = {\n",
    "\t\t\"1\" : 2,\n",
    "\t\t\"2\" : 3,\n",
    "\t\t\"3\" : 5, \n",
    "\t\t\"4\" : 4,\n",
    "\t\t\"5\" : 4,\n",
    "\t\t\"6\" : 3,\n",
    "\t\t\"7\" : 5\n",
    "\t}\n",
    "RNN_LIST = [\"lstm\", \"gru\", \"o2rnn\", \"mirnn\"]\n",
    "MLIST = [2]\n",
    "METRICS = [\"accuracy\", \"recall\", \"precision\", \"f1\"]\n",
    "STATISTICS = [\"mean\", \"std\"]\n",
    "TEST_BINS = [\"bin_0\", \"bin_1\"]\n",
    "PARAMS = [\"n_states\"]\n",
    "PARAMS_METRICS = [\"min\", \"max\", \"mode\"]\n",
    "CLUSTER_METHODS = [\"kmeans\", \"som\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_results_file(grammar, rnn, sdim, nbin, cmethod):\n",
    "    fname = \"g{0}_{1}_sdim_{2}_es_0.85_{4}_nbin_{3}.json\".format(grammar, rnn, sdim, nbin, cmethod)\n",
    "    fpath = os.path.join(HOME, fname)\n",
    "    with open(fpath, \"r+\") as ff:\n",
    "        results = json.load(ff)\n",
    "\n",
    "    return results\n",
    "\n",
    "def update_summary(summary, res_doc):\n",
    "    for key in res_doc:\n",
    "        summary[key].append(res_doc[key])\n",
    "    return summary\n",
    "\n",
    "def parse_results(result_doc):\n",
    "    summary = defaultdict(list)\n",
    "    result_doc = result_doc[-10:]\n",
    "    for sample in result_doc:\n",
    "        summary[\"seed\"].append(sample[\"seed\"])\n",
    "        #print(sample[\"seed\"])\n",
    "        if \"n_parameters\" in sample:\n",
    "            summary[\"n_params\"].append(sample[\"n_parameters\"])\n",
    "        elif \"n_states\" in sample:\n",
    "            summary[\"n_states\"].append(sample[\"n_states\"])\n",
    "        summary = update_summary(summary, sample[\"result\"])\n",
    "    \n",
    "    return pandas.DataFrame.from_dict(summary)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_empty_dataframe():\n",
    "    row_items = [RNN_LIST, TEST_BINS]\n",
    "    col_items = [CLUSTER_METHODS , METRICS, STATISTICS]\n",
    "\n",
    "    row_index = pandas.MultiIndex.from_product(row_items, names=[\"rnn\", \"test_bin\"])\n",
    "    col_index = pandas.MultiIndex.from_product(col_items, names=[\"cluster_method\", \"metrics\", \"statistics\"])\n",
    "\n",
    "    n_rows = len(RNN_LIST)*len(TEST_BINS)\n",
    "    n_cols = len(CLUSTER_METHODS)*len(METRICS)*len(STATISTICS)\n",
    "\n",
    "    results = pandas.DataFrame(np.zeros([n_rows, n_cols]), index=row_index, columns=col_index)\n",
    "    return results\n",
    "\n",
    "\n",
    "def get_empty_states_frame():\n",
    "    #row_items = [(\"tomita_{}\".format(g), sdim) for g in range(1, 8) for sdim in [BDIM_LOOKUP[str(g)]*mdim for mdim in range(1, 6)]]\n",
    "    #row_index = pandas.MultiIndex.from_tuples(row_items, names=[\"grammar\"])\n",
    "    row_index = pandas.Index([\"tomita_{}\".format(i) for i in range(1, 8)], name = \"grammar\")\n",
    "    col_items = [RNN_LIST, CLUSTER_METHODS, PARAMS_METRICS]\n",
    "    col_index = pandas.MultiIndex.from_product(col_items, names=[\"rnn\", \"cluster_methods\", \"statistics\"])\n",
    "    params = pandas.DataFrame(np.zeros([7,len(RNN_LIST)*len(CLUSTER_METHODS)*len(PARAMS_METRICS)]), index=row_index, columns=col_index, dtype=int)\n",
    "    return params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_num_states():\n",
    "    sframe = get_empty_states_frame()\n",
    "    for grammar in [1, 2, 3, 4, 5, 6, 7]:\n",
    "        sdim = 2*BDIM_LOOKUP[str(grammar)]\n",
    "        for rnn in RNN_LIST:\n",
    "            for cm in CLUSTER_METHODS:\n",
    "                res_doc = load_results_file(grammar, rnn, sdim, 0, cm)\n",
    "                res_df = parse_results(res_doc)\n",
    "                states = res_df[\"n_states\"]\n",
    "                min_states = states.min().item()\n",
    "                max_states = states.max().item()\n",
    "                modes = states.mode()\n",
    "                mode_states = modes[len(modes)-1].item()\n",
    "                sframe.loc[\"tomita_{}\".format(grammar), (rnn, cm, PARAMS_METRICS)] = [min_states, max_states, mode_states]\n",
    "\n",
    "    return sframe"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "rnn               lstm                          gru               ...  o2rnn  \\\n",
      "cluster_methods kmeans          som          kmeans          som  ... kmeans   \n",
      "statistics         min max mode min max mode    min max mode min  ...   mode   \n",
      "grammar                                                           ...          \n",
      "tomita_1             1   4    1   1   2    1      1   4    2   1  ...      6   \n",
      "tomita_2             1   7    6   1  10    6      1  10    6   1  ...      4   \n",
      "tomita_3             7  24    9   8  14   14      9  22   16   6  ...     30   \n",
      "tomita_4             9  18   15   6  18   17     11  19   19   9  ...     10   \n",
      "tomita_5             7  20   17   2  11    7      3  19    9   2  ...     12   \n",
      "tomita_6             4  15   15   3  17    8      6  19   19   6  ...      4   \n",
      "tomita_7             2  13   11   3  18   13     10  26   21   6  ...     22   \n",
      "\n",
      "rnn                           mirnn                        \n",
      "cluster_methods som          kmeans          som           \n",
      "statistics      min max mode    min max mode min max mode  \n",
      "grammar                                                    \n",
      "tomita_1          2   6    2      2  10    2   2   9    2  \n",
      "tomita_2          4   6    4      4  10    4   4   7    6  \n",
      "tomita_3         11  20   20     14  27   25   7  21   14  \n",
      "tomita_4          7  20    7      8  16   11   8  18   10  \n",
      "tomita_5          2  16    7      2  13    3   2  12    2  \n",
      "tomita_6          3   3    3      1  20   11   1  12   12  \n",
      "tomita_7         14  22   17      9  27   13  13  19   15  \n",
      "\n",
      "[7 rows x 24 columns]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_22888/3280857277.py:14: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  ff.write(sframe.to_latex())\n"
     ]
    }
   ],
   "source": [
    "sframe = get_num_states()\n",
    "print(sframe)\n",
    "\n",
    "#----- save csv ---------\n",
    "\n",
    "fpath=\"../../results/dfa_0.85_csv/states.csv\"\n",
    "with open(fpath, \"w+\") as ff:\n",
    "    ff.write(sframe.to_csv())\n",
    "\n",
    "#----- save latex ---------\n",
    "\n",
    "fpath=\"../../results/dfa_0.85_latex/states.txt\"\n",
    "with open(fpath, \"w+\") as ff:\n",
    "    ff.write(sframe.to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def consolidated_results(grammar, sdim):\n",
    "    res_frame = get_empty_dataframe()\n",
    "    for rnn in RNN_LIST:\n",
    "        for nbin in TEST_BINS:\n",
    "            for cm in CLUSTER_METHODS:\n",
    "                bin = nbin.split(\"_\")[-1]\n",
    "                res_doc = load_results_file(grammar, rnn, sdim, bin, cm)\n",
    "                res_df = parse_results(res_doc)\n",
    "                metrics_df = res_df[METRICS].copy() * 100\n",
    "                #metrics_df.multiply(100, axis=tuple(METRICS))\n",
    "                metrics_mean = metrics_df.mean()\n",
    "                metrics_std = metrics_df.std()\n",
    "                #print(metrics_mean)\n",
    "                #print(metrics_std)\n",
    "                mean_cols = [(cm, m,\"mean\") for m in METRICS]\n",
    "                std_cols = [(cm, m, \"std\") for m in METRICS]\n",
    "                row_idx= (rnn, nbin)\n",
    "                res_frame.loc[row_idx, mean_cols] = metrics_mean.tolist()\n",
    "                #print(res_frame.loc[row_idx, mean_cols])\n",
    "                res_frame.loc[row_idx, std_cols] = metrics_std.tolist()\n",
    "                #print(res_frame.loc[row_idx, std_cols])\n",
    "    return res_frame"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cluster_method     kmeans                                              \\\n",
      "metrics          accuracy                recall             precision   \n",
      "statistics           mean        std       mean        std       mean   \n",
      "rnn   test_bin                                                          \n",
      "lstm  bin_0     85.143786  15.572493  91.640820  12.086018  85.809363   \n",
      "      bin_1     89.172500  16.264090  96.930000   6.446196  88.825671   \n",
      "gru   bin_0     70.780195   5.911971  87.168584  11.356063  65.988901   \n",
      "      bin_1     75.517500   4.965227  93.680000   8.043776  69.147633   \n",
      "o2rnn bin_0     74.681170   2.016284  73.971986   2.914937  75.099702   \n",
      "      bin_1     82.447500   1.839061  90.955000   1.082038  77.798146   \n",
      "mirnn bin_0     81.015254  11.167125  86.868434  11.150012  78.676996   \n",
      "      bin_1     85.382500  10.428767  94.255000   6.151217  81.151955   \n",
      "\n",
      "cluster_method                                         som             \\\n",
      "metrics                           f1              accuracy              \n",
      "statistics            std       mean        std       mean        std   \n",
      "rnn   test_bin                                                          \n",
      "lstm  bin_0     17.015062  87.055820  11.244401  80.732683  11.638142   \n",
      "      bin_1     18.098259  91.440534  11.261726  84.630000  13.749878   \n",
      "gru   bin_0      5.321253  74.724088   5.707779  71.550388   5.739309   \n",
      "      bin_1      5.337323  79.281511   4.110976  74.697500   4.664217   \n",
      "o2rnn bin_0      2.549644  74.488679   2.005544  72.833208   1.736338   \n",
      "      bin_1      2.397593  83.842154   1.441680  80.365000   1.469892   \n",
      "mirnn bin_0     11.909153  82.203724  10.091362  80.187547  10.701566   \n",
      "      bin_1     11.970927  86.966833   8.928622  82.425000  10.119481   \n",
      "\n",
      "cluster_method                                                         \\\n",
      "metrics            recall             precision                    f1   \n",
      "statistics           mean        std       mean        std       mean   \n",
      "rnn   test_bin                                                          \n",
      "lstm  bin_0     84.657328  12.512122  81.449219  15.172516  81.858745   \n",
      "      bin_1     88.400000  19.807869  86.346303  16.757831  84.797496   \n",
      "gru   bin_0     88.189094  11.483557  66.538311   5.350672  75.441254   \n",
      "      bin_1     91.965000   9.945827  68.863513   5.079160  78.346071   \n",
      "o2rnn bin_0     75.227613   2.748373  71.815758   1.964318  73.453687   \n",
      "      bin_1     91.500000   1.084230  74.873307   1.811511  82.342330   \n",
      "mirnn bin_0     85.272636  12.029099  79.247953  13.414301  81.322173   \n",
      "      bin_1     88.245000  16.133014  81.531956  13.272638  83.139938   \n",
      "\n",
      "cluster_method             \n",
      "metrics                    \n",
      "statistics            std  \n",
      "rnn   test_bin             \n",
      "lstm  bin_0      9.783657  \n",
      "      bin_1     15.035098  \n",
      "gru   bin_0      5.432979  \n",
      "      bin_1      4.000293  \n",
      "o2rnn bin_0      1.796043  \n",
      "      bin_1      1.156531  \n",
      "mirnn bin_0      9.471553  \n",
      "      bin_1     10.231639  \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_22888/253514758.py:16: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  ff.write(result.to_latex())\n"
     ]
    }
   ],
   "source": [
    "grammar = 7\n",
    "sdim = 2*BDIM_LOOKUP[str(grammar)]\n",
    "result = consolidated_results(grammar, sdim)\n",
    "print(result)\n",
    "\n",
    "#----- save csv ---------\n",
    "\n",
    "fpath=\"../../results/dfa_0.85_csv/g{}.csv\".format(grammar)\n",
    "with open(fpath, \"w+\") as ff:\n",
    "    ff.write(result.to_csv())\n",
    "\n",
    "#----- save csv ---------\n",
    "\n",
    "fpath=\"../../results/dfa_0.85_latex/g{}.txt\".format(grammar)\n",
    "with open(fpath, \"w+\") as ff:\n",
    "    ff.write(result.to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_7831/1207625089.py:42: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"\"] + RNN_LIST)\n",
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_7831/1207625089.py:42: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"\"] + RNN_LIST)\n"
     ]
    },
    {
     "data": {
      "image/png": "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/fSTwzEKr/sTJ06of//+CgoKUkREhMaPH6+8vDzXfRAuUHgN7t+/X8OGDVNoaKgiIiI0depU2Ww2HTt2TLfffrtCQkJUv359zZ07175vSddf4Wdz8OBB3XTTTQoODtbQoUMlnb++P/nkE7Vr104mk0lt27bVmjVrSozp999/17333quwsDCFhobqvvvuU0ZGRpV8LnAv2qWqQ9tUMbRLrkXbVH70RLlJcnKy+vbtq4iICD3xxBMKCwvT4cOH9fHHH0uSIiIiNH/+fI0ePVp33HGHBgwYIElq3769/Rh5eXnq16+fevTooRdeeEFLly5VfHy8AgMD9eSTT2ro0KEaMGCA3nzzTQ0fPlxdu3ZV06ZN3fJ+3WXnzp2Ki4tTVFSUpk+frry8PD3zzDP2LwJFffPNN/rwww8VHx+vunXrqkmTJkpNTa36oD3Eb7/9pu7duyskJEQTJ06Ur6+v3nrrLcXGxuq7777TNddcU+q+J0+eVN26dYuVnz59Wv369dPdd9+tYcOGqV69evZt77//vs6ePat//OMf8vLy0gsvvKABAwbojz/+cBgakJeXpxtvvFHXXHON5syZo6+++kpz585V8+bNNXr06Mr9EKrAXXfdpdatW+u5557T559/rmeffVZ16tTRW2+9pV69eun555/X0qVLNX78eF199dXq0aNHqceyWq268cYb1a1bN82ZM8fh19RNmzbp448/1pgxYxQcHKx//etfGjhwoI4eParw8HCH4wwePFhNmzbV7NmztWPHDr3zzjuKjIzU888/77LPAe5Hu1R1aJsqhnap6tA2lYMNVWbBggU2SbZDhw7Z/vOf/9gk2X766adS66ekpNgk2aZNm1Zs24gRI2ySbLNmzbKXWSwWm7+/v83Ly8u2bNkye/m+fftKPU5Nd+utt9oCAgJsJ06csJcdOHDAZjAYbEUvf0k2b29v22+//eaw/7fffmuTZPv2228dyg8dOmSTZFuwYIErw3er/v3724xGo+3gwYP2ssTERFtwcLCtR48epe63YcMGm5eXl23q1KkO5T179rRJsr355psO5YWfZXh4uO2vv/6yl69atcomyfbZZ5/Zywqv+2eeecbhGJ06dbJdddVVFXqf7jJt2jSbJNuoUaPsZVar1dawYUObl5eX7bnnnrOXF/7bHjFihM1mK/n6K/xsnnjiiWLnkmQzGo22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4w4FBASoRYsW+vTTT+3bLRaLhg4dqoiICPn7+6tFixbF4ijJ5s2b1b59e/n5+elvf/ubdu/ebd+2cOFCh6FVTz/9tDp27KjFixerSZMmCg0N1d13362zZ8+W67N86aWX9OCDD+q+++5TmzZt9OabbyogIEDvvvtuufYH12NlXo/9+vXTs88+qzvuuKNc9SGtXLlSV1xxhfz9/RUeHq4+ffro3Llzys/P1zPPPKOGDRvKZDKpY8eOWrNmjX2/w4cPy8vLSx9++KG6d+8uf39/XX311dq/f79++uknde7cWUFBQerXr59SyjExgtVqVXx8vEJDQ1W3bl1NnTpVRe8maNKkicMwrotdr2VZu3at9uzZoyVLlqhjx47q16+fZsyYoTfeeEM5F0lUaqvaeJ1I0r/+9S89/PDDatasWbn3AQqRRKFGef/993XPPfdo6dKlGjp0qCTpm2++UWJiojZs2KCXXnpJ06ZN0y233CKz2awffvhBDz30kP7xj3/o+PHjkgqmLr3xxhsVHBysjRs3avPmzQoKClJcXJy9AT579qxGjBihTZs26fvvv1eLFi100003FfsyOH36dA0ePFi//PKLbrrpJg0dOlR//fWXJGnq1Knas2ePEhIStHfvXs2fP19169a96HucMGGC5s6dq59++kkRERG69dZby5xu9eDBg/rkk0+0evVqrV69Wt99952ee+7iEzDk5ORo+/bt6tOnj73M29tbffr00datWy+6P7geS1LR6xHOS0pK0j333KP7779fe/fu1fr16zVgwADZbDa9+uqrmjt3rubMmaNffvlFN954o2677TYdOOA4UdC0adP01FNPaceOHTIYDBoyZIgmTpyoV199VRs3btTvv/9erh6eRYsWyWAw6Mcff9Srr76ql156Se+8806Z+5R1vZZl69atuuKKK1SvXj172Y033qi0tDT99ttvF92/tqmt1wlwyWzA/2RmZtr27Nljy8zMdHrfX4+n2hpPWn3Rx6/HUys97p49e9oeffRR2+uvv24LDQ21rV+/3r5txIgRtsaNG9vy8vLsZa1atbJ1797d/tpqtdoCAwNtH3zwgc1ms9kWL15sa9WqlS0/P99eJzs72+bv72/78ssvS4whLy/PFhwcbPvss8/sZZJsTz31lP11enq6TZItISHBZrPZbLfeeqvtvvvuK/f7/Pbbb22SbMuWLbOXnT592ubv729bvny5zWaz2RYsWGALDQ21b582bZotICDAlpaWZi+bMGGC7Zprrrno+U6cOGGTZNuyZYtD+YQJE2xdunQpd9xV7sROm21ayMUfJ3a65PRcj665Hi8kyfaf//zH6f2q2m9//mZrt7DdRR+//flbpZ97+/btNkm2w4cPF9sWHR1tmzlzpkPZ1VdfbRszZozNZrPZDh06ZJNke+edd+zbP/jgA5sk29dff20vmz17tq1Vq1ZlxtGzZ09b69atHa7hSZMm2Vq3bm1/3bhxY9vLL79sf32x67UsDz74oK1v374OZefOnbNJsn3xxRcX3d8dMnbvtu1pdflFHxm7d1f6uWvrdVLUtGnTbB06dLhovUv5noSah54o1AgrV67UuHHjtG7dOvXs2dNhW9u2beXtff5Sr1evnq644gr7ax8fH4WHh9vv8/n555/1+++/Kzg4WEFBQQoKClKdOnWUlZWlgwcPSpJOnTqlBx98UC1atFBoaKhCQkKUnp6uo0ePOpy7ffv29ueBgYEKCQmxn2f06NFatmyZOnbsqIkTJ2rLli32uv369bOfu23btg7H7Nq1q/15nTp11KpVK+3du7fUz6ZJkyYKDg62v46KivLse5pqAK5HrkdP0KFDB/Xu3VtXXHGFBg0apP/7v/+TxWJRWlqaEhMTdd111znUv+6664r9vyt6zRT27BS9XuvVq2f//7dx40b7dRIUFKSlS5fa6/3tb39zWGOna9euOnDggH2R95KUdb2i8nCdABXjWdPUABXUqVMn7dixQ++++646d+7s8EfY19fXoa6Xl1eJZfn5BRNjpKen66qrrnL4w14o4n/Ty44YMUKnT5/Wq6++qsaNG8tkMqlr167FxtuXdZ5+/frpyJEj+uKLL7Ru3Tr17t1bDz/8sObMmaN33nlHmZmZJR7DWWXFUJa6devKx8dHp06dcig/deqU6tdncdqycD2WrqLXI5zn4+OjdevWacuWLVq7dq1ee+01Pfnkk1q3bl25j1H0/1fhdXxhWeH/v86dOzvMblZ0OF1FVPRaqV+/vn788UeHssK/Y/ztKq62XifApaInCjVC8+bN9e2332rVqlV65JFHLr5DGa688kodOHBAkZGRuuyyyxweoaGhkgpuph87dqxuuukmtW3bViaTSX/++afT54qIiNCIESO0ZMkSvfLKK3r77bclSQ0aNLCfs3Hjxg77fP/99/bnFotF+/fvV+vWrS/hHZfMaDTqqquu0tdff20vy8/P19dff+3Q+4DiuB4r/3pExXh5eem6667T9OnTtXPnThmNRn399deKjo7W5s2bHepu3rxZbdq0qfC5/P39Ha7Poj2OP/zwg0Pdwnv3fHx8Kny+0nTt2lW//vqrQ2/EunXrFBIScknvryarjdcJcKnoiUKlMAcaZTJ4lznNucngLXOg0WUxtGzZUt9++61iY2NlMBgqvNjp0KFD9eKLL+r222+3z0p05MgRffzxx5o4caIaNmyoFi1aaPHixercubPS0tI0YcIE+fs7t/7VP//5T1111VVq27atsrOztXr16nJ9+XzmmWcUHh6uevXq6cknn1TdunVdtlbO448/rhEjRqhz587q0qWLXnnlFZ07d0733XefS85XKQLCC9aBKmuac4OpoJ4LcT1WvvT0dP3+++/214cOHdKuXbtUp04dNWrUyCXnvFRmk1lGH2OZ05wbfYwym8yVfu4ffvhBX3/9tfr27avIyEj98MMPSklJUevWrTVhwgRNmzZNzZs3V8eOHbVgwQLt2rWrxB7PynD06FE9/vjj+sc//qEdO3botdde09y5c11yrr59+6pNmzb6+9//rhdeeEEnT57UU089pYcfflim/y1c62kMZrO8jMYypzn3MhplMHOdVKbff/9d6enpOnnypDIzM+09ZG3atJHR6LrvK6gZSKJQKRqE+eub8bGynMtRVm6e7nyzYPa2lQ91lZ9vwS9I5kCjyxfabdWqlb755hvFxsZW+JergIAAbdiwQZMmTdKAAQN09uxZNWjQQL1791ZISIgk6d///rdGjRqlK6+8UjExMZo1a5bGjx/v1HmMRqMmT56sw4cPy9/fX927d9eyZcsuut9zzz2nRx99VAcOHFDHjh312WefueyP/V133aWUlBT985//1MmTJ+3T217q8AuXCospWEg347RkzZTejSsov3+NZPjf9RcQXiUL7XI9Vq5t27bp+uuvt79+/PHHJRUMZ1y4cKFLznmpooKitLr/almyLcqyZmnEmhGSpEVxi+Rn8JNUkGi5YqHdkJAQbdiwQa+88orS0tLUuHFjzZ07V/369dONN96oM2fO6P/9v/+n5ORktWnTRp9++qlatGhR6XFI0vDhw5WZmakuXbrIx8dHjz76qEaNGuWSc/n4+Gj16tUaPXq0unbtqsDAQI0YMULPPPOMS85XGXyjo9V8TULBelFZWToydJgkqfHSJfLyK7hODGazSxbara3XiSQ98MAD+u677+yvO3XqJKngB5omTZq47LyoGbxstiIT8KNWy8rK0qFDh9S0aVP5/e+P9sUkp2Up+azjL/6lJVFFRQabFBlSvnMA5XL2ZMGjqNKSqKKC6xc8gEqUkpGilEzHdXFKS6KKivCPUERARJXECPfLTU6W9YL1k0pLoooyRETItxIXskb5VOR7EmoukijYVeSPw8vr9uvVrw9cvOIFHu3dQuNuaOn0fkCpvp0tfVeB9YZ6PiFdP7ny40GtNm/XPM3/eb7T+43uMFpjOo5xQUTwRCmvva4/33jD6f3qPvywIh6Jd0FEKAtJFIoiiYJdZfVElQc9Ue539OjRMm8O3rNnj8feZ1KiknqiyoOeKI9Q067HknqiyoOeqIt76KGHtGTJkhK3DRs2TG+++WYVR1RxJfVElQc9URfniuuEJApFkUTBjj8OtYvVatXhw4dL3d6kSRMZDNw2iarB9YjySk5OVlpaWonbQkJCFElyAbnmOuF7EooiiYIdfxwAAABKxvckFMU6USiGvBoAAMAR349QFEkU7AqnYM4pY50KAACA2igjI0OS5Ovr6+ZI4AkYYA47g8GggIAApaSkyNfXV97e5NgAAKB2s9lsysjIUHJyssLCwiq87h9qFu6JgoOcnBwdOnRI+fn57g4FAADAY4SFhal+/fry8vJydyjwACRRKCY/P58hfQAAAP/j6+tLDxQckEQBAAAAgBO46QUAAAAAnEASBQAAAABOIIkCAAAAACeQRAEAAACAE/4/kw0rzkFLEqIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#fig = plt.figure(layout = \"constrained\", figsize=(8, 16))\n",
    "fig = plt.figure(figsize=(16, 4))\n",
    "gs = GridSpec(1, 4, figure=fig)\n",
    "\n",
    "plt.rcParams.update({'font.size': 14})\n",
    "all_lines = []\n",
    "all_labels = []\n",
    "#for idx, grammar in enumerate(range(1, 8)):\n",
    "for idx, grammar in enumerate([3, 5, 6, 7]):\n",
    "    # if idx < 4:\n",
    "    #     ax = fig.add_subplot(gs[0, 2*idx : 2*(idx+1)])\n",
    "    # else:\n",
    "    #     _idx = idx - 4\n",
    "    #     ax = fig.add_subplot(gs[1, 1 + 2*_idx : 1 + 2*(_idx+1)])\n",
    "    ax = fig.add_subplot(gs[0, idx])\n",
    "\n",
    "    #sdim = [BDIM_LOOKUP[str(grammar)]*mdim for mdim in range(1, 6)]\n",
    "    sdim = 2*BDIM_LOOKUP[str(grammar)]\n",
    "    result = consolidated_results(grammar, sdim)\n",
    "    #for rnn in RNN_LIST:\n",
    "    X = np.arange(4) + 1\n",
    "    d = [-0.3, -0.1, 0.1, 0.3]\n",
    "    markers = [\"s\", \"o\", \"*\", \"^\"]\n",
    "    for cm in CLUSTER_METHODS:\n",
    "        for bin in TEST_BINS:\n",
    "            mean = [result.loc[rnn, bin][cm, \"accuracy\", \"mean\"] for rnn in RNN_LIST]\n",
    "            std = [result.loc[rnn, bin][cm, \"accuracy\", \"std\"] for rnn in RNN_LIST]\n",
    "            #l, = ax.plot(sdim, mean, marker=\"s\")\n",
    "            std = np.array(std)\n",
    "            mean = np.array(mean)\n",
    "            y_max = np.min([np.array([100]*len(std)), np.array(mean) + std], axis = 0)\n",
    "            y_err_max = y_max - mean\n",
    "            y_err = np.stack([std, y_err_max], axis = 0)\n",
    "            #print(\"mean : \", mean)\n",
    "            #print(\"std : \", std)\n",
    "            #print(\"y_rr : \",  y_err)\n",
    "            l = ax.errorbar(X+d.pop(0), mean, yerr = y_err, fmt=\"s\", capsize=5)\n",
    "\n",
    "            if idx == 0:\n",
    "                all_lines.append(l)\n",
    "                all_labels.append(\"{}-{}\".format(cm, bin))\n",
    "                \n",
    "    ax.set_xticklabels([\"\"] + RNN_LIST) \n",
    "    ax.set_ylabel(\"accuracy\")\n",
    "    ax.set_title(\"Tomita-{}\".format(grammar))\n",
    "    #ax.set_ylim(top = 102, bottom = 60)\n",
    "\n",
    "#ax = plt.subplot(2,4,8)\n",
    "#plt.subplots_adjust(wspace=0.5, hspace=0.5)\n",
    "fig.legend(handles=all_lines, labels=all_labels, prop={\"size\" : 10}, loc= \"lower center\", ncol = 4)   \n",
    "plt.subplots_adjust(bottom=0.15, hspace = 0.3)\n",
    "#plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_7252/1825064443.py:55: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"\"] + RNN_LIST)\n",
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_7252/1825064443.py:55: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"\"] + RNN_LIST)\n",
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_7252/1825064443.py:55: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"\"] + RNN_LIST)\n",
      "/var/folders/yy/hb5j8vgj2gx5_492tnfyz7z40000gn/T/ipykernel_7252/1825064443.py:55: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"\"] + RNN_LIST)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABTEAAAGECAYAAADuu2QsAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAACrnUlEQVR4nOzde1yTdf8/8Nc4DRgMREGEiIOiSFbeJpahAXorduetmVlZfm/TLNOsFI/41UCxGzATu7O04iuaP+2gmFi3Ch6x6JzobamJZxJJbkMmE8bp+v2xNpjbFMYOF9vr+Xjs0fa5Pte195a+3d77HCSCIAggIiIiIiIiIiIiEiknWwdAREREREREREREdCssYhIREREREREREZGosYhJREREREREREREosYiJhEREREREREREYkai5hEREREREREREQkaixiEhERERERERERkaixiElERERERERERESixiImERERERERERERiRqLmERERERERERERCRqLGISAVi/fj0kEgni4+NtHQoRkegwRxIRGcccSURkHHMkmROLmNRuEonEpNv69ettHXqrrFq1CqmpqTh//rxNnv+dd97BxIkTce+996Jr165wc3ODj48PYmJisHTpUly7ds0mcRFR6zBHWlZ8fPxt38vdu3fbJDYiuj3mSOtoamrC+vXrMWzYMHTt2hVSqRRBQUGIj4/H0qVLbRobERnHHGk5muJqa26TJk2yenxkmIutA6COLzY21mB7UVERACAyMhIBAQF6x7t27WrRuNrCx8cHvXr1wp133ql3bNWqVbhw4QLi4+MRFhZm9dheffVVNDY2wsPDA0FBQbjzzjtRXl6OH3/8ET/++CPWrl2LPXv24K677rJ6bER0e8yR1mHsfQSATp06WTkaImot5kjL++9//4uRI0fiu+++AwD06NEDoaGhuHLlCoqKivDVV1/htddes0lsRHRrzJGW07VrV6PvLwBUV1fj6NGjAIBBgwZZKyy6DYkgCIKtgyD7JJFIAAA5OTl49tlnbRtMO4SFheHChQs4cOCATYbAv/HGG0hISEC/fv3g5NQ8ePrw4cN45plncPLkSdx99934z3/+Y/XYiMh0zJHmER8fj8LCwg7/PhKRLuZI86irq8PAgQNx+PBhjBs3DitWrNApJCgUCuzbtw9jxoyxemxEZDrmSMvLyspCUlISZDIZ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VHsKHgBERERo3IyXqCVhjqzBHMkcSfQg5sgazJHMkUQPYo6swRzJHNnasIjZREJDQ5GTk4PDhw9jx44dKCoqgqurK6KjozF79mz06NFDOXbo0KH44IMPsHr1aixZsgRyuRyBgYEtJrECwPr169G9e3d8/vnnWLFiBdzc3DBjxgwMHDgQu3fv1rg5bF28vLywb98+zJ07F9u2bYO1tTWeffZZLF68GFFRUU34VdTtww8/RK9evZCcnIxPP/0UAPDEE0/gvffew9ixY5XjcnJyAABFRUV4//33NZ6rU6dOTKzU4jFHqmKOrMYcSVSNOVIVc2Q15kiiasyRqpgjqzFHtg4SIYTQdRDUen322Wd45ZVXsGrVKsTHx+s6HCIivcIcSURUN+ZIIqK6MUdSS8QiJjWLGzduoF27dipPusrNzYWfnx+uXbuG7OxsPPbYYzqMkIhId5gjiYjqxhxJRFQ35khqTXg7OTWLxMRE7NmzB/3790fbtm1x9epVfP3117h37x7effddJlUiatWYI4mI6sYcSURUN+ZIak1YxKRmMWTIEGRlZWHPnj24e/cupFIpvL29MWnSJMTExOg6PCIinWKOJCKqG3MkEVHdmCOpNeHt5ERERERERERERKTXjHQdABEREREREREREVF9WMQkIiIiIiIiIiIivcYiJhEREREREREREek1FjGJiIiIiIiIiIhIr7GISURERERERERERHqNRUwiIiIiIiIiIiLSayxiEhERERERERERkV5jEZOIiIiIiIiIiIj0GouYREREREREREREpNdYxCQiIiIiIiIiIiK9xiImERERERERERER6TUWMYmIiIiIiIiIiEivmeg6ACIiejRyuRyVlZW6DoOIiIhIrxkbG8PU1FTXYRAR0V/EIiYRkYEqLCxEXl4eysrKdB0KERERkUEwNzeHk5MTbG1tdR0KERFpiUVMIiIDVFhYiNzcXFhbW8PJyQmmpqaQSCS6DouIiIhILwkhIJfLUVBQgNzcXABgIZOIyMBIhBBC10EQEZF2Ll++DFNTU7i5ubF4SURERNRAQghcu3YNcrkcHh4eug6HiIi0wAf7EBEZGLlcjrKyMtjZ2bGASURERKQFiUQCOzs7lJWVQS6X6zocIiLSAouYREQGRvEQH25MT0RERKQ9xc9QfDAiEZFh4Z6YREQGqrFXYd4qLMWte9o/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",
      "text/plain": [
       "<Figure size 1600x400 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "lstar_doc = {3: {'mean': [50.0, 50.0, 77.37499952316284, 53.7075001001358], 'y_err': np.array([[ 0.        ,  0.        ,  4.37523086, 11.72414474],\n",
    "        [ 0.        ,  0.        ,  4.37523086, 11.72414474]])}, \n",
    "        5: {'mean': [79.67749953269958, 87.73750007152557, 90.79500019550323, 89.29999947547913], 'y_err': np.array([[14.08691045, 15.96505401, 14.82823289, 13.80415128],\n",
    "        [14.08691045, 12.26249993,  9.2049998 , 10.70000052]])},\n",
    "        6: {'mean': [70.06249964237213, 61.27750039100647, 100.0, 81.49749994277954], 'y_err': np.array([[21.04977997, 20.54067581,  0.        , 21.37300145],\n",
    "        [21.04977997, 20.54067581,  0.        , 18.50250006]])}, \n",
    "        7: {'mean': [50.25250017642975, 50.0, 75.50749957561493, 59.9099999666214], 'y_err': np.array([[ 0.79847567,  0.        ,  1.60334152, 13.1840299 ],\n",
    "        [ 0.79847567,  0.        ,  1.60334152, 13.1840299 ]])}}\n",
    "\n",
    "\n",
    "#fig = plt.figure(layout = \"constrained\", figsize=(8, 16))\n",
    "fig = plt.figure(figsize=(16, 4))\n",
    "gs = GridSpec(1, 4, figure=fig)\n",
    "\n",
    "plt.rcParams.update({'font.size': 14})\n",
    "all_lines = []\n",
    "all_labels = []\n",
    "#for idx, grammar in enumerate(range(1, 8)):\n",
    "for idx, grammar in enumerate([3, 5, 6, 7]):\n",
    "    # if idx < 4:\n",
    "    #     ax = fig.add_subplot(gs[0, 2*idx : 2*(idx+1)])\n",
    "    # else:\n",
    "    #     _idx = idx - 4\n",
    "    #     ax = fig.add_subplot(gs[1, 1 + 2*_idx : 1 + 2*(_idx+1)])\n",
    "    ax = fig.add_subplot(gs[0, idx])\n",
    "\n",
    "    #sdim = [BDIM_LOOKUP[str(grammar)]*mdim for mdim in range(1, 6)]\n",
    "    sdim = 2*BDIM_LOOKUP[str(grammar)]\n",
    "    result = consolidated_results(grammar, sdim)\n",
    "    #for rnn in RNN_LIST:\n",
    "    X = np.arange(4) + 1\n",
    "    d = [-0.3, -0.1, 0.1, 0.3]\n",
    "    markers = [\"s\", \"o\", \"*\", \"^\"]\n",
    "    for cm in CLUSTER_METHODS + [\"lstar\"]:\n",
    "        for bin in [\"bin_0\"]:\n",
    "            if cm == \"lstar\":\n",
    "                mean = lstar_doc[grammar][\"mean\"]\n",
    "                y_err = lstar_doc[grammar][\"y_err\"]\n",
    "            else:\n",
    "                mean = [result.loc[rnn, bin][cm, \"accuracy\", \"mean\"] for rnn in RNN_LIST]\n",
    "                std = [result.loc[rnn, bin][cm, \"accuracy\", \"std\"] for rnn in RNN_LIST]\n",
    "                #l, = ax.plot(sdim, mean, marker=\"s\")\n",
    "                std = np.array(std)\n",
    "                mean = np.array(mean)\n",
    "                y_max = np.min([np.array([100]*len(std)), np.array(mean) + std], axis = 0)\n",
    "                y_err_max = y_max - mean\n",
    "                y_err = np.stack([std, y_err_max], axis = 0)\n",
    "\n",
    "            l = ax.errorbar(X+d.pop(0), mean, yerr = y_err, fmt=markers.pop(0), capsize=5)\n",
    "\n",
    "            if idx == 0:\n",
    "                all_lines.append(l)\n",
    "                all_labels.append(\"{}-{}\".format(cm, bin))\n",
    "                \n",
    "    ax.set_xticklabels([\"\"] + RNN_LIST) \n",
    "    ax.set_ylabel(\"accuracy\")\n",
    "    ax.set_title(\"Tomita-{}\".format(grammar))\n",
    "    #ax.set_ylim(top = 102, bottom = 60)\n",
    "\n",
    "#ax = plt.subplot(2,4,8)\n",
    "#plt.subplots_adjust(wspace=0.5, hspace=0.5)\n",
    "fig.legend(handles=all_lines, labels=all_labels, loc= \"lower center\", ncol = 4)   \n",
    "plt.subplots_adjust(bottom=0.22, wspace = 0.3)\n",
    "#plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.13 ('py39')",
   "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.9.13"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "61b4062b24dfb1010f420dad5aa3bd73a4d2af47d0ec44eafec465a35a9d7239"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
